encryption fixes from huntsberg & jayce
[freeside.git] / httemplate / edit / cust_main / billing.html
1 %
2 %
3 %my( $cust_main, %options ) = @_;
4 %my @invoicing_list = @{ $options{'invoicing_list'} };
5 %my $conf = new FS::Conf;
6 %my $payby_default = $conf->config('payby-default');
7 %
8 %my @payby = grep /\w/, $conf->config('payby');
9 %#@payby = (qw( CARD DCRD CHEK DCHK LECB BILL CASH WEST COMP ))
10 %@payby = (qw( CARD DCRD CHEK DCHK LECB BILL CASH COMP ))
11 %  unless @payby;
12 %
13 %if ( $payby_default eq 'HIDE' ) {
14 %
15 %  $cust_main->payby('BILL') unless $cust_main->payby;
16 %
17 %
18
19
20   <INPUT TYPE="hidden" NAME="select" VALUE="<% $cust_main->payby %>">
21
22   </FORM>
23
24   <FORM NAME="<% $cust_main->payby %>" STYLE="margin-top: 0; margin-bottom: 0"> 
25 % # XXX key 
26
27
28     <INPUT TYPE="hidden" NAME="payinfo" VALUE="<% $cust_main->paymask %>">
29 % foreach my $field (qw( payname paycvv paystart_month paystart_year payissue payip )) { 
30
31
32     <INPUT TYPE="hidden" NAME="<% $field %>" VALUE="<% $cust_main->getfield($field) %>">
33 % } 
34 %
35 %  #false laziness w/elements/select-month_year.html & view/cust_main/billing.html
36 %  my( $mon, $year );
37 %  my $date = $cust_main->paydate || '12-2037';
38 %  if ( $date  =~ /^(\d{4})-(\d{1,2})-\d{1,2}$/ ) { #PostgreSQL date format
39 %    ( $mon, $year ) = ( $2, $1 );
40 %  } elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
41 %    ( $mon, $year ) = ( $1, $3 );
42 %  } else {
43 %    die "unrecognized expiration date format: $date";
44 %  }
45 %  
46
47
48   <INPUT TYPE="hidden" NAME="exp_month" VALUE="<% $mon %>">
49   <INPUT TYPE="hidden" NAME="exp_year"  VALUE="<% $year %>">
50
51   </FORM>
52
53   <FORM NAME="billing_bottomform" STYLE="margin-top: 0; margin-bottom: 0">
54
55   <INPUT TYPE="hidden" NAME="tax" VALUE="<% $cust_main->tax %>">
56
57   <INPUT TYPE="hidden" NAME="invoicing_list" VALUE="<% join(', ', @invoicing_list) %>">
58
59   </FORM>
60 % } else {
61 %
62 %  my $r = qq!<font color="#ff0000">*</font>&nbsp;!;
63 %
64 %
65
66
67   <BR>Billing information
68   <% &ntable("#cccccc") %>
69
70     <TR>
71       <TD ALIGN="right" WIDTH="200"><%$r%>Billing type</TD>
72
73   <SCRIPT>
74
75     var mywindow = -1;
76     function myopen(filename,windowname,properties) {
77       myclose();
78       mywindow = window.open(filename,windowname,properties);
79     }
80     function myclose() {
81       if ( mywindow != -1 )
82         mywindow.close();
83       mywindow = -1;
84     }
85
86     var achwindow = -1;
87     function achopen(filename,windowname,properties) {
88       achclose();
89       achwindow = window.open(filename,windowname,properties);
90     }
91     function achclose() {
92       if ( achwindow != -1 )
93         achwindow.close();
94       achwindow = -1;
95     }
96
97     function card_changed(what) {
98       if (
99              what.form.payinfo.value.substring(0, 4) == '4093' 
100           || what.form.payinfo.value.substring(0, 4) == '4911' 
101           || what.form.payinfo.value.substring(0, 4) == '4936' 
102           || what.form.payinfo.value.substring(0, 6) == '564132' 
103           || what.form.payinfo.value.substring(0, 2) == '63' 
104           || what.form.payinfo.value.substring(0, 2) == '67' 
105          )
106       {
107         what.form.paystart_month.disabled = false;
108         what.form.paystart_year.disabled = false;
109         what.form.payissue.disabled = false;
110         what.form.paystart_month.style.backgroundColor = '#ffffff';
111         what.form.paystart_year.style.backgroundColor = '#ffffff';
112         what.form.payissue.style.backgroundColor = '#ffffff';
113         document.getElementById('paystart_label').style.color = '#000000';
114         document.getElementById('payissue_label').style.color = '#000000';
115       } else {
116         what.form.paystart_month.disabled = true;
117         what.form.paystart_year.disabled = true;
118         what.form.payissue.disabled = true;
119         what.form.paystart_month.style.backgroundColor = '#dddddd';
120         what.form.paystart_year.style.backgroundColor = '#dddddd';
121         what.form.payissue.style.backgroundColor = '#dddddd';
122         document.getElementById('paystart_label').style.color = '#999999';
123         document.getElementById('payissue_label').style.color = '#999999';
124       }
125       return true;
126     }
127
128   </SCRIPT>
129
130   <SCRIPT TYPE="text/javascript" SRC="../elements/overlibmws.js"></SCRIPT>
131   <SCRIPT TYPE="text/javascript" SRC="../elements/overlibmws_iframe.js"></SCRIPT>
132   <SCRIPT TYPE="text/javascript" SRC="../elements/overlibmws_draggable.js"></SCRIPT>
133   <SCRIPT TYPE="text/javascript">
134   function OLiframeContent(src, width, height, name) {
135     return ('<iframe src="'+src+'" width="'+width+'" height="'+height+'"'
136      +(name?' name="'+name+'" id="'+name+'"':'')+' scrolling="auto">'
137      +'<div>[iframe not supported]</div></iframe>');
138   }
139   </SCRIPT>
140 %
141 %
142 %  my($payby, $paymask, $payname)=(
143 %    $cust_main->payby,
144 %    $cust_main->paymask,
145 %    $cust_main->payname,
146 %  );
147 %  my( $account, $aba ) = split('@', $paymask);
148 %
149 %  my $disabled = 'DISABLED style="background-color: #dddddd"';
150 %  my $text_disabled = 'style="color: #999999"';
151 %
152 %  # this is not going to work unless the mask-generation recognizes
153 %  # Switch/Solo cards
154 %  if ( $payby =~ /^(CARD|DCRD)$/ && cardtype($paymask) =~ /^(Switch|Solo)$/ ) {
155 %    $disabled = 'style="background-color: #ffffff"';
156 %    $text_disabled = 'style="color: #000000";'
157 %  }
158 %
159 %  my %payby = (
160 %
161 %    'CARD' =>
162 %
163 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
164 %
165 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Card number </TD>!.
166 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="payinfo" VALUE="!. ( $payby =~ /^(CARD|DCRD)$/ ? $paymask : '' ). qq!" MAXLENGTH=19 onChange="card_changed(this)" onKeyUp="card_changed(this)"></TD></TR>!.
167 %
168 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Expiration </TD>!.
169 %          '<TD WIDTH="408">'.
170 %
171 %          include('/elements/select-month_year.html',
172 %                    'prefix' => 'exp',
173 %                    'selected_date' =>
174 %                      ( $payby =~ /^(CARD|DCRD)$/ ? $cust_main->paydate : '' ),
175 %                 ).
176 %
177 %          '</TD></TR>'.
178 %
179 %        qq!<TR><TD ALIGN="right" WIDTH="200">CVV2&nbsp;!.
180 %
181 %          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>)!.
182 %          qq!</TD>!.
183 %          '<TD WIDTH="408"><INPUT TYPE="text" NAME="paycvv" VALUE="'. ( $payby =~ /^(CARD|DCRD)$/ && !$cust_main->is_encrypted($cust_main->paycvv) ? $cust_main->paycvv : '' ). '" SIZE=4 MAXLENGTH=4>'.
184 %
185 %
186 %        qq!<TR><TD ALIGN="right" WIDTH="200"><SPAN ID="paystart_label" $text_disabled>Start date </SPAN></TD>!.
187 %          '<TD WIDTH="408">'.
188 %
189 %          include('/elements/select-month_year.html',
190 %                    'prefix' => 'paystart',
191 %                    'disabled' => $disabled,
192 %                    'empty_option' => 1,
193 %                    'start_year' => 2000,
194 %                    'end_year'   => (localtime())[5] + 1900,
195 %                    'selected_date' => (
196 %                      ( $payby =~ /^(CARD|DCRD)$/
197 %                        && cardtype($paymask) =~ /^(Switch|Solo)$/ ) #also
198 %                          ? $cust_main->paystart_month. '-'.
199 %                            $cust_main->paystart_year 
200 %                          : ''
201 %                    )
202 %                 ).
203 %
204 %        qq!<SPAN ID="payissue_label" $text_disabled> or Issue number </SPAN>!.
205 %          '<INPUT TYPE="text" NAME="payissue" VALUE="'. ( $payby =~ /^(CARD|DCRD)$/ ? $cust_main->payissue : '' ). qq!" SIZE=3 MAXLENGTH=2 $disabled></TD></TR>!.
206 %
207 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Exact name on card </TD>!.
208 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="payname" VALUE="!. ( $payby =~ /^(CARD|DCRD)$/ ? $cust_main->payname : '' ). qq!"></TD></TR>!.
209 %
210 %        qq!<TR><TD COLSPAN=2 WIDTH="608"><INPUT TYPE="checkbox" NAME="payauto" !. ( $payby eq 'DCRD' ? '' : 'CHECKED' ). '> Charge future payments to this card automatically</TD></TR>'.
211 %
212 %      '</TABLE>',
213 %
214 %    'CHEK' => 
215 %
216 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
217 %
218 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Account number </TD>!.
219 %          qq!<TD WIDTH="408"><INPUT TYPE="text" SIZE=10 NAME="payinfo1" VALUE="!. ( $payby =~ /^(CHEK|DCHK)$/ ? $account : '' ). '"></TD></TR>'.
220 %
221 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}ABA/Routing number </TD>!.
222 %          qq!<TD WIDTH="408"><INPUT TYPE="text" SIZE=10 MAXLENGTH=9 NAME="payinfo2" VALUE="!. ( $payby =~ /^(CHEK|DCHK)$/ ? $aba : '' ). qq!" SIZE=10 MAXLENGTH=9> !.
223 %          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>)!.
224 %          qq!</TD></TR>!.
225 %
226 %        qq!<INPUT TYPE="hidden" NAME="exp_month" VALUE="12">!.
227 %        qq!<INPUT TYPE="hidden" NAME="exp_year" VALUE="2037">!.
228 %
229 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Bank name </TD>!.
230 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="payname" VALUE="!. ( $payby =~ /^(CHEK|DCHK)$/ ? $cust_main->payname : '' ). qq!"></TD></TR>!.
231 %
232 %        qq!<TR><TD COLSPAN=2 WIDTH="608"><INPUT TYPE="checkbox" NAME="payauto" !. ( $payby eq 'DCHK' ? '' : 'CHECKED' ). '> Charge future payments to this electronic check automatically</TD></TR>'.
233 %
234 %        '<TR><TD>&nbsp;</TD></TR>'.
235 %        '<TR><TD>&nbsp;</TD></TR>'.
236 %        '<TR><TD>&nbsp;</TD></TR>'.
237 %
238 %      '</TABLE>',
239 %
240 %    'LECB' =>  
241 %
242 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
243 %
244 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Phone number </TD>!.
245 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="payinfo" VALUE="!. ( $payby eq 'LECB' ? $cust_main->paymask : '' ). qq!" MAXLENGTH=15 SIZE=16></TD></TR>!.
246 %
247 %        qq!<INPUT TYPE="hidden" NAME="exp_month" VALUE="12">!.
248 %        qq!<INPUT TYPE="hidden" NAME="exp_year" VALUE="2037">!.
249 %        qq!<INPUT TYPE="hidden" NAME="payname" VALUE="">!.
250 %
251 %        '<TR><TD>&nbsp;</TD></TR>'.
252 %        '<TR><TD>&nbsp;</TD></TR>'.
253 %        '<TR><TD>&nbsp;</TD></TR>'.
254 %        '<TR><TD>&nbsp;</TD></TR>'.
255 %        '<TR><TD>&nbsp;</TD></TR>'.
256 %        '<TR><TD>&nbsp;</TD></TR>'.
257 %
258 %      '</TABLE>',
259 %
260 %    'BILL' =>  
261 %
262 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
263 %
264 %        qq!<TR><TD ALIGN="right" WIDTH="200">P.O. </TD>!.
265 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="payinfo" VALUE="!. ( $payby eq 'BILL' ? $cust_main->paymask : '' ). qq!"></TD></TR>!.
266 %
267 %        qq!<INPUT TYPE="hidden" NAME="exp_month" VALUE="12">!.
268 %        qq!<INPUT TYPE="hidden" NAME="exp_year" VALUE="2037">!.
269 %
270 %        qq!<TR><TD ALIGN="right" WIDTH="200">Attention </TD>!.
271 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="payname" VALUE="!. ( $payby eq 'BILL' ? $cust_main->payname : '' ). qq!"></TD></TR>!.
272 %
273 %        '<TR><TD>&nbsp;</TD></TR>'.
274 %        '<TR><TD>&nbsp;</TD></TR>'.
275 %        '<TR><TD>&nbsp;</TD></TR>'.
276 %        '<TR><TD>&nbsp;</TD></TR>'.
277 %        '<TR><TD>&nbsp;</TD></TR>'.
278 %
279 %      '</TABLE>',
280 %
281 %    'COMP' =>   
282 %
283 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
284 %
285 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Approved by </TD>!.
286 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="payinfo" VALUE=""></TD></TR>!.
287 %
288 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Expiration </TD>!.
289 %          '<TD WIDTH="408">'.
290 %
291 %          include('/elements/select-month_year.html',
292 %                    'prefix' => 'exp',
293 %                    'selected_date' =>
294 %                      ( $payby eq 'COMP' ? $cust_main->paydate : '' ),
295 %                 ).
296 %
297 %          '</TD></TR>'.
298 %
299 %        '<TR><TD>&nbsp;</TD></TR>'.
300 %        '<TR><TD>&nbsp;</TD></TR>'.
301 %        '<TR><TD>&nbsp;</TD></TR>'.
302 %        '<TR><TD>&nbsp;</TD></TR>'.
303 %        '<TR><TD>&nbsp;</TD></TR>'.
304 %
305 %      '</TABLE>',
306 %
307 %    'CASH' =>
308 %
309 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
310 %
311 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Amount </TD>!.
312 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="paid" VALUE="!. ( $payby eq 'CASH' ? $cust_main->paid : '' ). qq!"></TD></TR>!.
313 %
314 %        '<TR><TD>&nbsp;</TD></TR>'.
315 %        '<TR><TD>&nbsp;</TD></TR>'.
316 %        '<TR><TD>&nbsp;</TD></TR>'.
317 %        '<TR><TD>&nbsp;</TD></TR>'.
318 %        '<TR><TD>&nbsp;</TD></TR>'.
319 %        '<TR><TD>&nbsp;</TD></TR>'.
320 %
321 %      '</TABLE>',
322 %
323 %    'WEST' =>
324 %
325 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
326 %
327 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Amount </TD>!.
328 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="paid" VALUE="!. ( $payby eq 'WEST' ? $cust_main->paid : '' ). qq!"></TD></TR>!.
329 %
330 %        '<TR><TD>&nbsp;</TD></TR>'.
331 %        '<TR><TD>&nbsp;</TD></TR>'.
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 %
337 %      '</TABLE>',
338 %
339 %    'MCRD' =>
340 %
341 %      '<TABLE BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 HEIGHT=192>'.
342 %
343 %        qq!<TR><TD ALIGN="right" WIDTH="200">${r}Amount </TD>!.
344 %          qq!<TD WIDTH="408"><INPUT TYPE="text" NAME="paid" VALUE="!. ( $payby eq 'MCRD' ? $cust_main->paid : '' ). qq!"></TD></TR>!.
345 %
346 %        '<TR><TD>&nbsp;</TD></TR>'.
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 %
353 %      '</TABLE>',
354 %
355 %  );
356 %
357 %  #this should use FS::payby
358 %  my %allopt = (
359 %    'CARD' => 'Credit card',
360 %    'CHEK' => 'Electronic check',
361 %    'LECB' => 'Phone bill billing',
362 %    'BILL' => 'Billing',
363 %    'CASH' => 'Cash', # initial payment, then billing',
364 %    'WEST' => 'Western Union', # initial payment, then billing',
365 %    'MCRD' => 'Manual credit card', # initial payment, then billing',
366 %    'COMP' => 'Complimentary',
367 %  );
368 %  if ( $cust_main->custnum ) { #don't offer CASH/WEST/MCRD initial payment types
369 %                               # when editing customer
370 %    delete $allopt{$_} for qw(CASH WEST MCRD);
371 %  }
372 %  
373 %  tie my %options, 'Tie::IxHash',
374 %    map  { $_ => $allopt{$_} }
375 %    grep { exists $allopt{$_} }
376 %         @payby;
377 %
378 %  my %payby2option = (
379 %    ( map { $_ => $_ } keys %options ),
380 %    'DCRD' => 'CARD',
381 %    'DCHK' => 'CHEK',
382 %  );
383 %
384 %  my $widget = new HTML::Widgets::SelectLayers(
385 %    'options'        => \%options,
386 %    #'form_name'      => 'dummy',
387 %    #'form_action'    => 'nothingyet',
388 %    #chops bottom of page in IE# 'under_position' => 'absolute',
389 %    'html_between'   => '</TD></TR></TABLE>',
390 %    'selected_layer' => $payby2option{$payby || $payby_default || $payby[0] },
391 %    'layer_callback' => sub { my $layer = shift; $payby{$layer}; },
392 %  );
393 %
394 %  
395
396
397   <TD WIDTH="408"><% $widget->html %>
398
399   <FORM NAME="billing_bottomform" STYLE="margin-top: 0; margin-bottom: 0">
400
401   <% &ntable("#cccccc") %>
402
403     <TR><TD>&nbsp;</TD></TR>
404
405     <TR>
406       <TD WIDTH="608" COLSPAN="2"><INPUT TYPE="checkbox" NAME="tax" VALUE="Y" <% $cust_main->tax eq "Y" ? 'CHECKED' : '' %>> Tax Exempt</TD>
407     </TR>
408
409     <TR>
410       <TD WIDTH="608" COLSPAN="2"><INPUT TYPE="checkbox" NAME="invoicing_list_POST" VALUE="POST" <%
411
412         ( (    ! @invoicing_list
413             && ! $conf->exists('disablepostalinvoicedefault')
414             && ! $cust_main->custnum
415           )
416           || grep { $_ eq 'POST' } @invoicing_list                     )
417
418           ? 'CHECKED'
419           : ''
420
421         %>> Postal mail invoice
422
423       </TD>
424     </TR>
425
426     <TR>
427       <TD WIDTH="608" COLSPAN="2"><INPUT TYPE="checkbox" NAME="invoicing_list_FAX" VALUE="FAX" <%
428
429         ( grep { $_ eq 'FAX' } @invoicing_list )
430           ? 'CHECKED'
431           : ''
432
433         %>> Fax invoice
434
435       </TD>
436     </TR>
437
438     <TR>
439       <TD ALIGN="right" WIDTH="200">Email invoice </TD>
440       <TD WIDTH="408"><INPUT TYPE="text" NAME="invoicing_list" VALUE="<% join(', ', grep { $_ !~ /^(POST|FAX)$/ } @invoicing_list ) %>"></TD>
441     </TR>
442 % if ( $conf->exists('voip-cust_cdr_spools') ) { 
443
444       <TR>
445        <TD COLSPAN="2"><INPUT TYPE="checkbox" NAME="spool_cdr" VALUE="Y" <% $cust_main->spool_cdr eq "Y" ? 'CHECKED' : '' %>> Spool CDRs</TD>
446       </TR>
447 % } else { 
448
449       <INPUT TYPE="hidden" NAME="spool_cdr" VALUE="<% $cust_main->spool_cdr %>">
450 % } 
451
452
453   </TABLE>
454
455   </FORM>
456
457   <% $r %> required fields
458 % } 
459
460