summaryrefslogtreecommitdiff
path: root/FS/FS
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2014-12-05 15:30:19 -0800
committerIvan Kohler <ivan@freeside.biz>2014-12-05 15:30:19 -0800
commit0a1b4524bb9e69ed5fb066712d01fcba4effe720 (patch)
treede2fadbc665aa5aeae4c772429ec365f2ce45c4f /FS/FS
parent16e107a846556c19d837c8fd704d5e2089199597 (diff)
add condition on signupdate age, RT#31213
Diffstat (limited to 'FS/FS')
-rw-r--r--FS/FS/part_event/Condition/signupdate_age.pm44
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;