fix browse results for selecting counties (resulting from separating tax classes...
[freeside.git] / httemplate / misc / payment.cgi
1 <% include( '/elements/header.html', "Process $type{$payby} payment" ) %>
2 <% include( '/elements/small_custview.html', $cust_main, '', '', popurl(2) . "view/cust_main.cgi" ) %>
3 <FORM NAME="OneTrueForm" ACTION="process/payment.cgi" METHOD="POST" onSubmit="document.OneTrueForm.process.disabled=true">
4 <INPUT TYPE="hidden" NAME="custnum"   VALUE="<% $custnum %>">
5 <INPUT TYPE="hidden" NAME="payby"     VALUE="<% $payby %>">
6 <INPUT TYPE="hidden" NAME="payunique" VALUE="<% $payunique %>">
7 <INPUT TYPE="hidden" NAME="balance"   VALUE="<% $balance %>">
8
9 <% include('/elements/init_overlib.html') %>
10
11 % #include( '/elements/table.html', '#cccccc' ) 
12
13 <% ntable('#cccccc') %>
14   <TR>
15     <TD ALIGN="right">Payment amount</TD>
16     <TD>
17       <TABLE><TR><TD BGCOLOR="#ffffff">
18         $<INPUT TYPE="text" NAME="amount" SIZE=8 VALUE="<% $balance > 0 ? sprintf("%.2f", $balance) : '' %>">
19       </TD></TR></TABLE>
20     </TD>
21   </TR>
22
23 % if ( $payby eq 'CARD' ) {
24 %
25 %   my( $payinfo, $paycvv, $month, $year ) = ( '', '', '', '' );
26 %   my $payname = $cust_main->first. ' '. $cust_main->getfield('last');
27 %   my $address1 = $cust_main->address1;
28 %   my $address2 = $cust_main->address2;
29 %   my $city     = $cust_main->city;
30 %   my $state    = $cust_main->state;
31 %   my $zip     = $cust_main->zip;
32 %   if ( $cust_main->payby =~ /^(CARD|DCRD)$/ ) {
33 %     $payinfo = $cust_main->paymask;
34 %     $paycvv = $cust_main->paycvv;
35 %     ( $month, $year ) = $cust_main->paydate_monthyear;
36 %     $payname = $cust_main->payname if $cust_main->payname;
37 %   }
38
39     <TR>
40       <TD ALIGN="right">Card&nbsp;number</TD>
41       <TD>
42         <TABLE>
43           <TR>
44             <TD>
45               <INPUT TYPE="text" NAME="payinfo" SIZE=20 MAXLENGTH=19 VALUE="<%$payinfo%>"> </TD>
46             <TD>Exp.</TD>
47             <TD>
48               <SELECT NAME="month">
49 % for ( ( map "0$_", 1 .. 9 ), 10 .. 12 ) { 
50
51                   <OPTION<% $_ == $month ? ' SELECTED' : '' %>><% $_ %>
52 % } 
53
54               </SELECT>
55             </TD>
56             <TD> / </TD>
57             <TD>
58               <SELECT NAME="year">
59 % my @a = localtime; for ( $a[5]+1900 .. $a[5]+1915 ) { 
60
61                   <OPTION<% $_ == $year ? ' SELECTED' : '' %>><% $_ %>
62 % } 
63
64               </SELECT>
65             </TD>
66           </TR>
67         </TABLE>
68       </TD>
69     </TR>
70     <TR>
71       <TD ALIGN="right">CVV2</TD>
72       <TD><INPUT TYPE="text" NAME="paycvv" VALUE="<% $paycvv %>" SIZE=4 MAXLENGTH=4>
73           (<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>)
74       </TD>
75     </TR>
76     <TR>
77       <TD ALIGN="right">Exact&nbsp;name&nbsp;on&nbsp;card</TD>
78       <TD><INPUT TYPE="text" SIZE=32 MAXLENGTH=80 NAME="payname" VALUE="<%$payname%>"></TD>
79     </TR><TR>
80       <TD ALIGN="right">Card&nbsp;billing&nbsp;address</TD>
81       <TD>
82         <INPUT TYPE="text" SIZE=40 MAXLENGTH=80 NAME="address1" VALUE="<%$address1%>">
83       </TD>
84     </TR><TR>
85       <TD ALIGN="right">Address&nbsp;line&nbsp;2</TD>
86       <TD>
87         <INPUT TYPE="text" SIZE=40 MAXLENGTH=80 NAME="address2" VALUE="<%$address2%>">
88       </TD>
89     </TR><TR>
90       <TD ALIGN="right">City</TD>
91       <TD>
92         <TABLE>
93           <TR>
94             <TD>
95               <INPUT TYPE="text" NAME="city" SIZE="12" MAXLENGTH=80 VALUE="<%$city%>">
96             </TD>
97             <TD>State</TD>
98             <TD>
99               <SELECT NAME="state">
100 % for ( @states ) { 
101
102                   <OPTION<% $_ eq $state ? ' SELECTED' : '' %>><% $_ %> 
103 % } 
104
105               </SELECT>
106             </TD>
107             <TD>Zip</TD>
108             <TD>
109               <INPUT TYPE="text" NAME="zip" SIZE=11 MAXLENGTH=10 VALUE="<%$zip%>">
110             </TD>
111           </TR>
112         </TABLE>
113       </TD>
114     </TR>
115
116 % } elsif ( $payby eq 'CHEK' ) {
117 %
118 %   my( $payinfo1, $payinfo2, $payname, $ss, $paytype, $paystate,
119 %       $stateid, $stateid_state )
120 %     = ( '', '', '', '', '', '', '', '' );
121 %   if ( $cust_main->payby =~ /^(CHEK|DCHK)$/ ) {
122 %     $cust_main->paymask =~ /^([\dx]+)\@([\dx]+)$/i
123 %       or die "unparsable payinfo ". $cust_main->payinfo;
124 %     ($payinfo1, $payinfo2) = ($1, $2);
125 %     $payname = $cust_main->payname;
126 %     $ss = $cust_main->ss;
127 %     $paytype = $cust_main->getfield('paytype');
128 %     $paystate = $cust_main->getfield('paystate');
129 %     $stateid = $cust_main->getfield('stateid');
130 %     $stateid_state = $cust_main->getfield('stateid_state');
131 %   }
132
133     <INPUT TYPE="hidden" NAME="month" VALUE="12">
134     <INPUT TYPE="hidden" NAME="year" VALUE="2037">
135     <TR>
136       <TD ALIGN="right">Account&nbsp;number</TD>
137       <TD><INPUT TYPE="text" SIZE=10 NAME="payinfo1" VALUE="<%$payinfo1%>"></TD>
138       <TD ALIGN="right">Type</TD>
139       <TD><SELECT NAME="paytype"><% join('', map { qq!<OPTION VALUE="$_" !.($paytype eq $_ ? 'SELECTED' : '').">$_</OPTION>" } @FS::cust_main::paytypes) %></SELECT></TD>
140     </TR>
141     <TR>
142       <TD ALIGN="right">ABA/Routing&nbsp;number</TD>
143       <TD>
144         <INPUT TYPE="text" SIZE=10 MAXLENGTH=9 NAME="payinfo2" VALUE="<%$payinfo2%>">
145         (<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>)
146       </TD>
147     </TR>
148     <TR>
149       <TD ALIGN="right">Bank&nbsp;name</TD>
150       <TD><INPUT TYPE="text" NAME="payname" VALUE="<%$payname%>"></TD>
151     </TR>
152
153 %   if ( $conf->exists('show_bankstate') ) {
154       <TR>
155         <TD ALIGN="right">Bank&nbsp;state</TD>
156         <TD><% include('/elements/select-state.html',
157                          'disable_empty' => 0,
158                          'empty_label'   => '(choose)',
159                          'state'         => $paystate,
160                          'country'       => $cust_main->country,
161                          'prefix'        => 'pay',
162                       )
163             %>
164         </TD>
165       </TR>
166 %   } else {
167       <INPUT TYPE="hidden" NAME="paystate" VALUE="<% $paystate %>">
168 %   }
169
170 %   if ( $conf->exists('show_ss') ) {
171       <TR>
172         <TD ALIGN="right">
173           Account&nbsp;holder<BR>
174           Social&nbsp;security&nbsp;or&nbsp;tax&nbsp;ID&nbsp;#
175         </TD>
176         <TD><INPUT TYPE="text" NAME="ss" VALUE="<% $ss %>"></TD>
177       </TR>
178 %   } else {
179       <INPUT TYPE="hidden" NAME="ss" VALUE="<% $ss %>"></TD>
180 %   }
181
182 %   if ( $conf->exists('show_stateid') ) {
183       <TR>
184         <TD ALIGN="right">
185           Account&nbsp;holder<BR>
186           Driver&rsquo;s&nbsp;license&nbsp;or&nbsp;state&nbsp;ID&nbsp;#
187         </TD>
188         <TD><INPUT TYPE="text" NAME="stateid" VALUE="<% $stateid %>"></TD>
189         <TD ALIGN="right">State</TD>
190         <TD><% include('/elements/select-state.html',
191                          'disable_empty' => 0,
192                          'empty_label'   => '(choose)',
193                          'state'         => $stateid_state,
194                          'country'       => $cust_main->country,
195                          'prefix'        => 'stateid_',
196                       )
197             %>
198         </TD>
199       </TR>
200 %   } else {
201       <INPUT TYPE="hidden" NAME="stateid" VALUE="<% $stateid %>">
202       <INPUT TYPE="hidden" NAME="stateid_state" VALUE="<% $stateid_state %>">
203 %   }
204
205 % } #end CARD/CHEK-specific section
206
207
208 <TR>
209   <TD COLSPAN=2>
210     <INPUT TYPE="checkbox" CHECKED NAME="save" VALUE="1">
211     Remember this information
212   </TD>
213 </TR>
214
215 % if ( $conf->exists("batch-enable")
216 %      || grep $payby eq $_, $conf->config('batch-enable_payby')
217 %    ) {
218 %
219 %     if ( grep $payby eq $_, $conf->config('realtime-disable_payby') ) {
220
221           <INPUT TYPE="hidden" NAME="batch" VALUE="1">
222
223 %     } else {
224
225           <TR>
226             <TD COLSPAN=2>
227               <INPUT TYPE="checkbox" NAME="batch" VALUE="1">
228               Add to current batch
229             </TD>
230           </TR>
231
232 %     }
233 % }
234
235 <TR>
236   <TD COLSPAN=2>
237     <INPUT TYPE="checkbox"<% ( ( $payby eq 'CARD' && $cust_main->payby ne 'DCRD' ) || ( $payby eq 'CHEK' && $cust_main->payby eq 'CHEK' ) ) ? ' CHECKED' : '' %> NAME="auto" VALUE="1" onClick="if (this.checked) { document.OneTrueForm.save.checked=true; }">
238     Charge future payments to this <% $type{$payby} %> automatically
239   </TD>
240 </TR>
241
242 </TABLE>
243
244 <BR>
245 <INPUT TYPE="submit" NAME="process" VALUE="Process payment">
246 </FORM>
247
248 <% include('/elements/footer.html') %>
249 <%init>
250
251 die "access denied"
252   unless $FS::CurrentUser::CurrentUser->access_right('Process payment');
253
254 my %type = ( 'CARD' => 'credit card',
255              'CHEK' => 'electronic check (ACH)',
256            );
257
258 $cgi->param('payby') =~ /^(CARD|CHEK)$/
259   or die "unknown payby ". $cgi->param('payby');
260 my $payby = $1;
261
262 $cgi->param('custnum') =~ /^(\d+)$/
263   or die "illegal custnum ". $cgi->param('custnum');
264 my $custnum = $1;
265
266 my $cust_main = qsearchs( 'cust_main', { 'custnum'=>$custnum } );
267 die "unknown custnum $custnum" unless $cust_main;
268
269 my $balance = $cust_main->balance;
270
271 my $payinfo = '';
272
273 #false laziness w/selfservice make_payment.html shortcut for one-country
274 my $conf = new FS::Conf;
275 my %states = map { $_->state => 1 }
276                qsearch('cust_main_county', {
277                  'country' => $conf->config('countrydefault') || 'US'
278                } );
279 my @states = sort { $a cmp $b } keys %states;
280
281 my $payunique = "webui-payment-". time. "-$$-". rand() * 2**32;
282
283 </%init>
284
285