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