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