034389755d755f0dab26f98165c20bf8d511b31e
[freeside.git] / htdocs / view / cust_pkg.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: cust_pkg.cgi,v 1.4 1998-12-23 03:08:40 ivan Exp $
4 #
5 # Usage: cust_pkg.cgi pkgnum
6 #        http://server.name/path/cust_pkg.cgi?pkgnum
7 #
8 # Note: Should be run setuid freeside as user nobody.
9 #
10 # ivan@voicenet.com 96-dec-15
11 #
12 # services section needs to be cleaned up, needs to display extraneous
13 # entries in cust_pkg!
14 # ivan@voicenet.com 96-dec-31
15 #
16 # added navigation bar
17 # ivan@voicenet.com 97-jan-30
18 #
19 # changed and fixed up suspension and cancel stuff, now you can't add
20 # services to a cancelled package
21 # ivan@voicenet.com 97-feb-27
22 #
23 # rewrote for new API, still needs to be cleaned up!
24 # ivan@voicenet.com 97-jul-29
25 #
26 # no FS::Search ivan@sisd.com 98-mar-7
27
28 # $Log: cust_pkg.cgi,v $
29 # Revision 1.4  1998-12-23 03:08:40  ivan
30 # $cgi->keywords instead of $cgi->query_string
31 #
32 # Revision 1.3  1998/12/17 09:57:22  ivan
33 # s/CGI::(Base|Request)/CGI.pm/;
34 #
35 # Revision 1.2  1998/11/13 09:56:49  ivan
36 # change configuration file layout to support multiple distinct databases (with
37 # own set of config files, export, etc.)
38 #
39
40 use strict;
41 use Date::Format;
42 use CGI;
43 use CGI::Carp qw(fatalsToBrowser);
44 use FS::UID qw(cgisuidsetup);
45 use FS::CGI qw(popurl header);
46 use FS::Record qw(qsearch qsearchs);
47 use FS::part_svc;
48 use FS::cust_pkg;
49 use FS::part_pkg;
50 use FS::pkg_svc;
51 use FS::cust_svc;
52
53 my($cgi) = new CGI;
54 cgisuidsetup($cgi);
55
56 my(%uiview,%uiadd);
57 my($part_svc);
58 foreach $part_svc ( qsearch('part_svc',{}) ) {
59   $uiview{$part_svc->svcpart} = popurl(2). "view/". $part_svc->svcdb . ".cgi";
60   $uiadd{$part_svc->svcpart}= popurl(2). "edit/". $part_svc->svcdb . ".cgi";
61 }
62
63 print $cgi->header, header('Package View', '');
64
65 $cgi->query_string =~ /^(\d+)$/ or die $cgi->query_string;
66 my($pkgnum)=$1;
67
68 #get package record
69 my($cust_pkg)=qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});
70 die "No package!" unless $cust_pkg;
71 my($part_pkg)=qsearchs('part_pkg',{'pkgpart'=>$cust_pkg->getfield('pkgpart')});
72
73 #nav bar
74 my($custnum)=$cust_pkg->getfield('custnum');
75 print qq!<CENTER><A HREF="../view/cust_main.cgi?$custnum">View this customer!,
76       qq! (#$custnum)</A> | <A HREF="../">Main menu</A></CENTER><BR>!;
77
78 #print info
79 my($susp,$cancel,$expire)=(
80   $cust_pkg->getfield('susp'),
81   $cust_pkg->getfield('cancel'),
82   $cust_pkg->getfield('expire'),
83 );
84 print "<FONT SIZE=+1><CENTER>Package #<B>$pkgnum</B></FONT>";
85 print qq!<BR><A HREF="#package">Package Information</A>!;
86 print qq! | <A HREF="#services">Service Information</A>! unless $cancel;
87 print qq!</CENTER><HR>\n!;
88
89 my($pkg,$comment)=($part_pkg->getfield('pkg'),$part_pkg->getfield('comment'));
90 print qq!<A NAME="package"><CENTER><FONT SIZE=+1>Package Information!,
91       qq!</FONT></A>!;
92 print qq!<BR><A HREF="../unimp.html">Edit this information</A></CENTER>!;
93 print "<P>Package: <B>$pkg - $comment</B>";
94
95 my($setup,$bill)=($cust_pkg->getfield('setup'),$cust_pkg->getfield('bill'));
96 print "<BR>Setup: <B>", $setup ? time2str("%D",$setup) : "(Not setup)" ,"</B>";
97 print "<BR>Next bill: <B>", $bill ? time2str("%D",$bill) : "" ,"</B>";
98
99 if ($susp) {
100   print "<BR>Suspended: <B>", time2str("%D",$susp), "</B>";
101   print qq! <A HREF="../misc/unsusp_pkg.cgi?$pkgnum">Unsuspend</A>! unless $cancel;
102 } else {
103   print qq!<BR><A HREF="../misc/susp_pkg.cgi?$pkgnum">Suspend</A>! unless $cancel;
104 }
105
106 if ($expire) {
107   print "<BR>Expire: <B>", time2str("%D",$expire), "</B>";
108 }
109   print <<END;
110 <FORM ACTION="../misc/expire_pkg.cgi" METHOD="post">
111 <INPUT TYPE="hidden" NAME="pkgnum" VALUE="$pkgnum">
112 Expire (date): <INPUT TYPE="text" NAME="date" VALUE="" >
113 <INPUT TYPE="submit" VALUE="Cancel later">
114 END
115
116 if ($cancel) {
117   print "<BR>Cancelled: <B>", time2str("%D",$cancel), "</B>";
118 } else {
119   print qq!<BR><A HREF="../misc/cancel_pkg.cgi?$pkgnum">Cancel now</A>!;
120 }
121
122 #otaker
123 my($otaker)=$cust_pkg->getfield('otaker');
124 print "<P>Order taken by <B>$otaker</B>";
125
126 unless ($cancel) {
127
128   #services
129   print <<END;
130 <HR><A NAME="services"><CENTER><FONT SIZE=+1>Service Information</FONT></A>
131 <BR>Click on service to view/edit/add service.</CENTER><BR>
132 <CENTER><B>Do NOT pick the "Link to existing" option unless you are auditing!!!</B></CENTER>
133 <CENTER><TABLE BORDER=4>
134 <TR><TH>Service</TH>
135 END
136
137   #list of services this pkgpart includes
138   my($pkg_svc,%pkg_svc);
139   foreach $pkg_svc ( qsearch('pkg_svc',{'pkgpart'=> $cust_pkg->pkgpart }) ) {
140     $pkg_svc{$pkg_svc->svcpart} = $pkg_svc->quantity if $pkg_svc->quantity;
141   }
142
143   #list of records from cust_svc
144   my($svcpart);
145   foreach $svcpart (sort {$a <=> $b} keys %pkg_svc) {
146
147     my($svc)=qsearchs('part_svc',{'svcpart'=>$svcpart})->getfield('svc');
148
149     my(@cust_svc)=qsearch('cust_svc',{'pkgnum'=>$pkgnum, 
150                                       'svcpart'=>$svcpart,
151                                      });
152
153     my($enum);
154     for $enum ( 1 .. $pkg_svc{$svcpart} ) {
155
156       my($cust_svc);
157       if ( $cust_svc=shift @cust_svc ) {
158         my($svcnum)=$cust_svc->svcnum;
159         print <<END;
160 <TR><TD><A HREF="$uiview{$svcpart}?$svcnum">(View) $svc<A></TD></TR>
161 END
162       } else {
163         print <<END;
164 <TR>
165   <TD><A HREF="$uiadd{$svcpart}?pkgnum$pkgnum-svcpart$svcpart">
166       (Add) $svc</A>
167    or <A HREF="../misc/link.cgi?pkgnum$pkgnum-svcpart$svcpart">
168       (Link to existing) $svc</A>
169   </TD>
170 </TR>
171 END
172       }
173
174     }
175     warn "WARNING: Leftover services pkgnum $pkgnum!" if @cust_svc;; 
176   }
177
178   print "</TABLE></CENTER>";
179
180 }
181
182 #formatting
183 print <<END;
184   </BODY>
185 </HTML>
186 END
187