1 <!-- $Id: cust_pay.cgi,v 1.11 2002-01-30 14:18:08 ivan Exp $ -->
4 my $conf = new FS::Conf;
6 my($link, $linknum, $paid, $payby, $payinfo, $quickpay);
7 if ( $cgi->param('error') ) {
8 $link = $cgi->param('link');
9 $linknum = $cgi->param('linknum');
10 $paid = $cgi->param('paid');
11 $payby = $cgi->param('payby');
12 $payinfo = $cgi->param('payinfo');
13 $quickpay = $cgi->param('quickpay');
14 } elsif ($cgi->keywords) {
15 my($query) = $cgi->keywords;
23 } elsif ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
29 $quickpay = $cgi->param('quickpay');
31 die "illegal query ". $cgi->keywords;
36 print header("Post payment", '');
38 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
40 if $cgi->param('error');
42 print <<END, ntable("#cccccc",2);
43 <FORM ACTION="${p1}process/cust_pay.cgi" METHOD=POST>
44 <INPUT TYPE="hidden" NAME="link" VALUE="$link">
45 <INPUT TYPE="hidden" NAME="linknum" VALUE="$linknum">
46 <INPUT TYPE="hidden" NAME="quickpay" VALUE="$quickpay">
50 if ( $link eq 'invnum' ) {
52 my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
53 or die "unknown invnum $linknum";
54 print "Invoice #<B>$linknum</B>". ntable("#cccccc",2).
55 '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
56 time2str("%D", $cust_bill->_date). '</TD></TR>'.
57 '<TR><TD ALIGN="right" VALIGN="top">Items</TD><TD BGCOLOR="#ffffff">';
58 foreach ( $cust_bill->cust_bill_pkg ) { #false laziness with FS::cust_bill
61 my($cust_pkg)=qsearchs('cust_pkg', { 'pkgnum', $_->pkgnum } );
62 my($part_pkg)=qsearchs('part_pkg',{'pkgpart'=>$cust_pkg->pkgpart});
63 my($pkg)=$part_pkg->pkg;
65 if ( $_->setup != 0 ) {
66 print "$pkg Setup<BR>"; # $money_char. sprintf("%10.2f",$_->setup);
68 map { " ". $_->[0]. ": ". $_->[1] } $cust_pkg->labels
72 if ( $_->recur != 0 ) {
74 "$pkg (" . time2str("%x",$_->sdate) . " - " .
75 time2str("%x",$_->edate) . ")<BR>";
76 #$money_char. sprintf("%10.2f",$_->recur)
78 map { '--->'. $_->[0]. ": ". $_->[1] } $cust_pkg->labels
83 print "Tax<BR>" # $money_char. sprintf("%10.2f",$_->setup)
88 print '</TD></TR></TABLE><BR><BR>';
90 $custnum = $cust_bill->custnum;
92 } elsif ( $link eq 'custnum' ) {
96 print small_custview($custnum, $conf->config('countrydefault'));
98 print qq!<INPUT TYPE="hidden" NAME="_date" VALUE="$_date">!;
99 print qq!<INPUT TYPE="hidden" NAME="payby" VALUE="$payby">!;
101 print '<BR><BR>Payment'. ntable("#cccccc", 2).
102 '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
103 time2str("%D",$_date). '</TD></TR>';
105 print qq!<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">\$<INPUT TYPE="text" NAME="paid" VALUE="$paid" SIZE=8 MAXLENGTH=8></TD></TR>!;
107 print qq!<TR><TD ALIGN="right">Payby</TD><TD BGCOLOR="#ffffff">$payby</TD></TR>!;
109 #payinfo (check # now as payby="BILL" hardcoded.. what to do later?)
110 print qq!<TR><TD ALIGN="right">Check #</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="payinfo" VALUE="$payinfo"></TD></TR>!;
112 print qq!<TR><TD ALIGN="right">Auto-apply<BR>to invoices</TD><TD><SELECT NAME="apply"><OPTION VALUE="yes" SELECTED>yes<OPTION>no</SELECT></TD>!;
115 print qq!<INPUT TYPE="hidden" NAME="paybatch" VALUE="">!;
120 <INPUT TYPE="submit" VALUE="Post payment">