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