further optimize condition_sql for "Invoice eligible for automatic collection" condit...
[freeside.git] / FS / FS / part_event / Condition / pkg_status.pm
1 package FS::part_event::Condition::pkg_status;
2
3 use strict;
4
5 use base qw( FS::part_event::Condition );
6 use FS::Record qw( qsearch );
7
8 sub description {
9   'Package Status';
10 }
11
12 sub eventtable_hashref {
13     { 'cust_main' => 0,
14       'cust_bill' => 0,
15       'cust_pkg'  => 1,
16       'svc_acct'  => 1,
17     };
18 }
19
20 #something like this
21 sub option_fields {
22   (
23     'status'  => { 'label'    => 'Package Status',
24                    'type'     => 'select-cust_pkg-status',
25                    'multiple' => 1,
26                  },
27   );
28 }
29
30 sub condition {
31   my( $self, $object ) = @_;
32
33   my $cust_pkg = $self->cust_pkg($object);
34   #XXX test
35   my $hashref = $self->option('status') || {};
36   $hashref->{ $cust_pkg->status };
37 }
38
39 sub condition_sql {
40   my( $self, $table ) = @_;
41
42   '('.FS::cust_pkg->status_sql . ') IN '.
43   $self->condition_sql_option_option('status');
44 }
45
46 1;