3 my($paynum, $amount, $invnum);
4 if ( $cgi->param('error') ) {
5 $paynum = $cgi->param('paynum');
6 $amount = $cgi->param('amount');
7 $invnum = $cgi->param('invnum');
9 my($query) = $cgi->keywords;
16 my $otaker = getotaker;
20 print header("Apply Payment", '');
21 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
23 if $cgi->param('error');
25 <FORM ACTION="${p1}process/cust_bill_pay.cgi" METHOD=POST>
28 my $cust_pay = qsearchs('cust_pay', { 'paynum' => $paynum } );
29 die "payment $paynum not found!" unless $cust_pay;
31 my $unapplied = $cust_pay->unapplied;
33 print "Payment # <B>$paynum</B>".
34 qq!<INPUT TYPE="hidden" NAME="paynum" VALUE="$paynum">!.
35 '<BR>Date: <B>'. time2str("%D", $cust_pay->_date). '</B>'.
36 '<BR>Amount: $<B>'. $cust_pay->paid. '</B>'.
37 "<BR>Unapplied amount: \$<B>$unapplied</B>"
40 my @cust_bill = grep $_->owed != 0,
41 qsearch('cust_bill', { 'custnum' => $cust_pay->custnum } );
45 function changed(what) {
46 cust_bill = what.options[what.selectedIndex].value;
49 foreach my $cust_bill ( @cust_bill ) {
50 my $invnum = $cust_bill->invnum;
51 my $changeto = $cust_bill->owed < $unapplied
55 if ( cust_bill == $invnum ) {
56 what.form.amount.value = "$changeto";
62 # if ( cust_bill == "Refund" ) {
63 # what.form.amount.value = "$credited";
70 print qq!<BR>Invoice #<SELECT NAME="invnum" SIZE=1 onChange="changed(this)">!,
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;
78 #print qq!<OPTION VALUE="Refund">Refund!;
81 print qq!<BR>Amount \$<INPUT TYPE="text" NAME="amount" VALUE="$amount" SIZE=8 MAXLENGTH=8>!;
85 <INPUT TYPE="submit" VALUE="Apply">