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