summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Wells <mark@freeside.biz>2015-10-26 18:01:01 -0700
committerMark Wells <mark@freeside.biz>2015-10-26 18:01:23 -0700
commit83ec1a32d5671d1f426da6d5732fdd37169816c6 (patch)
treef5d7f5aa89ac15ccfe6de10cf128d75c4a59cb66
parent78908b703c8a24a89fabbcd7d8fb38a4175a859d (diff)
calculate in_transit_payments correctly for partially complete batches, #37193
-rw-r--r--FS/FS/cust_main/Billing_Batch.pm9
1 files changed, 8 insertions, 1 deletions
diff --git a/FS/FS/cust_main/Billing_Batch.pm b/FS/FS/cust_main/Billing_Batch.pm
index c2416ab32..2f68d7ff1 100644
--- a/FS/FS/cust_main/Billing_Batch.pm
+++ b/FS/FS/cust_main/Billing_Batch.pm
@@ -48,7 +48,13 @@ sub batch_card {
}else{
$amount = sprintf("%.2f", $self->balance - $self->in_transit_payments);
}
- return '' unless $amount > 0;
+ if ($amount <= 0) {
+ warn(sprintf("Customer balance %.2f - in transit amount %.2f is <= 0.\n",
+ $self->balance,
+ $self->in_transit_payments
+ ));
+ return;
+ }
my $invnum = delete $options{invnum};
my $payby = $options{payby} || $self->payby; #still dubious
@@ -206,6 +212,7 @@ sub in_transit_payments {
foreach my $cust_pay_batch ( qsearch('cust_pay_batch', {
'batchnum' => $pay_batch->batchnum,
'custnum' => $self->custnum,
+ 'status' => '',
} ) ) {
$in_transit_payments += $cust_pay_batch->amount;
}