ommitted file
[freeside.git] / httemplate / view / cust_main / billing.html
1 Billing information
2 %  # If we can't see the unencrypted card, then bill now is an exercise in frustration 
3 %if ( ! $cust_main->is_encrypted($cust_main->payinfo) ) { 
4   (<A HREF="<% $p %>misc/bill.cgi?<% $cust_main->custnum %>">Bill now</A>)
5 % } 
6
7 <% ntable("#cccccc") %><TR><TD><% ntable("#cccccc",2) %>
8 %
9 %( my $balance = $cust_main->balance )
10 %  =~ s/^(\-?)(.*)$/<FONT SIZE=+1>$1<\/FONT>$money_char$2/;
11 %
12
13
14 <TR>
15   <TD ALIGN="right">Balance due</TD>
16   <TD BGCOLOR="#ffffff"><B><% $balance %></B></TD>
17 </TR>
18
19 <TR>
20   <TD ALIGN="right">Billing&nbsp;type</TD>
21   <TD BGCOLOR="#ffffff">
22 % if ( $cust_main->payby eq 'CARD' || $cust_main->payby eq 'DCRD' ) { 
23
24
25     Credit&nbsp;card&nbsp;<% $cust_main->payby eq 'CARD' ? '(automatic)' : '(on-demand)' %>
26   </TD>
27 </TR>
28 <TR>
29   <TD ALIGN="right">Card number</TD>
30   <TD BGCOLOR="#ffffff"><% $cust_main->paymask %></TD>
31 </TR>
32 %
33 %#false laziness w/elements/select-month_year.html & edit/cust_main/billing.html
34 %my( $mon, $year );
35 %my $date = $cust_main->paydate || '12-2037';
36 %if ( $date  =~ /^(\d{4})-(\d{1,2})-\d{1,2}$/ ) { #PostgreSQL date format
37 %  ( $mon, $year ) = ( $2, $1 );
38 %} elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
39 %  ( $mon, $year ) = ( $1, $3 );
40 %} else {
41 %  warn "unrecognized expiration date format: $date";
42 %  ( $mon, $year ) = ( '', '' );
43 %}
44 %
45
46 <TR>
47   <TD ALIGN="right">Expiration</TD>
48   <TD BGCOLOR="#ffffff"><% "$mon/$year" %></TD>
49 </TR>
50 % if ( $cust_main->paystart_month ) { 
51
52   <TR>
53     <TD ALIGN="right">Start date</TD>
54     <TD BGCOLOR="#ffffff"><% $cust_main->paystart_month. '/'. $cust_main->paystart_year %>
55   </TR>
56 % } elsif ( $cust_main->payissue ) { 
57
58   <TR>
59     <TD ALIGN="right">Issue #</TD>
60     <TD BGCOLOR="#ffffff"><% $cust_main->payissue %>
61   </TR>
62 % } 
63
64
65 <TR>
66   <TD ALIGN="right">Name on card</TD>
67   <TD BGCOLOR="#ffffff"><% $cust_main->payname %></TD>
68 </TR>
69 % } elsif ( $cust_main->payby eq 'CHEK' || $cust_main->payby eq 'DCHK') {
70 %     my( $account, $aba ) = split('@', $cust_main->payinfo );
71 %
72
73
74     Electronic&nbsp;check&nbsp;<% $cust_main->payby eq 'CHEK' ? '(automatic)' : '(on-demand)' %>
75   </TD>
76 </TR>
77 <TR>
78   <TD ALIGN="right">ABA/Routing code</TD>
79   <TD BGCOLOR="#ffffff"><% $aba %></TD>
80 </TR>
81 <TR>
82   <TD ALIGN="right">Account number</TD>
83   <TD BGCOLOR="#ffffff"><% 'x'x(length($account)-2). substr($account,(length($account)-2)) %></TD>
84   <TD ALIGN="right">Account type</TD>
85   <TD BGCOLOR="#ffffff"><% $cust_main->paytype %></TD>
86 </TR>
87 <TR>
88   <TD ALIGN="right">Bank name</TD>
89   <TD BGCOLOR="#ffffff"><% $cust_main->payname %></TD>
90   <TD ALIGN="right"><% $paystate_label %></TD>
91   <TD BGCOLOR="#ffffff"><% $cust_main->paystate || '&nbsp;&nbsp;&nbsp;' %></TD>
92 </TR>
93 % } elsif ( $cust_main->payby eq 'LECB' ) {
94 %     $cust_main->payinfo =~ /^(\d{3})(\d{3})(\d{4})$/;
95 %     my $payinfo = "$1-$2-$3";
96 %
97
98
99     Phone&nbsp;bill&nbsp;billing
100   </TD>
101 </TR>
102 <TR>
103   <TD ALIGN="right">Phone number</TD>
104   <TD BGCOLOR="#ffffff"><% $payinfo %></TD>
105 </TR>
106 % } elsif ( $cust_main->payby eq 'BILL' ) { 
107
108
109     Billing
110   </TD>
111 </TR>
112 % if ( $cust_main->payinfo ) { 
113
114 <TR>
115   <TD ALIGN="right">P.O. </TD>
116   <TD BGCOLOR="#ffffff"><% $cust_main->payinfo %></TD>
117 </TR>
118 % } 
119
120
121 <TR>
122   <TD ALIGN="right">Attention</TD>
123   <TD BGCOLOR="#ffffff"><% $cust_main->payname %></TD>
124 </TR>
125 % } elsif ( $cust_main->payby eq 'COMP' ) { 
126
127
128     Complimentary
129   </TD>
130 </TR>
131 <TR>
132   <TD ALIGN="right">Authorized&nbsp;by</TD>
133   <TD BGCOLOR="#ffffff"><% $cust_main->payinfo %></TD>
134 </TR>
135 %
136 %#false laziness w/above etc.
137 %my( $mon, $year );
138 %my $date = $cust_main->paydate || '12-2037';
139 %if ( $date  =~ /^(\d{4})-(\d{1,2})-\d{1,2}$/ ) { #PostgreSQL date format
140 %  ( $mon, $year ) = ( $2, $1 );
141 %} elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
142 %  ( $mon, $year ) = ( $1, $3 );
143 %} else {
144 %  warn "unrecognized expiration date format: $date";
145 %  ( $mon, $year ) = ( '', '' );
146 %}
147 %
148
149 <TR>
150   <TD ALIGN="right">Expiration</TD>
151   <TD BGCOLOR="#ffffff"><% "$mon/$year" %></TD>
152 </TR>
153 % } 
154
155
156 <TR>
157   <TD ALIGN="right">Tax&nbsp;exempt</TD>
158   <TD BGCOLOR="#ffffff"><% $cust_main->tax ? 'yes' : 'no' %></TD>
159 </TR>
160 <TR>
161   <TD ALIGN="right">Postal&nbsp;invoices</TD>
162   <TD BGCOLOR="#ffffff">
163     <% ( grep { $_ eq 'POST' } @invoicing_list ) ? 'yes' : 'no' %>
164   </TD>
165 </TR>
166 <TR>
167   <TD ALIGN="right">FAX&nbsp;invoices</TD>
168   <TD BGCOLOR="#ffffff">
169     <% ( grep { $_ eq 'FAX' } @invoicing_list ) ? 'yes' : 'no' %>
170   </TD>
171 </TR>
172 <TR>
173   <TD ALIGN="right">Email&nbsp;invoices</TD>
174   <TD BGCOLOR="#ffffff">
175     <% join(', ', grep { $_ !~ /^(POST|FAX)$/ } @invoicing_list ) || 'no' %>
176   </TD>
177 </TR>
178 <TR>
179   <TD ALIGN="right">Invoice&nbsp;terms</TD>
180   <TD BGCOLOR="#ffffff">
181     <% $cust_main->invoice_terms || 'Default ('. ( $conf->config('invoice_default_terms') || 'Payable upon receipt' ). ')' %>
182   </TD>
183 </TR>
184
185 % if ( $conf->exists('voip-cust_cdr_spools') ) { 
186   <TR>
187     <TD ALIGN="right">Spool&nbsp;CDRs</TD>
188     <TD BGCOLOR="#ffffff"><% $cust_main->spool_cdr ? 'yes' : 'no' %></TD>
189   </TR>
190 % } 
191
192 </TABLE></TD></TR></TABLE>
193 <%once>
194
195 my $paystate_label = FS::Msgcat::_gettext('paystate');
196 $paystate_label = 'Bank state' if $paystate_label =~/^paystate$/;
197
198 </%once>
199 <%init>
200 my( $cust_main ) = @_;
201 my @invoicing_list = $cust_main->invoicing_list;
202 my $conf = new FS::Conf;
203 my $money_char = $conf->config('money_char') || '$';
204 </%init>