expedited check entry
[freeside.git] / httemplate / edit / cust_pay.cgi
1 <%
2 #<!-- $Id: cust_pay.cgi,v 1.9 2001-12-26 05:19:01 ivan Exp $ -->
3
4 use strict;
5 use vars qw( $cgi $link $linknum $p1 $_date $payby $payinfo $paid $quickpay );
6 use Date::Format;
7 use CGI;
8 use CGI::Carp qw(fatalsToBrowser);
9 use FS::Conf;
10 use FS::UID qw(cgisuidsetup);
11 use FS::CGI qw(header popurl ntable small_custview);
12
13 my $conf = new FS::Conf;
14
15 $cgi = new CGI;
16 cgisuidsetup($cgi);
17
18 if ( $cgi->param('error') ) {
19   $link = $cgi->param('link');
20   $linknum = $cgi->param('linknum');
21   $paid = $cgi->param('paid');
22   $payby = $cgi->param('payby');
23   $payinfo = $cgi->param('payinfo');
24   $quickpay = $cgi->param('quickpay');
25 } elsif ($cgi->keywords) {
26   my($query) = $cgi->keywords;
27   $query =~ /^(\d+)$/;
28   $link = 'invnum';
29   $linknum = $1;
30   $paid = '';
31   $payby = 'BILL';
32   $payinfo = "";
33   $quickpay = '';
34 } elsif ( $cgi->param('custnum')  =~ /^(\d+)$/ ) {
35   $link = 'custnum';
36   $linknum = $1;
37   $paid = '';
38   $payby = 'BILL';
39   $payinfo = '';
40   $quickpay = $cgi->param('quickpay');
41 } else {
42   die "illegal query ". $cgi->keywords;
43 }
44 $_date = time;
45
46 $p1 = popurl(1);
47 print header("Post payment", '');
48
49 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
50       "</FONT><BR><BR>"
51   if $cgi->param('error');
52
53 print <<END, ntable("#cccccc",2);
54     <FORM ACTION="${p1}process/cust_pay.cgi" METHOD=POST>
55     <INPUT TYPE="hidden" NAME="link" VALUE="$link">
56     <INPUT TYPE="hidden" NAME="linknum" VALUE="$linknum">
57     <INPUT TYPE="hidden" NAME="quickpay" VALUE="$quickpay">
58 END
59
60 my $custnum;
61 if ( $link eq 'invnum' ) {
62
63   my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
64     or die "unknown invnum $linknum";
65   print "Invoice #<B>$linknum</B>". ntable("#cccccc",2).
66         '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
67         time2str("%D", $cust_bill->_date). '</TD></TR>'.
68         '<TR><TD ALIGN="right" VALIGN="top">Items</TD><TD BGCOLOR="#ffffff">';
69   foreach ( $cust_bill->cust_bill_pkg ) { #false laziness with FS::cust_bill
70     if ( $_->pkgnum ) {
71
72       my($cust_pkg)=qsearchs('cust_pkg', { 'pkgnum', $_->pkgnum } );
73       my($part_pkg)=qsearchs('part_pkg',{'pkgpart'=>$cust_pkg->pkgpart});
74       my($pkg)=$part_pkg->pkg;
75
76       if ( $_->setup != 0 ) {
77         print "$pkg Setup<BR>"; # $money_char. sprintf("%10.2f",$_->setup);
78         print join('<BR>',
79           map { "  ". $_->[0]. ": ". $_->[1] } $cust_pkg->labels
80         ). '<BR>';
81       }
82
83       if ( $_->recur != 0 ) {
84         print
85           "$pkg (" . time2str("%x",$_->sdate) . " - " .
86                                 time2str("%x",$_->edate) . ")<BR>";
87           #$money_char. sprintf("%10.2f",$_->recur)
88         print join('<BR>',
89           map { '--->'. $_->[0]. ": ". $_->[1] } $cust_pkg->labels
90         ). '<BR>';
91       }
92
93     } else { #pkgnum Tax
94       print "Tax<BR>" # $money_char. sprintf("%10.2f",$_->setup)
95         if $_->setup != 0;
96     }
97
98   }
99   print '</TD></TR></TABLE>';
100
101   $custnum = $cust_bill->custnum;
102
103 } elsif ( $link eq 'custnum' ) {
104   $custnum = $linknum;
105 }
106
107 print small_custview($custnum, $conf->config('countrydefault'));
108
109 print qq!<INPUT TYPE="hidden" NAME="_date" VALUE="$_date">!;
110 print qq!<INPUT TYPE="hidden" NAME="payby" VALUE="$payby">!;
111
112 print '<BR><BR>Payment'. ntable("#cccccc", 2).
113       '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
114       time2str("%D",$_date).  '</TD></TR>';
115
116 print qq!<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">\$<INPUT TYPE="text" NAME="paid" VALUE="$paid" SIZE=8 MAXLENGTH=8></TD></TR>!;
117
118 print qq!<TR><TD ALIGN="right">Payby</TD><TD BGCOLOR="#ffffff">$payby</TD></TR>!;
119
120 #payinfo (check # now as payby="BILL" hardcoded.. what to do later?)
121 print qq!<TR><TD ALIGN="right">Check #</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="payinfo" VALUE="$payinfo"></TD></TR>!;
122
123 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>!;
124
125 #paybatch
126 print qq!<INPUT TYPE="hidden" NAME="paybatch" VALUE="">!;
127
128 print <<END;
129 </TABLE>
130 <BR>
131 <INPUT TYPE="submit" VALUE="Post payment">
132     </FORM>
133   </BODY>
134 </HTML>
135 END
136
137 %>