encryption fixes from huntsberg & jayce
[freeside.git] / httemplate / edit / cust_refund.cgi
1 %
2 %
3 %my $conf = new FS::Conf;
4 %my $custnum = $cgi->param('custnum');
5 %my $refund  = $cgi->param('refund');
6 %my $payby   = $cgi->param('payby');
7 %my $reason  = $cgi->param('reason');
8 %
9 %my( $paynum, $cust_pay ) = ( '', '' );
10 %if ( $cgi->param('paynum') =~ /^(\d+)$/ ) {
11 %  $paynum = $1;
12 %  $cust_pay = qsearchs('cust_pay', { paynum=>$paynum } )
13 %    or die "unknown payment # $paynum";
14 %  $refund ||= $cust_pay->unrefunded;
15 %  if ( $custnum ) {
16 %    die "payment # $paynum is not for specified customer # $custnum"
17 %      unless $custnum == $cust_pay->custnum;
18 %  } else {
19 %    $custnum = $cust_pay->custnum;
20 %  }
21 %}
22 %die "no custnum or paynum specified!" unless $custnum;
23 %
24 %my $_date = time;
25 %
26 %my $p1 = popurl(1);
27 %
28 %
29
30
31 <% include('/elements/header.html', 'Refund '. ucfirst(lc($payby)). ' payment', '') %>
32 % if ( $cgi->param('error') ) { 
33
34   <FONT SIZE="+1" COLOR="#ff0000">Error: <% $cgi->param('error') %></FONT>
35   <BR><BR>
36 % } 
37
38
39 <% small_custview($custnum, $conf->config('countrydefault')) %>
40
41 <FORM NAME="RefundForm" ACTION="<% $p1 %>process/cust_refund.cgi" METHOD=POST onSubmit="document.RefundForm.submit.disabled=true">
42 <INPUT TYPE="hidden" NAME="refundnum" VALUE="">
43 <INPUT TYPE="hidden" NAME="custnum" VALUE="<% $custnum %>">
44 <INPUT TYPE="hidden" NAME="paynum" VALUE="<% $paynum %>">
45 <INPUT TYPE="hidden" NAME="_date" VALUE="<% $_date %>">
46 <INPUT TYPE="hidden" NAME="payby" VALUE="<% $payby %>">
47 <INPUT TYPE="hidden" NAME="payinfo" VALUE="">
48 <INPUT TYPE="hidden" NAME="paybatch" VALUE="">
49 <INPUT TYPE="hidden" NAME="credited" VALUE="">
50 <BR>
51 % if ( $cust_pay ) {
52 %
53 %  #false laziness w/FS/FS/cust_pay.pm
54 %  my $payby = $cust_pay->payby;
55 %  my $paymask = $cust_pay->paymask;
56 %  $payby =~ s/^BILL$/Check/ if $paymask;
57 %  $payby =~ s/^CHEK$/Electronic check/;
58 %
59 %
60
61
62   <BR>Payment
63   <% ntable("#cccccc", 2) %>
64
65     <TR>
66       <TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$<% $cust_pay->paid %></TD>
67     </TR>
68
69   <TR>
70     <TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff"><% time2str("%D",$cust_pay->_date) %></TD>
71   </TR>
72
73   <TR>
74     <TD ALIGN="right">Method</TD><TD BGCOLOR="#ffffff"><% ucfirst(lc($payby)) %> # <% $paymask %></TD>
75   </TR>
76 %
77 %  #false laziness w/FS/FS/cust_main::realtime_refund_bop
78 %  if ( $cust_pay->paybatch =~ /^(\w+):(\w+)(:(\w+))?$/ ) {
79 %    my ( $processor, $auth, $order_number ) = ( $1, $2, $4 );
80 %  
81
82
83     <TR>
84       <TD ALIGN="right">Processor</TD><TD BGCOLOR="#ffffff"><% $processor %></TD>
85     </TR>
86 % if ( length($auth) ) { 
87
88       <TR>
89         <TD ALIGN="right">Authorization</TD><TD BGCOLOR="#ffffff"><% $auth %></TD>
90       </TR>
91 % } 
92 % if ( length($order_number) ) { 
93
94       <TR>
95         <TD ALIGN="right">Order number</TD><TD BGCOLOR="#ffffff"><% $order_number %></TD>
96       </TR>
97 % } 
98 % } 
99
100   </TABLE>
101 % } 
102
103
104 <BR>Refund
105 <% ntable("#cccccc", 2) %>
106
107   <TR>
108     <TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff"><% time2str("%D",$_date) %></TD>
109   </TR>
110
111   <TR>
112     <TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$<INPUT TYPE="text" NAME="refund" VALUE="<% $refund %>" SIZE=8 MAXLENGTH=8></TD>
113   </TR>
114
115   <TR>
116     <TD ALIGN="right">Reason</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="reason" VALUE="<% $reason %>"></TD>
117   </TR>
118 </TABLE>
119
120 <BR>
121 <INPUT TYPE="submit" NAME="submit" VALUE="Post refund">
122
123 </FORM>
124
125 <% include('/elements/footer.html') %>
126