DEL out voided payments to distinguish them visually better
[freeside.git] / httemplate / edit / cust_refund.cgi
1 <!-- mason kludge -->
2 <%
3
4 my $conf = new FS::Conf;
5 my $custnum = $cgi->param('custnum');
6 my $refund  = $cgi->param('refund');
7 my $payby   = $cgi->param('payby');
8 my $reason  = $cgi->param('reason');
9
10 my( $paynum, $cust_pay ) = ( '', '' );
11 if ( $cgi->param('paynum') =~ /^(\d+)$/ ) {
12   $paynum = $1;
13   $cust_pay = qsearchs('cust_pay', { paynum=>$paynum } )
14     or die "unknown payment # $paynum";
15   $refund ||= $cust_pay->unrefunded;
16   if ( $custnum ) {
17     die "payment # $paynum is not for specified customer # $custnum"
18       unless $custnum == $cust_pay->custnum;
19   } else {
20     $custnum = $cust_pay->custnum;
21   }
22 }
23 die "no custnum or paynum specified!" unless $custnum;
24
25 my $_date = time;
26
27 my $p1 = popurl(1);
28
29 print header('Refund '. ucfirst(lc($payby)). ' payment', '');
30 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
31       "</FONT>"
32   if $cgi->param('error');
33 print <<END, small_custview($custnum, $conf->config('countrydefault'));
34     <FORM ACTION="${p1}process/cust_refund.cgi" METHOD=POST>
35     <INPUT TYPE="hidden" NAME="refundnum" VALUE="">
36     <INPUT TYPE="hidden" NAME="custnum" VALUE="$custnum">
37     <INPUT TYPE="hidden" NAME="paynum" VALUE="$paynum">
38     <INPUT TYPE="hidden" NAME="_date" VALUE="$_date">
39     <INPUT TYPE="hidden" NAME="payby" VALUE="$payby">
40     <INPUT TYPE="hidden" NAME="payinfo" VALUE="">
41     <INPUT TYPE="hidden" NAME="paybatch" VALUE="">
42     <INPUT TYPE="hidden" NAME="credited" VALUE="">
43     <BR>
44 END
45
46 if ( $cust_pay ) {
47
48   #false laziness w/FS/FS/cust_pay.pm
49   my $payby = $cust_pay->payby;
50   my $payinfo = $cust_pay->payinfo;
51   $payby =~ s/^BILL$/Check/ if $payinfo;
52   $payinfo = $cust_pay->payinfo_masked if $payby eq 'CARD';
53
54   print '<BR>Payment'. ntable("#cccccc", 2).
55         '<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$'.
56           $cust_pay->paid. '</TD></TR>'.
57         '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
58           time2str("%D",$cust_pay->_date). '</TD></TR>'.
59         '<TR><TD ALIGN="right">Method</TD><TD BGCOLOR="#ffffff">'.
60           ucfirst(lc($payby)). ' # '. $payinfo. '</TD></TR>';
61   #false laziness w/FS/FS/cust_main::realtime_refund_bop
62   if ( $cust_pay->paybatch =~ /^(\w+):(\w+)(:(\w+))?$/ ) {
63     my ( $processor, $auth, $order_number ) = ( $1, $2, $4 );
64     print '<TR><TD ALIGN="right">Processor</TD><TD BGCOLOR="#ffffff">'.
65           $processor. '</TD></TR>';
66     print '<TR><TD ALIGN="right">Authorization</TD><TD BGCOLOR="#ffffff">'.
67           $auth. '</TD></TR>'
68       if length($auth);
69     print '<TR><TD ALIGN="right">Order number</TD><TD BGCOLOR="#ffffff">'.
70           $order_number. '</TD></TR>'
71       if length($order_number);
72   }
73   print '</TABLE>';
74 }
75
76 print '<BR>Refund'. ntable("#cccccc", 2).
77       '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
78       time2str("%D",$_date). '</TD></TR>';
79
80 print qq!<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">\$<INPUT TYPE="text" NAME="refund" VALUE="$refund" SIZE=8 MAXLENGTH=8></TD></TR>!;
81
82 print qq!<TR><TD ALIGN="right">Reason</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="reason" VALUE="$reason"></TD></TR>!;
83
84 print <<END;
85 </TABLE>
86 <BR>
87 <INPUT TYPE="submit" VALUE="Post refund">
88     </FORM>
89   </BODY>
90 </HTML>
91 END
92
93 %>