encryption fixes from huntsberg & jayce
[freeside.git] / httemplate / view / cust_main / billing.html
1 %
2 %  my( $cust_main ) = @_;
3 %  my @invoicing_list = $cust_main->invoicing_list;
4 %  my $conf = new FS::Conf;
5 %  my $money_char = $conf->config('money_char') || '$';
6 %
7
8
9 Billing information
10 %  # If we can't see the unencrypted card, then bill now is an exercise in frustration 
11 %if ( ! $cust_main->is_encrypted($cust_main->payinfo) ) { 
12   (<A HREF="<% $p %>misc/bill.cgi?<% $cust_main->custnum %>">Bill now</A>)
13 % } 
14
15 <% ntable("#cccccc") %><TR><TD><% ntable("#cccccc",2) %>
16 %
17 %( my $balance = $cust_main->balance )
18 %  =~ s/^(\-?)(.*)$/<FONT SIZE=+1>$1<\/FONT>$money_char$2/;
19 %
20
21
22 <TR>
23   <TD ALIGN="right">Balance due</TD>
24   <TD BGCOLOR="#ffffff"><B><% $balance %></B></TD>
25 </TR>
26
27 <TR>
28   <TD ALIGN="right">Billing&nbsp;type</TD>
29   <TD BGCOLOR="#ffffff">
30 % if ( $cust_main->payby eq 'CARD' || $cust_main->payby eq 'DCRD' ) { 
31
32
33     Credit&nbsp;card&nbsp;<% $cust_main->payby eq 'CARD' ? '(automatic)' : '(on-demand)' %>
34   </TD>
35 </TR>
36 <TR>
37   <TD ALIGN="right">Card number</TD>
38   <TD BGCOLOR="#ffffff"><% $cust_main->paymask %></TD>
39 </TR>
40 %
41 %#false laziness w/elements/select-month_year.html & edit/cust_main/billing.html
42 %my( $mon, $year );
43 %my $date = $cust_main->paydate || '12-2037';
44 %if ( $date  =~ /^(\d{4})-(\d{1,2})-\d{1,2}$/ ) { #PostgreSQL date format
45 %  ( $mon, $year ) = ( $2, $1 );
46 %} elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
47 %  ( $mon, $year ) = ( $1, $3 );
48 %} else {
49 %  warn "unrecognized expiration date format: $date";
50 %  ( $mon, $year ) = ( '', '' );
51 %}
52 %
53
54 <TR>
55   <TD ALIGN="right">Expiration</TD>
56   <TD BGCOLOR="#ffffff"><% "$mon/$year" %></TD>
57 </TR>
58 % if ( $cust_main->paystart_month ) { 
59
60   <TR>
61     <TD ALIGN="right">Start date</TD>
62     <TD BGCOLOR="#ffffff"><% $cust_main->paystart_month. '/'. $cust_main->paystart_year %>
63   </TR>
64 % } elsif ( $cust_main->payissue ) { 
65
66   <TR>
67     <TD ALIGN="right">Issue #</TD>
68     <TD BGCOLOR="#ffffff"><% $cust_main->payissue %>
69   </TR>
70 % } 
71
72
73 <TR>
74   <TD ALIGN="right">Name on card</TD>
75   <TD BGCOLOR="#ffffff"><% $cust_main->payname %></TD>
76 </TR>
77 % } elsif ( $cust_main->payby eq 'CHEK' || $cust_main->payby eq 'DCHK') {
78 %     my( $account, $aba ) = split('@', $cust_main->payinfo );
79 %
80
81
82     Electronic&nbsp;check&nbsp;<% $cust_main->payby eq 'CHEK' ? '(automatic)' : '(on-demand)' %>
83   </TD>
84 </TR>
85 <TR>
86   <TD ALIGN="right">ABA/Routing code</TD>
87   <TD BGCOLOR="#ffffff"><% $aba %></TD>
88 </TR>
89 <TR>
90   <TD ALIGN="right">Account number</TD>
91   <TD BGCOLOR="#ffffff"><% 'x'x(length($account)-2). substr($account,(length($account)-2)) %></TD>
92 </TR>
93 <TR>
94   <TD ALIGN="right">Bank name</TD>
95   <TD BGCOLOR="#ffffff"><% $cust_main->payname %></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 % if ( $conf->exists('voip-cust_cdr_spools') ) { 
183
184   <TR>
185     <TD ALIGN="right">Spool&nbsp;CDRs</TD>
186     <TD BGCOLOR="#ffffff"><% $cust_main->spool_cdr ? 'yes' : 'no' %></TD>
187   </TR>
188 % } 
189
190
191 </TABLE></TD></TR></TABLE>
192