This commit was generated by cvs2svn to compensate for changes in r5562,
[freeside.git] / httemplate / edit / cust_bill_pay.cgi
1 <% header("Apply Payment", '') %>
2
3 % if ( $cgi->param('error') ) { 
4   <FONT SIZE="+1" COLOR="#ff0000">Error: <% $cgi->param('error') %></FONT>
5   <BR><BR>
6 % } 
7
8 <FORM ACTION="<% $p1 %>process/cust_bill_pay.cgi" METHOD=POST>
9
10 Payment #<B><% $paynum %></B>
11 <INPUT TYPE="hidden" NAME="paynum" VALUE="<% $paynum %>">
12
13 <BR>Date: <B><% time2str("%D", $cust_pay->_date) %></B>
14
15 <BR>Amount: $<B><% $cust_pay->paid %></B>
16
17 <BR>Unapplied amount: $<B><% $unapplied %></B>
18
19 <SCRIPT TYPE="text/javascript">
20 function changed(what) {
21   cust_bill = what.options[what.selectedIndex].value;
22
23 % foreach my $cust_bill ( @cust_bill ) {
24
25     if ( cust_bill == <% $cust_bill->invnum %> ) {
26       what.form.amount.value = "<% min($cust_bill->owed, $unapplied) %>";
27     }
28
29 % } 
30
31   if ( cust_bill == "Refund" ) {
32     what.form.amount.value = "<% $unapplied %>";
33   }
34 }
35 </SCRIPT>
36
37 <BR>Invoice #<SELECT NAME="invnum" SIZE=1 onChange="changed(this)">
38 <OPTION VALUE="">
39
40 % foreach my $cust_bill ( @cust_bill ) { 
41   <OPTION<% $cust_bill->invnum eq $invnum ? ' SELECTED' : '' %> VALUE="<% $cust_bill->invnum %>"><% $cust_bill->invnum %> - <% time2str("%D", $cust_bill->_date) %> - $<% $cust_bill->owed %>
42 % } 
43
44 <OPTION VALUE="Refund">Refund
45 </SELECT>
46
47 <BR>Amount $<INPUT TYPE="text" NAME="amount" VALUE="<% $amount %>" SIZE=8 MAXLENGTH=8>
48
49 <BR>
50 <CENTER><INPUT TYPE="submit" VALUE="Apply"></CENTER>
51
52 </FORM>
53 </BODY>
54 </HTML>
55
56 <%init>
57 my($paynum, $amount, $invnum);
58 if ( $cgi->param('error') ) {
59   $paynum = $cgi->param('paynum');
60   $amount = $cgi->param('amount');
61   $invnum = $cgi->param('invnum');
62 } else {
63   my($query) = $cgi->keywords;
64   $query =~ /^(\d+)$/;
65   $paynum = $1;
66   $amount = '';
67   $invnum = '';
68 }
69
70 my $otaker = getotaker;
71
72 my $p1 = popurl(1);
73
74 my $cust_pay = qsearchs('cust_pay', { 'paynum' => $paynum } );
75 die "payment $paynum not found!" unless $cust_pay;
76
77 my $unapplied = $cust_pay->unapplied;
78
79 my @cust_bill = sort {    $a->_date  <=> $b->_date
80                        or $a->invnum <=> $b->invnum
81                      }
82                 grep { $_->owed != 0 }
83                 qsearch('cust_bill', { 'custnum' => $cust_pay->custnum } );
84 </%init>
85