html table fix
[freeside.git] / httemplate / edit / part_bill_event.cgi
1 <!-- mason kludge -->
2 <%
3
4 if ( $cgi->param('eventpart') && $cgi->param('eventpart') =~ /^(\d+)$/ ) {
5   $cgi->param('eventpart', $1);
6 } else {
7   $cgi->param('eventpart', '');
8 }
9
10 my ($query) = $cgi->keywords;
11 my $action = '';
12 my $part_bill_event = '';
13 if ( $cgi->param('error') ) {
14   $part_bill_event = new FS::part_bill_event ( {
15     map { $_, scalar($cgi->param($_)) } fields('part_bill_event')
16   } );
17 }
18 if ( $query && $query =~ /^(\d+)$/ ) {
19   $part_bill_event ||= qsearchs('part_bill_event',{'eventpart'=>$1});
20 } else {
21   $part_bill_event ||= new FS::part_bill_event {};
22 }
23 $action ||= $part_bill_event->eventpart ? 'Edit' : 'Add';
24 my $hashref = $part_bill_event->hashref;
25
26 print header("$action Invoice Event Definition", menubar(
27   'Main Menu' => popurl(2),
28   'View all invoice events' => popurl(2). 'browse/part_bill_event.cgi',
29 ));
30
31 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
32       "</FONT>"
33   if $cgi->param('error');
34
35 print '<FORM ACTION="', popurl(1), 'process/part_bill_event.cgi" METHOD=POST>'.
36       '<INPUT TYPE="hidden" NAME="eventpart" VALUE="'.
37       $part_bill_event->eventpart  .'">';
38 print "Invoice Event #", $hashref->{eventpart} ? $hashref->{eventpart} : "(NEW)";
39
40 print ntable("#cccccc",2), <<END;
41 <TR><TD ALIGN="right">Payby</TD><TD><SELECT NAME="payby">
42 END
43
44 for (qw(CARD DCRD CHEK DCHK LECB BILL COMP)) {
45   print qq!<OPTION VALUE="$_"!;
46   if ($part_bill_event->payby eq $_) {
47     print " SELECTED>$_</OPTION>";
48   } else {
49     print ">$_</OPTION>";
50   }
51 }
52
53 my $days = $hashref->{seconds}/86400;
54
55 print <<END;
56 </SELECT></TD></TR>
57 <TR><TD ALIGN="right">Event</TD><TD><INPUT TYPE="text" NAME="event" VALUE="$hashref->{event}"></TD></TR>
58 <TR><TD ALIGN="right">After</TD><TD><INPUT TYPE="text" NAME="days" VALUE="$days"> days</TD></TR>
59 END
60
61 print '<TR><TD ALIGN="right">Disabled</TD><TD>';
62 print '<INPUT TYPE="checkbox" NAME="disabled" VALUE="Y"';
63 print ' CHECKED' if $hashref->{disabled} eq "Y";
64 print '>';
65 print '</TD></TR>';
66
67 print '<TR><TD ALIGN="right">Action</TD><TD>';
68
69 #print ntable();
70
71 sub select_pkgpart {
72   my $label = shift;
73   my $plandata = shift;
74   my %selected = map { $_=>1 } split(/,\s*/, $plandata->{$label});
75   qq(<SELECT NAME="$label" MULTIPLE>).
76   join("\n", map {
77     '<OPTION VALUE="'. $_->pkgpart. '"'.
78     ( $selected{$_->pkgpart} ? ' SELECTED' : '' ).
79     '>'. $_->pkg. ' - '. $_->comment
80   } qsearch('part_pkg', { 'disabled' => '' } ) ).
81   '</SELECT>';
82 }
83
84 sub select_agentnum {
85   my $plandata = shift;
86   my $agentnum = $plandata->{'agentnum'};
87   '<SELECT NAME="agentnum">'.
88   join("\n", map {
89     '<OPTION VALUE="'. $_->agentnum. '"'.
90     ( $_->agentnum == $agentnum ? ' SELECTED' : '' ).
91     '>'. $_->agent
92   } qsearch('agent', { 'disabled' => '' } ) ).
93   '</SELECT>';
94 }
95
96 #this is pretty kludgy right here.
97 tie my %events, 'Tie::IxHash',
98
99   'fee' => {
100     'name'   => 'Late fee',
101     'code'   => '$cust_main->charge( %%%charge%%%, \'%%%reason%%%\' );',
102     'html'   => 
103       'Amount <INPUT TYPE="text" SIZE="7" NAME="charge" VALUE="%%%charge%%%">'.
104       '<BR>Reason <INPUT TYPE="text" NAME="reason" VALUE="%%%reason%%%">',
105     'weight' => 10,
106   },
107   'suspend' => {
108     'name'   => 'Suspend',
109     'code'   => '$cust_main->suspend();',
110     'weight' => 10,
111   },
112   'suspend-if-pkgpart' => {
113     'name'   => 'Suspend packages',
114     'code'   => '$cust_main->suspend_if_pkgpart(%%%if_pkgpart%%%);',
115     'html'   => sub { &select_pkgpart('if_pkgpart', @_) },
116     'weight' => 10,
117   },
118   'suspend-unless-pkgpart' => {
119     'name'   => 'Suspend packages except',
120     'code'   => '$cust_main->suspend_unless_pkgpart(%%%unless_pkgpart%%%);',
121     'html'   => sub { &select_pkgpart('unless_pkgpart', @_) },
122     'weight' => 10,
123   },
124   'cancel' => {
125     'name'   => 'Cancel',
126     'code'   => '$cust_main->cancel();',
127     'weight' => 10,
128   },
129
130   'addpost' => {
131     'name' => 'Add postal invoicing',
132     'code' => '$cust_main->invoicing_list_addpost(); "";',
133     'weight'  => 20,
134   },
135
136   'comp' => {
137     'name' => 'Pay invoice with a complimentary "payment"',
138     'code' => '$cust_bill->comp();',
139     'weight' => 30,
140   },
141
142   'realtime-card' => {
143     'name' => 'Run card with a <a href="http://search.cpan.org/search?mode=module&query=Business%3A%3AOnlinePayment">Business::OnlinePayment</a> realtime gateway',
144     'code' => '$cust_bill->realtime_card();',
145     'weight' => 30,
146   },
147
148   'realtime-check' => {
149     'name' => 'Run check with a <a href="http://search.cpan.org/search?mode=module&query=Business%3A%3AOnlinePayment">Business::OnlinePayment</a> realtime gateway',
150     'code' => '$cust_bill->realtime_ach();',
151     'weight' => 30,
152   },
153
154   'realtime-lec' => {
155     'name' => 'Run phone bill ("LEC") billing with a <a href="http://search.cpan.org/search?mode=module&query=Business%3A%3AOnlinePayment">Business::OnlinePayment</a> realtime gateway',
156     'code' => '$cust_bill->realtime_lec();',
157     'weight' => 30,
158   },
159
160   'batch-card' => {
161     'name' => 'Add card to the pending credit card batch',
162     'code' => '$cust_bill->batch_card();',
163     'weight' => 40,
164   },
165
166   'send' => {
167     'name' => 'Send invoice (email/print)',
168     'code' => '$cust_bill->send();',
169     'weight' => 50,
170   },
171
172   'send_alternate' => {
173     'name' => 'Send invoice (email/print) with alternate template',
174     'code' => '$cust_bill->send(\'%%%templatename%%%\');',
175     'html' =>
176         '<INPUT TYPE="text" NAME="templatename" VALUE="%%%templatename%%%">',
177     'weight' => 50,
178   },
179
180   'send_agent' => {
181     'name' => 'Send invoice (email/print) ',
182     'code' => '$cust_bill->send(\'%%%agent_templatename%%%\', %%%agentnum%%%, \'%%%agent_invoice_from%%%\');',
183     'html' => sub {
184         '<TABLE BORDER=0>
185           <TR>
186             <TD ALIGN="right">only for agent </TD>
187             <TD>'. &select_agentnum(@_). '</TD>
188           </TR>
189           <TR>
190             <TD ALIGN="right">with template </TD>
191             <TD>
192               <INPUT TYPE="text" NAME="agent_templatename" VALUE="%%%agent_templatename%%%">
193             </TD>
194           </TR>
195           <TR>
196             <TD ALIGN="right">email From: </TD>
197             <TD>
198               <INPUT TYPE="text" NAME="agent_invoice_from" VALUE="%%%agent_invoice_from%%%">
199             </TD>
200           </TR>
201         </TABLE>';
202     },
203     'weight' => 50,
204   },
205
206   'send_csv_ftp' => {
207     'name' => 'Upload CSV invoice data to an FTP server',
208     'code' => '$cust_bill->send_csv( protocol => \'ftp\',
209                                      server   => \'%%%ftpserver%%%\',
210                                      username => \'%%%ftpusername%%%\',
211                                      password => \'%%%ftppassword%%%\',
212                                      dir      => \'%%%ftpdir%%%\'       );',
213     'html' =>
214         '<TABLE BORDER=0><TR><TD ALIGN="right">FTP server: </TD>'.
215           '<TD><INPUT TYPE="text" NAME="ftpserver" VALUE="%%%ftpserver%%%">'.
216           '</TD></TR>'.
217         '<TR><TD ALIGN="right">FTP username: </TD><TD>'.
218           '<INPUT TYPE="text" NAME="ftpusername" VALUE="%%%ftpusername%%%">'.
219           '</TD></TR>'.
220         '<TR><TD ALIGN="right">FTP password: </TD><TD>'.
221           '<INPUT TYPE="text" NAME="ftppassword" VALUE="%%%ftppassword%%%">'.
222           '</TD></TR>'.
223         '<TR><TD ALIGN="right">FTP directory: </TD>'.
224           '<TD><INPUT TYPE="text" NAME="ftpdir" VALUE="%%%ftpdir%%%">'.
225           '</TD></TR>'.
226         '</TABLE>',
227     'weight' => 50,
228   },
229
230   'bill' => {
231     'name' => 'Generate invoices (normally only used with a <i>Late Fee</i> event)',
232     'code' => '$cust_main->bill();',
233     'weight'  => 60,
234   },
235
236   'apply' => {
237     'name' => 'Apply unapplied payments and credits',
238     'code' => '$cust_main->apply_payments; $cust_main->apply_credits; "";',
239     'weight'  => 70,
240   },
241
242   'collect' => {
243     'name' => 'Collect on invoices (normally only used with a <i>Late Fee</i> and <i>Generate Invoice</i> events)',
244     'code' => '$cust_main->collect();',
245     'weight'  => 80,
246   },
247
248 ;
249
250 foreach my $event ( keys %events ) {
251   my %plandata = map { /^(\w+) (.*)$/; ($1, $2); }
252                    split(/\n/, $part_bill_event->plandata);
253   my $html = $events{$event}{html};
254   if ( ref($html) eq 'CODE' ) {
255     $html = &{$html}(\%plandata);
256   }
257   while ( $html =~ /%%%(\w+)%%%/ ) {
258     my $field = $1;
259     $html =~ s/%%%$field%%%/$plandata{$field}/;
260   }
261
262   print ntable( "#cccccc", 2).
263         qq!<TR><TD><INPUT TYPE="radio" NAME="plan_weight_eventcode" !;
264   print "CHECKED " if $event eq $part_bill_event->plan;
265   print qq!VALUE="!.  $event. ":". $events{$event}{weight}. ":".
266         encode_entities($events{$event}{code}).
267         qq!">$events{$event}{name}</TD>!;
268   print '<TD>'. $html. '</TD>' if $html;
269   print qq!</TR>!;
270   print '</TABLE>';
271 }
272
273 #print '</TABLE>';
274
275 print <<END;
276 </TD></TR>
277 </TABLE>
278 END
279
280 print qq!<INPUT TYPE="submit" VALUE="!,
281       $hashref->{eventpart} ? "Apply changes" : "Add invoice event",
282       qq!">!;
283 %>
284
285     </FORM>
286   </BODY>
287 </HTML>
288