don't put this information way out on the right in its own columns.
[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 </TR>
85 <TR>
86   <TD ALIGN="right">Account type</TD>
87   <TD BGCOLOR="#ffffff"><% $cust_main->paytype %></TD>
88 </TR>
89 <TR>
90   <TD ALIGN="right">Bank name</TD>
91   <TD BGCOLOR="#ffffff"><% $cust_main->payname %></TD>
92 </TR>
93 <TR>
94   <TD ALIGN="right"><% $paystate_label %></TD>
95   <TD BGCOLOR="#ffffff"><% $cust_main->paystate || '&nbsp;&nbsp;&nbsp;' %></TD>
96 </TR>
97 % } elsif ( $cust_main->payby eq 'LECB' ) {
98 %     $cust_main->payinfo =~ /^(\d{3})(\d{3})(\d{4})$/;
99 %     my $payinfo = "$1-$2-$3";
100 %
101
102
103     Phone&nbsp;bill&nbsp;billing
104   </TD>
105 </TR>
106 <TR>
107   <TD ALIGN="right">Phone number</TD>
108   <TD BGCOLOR="#ffffff"><% $payinfo %></TD>
109 </TR>
110 % } elsif ( $cust_main->payby eq 'BILL' ) { 
111
112
113     Billing
114   </TD>
115 </TR>
116 % if ( $cust_main->payinfo ) { 
117
118 <TR>
119   <TD ALIGN="right">P.O. </TD>
120   <TD BGCOLOR="#ffffff"><% $cust_main->payinfo %></TD>
121 </TR>
122 % } 
123
124
125 <TR>
126   <TD ALIGN="right">Attention</TD>
127   <TD BGCOLOR="#ffffff"><% $cust_main->payname %></TD>
128 </TR>
129 % } elsif ( $cust_main->payby eq 'COMP' ) { 
130
131
132     Complimentary
133   </TD>
134 </TR>
135 <TR>
136   <TD ALIGN="right">Authorized&nbsp;by</TD>
137   <TD BGCOLOR="#ffffff"><% $cust_main->payinfo %></TD>
138 </TR>
139 %
140 %#false laziness w/above etc.
141 %my( $mon, $year );
142 %my $date = $cust_main->paydate || '12-2037';
143 %if ( $date  =~ /^(\d{4})-(\d{1,2})-\d{1,2}$/ ) { #PostgreSQL date format
144 %  ( $mon, $year ) = ( $2, $1 );
145 %} elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
146 %  ( $mon, $year ) = ( $1, $3 );
147 %} else {
148 %  warn "unrecognized expiration date format: $date";
149 %  ( $mon, $year ) = ( '', '' );
150 %}
151 %
152
153 <TR>
154   <TD ALIGN="right">Expiration</TD>
155   <TD BGCOLOR="#ffffff"><% "$mon/$year" %></TD>
156 </TR>
157 % } 
158
159
160 <TR>
161   <TD ALIGN="right">Tax&nbsp;exempt</TD>
162   <TD BGCOLOR="#ffffff"><% $cust_main->tax ? 'yes' : 'no' %></TD>
163 </TR>
164 <TR>
165   <TD ALIGN="right">Postal&nbsp;invoices</TD>
166   <TD BGCOLOR="#ffffff">
167     <% ( grep { $_ eq 'POST' } @invoicing_list ) ? 'yes' : 'no' %>
168   </TD>
169 </TR>
170 <TR>
171   <TD ALIGN="right">FAX&nbsp;invoices</TD>
172   <TD BGCOLOR="#ffffff">
173     <% ( grep { $_ eq 'FAX' } @invoicing_list ) ? 'yes' : 'no' %>
174   </TD>
175 </TR>
176 <TR>
177   <TD ALIGN="right">Email&nbsp;invoices</TD>
178   <TD BGCOLOR="#ffffff">
179     <% join(', ', grep { $_ !~ /^(POST|FAX)$/ } @invoicing_list ) || 'no' %>
180   </TD>
181 </TR>
182 <TR>
183   <TD ALIGN="right">Invoice&nbsp;terms</TD>
184   <TD BGCOLOR="#ffffff">
185     <% $cust_main->invoice_terms || 'Default ('. ( $conf->config('invoice_default_terms') || 'Payable upon receipt' ). ')' %>
186   </TD>
187 </TR>
188
189 % if ( $conf->exists('voip-cust_cdr_spools') ) { 
190   <TR>
191     <TD ALIGN="right">Spool&nbsp;CDRs</TD>
192     <TD BGCOLOR="#ffffff"><% $cust_main->spool_cdr ? 'yes' : 'no' %></TD>
193   </TR>
194 % } 
195
196 </TABLE></TD></TR></TABLE>
197 <%once>
198
199 my $paystate_label = FS::Msgcat::_gettext('paystate');
200 $paystate_label = 'Bank state' if $paystate_label =~/^paystate$/;
201
202 </%once>
203 <%init>
204 my( $cust_main ) = @_;
205 my @invoicing_list = $cust_main->invoicing_list;
206 my $conf = new FS::Conf;
207 my $money_char = $conf->config('money_char') || '$';
208 </%init>