changes to track email addresses for email invoicing
[freeside.git] / htdocs / search / cust_pkg.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: cust_pkg.cgi,v 1.4 1999-01-18 09:22:33 ivan Exp $
4 #
5 # based on search/svc_acct.cgi ivan@sisd.com 98-jul-17
6 #
7 # $Log: cust_pkg.cgi,v $
8 # Revision 1.4  1999-01-18 09:22:33  ivan
9 # changes to track email addresses for email invoicing
10 #
11 # Revision 1.3  1998/12/23 03:05:59  ivan
12 # $cgi->keywords instead of $cgi->query_string
13 #
14 # Revision 1.2  1998/12/17 09:41:09  ivan
15 # s/CGI::(Base|Request)/CGI.pm/;
16 #
17
18 use strict;
19 use CGI;
20 use CGI::Carp qw(fatalsToBrowser);
21 use FS::UID qw(cgisuidsetup);
22 use FS::Record qw(qsearch qsearchs);
23 use FS::CGI qw(header idiot popurl);
24
25 my($cgi)=new CGI;
26 &cgisuidsetup($cgi);
27
28 my(@cust_pkg,$sortby);
29
30 my($query)=$cgi->keywords;
31 #this tree is a little bit redundant
32 if ( $query eq 'pkgnum' ) {
33   $sortby=\*pkgnum_sort;
34   @cust_pkg=qsearch('cust_pkg',{});
35 } elsif ( $query eq 'APKG_pkgnum' ) {
36   $sortby=\*pkgnum_sort;
37
38   #perhaps this should go in cust_pkg as a qsearch-like constructor?
39   my($cust_pkg);
40   foreach $cust_pkg (qsearch('cust_pkg',{})) {
41     my($flag)=0;
42     my($pkg_svc);
43     PKG_SVC: 
44     foreach $pkg_svc (qsearch('pkg_svc',{ 'pkgpart' => $cust_pkg->pkgpart })) {
45       if ( $pkg_svc->quantity 
46            > scalar(qsearch('cust_svc',{
47                'pkgnum' => $cust_pkg->pkgnum,
48                'svcpart' => $pkg_svc->svcpart,
49              }))
50          )
51       {
52         $flag=1;
53         last PKG_SVC;
54       }
55     }
56     push @cust_pkg, $cust_pkg if $flag;
57   }
58 } else {
59   die "Empty QUERY_STRING!";
60 }
61
62 if ( scalar(@cust_pkg) == 1 ) {
63   my($pkgnum)=$cust_pkg[0]->pkgnum;
64   print $cgi->redirect(popurl(2). "view/cust_pkg.cgi?$pkgnum");
65   exit;
66 } elsif ( scalar(@cust_pkg) == 0 ) { #error
67   &idiot("No packages found");
68   exit;
69 } else {
70   my($total)=scalar(@cust_pkg);
71   print $cgi->header, header('Package Search Results',''), <<END;
72     $total matching packages found
73     <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
74       <TR>
75         <TH>Package #</TH>
76         <TH>Customer #</TH>
77         <TH>Name</TH>
78         <TH>Company</TH>
79       </TR>
80 END
81
82   my(%saw,$cust_pkg);
83   foreach $cust_pkg (
84     sort $sortby grep(!$saw{$_->pkgnum}++, @cust_pkg)
85   ) {
86     my($cust_main)=qsearchs('cust_main',{'custnum'=>$cust_pkg->custnum});
87     my($pkgnum,$custnum,$name,$company)=(
88       $cust_pkg->pkgnum,
89       $cust_main->custnum,
90       $cust_main->last. ', '. $cust_main->first,
91       $cust_main->company,
92     );
93     print <<END;
94     <TR>
95       <TD><A HREF="../view/cust_pkg.cgi?$pkgnum"><FONT SIZE=-1>$pkgnum</FONT></A></TD>
96       <TD><FONT SIZE=-1>$custnum</FONT></TD>
97       <TD><FONT SIZE=-1>$name</FONT></TD>
98       <TD><FONT SIZE=-1>$company</FONT></TD>
99     </TR>
100 END
101
102   }
103  
104   print <<END;
105     </TABLE>
106     </CENTER>
107   </BODY>
108 </HTML>
109 END
110   exit;
111
112 }
113
114 sub pkgnum_sort {
115   $a->getfield('pkgnum') <=> $b->getfield('pkgnum');
116 }
117