import torrus 1.0.9
[freeside.git] / httemplate / edit / cust_refund.cgi
1 % if ( $link eq 'popup' ) { 
2   <% include('/elements/header-popup.html', $title ) %>
3 % } else { 
4   <% include("/elements/header.html", $title, '') %>
5 % } 
6
7 <% include('/elements/error.html') %>
8
9 % unless ( $link eq 'popup' ) { 
10     <% small_custview($custnum, $conf->config('countrydefault')) %>
11 % } 
12
13 <FORM NAME="RefundForm" ACTION="<% $p1 %>process/cust_refund.cgi" METHOD=POST onSubmit="document.RefundForm.submit.disabled=true">
14 <INPUT TYPE="hidden" NAME="popup" VALUE="<% $link %>">
15 <INPUT TYPE="hidden" NAME="refundnum" VALUE="">
16 <INPUT TYPE="hidden" NAME="custnum" VALUE="<% $custnum %>">
17 <INPUT TYPE="hidden" NAME="paynum" VALUE="<% $paynum %>">
18 <INPUT TYPE="hidden" NAME="_date" VALUE="<% $_date %>">
19 <INPUT TYPE="hidden" NAME="payby" VALUE="<% $payby %>">
20 <INPUT TYPE="hidden" NAME="paybatch" VALUE="">
21 <INPUT TYPE="hidden" NAME="credited" VALUE="">
22
23 <BR>
24
25 % if ( $cust_pay ) {
26 %
27 %  #false laziness w/FS/FS/cust_pay.pm
28 %  my $payby = FS::payby->payname($cust_pay->payby);
29 %  my $paymask = $cust_pay->paymask;
30 %  my $paydate = $cust_pay->paydate;
31 %  if ( $cgi->param('error') ) { 
32 %    $paydate = $cgi->param('exp_year'). '-'. $cgi->param('exp_month'). '-01';
33 %    $paydate = '' unless ($paydate =~ /^\d{2,4}-\d{1,2}-01$'/);
34 %  }
35
36   <BR>Payment
37   <% ntable("#cccccc", 2) %>
38
39     <TR>
40       <TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$<% $cust_pay->paid %></TD>
41     </TR>
42
43   <TR>
44     <TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff"><% time2str($date_format, $cust_pay->_date) %></TD>
45   </TR>
46
47   <TR>
48     <TD ALIGN="right">Method</TD><TD BGCOLOR="#ffffff"><% $payby %> # <% $paymask %></TD>
49   </TR>
50
51 % unless ( $paydate || $cust_pay->payby ne 'CARD' ) {  # possibly other reasons: i.e. card has since expired
52   <TR>
53     <TD ALIGN="right">Expiration</TD><TD BGCOLOR="#ffffff">
54       <% include( '/elements/select-month_year.html',
55                   'prefix' => 'exp',
56                   'selected_date' => $paydate,
57                   'empty_option' => !$paydate,
58                 ) %>
59     </TD>
60   </TR>
61 % } 
62
63 %
64 %  #false laziness w/FS/FS/cust_main::realtime_refund_bop
65 %  if ( $cust_pay->paybatch =~ /^(\w+):(\w+)(:(\w+))?$/ ) {
66 %    my ( $processor, $auth, $order_number ) = ( $1, $2, $4 );
67 %  
68
69
70     <TR>
71       <TD ALIGN="right">Processor</TD><TD BGCOLOR="#ffffff"><% $processor %></TD>
72     </TR>
73 % if ( length($auth) ) { 
74
75       <TR>
76         <TD ALIGN="right">Authorization</TD><TD BGCOLOR="#ffffff"><% $auth %></TD>
77       </TR>
78 % } 
79 % if ( length($order_number) ) { 
80
81       <TR>
82         <TD ALIGN="right">Order number</TD><TD BGCOLOR="#ffffff"><% $order_number %></TD>
83       </TR>
84 % } 
85 % } 
86
87   </TABLE>
88 % } 
89
90
91 <BR>Refund
92 <% ntable("#cccccc", 2) %>
93
94   <TR>
95     <TD ALIGN="right">Date</TD>
96     <TD BGCOLOR="#ffffff"><% time2str($date_format, $_date) %></TD>
97   </TR>
98
99   <TR>
100     <TD ALIGN="right">Amount</TD>
101     <TD BGCOLOR="#ffffff">$<INPUT TYPE="text" NAME="refund" VALUE="<% $refund %>" SIZE=8 MAXLENGTH=8> by <B><% FS::payby->payname($payby) %></B></TD>
102   </TR>
103
104 % if ( $payby eq 'BILL' ) { 
105     <TR>
106       <TD ALIGN="right">Check #</TD>
107       <TD COLSPAN=2><INPUT TYPE="text" NAME="payinfo" VALUE="<% $payinfo %>" SIZE=10></TD>
108     </TR>
109 % } else {
110     <INPUT TYPE="hidden" NAME="payinfo" VALUE="">
111 % }
112
113   <TR>
114     <TD ALIGN="right">Reason</TD>
115     <TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="reason" VALUE="<% $reason %>"></TD>
116   </TR>
117 </TABLE>
118
119 <BR>
120 <INPUT TYPE="submit" NAME="submit" VALUE="Post refund">
121
122 </FORM>
123
124 % if ( $link eq 'popup' ) { 
125     </BODY>
126     </HTML>
127 % } else { 
128     <% include('/elements/footer.html') %>
129 % } 
130
131 <%init>
132
133 my $conf = new FS::Conf;
134 my $date_format = $conf->config('date_format') || '%m/%d/%Y';
135
136 my $custnum = $cgi->param('custnum');
137 my $refund  = $cgi->param('refund');
138 my $payby   = $cgi->param('payby');
139 my $payinfo = $cgi->param('payinfo');
140 my $reason  = $cgi->param('reason');
141 my $link    = $cgi->param('popup') ? 'popup' : '';
142
143 my @rights = ();
144 push @rights, 'Post refund'                if $payby =~ /^(BILL|CASH)$/;
145 push @rights, 'Post check refund'          if $payby eq 'BILL';
146 push @rights, 'Post cash refund '          if $payby eq 'CASH';
147 push @rights, 'Refund payment'             if $payby =~ /^(CARD|CHEK)$/;
148 push @rights, 'Refund credit card payment' if $payby eq 'CARD';
149 push @rights, 'Refund Echeck payment'      if $payby eq 'CHEK';
150
151 die "access denied"
152   unless $FS::CurrentUser::CurrentUser->access_right(\@rights);
153
154 my( $paynum, $cust_pay ) = ( '', '' );
155 if ( $cgi->param('paynum') =~ /^(\d+)$/ ) {
156   $paynum = $1;
157   $cust_pay = qsearchs('cust_pay', { paynum=>$paynum } )
158     or die "unknown payment # $paynum";
159   $refund ||= $cust_pay->unrefunded;
160   if ( $custnum ) {
161     die "payment # $paynum is not for specified customer # $custnum"
162       unless $custnum == $cust_pay->custnum;
163   } else {
164     $custnum = $cust_pay->custnum;
165   }
166 }
167 die "no custnum or paynum specified!" unless $custnum;
168
169 my $_date = time;
170
171 my $p1 = popurl(1);
172
173 my $title = 'Refund '. FS::payby->payname($payby). ' payment';
174
175 </%init>