ho ho ho, merry XSSmas
[freeside.git] / httemplate / edit / cust_pay.cgi
1 % if ( $link eq 'popup' ) { 
2   <% include('/elements/header-popup.html', $title ) %>
3 % } else { 
4   <%  include("/elements/header.html", $title, '') %>
5 % } 
6
7 <% include('/elements/error.html') %>
8
9 <LINK REL="stylesheet" TYPE="text/css" HREF="../elements/calendar-win2k-2.css" TITLE="win2k-2">
10 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar_stripped.js"></SCRIPT>
11 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar-en.js"></SCRIPT>
12 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar-setup.js"></SCRIPT>
13
14 <FORM ACTION="<% popurl(1) %>process/cust_pay.cgi" METHOD=POST>
15 <INPUT TYPE="hidden" NAME="link" VALUE="<% $link %>">
16 <INPUT TYPE="hidden" NAME="linknum" VALUE="<% $linknum %>">
17
18 % unless ( $link eq 'popup' ) { 
19     <% small_custview($custnum, $conf->config('countrydefault')) %>
20 % } 
21
22 <INPUT TYPE="hidden" NAME="payby" VALUE="<% $payby %>">
23
24 <BR><BR>
25 Payment
26 <% ntable("#cccccc", 2) %>
27
28 <TR>
29   <TD ALIGN="right">Date</TD>
30   <TD COLSPAN=2>
31     <INPUT TYPE="text" NAME="_date" ID="_date_text" VALUE="<% time2str("%m/%d/%Y %r",$_date) %>">
32     <IMG SRC="../images/calendar.png" ID="_date_button" STYLE="cursor: pointer" TITLE="Select date">
33   </TD>
34 </TR>
35
36 <SCRIPT TYPE="text/javascript">
37   Calendar.setup({
38     inputField: "_date_text",
39     ifFormat:   "%m/%d/%Y",
40     button:     "_date_button",
41     align:      "BR"
42   });
43 </SCRIPT>
44
45 <TR>
46   <TD ALIGN="right">Amount</TD>
47   <TD BGCOLOR="#ffffff" ALIGN="right"><% $money_char %></TD>
48   <TD><INPUT TYPE="text" NAME="paid" VALUE="<% $paid %>" SIZE=8 MAXLENGTH=8> by <B><% $payby{$payby} %></B></TD>
49 </TR>
50
51 % if ( $payby eq 'BILL' ) { 
52   <TR>
53     <TD ALIGN="right">Check #</TD>
54     <TD COLSPAN=2><INPUT TYPE="text" NAME="payinfo" VALUE="<% $payinfo %>" SIZE=10></TD>
55   </TR>
56 % } 
57
58 <TR>
59 % if ( $link eq 'custnum' || $link eq 'popup' ) { 
60
61   <TD ALIGN="right">Auto-apply<BR>to invoices</TD>
62   <TD COLSPAN=2>
63     <SELECT NAME="apply">
64       <OPTION VALUE="yes" SELECTED>yes
65       <OPTION>no</SELECT>
66     </TD>
67
68 % } elsif ( $link eq 'invnum' ) { 
69
70   <TD ALIGN="right">Apply to</TD>
71   <TD COLSPAN=2 BGCOLOR="#ffffff">Invoice #<B><% $linknum %></B> only</TD>
72   <INPUT TYPE="hidden" NAME="apply" VALUE="no">
73
74 % } 
75 </TR>
76
77 </TABLE>
78
79 <INPUT TYPE="hidden" NAME="paybatch" VALUE="<% $paybatch %>">
80
81 <BR>
82 <INPUT TYPE="submit" VALUE="Post payment">
83
84 </FORM>
85 </BODY>
86 </HTML>
87
88 <%once>
89 my $conf = new FS::Conf;
90
91 my %payby = (
92   'BILL' => 'Check',
93   'CASH' => 'Cash',
94   'WEST' => 'Western Union',
95   'MCRD' => 'Manual credit card',
96 );
97
98 my $money_char = $conf->config('money_char') || '$';
99 </%once>
100
101 <%init>
102 my($link, $linknum, $paid, $payby, $payinfo, $_date); 
103 if ( $cgi->param('error') ) {
104   $link     = $cgi->param('link');
105   $linknum  = $cgi->param('linknum');
106   $paid     = $cgi->param('paid');
107   $payby    = $cgi->param('payby');
108   $payinfo  = $cgi->param('payinfo');
109   $_date    = $cgi->param('_date') ? str2time($cgi->param('_date')) : time;
110 } elsif ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
111   $link     = $cgi->param('popup') ? 'popup' : 'custnum';
112   $linknum  = $1;
113   $paid     = '';
114   $payby    = $cgi->param('payby') || 'BILL';
115   $payinfo  = '';
116   $_date    = time;
117 } elsif ( $cgi->param('invnum') =~ /^(\d+)$/ ) {
118   $link     = 'invnum';
119   $linknum  = $1;
120   $paid     = '';
121   $payby    = $cgi->param('payby') || 'BILL';
122   $payinfo  = "";
123   $_date    = time;
124 } else {
125   die "illegal query ". $cgi->keywords;
126 }
127
128 my $paybatch = "webui-$_date-$$-". rand() * 2**32;
129
130 my $title = 'Post '. $payby{$payby}. ' payment';
131 $title .= " against Invoice #$linknum" if $link eq 'invnum';
132
133 my $custnum;
134 if ( $link eq 'invnum' ) {
135   my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
136     or die "unknown invnum $linknum";
137   $custnum = $cust_bill->custnum;
138 } elsif ( $link eq 'custnum' ) {
139   $custnum = $linknum;
140 }
141 </%init>
142