a203e91317c3e1270ff2dee76559a49798db2902
[freeside.git] / httemplate / edit / cust_pay.cgi
1 % if ( $link eq 'popup' ) { 
2   <& /elements/header-popup.html, $title  &>
3 % } else { 
4   <& /elements/header-cust_main.html, view=>'payment_history', custnum=>$custnum &>
5   <h2><% $title |h %></h2>
6 % } 
7
8 <& /elements/init_calendar.html &>
9
10 <& /elements/error.html &>
11
12 <FORM NAME="PaymentForm" ACTION="<% popurl(1) %>process/cust_pay.cgi" METHOD=POST onSubmit="document.PaymentForm.submitButton.disabled=true">
13 <INPUT TYPE="hidden" NAME="link" VALUE="<% $link %>">
14 <INPUT TYPE="hidden" NAME="linknum" VALUE="<% $linknum %>">
15 <INPUT TYPE="hidden" NAME="payby" VALUE="<% $payby %>">
16 <INPUT TYPE="hidden" NAME="paybatch" VALUE="<% $paybatch %>">
17
18 <% mt('Payment') |h %> 
19 <% ntable("#cccccc", 2) %>
20
21 % my %date_args = (
22 %   'name'    =>  '_date',
23 %   'label'   => emt('Date'),
24 %   'value'   => $_date,
25 %   'format'  => $date_format. ' %r',
26 %   'colspan' => 2,
27 % );
28 % if ( $FS::CurrentUser::CurrentUser->access_right('Backdate payment') ) {
29
30   <& /elements/tr-input-date-field.html, \%date_args &>
31
32 % } else {
33
34   <& /elements/tr-fixed-date.html, \%date_args &>
35
36 % }
37
38 <TR>
39   <TD ALIGN="right"><% mt('Amount') |h %></TD>
40   <TD BGCOLOR="#ffffff"><% $money_char |h %><INPUT TYPE="text" NAME="paid" ID="paid" VALUE="<% $paid %>" SIZE=8 MAXLENGTH=9> <% mt('by') |h %> <B><% mt(FS::payby->payname($payby)) |h %></B></TD>
41 </TR>
42
43 % if ( $conf->exists('part_pkg-term_discounts') ) {
44     <& /elements/tr-select-discount_term.html,
45          'custnum'   => $custnum,
46          'amount_id' => 'paid',
47     &>
48 % }
49
50 % if ( $payby eq 'BILL' ) { 
51   <TR>
52     <TD ALIGN="right"><% mt('Check #') |h %></TD>
53     <TD COLSPAN=2><INPUT TYPE="text" NAME="payinfo" VALUE="<% $payinfo %>" SIZE=10></TD>
54   </TR>
55 % }
56 % elsif ( $payby eq 'CASH' and $conf->exists('require_cash_deposit_info') ) {
57   <TR>
58     <TD ALIGN="right"><% mt('Bank') |h %></TD>
59     <TD COLSPAN=3><INPUT TYPE="text" NAME="bank" VALUE="<% $cgi->param('bank') %>"></TD>
60   </TR>
61   <TR>
62     <TD ALIGN="right"><% mt('Check #') |h %></TD>
63     <TD COLSPAN=2><INPUT TYPE="text" NAME="payinfo" VALUE="<% $payinfo %>" SIZE=10></TD>
64   </TR>
65   <TR>
66     <TD ALIGN="right"><% mt('Teller #') |h %></TD>
67     <TD COLSPAN=2><INPUT TYPE="text" NAME="teller" VALUE="<% $cgi->param('teller') %>" SIZE=10></TD>
68   </TR>
69   <TR>
70     <TD ALIGN="right"><% mt('Depositor') |h %></TD>
71     <TD COLSPAN=3><INPUT TYPE="text" NAME="depositor" VALUE="<% $cgi->param('depositor') %>"></TD>
72   </TR>
73   <TR>
74     <TD ALIGN="right"><% mt('Account #') |h %></TD>
75     <TD COLSPAN=2><INPUT TYPE="text" NAME="account" VALUE="<% $cgi->param('account') %>" SIZE=18></TD>
76   </TR>
77 % }
78
79 <TR>
80 % if ( $link eq 'custnum' || $link eq 'popup' ) { 
81
82   <TD ALIGN="right"><% mt('Auto-apply to invoices') |h %></TD>
83   <TD COLSPAN=2>
84     <SELECT NAME="apply">
85       <OPTION VALUE="yes" SELECTED><% mt('yes') |h %></OPTION> 
86       <OPTION VALUE=""><% mt('not now') |h %></OPTION>
87       <OPTION VALUE="never"><% mt('never') |h %></OPTION>
88     </SELECT>
89   </TD>
90
91 % } elsif ( $link eq 'invnum' ) { 
92
93   <TD ALIGN="right"><% mt('Apply to') |h %></TD>
94   <TD COLSPAN=2 BGCOLOR="#ffffff">Invoice #<B><% $linknum %></B> only</TD>
95   <INPUT TYPE="hidden" NAME="apply" VALUE="">
96
97 % } 
98 </TR>
99
100 % if ( $conf->exists('pkg-balances') ) {
101   <& /elements/tr-select-cust_pkg-balances.html,
102                'custnum' => $custnum,
103                'cgi'     => $cgi
104   &>
105 % } else {
106   <INPUT TYPE="hidden" NAME="pkgnum" VALUE="">
107 % }
108
109 </TABLE>
110
111 <BR>
112 <INPUT NAME="submitButton" TYPE="submit" VALUE="<% mt('Post payment') |h %>">
113
114 </FORM>
115
116 % if ( $link eq 'popup' ) { 
117     </BODY>
118     </HTML>
119 % } else { 
120     <& /elements/footer-cust_main.html &>
121 % } 
122
123 <%init>
124
125 my $conf = new FS::Conf;
126
127 my $money_char  = $conf->config('money_char')  || '$';
128 my $date_format = $conf->config('date_format') || '%m/%d/%Y';
129
130 my($link, $linknum, $paid, $payby, $payinfo, $_date);
131 if ( $cgi->param('error') ) {
132   $link     = $cgi->param('link');
133   $linknum  = $cgi->param('linknum');
134   $paid     = $cgi->param('paid');
135   $payby    = $cgi->param('payby');
136   $payinfo  = $cgi->param('payinfo');
137   $_date    = $cgi->param('_date') ? parse_datetime($cgi->param('_date')) : time;
138 } elsif ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
139   $link     = $cgi->param('popup') ? 'popup' : 'custnum';
140   $linknum  = $1;
141   $paid     = '';
142   $payby    = $cgi->param('payby') || 'BILL';
143   $payinfo  = '';
144   $_date    = time;
145 } elsif ( $cgi->param('invnum') =~ /^(\d+)$/ ) {
146   $link     = 'invnum';
147   $linknum  = $1;
148   $paid     = '';
149   $payby    = $cgi->param('payby') || 'BILL';
150   $payinfo  = "";
151   $_date    = time;
152 } else {
153   die "illegal query ". $cgi->keywords;
154 }
155
156 my @rights = ('Post payment');
157 push @rights, 'Post check payment' if $payby eq 'BILL';
158 push @rights, 'Post cash payment'  if $payby eq 'CASH';
159
160 die "access denied"
161   unless $FS::CurrentUser::CurrentUser->access_right(\@rights);
162
163 my $paybatch = "webui-$_date-$$-". rand() * 2**32;
164
165 my $title = mt('Post '. FS::payby->payname($payby). ' payment');
166 $title .= mt(" against Invoice #[_1]",$linknum) if $link eq 'invnum';
167
168 my $custnum;
169 if ( $link eq 'invnum' ) {
170   my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
171     or die "unknown invnum $linknum";
172   $custnum = $cust_bill->custnum;
173 } elsif ( $link eq 'custnum' || $link eq 'popup' ) {
174   $custnum = $linknum;
175 }
176
177 </%init>