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