1 % if ( $link eq 'popup' ) {
2 <% include('/elements/header-popup.html', $title ) %>
4 <% include("/elements/header.html", $title, '') %>
7 % if ( $cgi->param('error') ) {
8 <FONT SIZE="+1" COLOR="#ff0000">Error: <% $cgi->param('error') %></FONT>
12 <LINK REL="stylesheet" TYPE="text/css" HREF="../elements/calendar-win2k-2.css" TITLE="win2k-2">
13 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar_stripped.js"></SCRIPT>
14 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar-en.js"></SCRIPT>
15 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar-setup.js"></SCRIPT>
17 <FORM ACTION="<% popurl(1) %>process/cust_pay.cgi" METHOD=POST>
18 <INPUT TYPE="hidden" NAME="link" VALUE="<% $link %>">
19 <INPUT TYPE="hidden" NAME="linknum" VALUE="<% $linknum %>">
21 % unless ( $link eq 'popup' ) {
22 <% small_custview($custnum, $conf->config('countrydefault')) %>
25 <INPUT TYPE="hidden" NAME="payby" VALUE="<% $payby %>">
29 <% ntable("#cccccc", 2) %>
32 <TD ALIGN="right">Date</TD>
34 <INPUT TYPE="text" NAME="_date" ID="_date_text" VALUE="<% time2str("%m/%d/%Y %r",$_date) %>">
35 <IMG SRC="../images/calendar.png" ID="_date_button" STYLE="cursor: pointer" TITLE="Select date">
39 <SCRIPT TYPE="text/javascript">
41 inputField: "_date_text",
43 button: "_date_button",
49 <TD ALIGN="right">Amount</TD>
50 <TD BGCOLOR="#ffffff" ALIGN="right"><% $money_char %></TD>
51 <TD><INPUT TYPE="text" NAME="paid" VALUE="<% $paid %>" SIZE=8 MAXLENGTH=8> by <B><% $payby{$payby} %></B></TD>
54 % if ( $payby eq 'BILL' ) {
56 <TD ALIGN="right">Check #</TD>
57 <TD COLSPAN=2><INPUT TYPE="text" NAME="payinfo" VALUE="<% $payinfo %>" SIZE=10></TD>
62 % if ( $link eq 'custnum' || $link eq 'popup' ) {
64 <TD ALIGN="right">Auto-apply<BR>to invoices</TD>
67 <OPTION VALUE="yes" SELECTED>yes
71 % } elsif ( $link eq 'invnum' ) {
73 <TD ALIGN="right">Apply to</TD>
74 <TD COLSPAN=2 BGCOLOR="#ffffff">Invoice #<B><% $linknum %></B> only</TD>
75 <INPUT TYPE="hidden" NAME="apply" VALUE="no">
82 <INPUT TYPE="hidden" NAME="paybatch" VALUE="<% $paybatch %>">
85 <INPUT TYPE="submit" VALUE="Post payment">
92 my $conf = new FS::Conf;
97 'WEST' => 'Western Union',
98 'MCRD' => 'Manual credit card',
101 my $money_char = $conf->config('money_char') || '$';
105 my($link, $linknum, $paid, $payby, $payinfo, $_date);
106 if ( $cgi->param('error') ) {
107 $link = $cgi->param('link');
108 $linknum = $cgi->param('linknum');
109 $paid = $cgi->param('paid');
110 $payby = $cgi->param('payby');
111 $payinfo = $cgi->param('payinfo');
112 $_date = $cgi->param('_date') ? str2time($cgi->param('_date')) : time;
113 } elsif ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
114 $link = $cgi->param('popup') ? 'popup' : 'custnum';
117 $payby = $cgi->param('payby') || 'BILL';
120 } elsif ( $cgi->param('invnum') =~ /^(\d+)$/ ) {
124 $payby = $cgi->param('payby') || 'BILL';
128 die "illegal query ". $cgi->keywords;
131 my $paybatch = "webui-$_date-$$-". rand() * 2**32;
133 my $title = 'Post '. $payby{$payby}. ' payment';
134 $title .= " against Invoice #$linknum" if $link eq 'invnum';
137 if ( $link eq 'invnum' ) {
138 my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
139 or die "unknown invnum $linknum";
140 $custnum = $cust_bill->custnum;
141 } elsif ( $link eq 'custnum' ) {