ACLs
[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
90 my $conf = new FS::Conf;
91
92 my %payby = (
93   'BILL' => 'Check',
94   'CASH' => 'Cash',
95   'WEST' => 'Western Union',
96   'MCRD' => 'Manual credit card',
97 );
98
99 my $money_char = $conf->config('money_char') || '$';
100
101 </%once>
102 <%init>
103
104 die "access denied"
105   unless $FS::CurrentUser::CurrentUser->access_right('Post payment');
106
107 my($link, $linknum, $paid, $payby, $payinfo, $_date); 
108 if ( $cgi->param('error') ) {
109   $link     = $cgi->param('link');
110   $linknum  = $cgi->param('linknum');
111   $paid     = $cgi->param('paid');
112   $payby    = $cgi->param('payby');
113   $payinfo  = $cgi->param('payinfo');
114   $_date    = $cgi->param('_date') ? str2time($cgi->param('_date')) : time;
115 } elsif ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
116   $link     = $cgi->param('popup') ? 'popup' : 'custnum';
117   $linknum  = $1;
118   $paid     = '';
119   $payby    = $cgi->param('payby') || 'BILL';
120   $payinfo  = '';
121   $_date    = time;
122 } elsif ( $cgi->param('invnum') =~ /^(\d+)$/ ) {
123   $link     = 'invnum';
124   $linknum  = $1;
125   $paid     = '';
126   $payby    = $cgi->param('payby') || 'BILL';
127   $payinfo  = "";
128   $_date    = time;
129 } else {
130   die "illegal query ". $cgi->keywords;
131 }
132
133 my $paybatch = "webui-$_date-$$-". rand() * 2**32;
134
135 my $title = 'Post '. $payby{$payby}. ' payment';
136 $title .= " against Invoice #$linknum" if $link eq 'invnum';
137
138 my $custnum;
139 if ( $link eq 'invnum' ) {
140   my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
141     or die "unknown invnum $linknum";
142   $custnum = $cust_bill->custnum;
143 } elsif ( $link eq 'custnum' ) {
144   $custnum = $linknum;
145 }
146 </%init>
147