1 <STYLE TYPE="text/css">
2 .invoice { font-family: sans-serif; font-size: 10pt }
3 .invoice_header { font-size: 10pt }
4 .invoice_headerright TH { border-top: 2px solid #000000; border-bottom: 2px solid #000000 }
5 .invoice_headerright TD { font-size: 10pt; empty-cells: show }
6 .invoice_summary TH { border-bottom: 2px solid #000000 }
7 .invoice_summary TD { font-size: 10pt; empty-cells: show }
8 .invoice_longtable table { cellspacing: none }
9 .invoice_longtable TH { border-top: 2px solid #000000; border-bottom: 1px solid #000000; padding-left: none; padding-right: none; font-size: 10pt }
10 .invoice_desc TD { border-top: 2px solid #000000; font-weight: bold; font-size: 10pt }
11 .invoice_desc_more TD { font-weight: bold; font-size: 10pt }
12 .invoice_extdesc TD { font-size: 8pt }
13 .invoice_totaldesc TD { font-size: 10pt; empty-cells: show }
16 <table class="invoice" bgcolor="#ffffff" WIDTH=625 CELLSPACING=8><tr><td>
18 <table class="invoice_header" width="100%">
20 <td><img src="<%= $cid ? "cid:$cid" : "cust_bill-logo.cgi?invnum=$invnum;template=$template" %>"></td>
21 <td align="left"><%= $returnaddress %></td>
23 <table CLASS="invoice_headerright" cellspacing=0>
39 <B><%= $custnum %></B>
44 <th colspan=3 align="center">
45 <FONT SIZE="+3"><%= $notice_name ? substr($notice_name, 0, 1) : 'I' %></FONT><FONT SIZE="+2"><%= $notice_name ? uc(substr($notice_name, 1)) : 'NVOICE' %></FONT>
57 <b><%= $payname %></b><BR>
58 <%= join('<BR>', grep length($_), $company,
61 "$city, $state $zip",
66 <%= $ship_enable ? ('<td align="left">'.
67 join('<BR>',grep length($_), '<b>Service Address</b>',
71 "$ship_city, $ship_state $ship_zip",
76 '</td><tr><td></td><td></td>'
83 $OUT .= qq! <img src="cid:$barcode_cid"><br> !;
86 $OUT .= qq! <img src="cust_bill-barcode.cgi?invnum=$invnum;template=$template"><br> !;
89 Terms: <%= $terms %><BR>
98 my $columncount = $unitprices ? 5 : 3;
99 foreach my $section ( grep { !$summary || $_->{description} ne $finance_section } @sections ) {
100 if ($section->{'pretotal'} && !$summary) {
101 $OUT .= '</table>' if $notfirst;
103 '<table width="100%"><tr><td>'.
104 '<p align="right"><b><font size="+1">'.
105 uc(substr($section->{'pretotal'},0,1)).
106 '</font><font size="+0">'. uc(substr($section->{'pretotal'},1)).
111 unless ($section->{'summarized'}) {
112 $OUT .= '</table>' if ( $notfirst || $section->{'pretotal'} && !$summary );
113 $OUT .= '<table><tr><td>';
114 if ($section->{'description'}) {
116 '<p><b><font size="+1">'. uc(substr($section->{'description'},0,1)).
117 '</font><font size="+0">'. uc(substr($section->{'description'},1)).
122 '<p><b><font size="+1">C</font><font size="+0">HARGES</font></b>'.
125 $OUT .= '</td></tr></table>';
128 '<table class="invoice_longtable" CELLSPACING=0 WIDTH="100%">'.
131 if ($section->{header_generator}) {
132 my $header = &{$section->{header_generator}}();
134 $columncount = scalar(my @array = split /<\/th><th/i, $header);
136 $OUT .= '<th align="center">Ref</th>'.
137 '<th align="left">Description</th>'.
139 ? '<th align="left">Unit Price</th>'.
140 '<th align="left">Quantity</th>'
143 '<th align="right">Amount</th>';
149 grep { ( scalar(@sections) > 1
150 ? $section->{'description'} eq $_->{'section'}->{'description'}
156 '<tr class="invoice_desc';
157 if ( $section->{description_generator} ) {
158 $OUT .= &{$section->{description_generator}}($line);
160 $OUT .= ( ($line->{'ref'} && $line->{'ref'} ne $lastref) ? '' : '_more' ).
162 '<td align="center">'.
163 ( $line->{'ref'} ne $lastref ? $line->{'ref'} : '' ). '</td>'.
164 '<td align="left">'. $line->{'description'}. '</td>'.
166 ? '<td align="left">'. $line->{'unit_amount'}. '</td>'.
167 '<td align="left">'. $line->{'quantity'}. '</td>'
171 '<td align="right">'. $line->{'amount'}. '</td>';
174 $lastref = $line->{'ref'};
175 if ( @{$line->{'ext_description'} } ) {
176 unless ( $section->{description_generator} ) {
177 $OUT .= '<tr class="invoice_extdesc"><td></td><td';
178 $OUT .= $unitprices ? ' colspan=3' : '';
179 $OUT .= '><table width="100%">';
181 foreach my $ext_desc ( @{$line->{'ext_description'} } ) {
183 '<tr class="invoice_extdesc">'.
184 ( $section->{'description_generator'} ? '<td></td>' : '' ).
186 ( $ext_desc =~ /<\/?TD>/i ? '' : 'colspan=99' ). '>'.
187 ' '. $ext_desc.
191 unless ( $section->{description_generator} ) {
192 $OUT .= '</table></td><td></td>';
199 if ($section->{'description'} || $multisection) {
200 my $style = 'border-top: 3px solid #000000;'.
201 'border-bottom: 3px solid #000000;';
203 '<tr class="invoice_totaldesc">'.
204 qq(<td style="$style"> </td>);
205 if ($section->{total_generator}) {
206 $OUT .= &{$section->{total_generator}}($section);
208 $OUT .= qq(<td align="left" style="$style").
209 ( $unitprices ? ' colspan=3>' : '>' ).
210 $section->{'description'}. ' Total </td>'.
211 qq(<td align="right" style="$style">).
212 $section->{'subtotal'}. '</td>';
217 if ($section->{'posttotal'}) {
218 $OUT .= '<tr><td align="right" colspan='. $columncount. '>';
220 '<p><font size="+1">'. $section->{'posttotal'}.
223 $OUT .= '</td></tr>';
230 my $style = 'border-top: 3px solid #000000;';
233 foreach my $line ( @total_items ) {
235 $style .= 'border-bottom: 3px solid #000000;'
236 if ++$linenum == scalar(@total_items) - ( $balance_due_below_line ? 1 : 0 );
239 '<tr class="invoice_totaldesc">';
240 if ($section->{total_line_generator}) {
241 $OUT .= &{$section->{total_line_generator}}($line);
243 $OUT .= qq(<td style="$style"> </td>).
244 qq(<td align="left" style="$style" colspan=").
245 ( $columncount - 2 ). '">'.
246 $line->{'total_item'}. '</td>'.
247 qq(<td align="right" style="$style">).
248 $line->{'total_amount'}. '</td>';
263 ? '<FONT SIZE="-1">'.$notes.'</FONT>'
268 <hr NOSHADE SIZE=2 COLOR="#000000">
269 <p align="center" <%= $smallerfooter ? 'STYLE="font-size:75%;"' : '' %>><%= $footer %>