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