summaryrefslogtreecommitdiff
path: root/httemplate/edit/cust_refund.cgi
blob: 8955c7cee3c785d2c0770100d74191ac7519a506 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<!-- mason kludge -->
<%

my $conf = new FS::Conf;
my $custnum = $cgi->param('custnum');
my $refund  = $cgi->param('refund');
my $payby   = $cgi->param('payby');
my $reason  = $cgi->param('reason');

my( $paynum, $cust_pay ) = ( '', '' );
if ( $cgi->param('paynum') =~ /^(\d+)$/ ) {
  $paynum = $1;
  $cust_pay = qsearchs('cust_pay', { paynum=>$paynum } )
    or die "unknown payment # $paynum";
  $refund ||= $cust_pay->unrefunded;
  if ( $custnum ) {
    die "payment # $paynum is not for specified customer # $custnum"
      unless $custnum == $cust_pay->custnum;
  } else {
    $custnum = $cust_pay->custnum;
  }
}
die "no custnum or paynum specified!" unless $custnum;

my $_date = time;

my $p1 = popurl(1);

print header('Refund '. ucfirst(lc($payby)). ' payment', '');
print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
      "</FONT>"
  if $cgi->param('error');
print <<END, small_custview($custnum, $conf->config('countrydefault'));
    <FORM ACTION="${p1}process/cust_refund.cgi" METHOD=POST>
    <INPUT TYPE="hidden" NAME="refundnum" VALUE="">
    <INPUT TYPE="hidden" NAME="custnum" VALUE="$custnum">
    <INPUT TYPE="hidden" NAME="paynum" VALUE="$paynum">
    <INPUT TYPE="hidden" NAME="_date" VALUE="$_date">
    <INPUT TYPE="hidden" NAME="payby" VALUE="$payby">
    <INPUT TYPE="hidden" NAME="payinfo" VALUE="">
    <INPUT TYPE="hidden" NAME="paybatch" VALUE="">
    <INPUT TYPE="hidden" NAME="credited" VALUE="">
    <BR>
END

if ( $cust_pay ) {

  #false laziness w/FS/FS/cust_pay.pm
  my $payby = $cust_pay->payby;
  my $payinfo = $cust_pay->payinfo;
  $payby =~ s/^BILL$/Check/ if $payinfo;
  $payby =~ s/^CHEK$/Electronic check/;
  $payinfo = $cust_pay->payinfo_masked if $payby eq 'CARD';

  print '<BR>Payment'. ntable("#cccccc", 2).
        '<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$'.
          $cust_pay->paid. '</TD></TR>'.
        '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
          time2str("%D",$cust_pay->_date). '</TD></TR>'.
        '<TR><TD ALIGN="right">Method</TD><TD BGCOLOR="#ffffff">'.
          ucfirst(lc($payby)). ' # '. $payinfo. '</TD></TR>';
  #false laziness w/FS/FS/cust_main::realtime_refund_bop
  if ( $cust_pay->paybatch =~ /^(\w+):(\w+)(:(\w+))?$/ ) {
    my ( $processor, $auth, $order_number ) = ( $1, $2, $4 );
    print '<TR><TD ALIGN="right">Processor</TD><TD BGCOLOR="#ffffff">'.
          $processor. '</TD></TR>';
    print '<TR><TD ALIGN="right">Authorization</TD><TD BGCOLOR="#ffffff">'.
          $auth. '</TD></TR>'
      if length($auth);
    print '<TR><TD ALIGN="right">Order number</TD><TD BGCOLOR="#ffffff">'.
          $order_number. '</TD></TR>'
      if length($order_number);
  }
  print '</TABLE>';
}

print '<BR>Refund'. ntable("#cccccc", 2).
      '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
      time2str("%D",$_date). '</TD></TR>';

print qq!<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">\$<INPUT TYPE="text" NAME="refund" VALUE="$refund" SIZE=8 MAXLENGTH=8></TD></TR>!;

print qq!<TR><TD ALIGN="right">Reason</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="reason" VALUE="$reason"></TD></TR>!;

print <<END;
</TABLE>
<BR>
<INPUT TYPE="submit" VALUE="Post refund">
    </FORM>
  </BODY>
</HTML>
END

%>