diff options
author | Ivan Kohler <ivan@freeside.biz> | 2014-12-05 15:30:19 -0800 |
---|---|---|
committer | Ivan Kohler <ivan@freeside.biz> | 2014-12-05 15:30:19 -0800 |
commit | 0a1b4524bb9e69ed5fb066712d01fcba4effe720 (patch) | |
tree | de2fadbc665aa5aeae4c772429ec365f2ce45c4f /FS/FS | |
parent | 16e107a846556c19d837c8fd704d5e2089199597 (diff) |
add condition on signupdate age, RT#31213
Diffstat (limited to 'FS/FS')
-rw-r--r-- | FS/FS/part_event/Condition/signupdate_age.pm | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/FS/FS/part_event/Condition/signupdate_age.pm b/FS/FS/part_event/Condition/signupdate_age.pm new file mode 100644 index 000000000..70b4bbd7b --- /dev/null +++ b/FS/FS/part_event/Condition/signupdate_age.pm @@ -0,0 +1,44 @@ +package FS::part_event::Condition::signupdate_age; +use base qw( FS::part_event::Condition ); + +use strict; + +sub description { 'Customer signup age'; } + +#lots of falze laziness w/cust_bill_age, basically just swapped out the field + +sub option_fields { + ( + 'age' => { label=>'Age', type=>'freq', }, + ); +} + +sub condition { + my( $self, $cust_bill, %opt ) = @_; + + my $age = $self->option_age_from('age', $opt{'time'} ); + + ( $cust_main->signupdate - 60 ) <= $age; + +} + +sub condition_sql { + my( $class, $table, %opt ) = @_; + + my $age = $class->condition_sql_option_age_from('age', $opt{'time'} ); + + "( cust_main.signupdate - 60 ) <= $age"; +} + +# i don't think it really matters what order, since we're a customer condition? +# this is for ordering different events for a customer +sub order_sql { + shift->condition_sql_option_age('age'); +} + +sub order_sql_weight { + -1; +} + +1; +1; |