explicit & for table/itable/ntable
[freeside.git] / htdocs / browse / part_pkg.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: part_pkg.cgi,v 1.7 1999-04-09 03:52:55 ivan Exp $
4 #
5 # ivan@sisd.com 97-dec-5,9
6 #
7 # Changes to allow page to work at a relative position in server
8 #       bmccane@maxbaud.net     98-apr-3
9 #
10 # lose background, FS::CGI ivan@sisd.com 98-sep-2
11 #
12 # $Log: part_pkg.cgi,v $
13 # Revision 1.7  1999-04-09 03:52:55  ivan
14 # explicit & for table/itable/ntable
15 #
16 # Revision 1.6  1999/01/19 05:13:27  ivan
17 # for mod_perl: no more top-level my() variables; use vars instead
18 # also the last s/create/new/;
19 #
20 # Revision 1.5  1999/01/18 09:41:17  ivan
21 # all $cgi->header calls now include ( '-expires' => 'now' ) for mod_perl
22 # (good idea anyway)
23 #
24 # Revision 1.4  1998/12/17 05:25:19  ivan
25 # fix visual and other bugs
26 #
27 # Revision 1.3  1998/11/21 07:23:45  ivan
28 # visual
29 #
30 # Revision 1.2  1998/11/21 07:00:32  ivan
31 # visual
32 #
33
34 use strict;
35 use vars qw( $cgi $p $part_pkg );
36 use CGI;
37 use CGI::Carp qw(fatalsToBrowser);
38 use FS::UID qw(cgisuidsetup swapuid);
39 use FS::Record qw(qsearch qsearchs);
40 use FS::CGI qw(header menubar popurl table);
41 use FS::part_pkg;
42 use FS::pkg_svc;
43 use FS::part_svc;
44
45 $cgi = new CGI;
46
47 &cgisuidsetup($cgi);
48
49 $p = popurl(2);
50
51 print $cgi->header( '-expires' => 'now' ), header("Package Part Listing",menubar(
52   'Main Menu' => $p,
53 )), "One or more services are grouped together into a package and given",
54   " pricing information. Customers purchase packages, not services.<BR><BR>", 
55   &table, <<END;
56     <TABLE BORDER>
57       <TR>
58         <TH COLSPAN=2>Package</TH>
59         <TH>Comment</TH>
60         <TH><FONT SIZE=-1>Setup Fee</FONT></TH>
61         <TH><FONT SIZE=-1>Freq.</FONT></TH>
62         <TH><FONT SIZE=-1>Recur. Fee</FONT></TH>
63         <TH>Service</TH>
64         <TH><FONT SIZE=-1>Quan.</FONT></TH>
65       </TR>
66 END
67
68 foreach $part_pkg ( sort { 
69   $a->getfield('pkgpart') <=> $b->getfield('pkgpart')
70 } qsearch('part_pkg',{}) ) {
71   my($hashref)=$part_pkg->hashref;
72   my(@pkg_svc)=grep $_->getfield('quantity'),
73     qsearch('pkg_svc',{'pkgpart'=> $hashref->{pkgpart} });
74   my($rowspan)=scalar(@pkg_svc);
75   print <<END;
76       <TR>
77         <TD ROWSPAN=$rowspan><A HREF="${p}edit/part_pkg.cgi?$hashref->{pkgpart}">
78           $hashref->{pkgpart}
79         </A></TD>
80         <TD ROWSPAN=$rowspan><A HREF="${p}edit/part_pkg.cgi?$hashref->{pkgpart}">$hashref->{pkg}</A></TD>
81         <TD ROWSPAN=$rowspan>$hashref->{comment}</TD>
82         <TD ROWSPAN=$rowspan>$hashref->{setup}</TD>
83         <TD ROWSPAN=$rowspan>$hashref->{freq}</TD>
84         <TD ROWSPAN=$rowspan>$hashref->{recur}</TD>
85 END
86
87   my($pkg_svc);
88   my($n)="";
89   foreach $pkg_svc ( @pkg_svc ) {
90     my($svcpart)=$pkg_svc->getfield('svcpart');
91     my($part_svc) = qsearchs('part_svc',{'svcpart'=> $svcpart });
92     print $n,qq!<TD><A HREF="${p}edit/part_svc.cgi?$svcpart">!,
93           $part_svc->getfield('svc'),"</A></TD><TD>",
94           $pkg_svc->getfield('quantity'),"</TD></TR>\n";
95     $n="<TR>";
96   }
97
98   print "</TR>";
99 }
100
101 print <<END;
102    <TR><TD COLSPAN=2><I><A HREF="${p}edit/part_pkg.cgi">Add new package</A></I></TD></TR>
103     </TABLE>
104   </BODY>
105 </HTML>
106 END
107