so Search.tsf and Search.rdf work
[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   $payby =~ s/^CHEK$/Electronic check/;
53   $payinfo = $cust_pay->payinfo_masked if $payby eq 'CARD';
54
55   print '<BR>Payment'. ntable("#cccccc", 2).
56         '<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$'.
57           $cust_pay->paid. '</TD></TR>'.
58         '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
59           time2str("%D",$cust_pay->_date). '</TD></TR>'.
60         '<TR><TD ALIGN="right">Method</TD><TD BGCOLOR="#ffffff">'.
61           ucfirst(lc($payby)). ' # '. $payinfo. '</TD></TR>';
62   #false laziness w/FS/FS/cust_main::realtime_refund_bop
63   if ( $cust_pay->paybatch =~ /^(\w+):(\w+)(:(\w+))?$/ ) {
64     my ( $processor, $auth, $order_number ) = ( $1, $2, $4 );
65     print '<TR><TD ALIGN="right">Processor</TD><TD BGCOLOR="#ffffff">'.
66           $processor. '</TD></TR>';
67     print '<TR><TD ALIGN="right">Authorization</TD><TD BGCOLOR="#ffffff">'.
68           $auth. '</TD></TR>'
69       if length($auth);
70     print '<TR><TD ALIGN="right">Order number</TD><TD BGCOLOR="#ffffff">'.
71           $order_number. '</TD></TR>'
72       if length($order_number);
73   }
74   print '</TABLE>';
75 }
76
77 print '<BR>Refund'. ntable("#cccccc", 2).
78       '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
79       time2str("%D",$_date). '</TD></TR>';
80
81 print qq!<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">\$<INPUT TYPE="text" NAME="refund" VALUE="$refund" SIZE=8 MAXLENGTH=8></TD></TR>!;
82
83 print qq!<TR><TD ALIGN="right">Reason</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="reason" VALUE="$reason"></TD></TR>!;
84
85 print <<END;
86 </TABLE>
87 <BR>
88 <INPUT TYPE="submit" VALUE="Post refund">
89     </FORM>
90   </BODY>
91 </HTML>
92 END
93
94 %>