summaryrefslogtreecommitdiff
path: root/httemplate/edit/cust_refund.cgi
blob: aa825af94c5069202ec930008675064cb8b6e173 (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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
%
%
%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);
%
%


<% include('/elements/header.html', 'Refund '. ucfirst(lc($payby)). ' payment', '') %>
% if ( $cgi->param('error') ) { 

  <FONT SIZE="+1" COLOR="#ff0000">Error: <% $cgi->param('error') %></FONT>
  <BR><BR>
% } 


<% small_custview($custnum, $conf->config('countrydefault')) %>

<FORM NAME="RefundForm" ACTION="<% $p1 %>process/cust_refund.cgi" METHOD=POST onSubmit="document.RefundForm.submit.disabled=true">
<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>
% if ( $cust_pay ) {
%
%  #false laziness w/FS/FS/cust_pay.pm
%  my $payby = $cust_pay->payby;
%  my $paymask = $cust_pay->paymask;
%  $payby =~ s/^BILL$/Check/ if $paymask;
%  $payby =~ s/^CHEK$/Electronic check/;
%
%


  <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)) %> # <% $paymask %></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 );
%  


    <TR>
      <TD ALIGN="right">Processor</TD><TD BGCOLOR="#ffffff"><% $processor %></TD>
    </TR>
% if ( length($auth) ) { 

      <TR>
        <TD ALIGN="right">Authorization</TD><TD BGCOLOR="#ffffff"><% $auth %></TD>
      </TR>
% } 
% if ( length($order_number) ) { 

      <TR>
        <TD ALIGN="right">Order number</TD><TD BGCOLOR="#ffffff"><% $order_number %></TD>
      </TR>
% } 
% } 

  </TABLE>
% } 


<BR>Refund
<% ntable("#cccccc", 2) %>

  <TR>
    <TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff"><% time2str("%D",$_date) %></TD>
  </TR>

  <TR>
    <TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">$<INPUT TYPE="text" NAME="refund" VALUE="<% $refund %>" SIZE=8 MAXLENGTH=8></TD>
  </TR>

  <TR>
    <TD ALIGN="right">Reason</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="reason" VALUE="<% $reason %>"></TD>
  </TR>
</TABLE>

<BR>
<INPUT TYPE="submit" NAME="submit" VALUE="Post refund">

</FORM>

<% include('/elements/footer.html') %>