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