Initial import.
[freeside.git] / FS / FS / part_event / Condition / cust_bill_has_service.pm
1 package FS::part_event::Condition::cust_bill_has_service;
2
3 use strict;
4 use FS::cust_bill;
5
6 use base qw( FS::part_event::Condition );
7
8 sub description {
9   'Invoice is billing for a certain service type';
10 }
11
12 sub eventtable_hashref {
13     { 'cust_main' => 0,
14       'cust_bill' => 1,
15       'cust_pkg'  => 0,
16     };
17 }
18
19 sub option_fields {
20   (
21     'has_service' => { 'label'      => 'Has service',
22                        'type'       => 'select-part_svc',
23                      },
24   );
25 }
26
27 sub condition {
28   #my($self, $cust_bill, %opt) = @_;
29   my($self, $cust_bill) = @_;
30
31   my $servicenum = $self->option('has_service');
32   grep { $servicenum == $_->svcnum } 
33   map { $_->cust_pkg->cust_svc }
34   $cust_bill->cust_bill_pkg ;
35 }
36
37 sub condition_sql {
38   my( $class, $table ) = @_;
39   
40   my $servicenum = $class->condition_sql_option('has_service');
41   my $sql = qq| 0 < ( SELECT COUNT(cs.svcpart)
42      FROM cust_bill_pkg cbp, cust_svc cs
43     WHERE cbp.invnum = cust_bill.invnum
44       AND cs.pkgnum = cbp.pkgnum
45       AND cs.svcpart = $servicenum
46   )
47   |;
48   return $sql;
49 }
50
51 1;