summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2014-01-16 02:25:42 -0800
committerIvan Kohler <ivan@freeside.biz>2014-01-16 02:25:42 -0800
commit997a69c08b78e7b3c517b668232a73ba918cf55f (patch)
tree32a2095c4b3aee36cc8900c1b4ebf34649e1fa11
parent9631cebbbe78d194966178e0ccd28e755e060c16 (diff)
"Continue recurring billing while suspended" checkbox for event-triggered cancels in addition to manual ones, RT#26470"
-rw-r--r--FS/FS/part_event/Action/suspend.pm17
1 files changed, 12 insertions, 5 deletions
diff --git a/FS/FS/part_event/Action/suspend.pm b/FS/FS/part_event/Action/suspend.pm
index ea795748e..84a710158 100644
--- a/FS/FS/part_event/Action/suspend.pm
+++ b/FS/FS/part_event/Action/suspend.pm
@@ -7,10 +7,14 @@ sub description { 'Suspend all of this customer\'s packages'; }
sub option_fields {
(
- 'reasonnum' => { 'label' => 'Reason',
- 'type' => 'select-reason',
- 'reason_class' => 'S',
- },
+ 'reasonnum' => { 'label' => 'Reason',
+ 'type' => 'select-reason',
+ 'reason_class' => 'S',
+ },
+ 'suspend_bill' => { 'label' => 'Continue recurring billing while suspended',
+ 'type' => 'checkbox',
+ 'value' => 'Y',
+ },
);
}
@@ -21,7 +25,10 @@ sub do_action {
my $cust_main = $self->cust_main($cust_object);
- my @err = $cust_main->suspend( 'reason' => $self->option('reasonnum') );
+ my @err = $cust_main->suspend(
+ 'reason' => $self->option('reasonnum'),
+ 'options' => { 'suspend_bill' => $self->option('suspend_bill') },
+ );
die join(' / ', @err) if scalar(@err);