change invoice terms for one-time charges (& bill them immediately), RT#5891
[freeside.git] / httemplate / edit / cust_main / billing.html
1 %if ( $payby_default eq 'HIDE' ) {
2 %
3 %  $cust_main->payby('BILL') unless $cust_main->payby;
4 %  my $payby = $cust_main->payby;
5
6   <INPUT TYPE="hidden" NAME="payby" VALUE="<% $payby %>">
7
8   <INPUT TYPE="hidden" NAME="<%$payby%>_payinfo" VALUE="<% $cust_main->paymask %>">
9
10 % foreach my $field (qw( payname paycvv paystart_month paystart_year payissue payip paytype paystate )) { 
11
12     <INPUT TYPE="hidden" NAME="<% $payby.'_'.$field %>" VALUE="<% $cust_main->get($field) %>">
13
14 % } 
15
16 %  #false laziness w/elements/select-month_year.html & view/cust_main/billing.html
17 %  my( $mon, $year );
18 %  my $date = $cust_main->paydate || '12-2037';
19 %  if ( $date  =~ /^(\d{4})-(\d{1,2})-\d{1,2}$/ ) { #PostgreSQL date format
20 %    ( $mon, $year ) = ( $2, $1 );
21 %  } elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
22 %    ( $mon, $year ) = ( $1, $3 );
23 %  } else {
24 %    die "unrecognized expiration date format: $date";
25 %  }
26
27   <INPUT TYPE="hidden" NAME="<%$payby%>_exp_month" VALUE="<% $mon %>">
28   <INPUT TYPE="hidden" NAME="<%$payby%>_exp_year"  VALUE="<% $year %>">
29
30   <INPUT TYPE="hidden" NAME="tax" VALUE="<% $cust_main->tax %>">
31
32   <INPUT TYPE="hidden" NAME="invoicing_list" VALUE="<% join(', ', @invoicing_list) %>">
33
34 % } else {
35 %
36 %  my $r = qq!<font color="#ff0000">*</font>&nbsp;!;
37
38   <BR><FONT SIZE="+1"><B>Billing information</B></FONT>
39   <% &ntable("#cccccc") %>
40
41     <TR>
42       <TD ALIGN="right" WIDTH="200"><%$r%>Billing type</TD>
43
44   <SCRIPT>
45
46     var mywindow = -1;
47     function myopen(filename,windowname,properties) {
48       myclose();
49       mywindow = window.open(filename,windowname,properties);
50     }
51     function myclose() {
52       if ( mywindow != -1 )
53         mywindow.close();
54       mywindow = -1;
55     }
56
57     var achwindow = -1;
58     function achopen(filename,windowname,properties) {
59       achclose();
60       achwindow = window.open(filename,windowname,properties);
61     }
62     function achclose() {
63       if ( achwindow != -1 )
64         achwindow.close();
65       achwindow = -1;
66     }
67
68     function card_changed(what) {
69       if (
70              what.form.payinfo.value.substring(0, 4) == '4093' 
71           || what.form.payinfo.value.substring(0, 4) == '4911' 
72           || what.form.payinfo.value.substring(0, 4) == '4936' 
73           || what.form.payinfo.value.substring(0, 6) == '564132' 
74           || what.form.payinfo.value.substring(0, 2) == '63' 
75           || what.form.payinfo.value.substring(0, 2) == '67' 
76          )
77       {
78         what.form.paystart_month.disabled = false;
79         what.form.paystart_year.disabled = false;
80         what.form.payissue.disabled = false;
81         what.form.paystart_month.style.backgroundColor = '#ffffff';
82         what.form.paystart_year.style.backgroundColor = '#ffffff';
83         what.form.payissue.style.backgroundColor = '#ffffff';
84         document.getElementById('paystart_label').style.color = '#000000';
85         document.getElementById('payissue_label').style.color = '#000000';
86       } else {
87         what.form.paystart_month.disabled = true;
88         what.form.paystart_year.disabled = true;
89         what.form.payissue.disabled = true;
90         what.form.paystart_month.style.backgroundColor = '#dddddd';
91         what.form.paystart_year.style.backgroundColor = '#dddddd';
92         what.form.payissue.style.backgroundColor = '#dddddd';
93         document.getElementById('paystart_label').style.color = '#999999';
94         document.getElementById('payissue_label').style.color = '#999999';
95       }
96       return true;
97     }
98
99   </SCRIPT>
100
101   <% include('/elements/init_overlib.html') %>
102
103 %  my $payby = $cust_main->payby;
104 %  my $paytype = $cust_main->paytype;
105 %  my( $account, $aba ) = split('@', $payinfo);
106 %
107 %  my $disabled = 'DISABLED style="background-color: #dddddd"';
108 %  my $text_disabled = 'style="color: #999999"';
109 %
110 %  if ( $payby =~ /^(CARD|DCRD)$/ && cardtype($payinfo) =~ /^(Switch|Solo)$/ ) {
111 %    $disabled = 'style="background-color: #ffffff"';
112 %    $text_disabled = 'style="color: #000000";'
113 %  }
114 %
115 %  my %payby = (
116 %
117 %    'CARD' =>
118 %
119 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
120 %
121 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Card number </TD>!.
122 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="CARD_payinfo" VALUE="!. ( $payby =~ /^(CARD|DCRD)$/ ? $payinfo : '' ). qq!" MAXLENGTH=19 onChange="card_changed(this)" onKeyUp="card_changed(this)"></TD></TR>!.
123 %
124 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Expiration </TD>!.
125 %          '<TD WIDTH="408">'.
126 %
127 %          include('/elements/select-month_year.html',
128 %                    'prefix' => 'CARD_exp',
129 %                    'selected_date' =>
130 %                      ( $payby =~ /^(CARD|DCRD)$/ ? $cust_main->paydate : '' ),
131 %                 ).
132 %
133 %          '</TD></TR>'.
134 %
135 %        qq!<TR><TD ALIGN="right" WIDTH="200">CVV2&nbsp;!.
136 %
137 %          qq!(<A HREF="javascript:void(0);" onClick="overlib( OLiframeContent('../docs/cvv2.html', 480, 352, 'cvv2_popup' ), CAPTION, 'CVV2 Help', STICKY, AUTOSTATUSCAP, CLOSECLICK, DRAGGABLE ); return false;">help</A>)!.
138 %          qq!</TD>!.
139 %          '<TD WIDTH="408"><INPUT TYPE="text" NAME="CARD_paycvv" VALUE="'. ( $payby =~ /^(CARD|DCRD)$/ && !$cust_main->is_encrypted($cust_main->paycvv) ? $cust_main->paycvv : '' ). '" SIZE=4 MAXLENGTH=4>'.
140 %
141 %
142 %        qq!<TR><TD ALIGN="right" WIDTH="200"><SPAN ID="paystart_label" $text_disabled>Start date </SPAN></TD>!.
143 %          '<TD WIDTH="408">'.
144 %
145 %          include('/elements/select-month_year.html',
146 %                    'prefix' => 'CARD_paystart',
147 %                    'disabled' => $disabled,
148 %                    'empty_option' => 1,
149 %                    'start_year' => 2000,
150 %                    'end_year'   => (localtime())[5] + 1900,
151 %                    'selected_date' => (
152 %                      ( $payby =~ /^(CARD|DCRD)$/
153 %                        && cardtype($payinfo) =~ /^(Switch|Solo)$/ )
154 %                          ? $cust_main->paystart_month. '-'.
155 %                            $cust_main->paystart_year 
156 %                          : ''
157 %                    )
158 %                 ).
159 %
160 %        qq!<SPAN ID="payissue_label" $text_disabled> or Issue number </SPAN>!.
161 %          '<INPUT TYPE="text" NAME="CARD_payissue" VALUE="'. ( $payby =~ /^(CARD|DCRD)$/ ? $cust_main->payissue : '' ). qq!" SIZE=3 MAXLENGTH=2 $disabled></TD></TR>!.
162 %
163 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Exact name on card </TD>!.
164 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="CARD_payname" VALUE="!. ( $payby =~ /^(CARD|DCRD)$/ ? $cust_main->payname : '' ). qq!"></TD></TR>!.
165 %
166 %        qq!<TR><TD COLSPAN=2 WIDTH="608"><INPUT TYPE="checkbox" NAME="CARD_payauto" !. ( $payby eq 'DCRD' ? '' : 'CHECKED' ). '> Charge future payments to this card automatically</TD></TR>'.
167 %
168 %      '</TABLE>',
169 %
170 %    'CHEK' => 
171 %
172 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
173 %
174 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Account number </TD>!.
175 %          qq!<TD><INPUT TYPE="text" SIZE=12 NAME="CHEK_payinfo1" VALUE="!. ( $payby =~ /^(CHEK|DCHK)$/ ? $account : '' ). '"></TD>'.
176 %          qq!<TD ALIGN="right">Type</TD><TD><SELECT NAME="CHEK_paytype">!.
177 %            join('', map { qq!<OPTION VALUE="$_" !.($paytype eq $_ ? 'SELECTED' : '').">$_</OPTION>" } @FS::cust_main::paytypes).
178 %          qq!</SELECT></TD></TR>!.
179 %
180 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}ABA/Routing number </TD>!.
181 %          qq!<TD COLSPAN="3" WIDTH="408"><INPUT TYPE="text" SIZE=10 MAXLENGTH=9 NAME="CHEK_payinfo2" VALUE="!. ( $payby =~ /^(CHEK|DCHK)$/ ? $aba : '' ). qq!" SIZE=10 MAXLENGTH=9> !.
182 %          qq!(<A HREF="javascript:void(0);" onClick="overlib( OLiframeContent('../docs/ach.html', 380, 240, 'ach_popup' ), CAPTION, 'ACH Help', STICKY, AUTOSTATUSCAP, CLOSECLICK, DRAGGABLE ); return false;">help</A>)!.
183 %          qq!</TD></TR>!.
184 %
185 %        qq!<INPUT TYPE="hidden" NAME="CHEK_exp_month" VALUE="12">!.
186 %        qq!<INPUT TYPE="hidden" NAME="CHEK_exp_year" VALUE="2037">!.
187 %
188 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Bank name </TD>!.
189 %          qq!<TD COLSPAN="3" WIDTH="408"><INPUT TYPE="text" NAME="CHEK_payname" VALUE="!. ( $payby =~ /^(CHEK|DCHK)$/ ? $cust_main->payname : '' ). qq!"></TD></TR>!.
190 %      ( $conf->exists('show_bankstate') ?
191 %          qq!<TR><TD ALIGN="right" WIDTH="200">$paystate_label</TD>!.
192 %          qq!<TD COLSPAN="3" WIDTH="408">!.
193 %          include('/elements/select-state.html',
194 %                    'empty'   => '(choose)',
195 %                    'state'   => $cust_main->paystate,
196 %                    'country' => $cust_main->country,
197 %                    'prefix'  => 'CHEK_pay',
198 %                 ). "</TD></TR>"
199 %         : '<INPUT TYPE="hidden" NAME="CHEK_paystate" VALUE="'.
200 %            $cust_main->paystate. '">'
201 %       ).
202 %
203 %
204 %        qq!<TR><TD COLSPAN=4 WIDTH="608"><INPUT TYPE="checkbox" NAME="CHEK_payauto" !. ( $payby eq 'DCHK' ? '' : 'CHECKED' ). '> Charge future payments to this electronic check automatically</TD></TR>'.
205 %
206 %        '<TR><TD>&nbsp;</TD></TR>'.
207 %        '<TR><TD>&nbsp;</TD></TR>'.
208 %        '<TR><TD>&nbsp;</TD></TR>'.
209 %
210 %      '</TABLE>',
211 %
212 %    'LECB' =>  
213 %
214 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
215 %
216 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Phone number </TD>!.
217 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="LECB_payinfo" VALUE="!. ( $payby eq 'LECB' ? $cust_main->payinfo : '' ). qq!" MAXLENGTH=15 SIZE=16></TD></TR>!.
218 %
219 %        qq!<INPUT TYPE="hidden" NAME="LECB_exp_month" VALUE="12">!.
220 %        qq!<INPUT TYPE="hidden" NAME="LECB_exp_year" VALUE="2037">!.
221 %        qq!<INPUT TYPE="hidden" NAME="LECB_payname" VALUE="">!.
222 %
223 %        '<TR><TD>&nbsp;</TD></TR>'.
224 %        '<TR><TD>&nbsp;</TD></TR>'.
225 %        '<TR><TD>&nbsp;</TD></TR>'.
226 %        '<TR><TD>&nbsp;</TD></TR>'.
227 %        '<TR><TD>&nbsp;</TD></TR>'.
228 %        '<TR><TD>&nbsp;</TD></TR>'.
229 %
230 %      '</TABLE>',
231 %
232 %    'BILL' =>  
233 %
234 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
235 %
236 %        qq!<TR><TD ALIGN="right" WIDTH="200">P.O. </TD>!.
237 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="BILL_payinfo" VALUE="!. ( $payby eq 'BILL' ? $cust_main->payinfo : '' ). qq!"></TD></TR>!.
238 %
239 %        qq!<INPUT TYPE="hidden" NAME="BILL_exp_month" VALUE="12">!.
240 %        qq!<INPUT TYPE="hidden" NAME="BILL_exp_year" VALUE="2037">!.
241 %
242 %        qq!<TR><TD ALIGN="right" WIDTH="200">Attention </TD>!.
243 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="BILL_payname" VALUE="!. ( $payby eq 'BILL' ? $cust_main->payname : '' ). qq!"></TD></TR>!.
244 %
245 %        '<TR><TD>&nbsp;</TD></TR>'.
246 %        '<TR><TD>&nbsp;</TD></TR>'.
247 %        '<TR><TD>&nbsp;</TD></TR>'.
248 %        '<TR><TD>&nbsp;</TD></TR>'.
249 %        '<TR><TD>&nbsp;</TD></TR>'.
250 %
251 %      '</TABLE>',
252 %
253 %    'COMP' =>   
254 %
255 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
256 %
257 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Approved by </TD>!.
258 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="COMP_payinfo" VALUE=""></TD></TR>!.
259 %
260 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Expiration </TD>!.
261 %          '<TD WIDTH="408">'.
262 %
263 %          include('/elements/select-month_year.html',
264 %                    'prefix' => 'COMP_exp',
265 %                    'selected_date' =>
266 %                      ( $payby eq 'COMP' ? $cust_main->paydate : '' ),
267 %                 ).
268 %
269 %          '</TD></TR>'.
270 %
271 %        '<TR><TD>&nbsp;</TD></TR>'.
272 %        '<TR><TD>&nbsp;</TD></TR>'.
273 %        '<TR><TD>&nbsp;</TD></TR>'.
274 %        '<TR><TD>&nbsp;</TD></TR>'.
275 %        '<TR><TD>&nbsp;</TD></TR>'.
276 %
277 %      '</TABLE>',
278 %
279 %    'CASH' =>
280 %
281 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
282 %
283 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Amount </TD>!.
284 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="CASH_paid" VALUE="!. ( $payby eq 'CASH' ? $cust_main->paid : '' ). qq!"></TD></TR>!.
285 %
286 %        '<TR><TD>&nbsp;</TD></TR>'.
287 %        '<TR><TD>&nbsp;</TD></TR>'.
288 %        '<TR><TD>&nbsp;</TD></TR>'.
289 %        '<TR><TD>&nbsp;</TD></TR>'.
290 %        '<TR><TD>&nbsp;</TD></TR>'.
291 %        '<TR><TD>&nbsp;</TD></TR>'.
292 %
293 %      '</TABLE>',
294 %
295 %    'WEST' =>
296 %
297 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
298 %
299 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Amount </TD>!.
300 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="WEST_paid" VALUE="!. ( $payby eq 'WEST' ? $cust_main->paid : '' ). qq!"></TD></TR>!.
301 %
302 %        '<TR><TD>&nbsp;</TD></TR>'.
303 %        '<TR><TD>&nbsp;</TD></TR>'.
304 %        '<TR><TD>&nbsp;</TD></TR>'.
305 %        '<TR><TD>&nbsp;</TD></TR>'.
306 %        '<TR><TD>&nbsp;</TD></TR>'.
307 %        '<TR><TD>&nbsp;</TD></TR>'.
308 %
309 %      '</TABLE>',
310 %
311 %    'MCRD' =>
312 %
313 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
314 %
315 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Amount </TD>!.
316 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="MCRD_paid" VALUE="!. ( $payby eq 'MCRD' ? $cust_main->paid : '' ). qq!"></TD></TR>!.
317 %
318 %        '<TR><TD>&nbsp;</TD></TR>'.
319 %        '<TR><TD>&nbsp;</TD></TR>'.
320 %        '<TR><TD>&nbsp;</TD></TR>'.
321 %        '<TR><TD>&nbsp;</TD></TR>'.
322 %        '<TR><TD>&nbsp;</TD></TR>'.
323 %        '<TR><TD>&nbsp;</TD></TR>'.
324 %
325 %      '</TABLE>',
326 %
327 %  );
328 %
329 %  #this should use FS::payby
330 %  my @allopt = qw( CARD CHEK LECB BILL CASH WEST MCRD COMP );
331 %
332 %  my %allopt = map { $_ => FS::payby->shortname($_) } @allopt;
333 %
334 %  if ( $cust_main->custnum ) {
335 %    #don't offer CASH/WEST/MCRD initial payment types when editing customer
336 %    delete $allopt{$_} for qw(CASH WEST MCRD);
337 %  }
338 %  
339 %  my @options = grep exists( $allopt{$_} ), @payby;
340 %
341 %  my %payby2option = (
342 %    ( map { $_ => $_ } @options ),
343 %    'DCRD' => 'CARD',
344 %    'DCHK' => 'CHEK',
345 %  );
346
347   <TD WIDTH="408">
348     <% include( '/elements/selectlayers.html',
349                   'field'      => 'payby',
350                   'curr_value' => $payby2option{$payby || $payby_default || $payby[0] },
351                   'options'    => \@options,
352                   'labels'     => \%allopt,
353                   'html_between' => '</TD></TR></TABLE>',
354                   'layer_callback' => sub { my $layer = shift; $payby{$layer}; },
355               )
356     %>
357
358   <% &ntable("#cccccc") %>
359
360     <TR><TD>&nbsp;</TD></TR>
361
362 %   my @exempt_groups = grep /\S/, $conf->config('tax-cust_exempt-groups');
363
364     <TR>
365       <TD WIDTH="608" COLSPAN="2"><INPUT TYPE="checkbox" NAME="tax" VALUE="Y" <% $cust_main->tax eq "Y" ? 'CHECKED' : '' %>> Tax Exempt<% @exempt_groups ? ' (all taxes)' : '' %></TD>
366     </TR>
367
368 %   foreach my $exempt_group ( @exempt_groups ) {
369 %     #escape $exempt_group for NAME
370       <TR>
371         <TD WIDTH="608" COLSPAN="2">&nbsp;&nbsp;<INPUT TYPE="checkbox" NAME="tax_<% $exempt_group %>" VALUE="Y" <% $cust_main->tax_exemption($exempt_group) ? 'CHECKED' : '' %>> Tax Exempt (<% $exempt_group %> taxes)<TD>
372       </TR>
373 %   }
374
375 % unless ( $conf->exists('emailinvoiceonly') ) {
376
377     <TR>
378       <TD WIDTH="608" COLSPAN="2"><INPUT TYPE="checkbox" NAME="invoicing_list_POST" VALUE="POST" <%
379
380         ( grep { $_ eq 'POST' } @invoicing_list )
381
382           ? 'CHECKED'
383           : ''
384
385         %>> Postal mail invoice
386
387       </TD>
388     </TR>
389
390     <TR>
391       <TD WIDTH="608" COLSPAN="2"><INPUT TYPE="checkbox" NAME="invoicing_list_FAX" VALUE="FAX" <%
392
393         ( grep { $_ eq 'FAX' } @invoicing_list )
394           ? 'CHECKED'
395           : ''
396
397         %>> Fax invoice
398
399       </TD>
400     </TR>
401
402 % }
403
404     <TR>
405       <TD ALIGN="right" WIDTH="200">
406         <% $conf->exists('cust_main-require_invoicing_list_email') ? $r : '' %>Email address(es)
407       </TD>
408       <TD WIDTH="408"><INPUT TYPE="text" NAME="invoicing_list" VALUE="<% join(', ', grep { $_ !~ /^(POST|FAX)$/ } @invoicing_list ) %>"></TD>
409     </TR>
410
411     <TR>
412       <TD ALIGN="right" WIDTH="200">Invoice terms </TD>
413       <TD WIDTH="408">
414         <% include('/elements/select-terms.html',
415                      'curr_value' => $cust_main->invoice_terms,
416                   )
417         %>
418       </TD>
419     </TR>
420
421 % if ( $conf->exists('voip-cust_cdr_spools') ) { 
422       <TR>
423        <TD COLSPAN="2"><INPUT TYPE="checkbox" NAME="spool_cdr" VALUE="Y" <% $cust_main->spool_cdr eq "Y" ? 'CHECKED' : '' %>> Spool CDRs</TD>
424       </TR>
425 % } else { 
426       <INPUT TYPE="hidden" NAME="spool_cdr" VALUE="<% $cust_main->spool_cdr %>">
427 % }
428
429 % if ( $conf->exists('voip-cust_cdr_squelch') ) { 
430       <TR>
431        <TD COLSPAN="2"><INPUT TYPE="checkbox" NAME="squelch_cdr" VALUE="Y" <% $cust_main->squelch_cdr eq "Y" ? 'CHECKED' : '' %>> Omit CDRs from invoices</TD>
432       </TR>
433 % } else { 
434       <INPUT TYPE="hidden" NAME="squelch_cdr" VALUE="<% $cust_main->squelch_cdr %>">
435 % }
436
437 % if ( $conf->exists('voip-cust_email_csv_cdr') ) { 
438       <TR>
439        <TD COLSPAN="2"><INPUT TYPE="checkbox" NAME="email_csv_cdr" VALUE="Y" <% $cust_main->email_csv_cdr eq "Y" ? 'CHECKED' : '' %>> Attach CDRs as CSV to emailed invoices</TD>
440       </TR>
441 % } else { 
442       <INPUT TYPE="hidden" NAME="email_csv_cdr" VALUE="<% $cust_main->email_csv_cdr %>">
443 % }
444
445 % if ( $show_term || $cust_main->cdr_termination_percentage ) {
446       <TR>
447        <TD ALIGN="right">CDR termination settlement</TD>
448        <TD><INPUT TYPE  = "text"
449                   NAME  = "cdr_termination_percentage"
450                   SIZE  = 6
451                   VALUE = "<% $cust_main->cdr_termination_percentage %>"
452                   STYLE = "text-align:right;"
453         ><B>%</B></TD>
454       </TR>
455 % } else {
456       <INPUT TYPE="hidden" NAME="cdr_termination_percentage" VALUE="<% $cust_main->cdr_termination_percentage %>">
457 % }
458
459   </TABLE>
460
461   <% $r %> required fields
462 % } 
463
464 <%once>
465
466 my $paystate_label = FS::Msgcat::_gettext('paystate');
467 $paystate_label = 'Bank state' if $paystate_label =~/^paystate$/;
468
469 </%once>
470 <%init>
471
472 my( $cust_main, %options ) = @_;
473 my @invoicing_list = @{ $options{'invoicing_list'} };
474 my $payinfo = $options{'payinfo'};
475 my $conf = new FS::Conf;
476 my $payby_default = $conf->config('payby-default');
477
478 my @payby = grep /\w/, $conf->config('payby');
479 #@payby = (qw( CARD DCRD CHEK DCHK LECB BILL CASH WEST COMP ))
480 @payby = (qw( CARD DCRD CHEK DCHK LECB BILL CASH COMP ))
481   unless @payby;
482
483 my $show_term = '';
484 if ( $cust_main->custnum ) {
485   #false laziness w/view/cust_main/billing.html
486   my $term_sql = "SELECT COUNT(*) FROM cust_pkg LEFT JOIN part_pkg USING ( pkgpart ) WHERE custnum = ? AND plan = 'cdr_termination' LIMIT 1";
487   my $term_sth = dbh->prepare($term_sql)  or die dbh->errstr;
488   $term_sth->execute($cust_main->custnum) or die $term_sth->errstr;
489   $show_term = $term_sth->fetchrow_arrayref->[0];
490 }
491
492 </%init>