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;
10 % $query =~ /^(\d+)$/;
16 %my $otaker = getotaker;
21 <% header("Apply Payment", '') %>
22 % if ( $cgi->param('error') ) {
24 <FONT SIZE="+1" COLOR="#ff0000">Error: <% $cgi->param('error') %></FONT>
29 <FORM ACTION="<% $p1 %>process/cust_bill_pay.cgi" METHOD=POST>
31 %my $cust_pay = qsearchs('cust_pay', { 'paynum' => $paynum } );
32 %die "payment $paynum not found!" unless $cust_pay;
34 %my $unapplied = $cust_pay->unapplied;
38 Payment #<B><% $paynum %></B>
39 <INPUT TYPE="hidden" NAME="paynum" VALUE="<% $paynum %>">
41 <BR>Date: <B><% time2str("%D", $cust_pay->_date) %></B>
43 <BR>Amount: $<B><% $cust_pay->paid %></B>
45 <BR>Unapplied amount: $<B><% $unapplied %></B>
47 %my @cust_bill = grep $_->owed != 0,
48 % qsearch('cust_bill', { 'custnum' => $cust_pay->custnum } );
54 function changed(what) {
55 cust_bill = what.options[what.selectedIndex].value;
56 % foreach my $cust_bill ( @cust_bill ) {
57 % my $invnum = $cust_bill->invnum;
58 % my $changeto = $cust_bill->owed < $unapplied
63 if ( cust_bill == $invnum ) {
64 what.form.amount.value = "<% $changeto %>";
69 if ( cust_bill == "Refund" ) {
70 what.form.amount.value = "<% $unapplied %>";
75 <BR>Invoice #<SELECT NAME="invnum" SIZE=1 onChange="changed(this)">
77 % foreach my $cust_bill ( @cust_bill ) {
80 <OPTION<% $cust_bill->invnum eq $invnum ? ' SELECTED' : '' %> VALUE="<% $cust_bill->invnum %>"><% $cust_bill->invnum %> - <% time2str("%D", $cust_bill->_date) %> - $<% $cust_bill->owed %>
84 <OPTION VALUE="Refund">Refund
87 <BR>Amount $<INPUT TYPE="text" NAME="amount" VALUE="<% $amount %>" SIZE=8 MAXLENGTH=8>
90 <CENTER><INPUT TYPE="submit" VALUE="Apply"></CENTER>