1 % if ( $link eq 'popup' ) {
2 <% include('/elements/header-popup.html', $title ) %>
4 <% include("/elements/header.html", $title, '') %>
7 <% include('/elements/error.html') %>
9 % unless ( $link eq 'popup' ) {
10 <% small_custview($custnum, $conf->config('countrydefault')) %>
13 <FORM NAME="RefundForm" ACTION="<% $p1 %>process/cust_refund.cgi" METHOD=POST onSubmit="document.RefundForm.submitButton.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="">
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$'/);
37 <% ntable("#cccccc", 2) %>
40 <TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$<% $cust_pay->paid %></TD>
44 <TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff"><% time2str($date_format, $cust_pay->_date) %></TD>
48 <TD ALIGN="right">Method</TD><TD BGCOLOR="#ffffff"><% $payby %> # <% $paymask %></TD>
51 % unless ( $paydate || $cust_pay->payby ne 'CARD' ) { # possibly other reasons: i.e. card has since expired
53 <TD ALIGN="right">Expiration</TD><TD BGCOLOR="#ffffff">
54 <% include( '/elements/select-month_year.html',
56 'selected_date' => $paydate,
57 'empty_option' => !$paydate,
62 % if ( $cust_pay->processor ) {
64 <TD ALIGN="right">Processor</TD>
65 <TD BGCOLOR="#ffffff"><% $cust_pay->processor %></TD>
67 % if ( length($cust_pay->auth) ) {
70 <TD ALIGN="right">Authorization</TD>
71 <TD BGCOLOR="#ffffff"><% $cust_pay->auth %></TD>
74 % if ( length($cust_pay->order_number) ) {
77 <TD ALIGN="right">Order number</TD>
78 <TD BGCOLOR="#ffffff"><% $cust_pay->order_number %></TD>
81 % } # if ($cust_pay->processor)
88 <% ntable("#cccccc", 2) %>
91 <TD ALIGN="right">Date</TD>
92 <TD BGCOLOR="#ffffff"><% time2str($date_format, $_date) %></TD>
96 <TD ALIGN="right">Amount</TD>
97 <TD BGCOLOR="#ffffff">$<INPUT TYPE="text" NAME="refund" VALUE="<% $refund %>" SIZE=8 MAXLENGTH=9> by <B><% FS::payby->payname($payby) %></B></TD>
100 % if ( $payby eq 'BILL' ) {
102 <TD ALIGN="right">Check #</TD>
103 <TD COLSPAN=2><INPUT TYPE="text" NAME="payinfo" VALUE="<% $payinfo %>" SIZE=10></TD>
106 <INPUT TYPE="hidden" NAME="payinfo" VALUE="">
109 <& /elements/tr-select-reason.html,
110 'field' => 'reasonnum',
111 'reason_class' => 'F',
112 'control_button' => "confirm_refund_button",
119 <INPUT TYPE="submit" NAME="submitButton" ID="confirm_refund_button" VALUE="<% mt('Post refund') |h %>" DISABLED>
123 % if ( $link eq 'popup' ) {
127 <% include('/elements/footer.html') %>
132 my $conf = new FS::Conf;
133 my $date_format = $conf->config('date_format') || '%m/%d/%Y';
135 my $custnum = $cgi->param('custnum');
136 my $refund = $cgi->param('refund');
137 my $payby = $cgi->param('payby');
138 my $payinfo = $cgi->param('payinfo');
139 my $reason = $cgi->param('reason');
140 my $link = $cgi->param('popup') ? 'popup' : '';
143 unless $FS::CurrentUser::CurrentUser->refund_access_right($payby);
145 my( $paynum, $cust_pay ) = ( '', '' );
146 if ( $cgi->param('paynum') =~ /^(\d+)$/ ) {
148 $cust_pay = qsearchs('cust_pay', { paynum=>$paynum } )
149 or die "unknown payment # $paynum";
150 $refund ||= $cust_pay->unrefunded;
152 die "payment # $paynum is not for specified customer # $custnum"
153 unless $custnum == $cust_pay->custnum;
155 $custnum = $cust_pay->custnum;
158 die "no custnum or paynum specified!" unless $custnum;
164 my $title = 'Refund '. FS::payby->payname($payby). ' payment';