$cgi->keywords instead of $cgi->query_string
[freeside.git] / htdocs / search / cust_pkg.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: cust_pkg.cgi,v 1.3 1998-12-23 03:05:59 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.3  1998-12-23 03:05:59  ivan
9 # $cgi->keywords instead of $cgi->query_string
10 #
11 # Revision 1.2  1998/12/17 09:41:09  ivan
12 # s/CGI::(Base|Request)/CGI.pm/;
13 #
14
15 use strict;
16 use CGI;
17 use CGI::Carp qw(fatalsToBrowser);
18 use FS::UID qw(cgisuidsetup);
19 use FS::Record qw(qsearch qsearchs);
20 use FS::CGI qw(header idiot popurl);
21
22 my($cgi)=new CGI;
23 &cgisuidsetup($cgi);
24
25 my(@cust_pkg,$sortby);
26
27 my($query)=$cgi->keywords;
28 #this tree is a little bit redundant
29 if ( $query eq 'pkgnum' ) {
30   $sortby=\*pkgnum_sort;
31   @cust_pkg=qsearch('cust_pkg',{});
32 } elsif ( $query eq 'APKG_pkgnum' ) {
33   $sortby=\*pkgnum_sort;
34
35   #perhaps this should go in cust_pkg as a qsearch-like constructor?
36   my($cust_pkg);
37   foreach $cust_pkg (qsearch('cust_pkg',{})) {
38     my($flag)=0;
39     my($pkg_svc);
40     PKG_SVC: 
41     foreach $pkg_svc (qsearch('pkg_svc',{ 'pkgpart' => $cust_pkg->pkgpart })) {
42       if ( $pkg_svc->quantity 
43            > scalar(qsearch('cust_svc',{
44                'pkgnum' => $cust_pkg->pkgnum,
45                'svcpart' => $pkg_svc->svcpart,
46              }))
47          )
48       {
49         $flag=1;
50         last PKG_SVC;
51       }
52     }
53     push @cust_pkg, $cust_pkg if $flag;
54   }
55 } else {
56   die "Empty QUERY_STRING!";
57 }
58
59 if ( scalar(@cust_pkg) == 1 ) {
60   my($pkgnum)=$cust_pkg[0]->pkgnum;
61   print $cgi->redirect(popurl(2). "view/cust_pkg.cgi?$pkgnum");
62   exit;
63 } elsif ( scalar(@cust_pkg) == 0 ) { #error
64   &idiot("No packages found");
65   exit;
66 } else {
67   my($total)=scalar(@cust_pkg);
68   CGI::Base::SendHeaders(); # one guess
69   print header('Package Search Results',''), <<END;
70     $total matching packages found
71     <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
72       <TR>
73         <TH>Package #</TH>
74         <TH>Customer #</TH>
75         <TH>Name</TH>
76         <TH>Company</TH>
77       </TR>
78 END
79
80   my($lines)=16;
81   my($lcount)=$lines;
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     if ($lcount-- == 0) { # lots of little tables instead of one big one
102       $lcount=$lines;
103       print <<END;   
104   </TABLE>
105   <TABLE BORDER=4 CELLSPACING=0 CELLPADDING=0>
106     <TR>
107         <TH>Package #</TH>
108         <TH>Customer #</TH>
109         <TH>Name</TH>
110         <TH>Company</TH>
111       <TH>
112     </TR>
113 END
114     }
115   }
116  
117   print <<END;
118     </TABLE>
119     </CENTER>
120   </BODY>
121 </HTML>
122 END
123   exit;
124
125 }
126
127 sub pkgnum_sort {
128   $a->getfield('pkgnum') <=> $b->getfield('pkgnum');
129 }
130