add name/address to post payment screen
[freeside.git] / httemplate / edit / cust_pay.cgi
1 <%
2 #<!-- $Id: cust_pay.cgi,v 1.6 2001-12-21 21:40:24 ivan Exp $ -->
3
4 use strict;
5 use vars qw( $cgi $link $linknum $p1 $_date $payby $payinfo $paid );
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);
12
13 my $conf = new FS::Conf;
14
15 my $countrydefault = $conf->config('countrydefault') || 'US';
16
17 $cgi = new CGI;
18 cgisuidsetup($cgi);
19
20 if ( $cgi->param('error') ) {
21   $link = $cgi->param('link');
22   $linknum = $cgi->param('linknum');
23   $paid = $cgi->param('paid');
24   $payby = $cgi->param('payby');
25   $payinfo = $cgi->param('payinfo');
26 } elsif ($cgi->keywords) {
27   my($query) = $cgi->keywords;
28   $query =~ /^(\d+)$/;
29   $link = 'invnum';
30   $linknum = $1;
31   $paid = '';
32   $payby = 'BILL';
33   $payinfo = "";
34 } elsif ( $cgi->param('custnum')  =~ /^(\d+)$/ ) {
35   $link = 'custnum';
36   $linknum = $1;
37   $paid = '';
38   $payby = 'BILL';
39   $payinfo = '';
40 } else {
41   die "illegal query ". $cgi->keywords;
42 }
43 $_date = time;
44
45 $p1 = popurl(1);
46 print header("Enter payment", '');
47
48 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
49       "</FONT>"
50   if $cgi->param('error');
51
52 print <<END, ntable("#cccccc",2);
53     <FORM ACTION="${p1}process/cust_pay.cgi" METHOD=POST>
54     <INPUT TYPE="hidden" NAME="link" VALUE="$link">
55     <INPUT TYPE="hidden" NAME="linknum" VALUE="$linknum">
56 END
57
58 my $custnum;
59 if ( $link eq 'invnum' ) {
60
61   my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
62     or die "unknown invnum $linknum";
63   print "Invoice #<B>$linknum</B>". ntable("#cccccc",2).
64         '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
65         time2str("%D", $cust_bill->_date). '</TD></TR>'.
66         '<TR><TD ALIGN="right" VALIGN="top">Items</TD><TD BGCOLOR="#ffffff">';
67   foreach ( $cust_bill->cust_bill_pkg ) { #false laziness with FS::cust_bill
68     if ( $_->pkgnum ) {
69
70       my($cust_pkg)=qsearchs('cust_pkg', { 'pkgnum', $_->pkgnum } );
71       my($part_pkg)=qsearchs('part_pkg',{'pkgpart'=>$cust_pkg->pkgpart});
72       my($pkg)=$part_pkg->pkg;
73
74       if ( $_->setup != 0 ) {
75         print "$pkg Setup<BR>"; # $money_char. sprintf("%10.2f",$_->setup);
76         print join('<BR>',
77           map { "  ". $_->[0]. ": ". $_->[1] } $cust_pkg->labels
78         ). '<BR>';
79       }
80
81       if ( $_->recur != 0 ) {
82         print
83           "$pkg (" . time2str("%x",$_->sdate) . " - " .
84                                 time2str("%x",$_->edate) . ")<BR>";
85           #$money_char. sprintf("%10.2f",$_->recur)
86         print join('<BR>',
87           map { '--->'. $_->[0]. ": ". $_->[1] } $cust_pkg->labels
88         ). '<BR>';
89       }
90
91     } else { #pkgnum Tax
92       print "Tax<BR>" # $money_char. sprintf("%10.2f",$_->setup)
93         if $_->setup != 0;
94     }
95
96   }
97   print '</TD></TR></TABLE>';
98
99   $custnum = $cust_bill->custnum;
100
101 } elsif ( $link eq 'custnum' ) {
102   $custnum = $linknum;
103 }
104
105 print "<BR><BR>Customer #<B>$custnum</B>". ntable('#e8e8e8');
106 my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } )
107   or die "unknown custnum $custnum";
108
109 print '<TR><TD>'. ntable("#cccccc",2).
110       '<TR><TD ALIGN="right" VALIGN="top">Billing</TD><TD BGCOLOR="#ffffff">'.
111       $cust_main->getfield('last'). ', '. $cust_main->first. '<BR>';
112 print $cust_main->company. '<BR>' if $cust_main->company;
113 print $cust_main->address1. '<BR>';
114 print $cust_main->address2. '<BR>' if $cust_main->address2;
115 print $cust_main->city. ', '. $cust_main->state. '  '. $cust_main->zip. '<BR>';
116 print $cust_main->country. '<BR>' if $cust_main->country
117                                      && $cust_main->country ne $countrydefault;
118
119 print '</TD>'.
120       '</TR></TABLE></TD>';
121
122 if ( defined $cust_main->dbdef_table->column('ship_last') ) {
123
124   print '<TD>'. ntable("#cccccc",2).
125         '<TR><TD ALIGN="right" VALIGN="top">Service</TD><TD BGCOLOR="#ffffff">'.
126         $cust_main->getfield('ship_last'). ', '. $cust_main->ship_first. '<BR>';
127   print $cust_main->ship_company. '<BR>' if $cust_main->ship_company;
128   print $cust_main->ship_address1. '<BR>';
129   print $cust_main->ship_address2. '<BR>' if $cust_main->ship_address2;
130   print $cust_main->ship_city. ', '. $cust_main->ship_state. '  '. $cust_main->ship_zip. '<BR>';
131   print $cust_main->ship_country. '<BR>'
132     if $cust_main->ship_country && $cust_main->ship_country ne $countrydefault;
133
134   print '</TD>'.
135         '</TR></TABLE></TD>';
136 }
137
138 print '</TR></TABLE>';
139
140
141 print '<BR><BR>Payment'. ntable("#cccccc", 2).
142       '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
143       time2str("%D",$_date).  '</TD></TR>'.
144       qq!<INPUT TYPE="hidden" NAME="_date" VALUE="$_date">!;
145
146 print qq!<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">\$<INPUT TYPE="text" NAME="paid" VALUE="$paid" SIZE=8 MAXLENGTH=8></TD></TR>!;
147
148 print qq!<TR><TD ALIGN="right">Payby</TD><TD BGCOLOR="#ffffff">$payby</TD></TR><INPUT TYPE="hidden" NAME="payby" VALUE="$payby">!;
149
150 #payinfo (check # now as payby="BILL" hardcoded.. what to do later?)
151 print qq!<TR><TD ALIGN="right">Check #</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="payinfo" VALUE="$payinfo"></TD></TR>!;
152
153 #paybatch
154 print qq!<INPUT TYPE="hidden" NAME="paybatch" VALUE="">!;
155
156 print <<END;
157 </TABLE>
158 <BR>
159 <INPUT TYPE="submit" VALUE="Post payment">
160 END
161
162 print <<END;
163
164     </FORM>
165   </BODY>
166 </HTML>
167 END
168
169 %>