fix visual and other bugs
[freeside.git] / htdocs / browse / part_pkg.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: part_pkg.cgi,v 1.4 1998-12-17 05:25:19 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.4  1998-12-17 05:25:19  ivan
14 # fix visual and other bugs
15 #
16 # Revision 1.3  1998/11/21 07:23:45  ivan
17 # visual
18 #
19 # Revision 1.2  1998/11/21 07:00:32  ivan
20 # visual
21 #
22
23 use strict;
24 use CGI;
25 use CGI::Carp qw(fatalsToBrowser);
26 use FS::UID qw(cgisuidsetup swapuid);
27 use FS::Record qw(qsearch qsearchs);
28 use FS::CGI qw(header menubar popurl table);
29 use FS::part_pkg;
30 use FS::pkg_svc;
31 use FS::part_svc;
32
33 my($cgi) = new CGI;
34
35 &cgisuidsetup($cgi);
36
37 my $p = popurl(2);
38
39 print $cgi->header, header("Package Part Listing",menubar(
40   'Main Menu' => $p,
41 )), "One or more services are grouped together into a package and given",
42   " pricing information. Customers purchase packages, not services.<BR><BR>", 
43   table, <<END;
44     <TABLE BORDER>
45       <TR>
46         <TH COLSPAN=2>Package</TH>
47         <TH>Comment</TH>
48         <TH><FONT SIZE=-1>Setup Fee</FONT></TH>
49         <TH><FONT SIZE=-1>Freq.</FONT></TH>
50         <TH><FONT SIZE=-1>Recur. Fee</FONT></TH>
51         <TH>Service</TH>
52         <TH><FONT SIZE=-1>Quan.</FONT></TH>
53       </TR>
54 END
55
56 my($part_pkg);
57 foreach $part_pkg ( sort { 
58   $a->getfield('pkgpart') <=> $b->getfield('pkgpart')
59 } qsearch('part_pkg',{}) ) {
60   my($hashref)=$part_pkg->hashref;
61   my(@pkg_svc)=grep $_->getfield('quantity'),
62     qsearch('pkg_svc',{'pkgpart'=> $hashref->{pkgpart} });
63   my($rowspan)=scalar(@pkg_svc);
64   print <<END;
65       <TR>
66         <TD ROWSPAN=$rowspan><A HREF="${p}edit/part_pkg.cgi?$hashref->{pkgpart}">
67           $hashref->{pkgpart}
68         </A></TD>
69         <TD ROWSPAN=$rowspan><A HREF="${p}edit/part_pkg.cgi?$hashref->{pkgpart}">$hashref->{pkg}</A></TD>
70         <TD ROWSPAN=$rowspan>$hashref->{comment}</TD>
71         <TD ROWSPAN=$rowspan>$hashref->{setup}</TD>
72         <TD ROWSPAN=$rowspan>$hashref->{freq}</TD>
73         <TD ROWSPAN=$rowspan>$hashref->{recur}</TD>
74 END
75
76   my($pkg_svc);
77   my($n)="";
78   foreach $pkg_svc ( @pkg_svc ) {
79     my($svcpart)=$pkg_svc->getfield('svcpart');
80     my($part_svc) = qsearchs('part_svc',{'svcpart'=> $svcpart });
81     print $n,qq!<TD><A HREF="${p}edit/part_svc.cgi?$svcpart">!,
82           $part_svc->getfield('svc'),"</A></TD><TD>",
83           $pkg_svc->getfield('quantity'),"</TD></TR>\n";
84     $n="<TR>";
85   }
86
87   print "</TR>";
88 }
89
90 print <<END;
91    <TR><TD COLSPAN=2><I><A HREF="${p}edit/part_pkg.cgi">Add new package</A></I></TD></TR>
92     </TABLE>
93   </BODY>
94 </HTML>
95 END
96