diff options
author | Mark Wells <mark@freeside.biz> | 2015-02-28 13:14:57 -0800 |
---|---|---|
committer | Mark Wells <mark@freeside.biz> | 2015-02-28 13:21:22 -0800 |
commit | 0b5ea482d5cb6685d3866a8940dc90eb6e8157cf (patch) | |
tree | 2c5d3d48c10f57b4e795f677041b4bebded0d701 /FS | |
parent | fe708edd0ced9686d96b3ceb3de1300f5984a92e (diff) |
change interaction between unsuspend_adjust_bill and unused_credit_suspend, #31651
Diffstat (limited to 'FS')
-rw-r--r-- | FS/FS/cust_pkg.pm | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/FS/FS/cust_pkg.pm b/FS/FS/cust_pkg.pm index 40f3a4e8f..3c9eab85f 100644 --- a/FS/FS/cust_pkg.pm +++ b/FS/FS/cust_pkg.pm @@ -1676,15 +1676,20 @@ sub unsuspend { and ! $self->option('no_suspend_bill',1) ) or $hash{'order_date'} == $hash{'susp'} - or $self->part_pkg->option('unused_credit_suspend') - or ( defined($reason) and $reason->unused_credit ) ) { $adjust_bill = 0; } - # then add the length of time suspended to the bill date if ( $adjust_bill ) { - $hash{'bill'} = ( $hash{'bill'} || $hash{'setup'} ) + $inactive + if ( $self->part_pkg->option('unused_credit_suspend') + or ( $reason and $reason->unused_credit ) ) { + # then the customer was credited for the unused time before suspending, + # so their next bill should be immediate. + $hash{'bill'} = time; + } else { + # add the length of time suspended to the bill date + $hash{'bill'} = ( $hash{'bill'} || $hash{'setup'} ) + $inactive; + } } $hash{'susp'} = ''; |