X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=conf%2Finvoice_latex;h=37f59d2eec644bde416469dc8deecfe26bcecd23;hp=d819160195eb9260fc3f2f914f26521ee49752e2;hb=62b12e8b09608b7081ffd596be899fafb5c2403f;hpb=9c42579467b332e5b188c75e5acb109eb33b7297 diff --git a/conf/invoice_latex b/conf/invoice_latex index d81916019..37f59d2ee 100644 --- a/conf/invoice_latex +++ b/conf/invoice_latex @@ -19,19 +19,21 @@ \documentclass[letterpaper]{article} -\usepackage{fancyhdr,lastpage,ifthen,longtable,afterpage,caption,multirow,bigstrut} +\usepackage{fancyhdr,lastpage,ifthen,array,fslongtable,afterpage,caption,multirow,bigstrut} \usepackage{graphicx} % required for logo graphic +\usepackage[utf8]{inputenc} % multilanguage support +\usepackage[T1]{fontenc} \addtolength{\voffset}{-0.0cm} % top margin to top of header \addtolength{\hoffset}{-0.6cm} % left margin on page -\addtolength{\topmargin}{-1.25cm} % top margin to top of header +\addtolength{\topmargin}{[@-- defined($topmargin) ? $topmargin : '-1.25cm' --@]} \setlength{\headheight}{2.0cm} % height of header -\setlength{\headsep}{1.0cm} % between header and text +\setlength{\headsep}{[@-- defined($headsep) ? $headsep : '1.0cm' --@]} \setlength{\footskip}{1.0cm} % bottom of footer from bottom of text %\addtolength{\textwidth}{2.1in} % width of text \setlength{\textwidth}{19.5cm} -\setlength{\textheight}{19.5cm} +\setlength{\textheight}{[@-- defined($textheight) ? $textheight : '19.5cm' --@]} \setlength{\oddsidemargin}{-0.9cm} % odd page left margin \setlength{\evensidemargin}{-0.9cm} % even page left margin @@ -51,7 +53,7 @@ } } -\newcommand{\extracouponspace}{3.6cm} +\newcommand{\extracouponspace}{[@-- defined($extracouponspace) ? $extracouponspace : '3.6cm' --@]} % Adjust the inset of the mailing address \newcommand{\addressinset}[1][]{\hspace{1.0cm}} @@ -80,14 +82,15 @@ $OUT .= '\vspace{-\extracouponspace}'; $OUT .= '\rule[0.5em]{\textwidth}{\footrulewidth}\\\\'; $OUT .= $coupon; + $OUT .= '\vspace{'. $couponfootsep. '}' if defined($couponfootsep); } ''; ---@] \small{ +--@] [@-- $smallerfooter ? '\scriptsize{' : '\small{' --@] [@-- $footer --@] }[@-- $coupon ? '\vspace{\extracouponspace}' : '' --@] } { % ... pages - \small{ + [@-- $smallerfooter ? '\scriptsize{' : '\small{' --@] [@-- $smallfooter --@] } } @@ -108,10 +111,10 @@ \returninset \makebox{ \begin{tabular}{ll} - \includegraphics{[@-- $logo_file --@]} & + \includegraphics{[@-- $logo_file --@]} & [@-- $verticalreturnaddress ? '\\\\' : '' --@] \begin{minipage}[b]{5.5cm} [@-- $returnaddress --@] - \end{minipage} + \end{minipage}\\ \end{tabular} } } @@ -124,10 +127,10 @@ \ifthenelse{\equal{\thepage}{1}} { % First page \begin{tabular}{ccc} - Invoice date & Invoice \#& Customer\#\\ + [@-- join(' & ', emt('Invoice date'), emt('Invoice #'), emt('Customer #') ) --@]\\ \vspace{0.2cm} \textbf{[@-- $date --@]} & \textbf{[@-- $invnum --@]} & \textbf{[@-- $custnum --@]} \\\hline - \rule{0pt}{5ex} &~~ \huge{\textsc{Invoice}} & \\ + \rule{0pt}{5ex} &~~ \huge{\textsc{[@-- emt($notice_name) --@]}} & \\ \vspace{-0.2cm} & & \\\hline \end{tabular} @@ -135,7 +138,7 @@ { % ... pages \small{ \begin{tabular}{lll} - Invoice date & Invoice \#& Customer\#\\ + [@-- join(' & ', emt('Invoice date'), emt('Invoice #'), emt('Customer #') ) --@]\\ \textbf{[@-- $date --@]} & \textbf{[@-- $invnum --@]} & \textbf{[@-- $custnum --@]}\\ \end{tabular} } @@ -157,26 +160,32 @@ % Commands for freeside table header... + +\newcommand{\FSdescriptionlength} { [@-- $unitprices ? '8.2cm' : '12.8cm' --@] } +\newcommand{\FSdescriptioncolumncount} { [@-- $unitprices ? '4' : '6' --@] } +\newcommand{\FSunitcolumns}{ [@-- + $unitprices + ? '\makebox[2.5cm][l]{\textbf{~~'.emt('Unit Price').'}}&\makebox[1.4cm]{\textbf{~'.emt('Quantity').'}}&' + : '' --@] } + \newcommand{\FShead}{ \hline \rule{0pt}{2.5ex} \makebox[1.4cm]{\textbf{Ref}} & - \makebox[2.9cm][l]{\textbf{Description}}& - \makebox[1.4cm][l]{}& - \makebox[1.4cm][l]{}& - \makebox[2.5cm][l]{}& - \makebox[2.5cm][l]{\textbf{[@-- $unitprices ? '~~Unit Price' : '' --@]}}& - \makebox[1.4cm]{\textbf{[@-- $unitprices ? '~Quantity' : '' --@]}}& - \makebox[1.6cm][r]{\textbf{Amount}} \\ + \multicolumn{\FSdescriptioncolumncount}{l}{\makebox[\FSdescriptionlength][l]{\textbf{[@-- emt('Description') --@]}}}& + \FSunitcolumns + \makebox[1.6cm][r]{\textbf{[@-- emt('Amount') --@]}} \\ \hline } % ...description... \newcommand{\FSdesc}[5]{ \multicolumn{1}{c}{\rule{0pt}{2.5ex}\textbf{#1}} & - \multicolumn{4}{l}{\textbf{#2}} & - \multicolumn{1}{l}{\textbf{#3}} & - \multicolumn{1}{r}{\textbf{#4}} & + \multicolumn{[@-- $unitprices ? '4' : '6' --@]}{l}{\textbf{#2}} & +[@-- $unitprices ? ' \multicolumn{1}{l}{\textbf{#3}} &'."\n". + ' \multicolumn{1}{r}{\textbf{#4}} &'."\n" + : '' +--@] \multicolumn{1}{r}{\textbf{\dollar #5}}\\ } % ...extended description... @@ -192,23 +201,11 @@ \begin{document} -% -%% Headers and footers defined for the first page -% -%% The LH Heading comprising logo -%% UNCOMMENT the following FOUR lines and change the path if necssary to provide a logo -% -%% The Heading comprising isue date, customer ref & INVOICE name -% -%% Header & footer changes for subsequent pages -% -% -% -[@-- $coupon ? '\enlargethispage{-\extracouponspace}' : '' --@] +% Headers and footers defined for the first page \addressinset \rule{0.5cm}{0cm} \makebox{ -\begin{minipage}[t]{5.0cm} -\vspace{0.25cm} +\begin{minipage}[t]{7.0cm} +\vspace{[@-- defined($addresssep) ? $addresssep : '0.25cm' --@]} \textbf{[@-- $payname --@]}\\ \addressline{[@-- $company --@]} \addressline{[@-- $address1 --@]} @@ -221,104 +218,128 @@ \begin{minipage}[t]{6.4cm} [@-- if ($ship_enable) { - $OUT .= '\textbf{Service Address}\\\\'; + $OUT .= '\textbf{' . emt('Service Address') . '}\\\\'; $OUT .= "\\addressline{$ship_company}"; $OUT .= "\\addressline{$ship_address1}"; $OUT .= "\\addressline{$ship_address2}"; $OUT .= "\\addressline{$ship_city, $ship_state~~$ship_zip}"; $OUT .= "\\addressline{$ship_country}"; $OUT .= '~\\\\'; - $OUT .= "\\textbf{ID:}~~$agent_custid\\\\" if $agent_custid; - $OUT .= "\\textbf{Fax:}~~$ship_fax\\\\" if $ship_fax; - $OUT .= '~\\\\' if ($ship_fax or $agent_custid); }else{ $OUT .= ''; } --@] \begin{flushright} -Terms: [@-- $terms --@]\\ +[@-- $terms ? emt('Terms') .": $terms" : '' --@]\\ [@-- $po_line --@]\\ \end{flushright} \end{minipage}} \vspace{1.5cm} % +[@-- $summary --@] +% \section*{} [@-- - foreach my $section ( @sections ) { - if ($section->{'pretotal'}) { + foreach my $section ( grep { !$summary || $_->{description} ne $finance_section } @sections ) { + if ($section->{'pretotal'} && !$summary) { $OUT .= '\begin{flushright}'; $OUT .= '\large\textsc{'. $section->{'pretotal'}. '}\\\\'; $OUT .= '\\end{flushright}'; } - $OUT .= '\pagebreak' if $section{'post_total'}; - $OUT .= '\captionsetup{singlelinecheck=false,justification=raggedright,font={Large,sc,bf}}'; - $OUT .= '\ifthenelse{\equal{\thepage}{1}}{\setlength{\LTextracouponspace}{\extracouponspace}}{\setlength{\LTextracouponspace}{0pt}}' - if $coupon; - $OUT .= '\begin{longtable}{cllllllr}'; - $OUT .= '\caption*{ '; - $OUT .= ($section->{'description'}) ? $section->{'description'}: 'Charges'; - $OUT .= '}\\\\'; - $OUT .= '\FShead'; - $OUT .= '\endfirsthead'; - $OUT .= '\multicolumn{7}{r}{\rule{0pt}{2.5ex}Continued from previous page}\\\\'; - $OUT .= '\FShead'; - $OUT .= '\endhead'; - $OUT .= '\multicolumn{7}{r}{\rule{0pt}{2.5ex}Continued on next page...}\\\\'; - $OUT .= '\endfoot'; - $OUT .= '\hline'; - - if (scalar(@sections) > 1) { - $OUT .= '\FStotaldesc{' . $section->{'description'} . ' Total}' . - '{' . $section->{'subtotal'} . '}' . "\n"; - } - - #if ($section == $sections[$#sections]) { - foreach my $line (grep {$_->{section}->{description} eq $section->{description}} @total_items) { - $OUT .= '\FStotaldesc{' . $line->{'total_item'} . '}' . - '{' . $line->{'total_amount'} . '}' . "\n"; + $OUT .= '\pagebreak' if $section->{'post_total'}; + unless ($section->{'summarized'} ) { + $OUT .= '\captionsetup{singlelinecheck=false,justification=raggedright,font={Large,sc,bf}}'; + $OUT .= '\ifthenelse{\equal{\thepage}{1}}{\setlength{\LTextracouponspace}{\extracouponspace}}{\setlength{\LTextracouponspace}{0pt}}' + if $coupon; + $OUT .= '\begin{longtable}{cllllllr}'; + $OUT .= '\caption*{ '; + $OUT .= ($section->{'description'}) ? $section->{'description'}: emt('Charges'); + $OUT .= '}\\\\'; + if ($section->{header_generator}) { + $OUT .= &{$section->{header_generator}}(); + } else { + $OUT .= '\FShead'; + } + $OUT .= '\endfirsthead'; + $OUT .= '\multicolumn{7}{r}{\rule{0pt}{2.5ex}'.emt('Continued from previous page').'}\\\\'; + if ($section->{header_generator}) { + $OUT .= &{$section->{header_generator}}(); + } else { + $OUT .= '\FShead'; } - #} - - $OUT .= '\hline'; - $OUT .= '\endlastfoot'; - - my $lastref = 0; - foreach my $line ( - grep { ( scalar( @sections ) > 1 - ? $section->{'description'} eq $_->{'section'}->{'description'} - : 1 - ) } - @detail_items ) - { - my $ext_description = $line->{'ext_description'}; + $OUT .= '\endhead'; + $OUT .= '\multicolumn{7}{r}{\rule{0pt}{2.5ex}'.emt('Continued on next page...').'}\\\\'; + $OUT .= '\endfoot'; + $OUT .= '\hline'; + + if (scalar(@sections) > 1) { + if ($section->{total_generator}) { + $OUT .= &{$section->{total_generator}}($section); + } else { + $OUT .= '\FStotaldesc{' . $section->{'description'} . ' Total}' . + '{' . $section->{'subtotal'} . '}' . "\n"; + } + } + + #if ($section == $sections[$#sections]) { + foreach my $line (grep {$_->{section}->{description} eq $section->{description}} @total_items) { + if ($section->{total_line_generator}) { + $OUT .= &{$section->{total_line_generator}}($line); + } else { + $OUT .= '\FStotaldesc{' . $line->{'total_item'} . '}' . + '{' . $line->{'total_amount'} . '}' . "\n"; + } + } + #} + + $OUT .= '\hline'; + $OUT .= '\endlastfoot'; + + my $lastref = 0; + foreach my $line ( + grep { ( scalar( @sections ) > 1 + ? $section->{'description'} eq $_->{'section'}->{'description'} + : 1 + ) } + @detail_items ) + { + my $ext_description = $line->{'ext_description'}; - # Don't break-up small packages. - my $rowbreak = @$ext_description < 5 ? '*' : ''; + # Don't break-up small packages. + my $rowbreak = @$ext_description < 5 ? '*' : ''; - $OUT .= "\\hline\n" if ($line->{'ref'} && $line->{'ref'} ne $lastref); - $OUT .= '\FSdesc'. - '{' . ( $line->{'ref'} ne $lastref ? $line->{'ref'} : '' ) . '}'. - '{' . $line->{'description'} . '}' . - '{' . ( $unitprices ? $line->{'unit_amount'} : '' ) . '}'. - '{' . ( $unitprices ? $line->{'quantity'} : '' ) . '}' . - '{' . $line->{'amount'} . "}${rowbreak}\n"; - $lastref = $line->{'ref'}; - - foreach my $ext_desc (@$ext_description) { - if ( $ext_desc !~ /[^\\]&/ ) { - $ext_desc = substr($ext_desc, 0, 80) . '...' - if (length($ext_desc) > 80); - $ext_desc = '\multicolumn{6}{l}{\small{~~~'. $ext_desc. '}}'; - }else{ - $ext_desc = "~~~$ext_desc"; + $OUT .= "\\hline\n" if ($line->{'ref'} && $line->{'ref'} ne $lastref); + if ($section->{description_generator}) { + $OUT .= &{$section->{description_generator}}($line); + } else { + $OUT .= '\FSdesc'. + '{' . ( $line->{'ref'} ne $lastref ? $line->{'ref'} : '' ) . '}'. + '{' . $line->{'description'} . '}' . + '{' . ( $unitprices ? $line->{'unit_amount'} : '' ) . '}'. + '{' . ( $unitprices ? $line->{'quantity'} : '' ) . '}' . + '{' . $line->{'amount'} . "}${rowbreak}\n"; + } + $lastref = $line->{'ref'}; + + foreach my $ext_desc (@$ext_description) { + if ($section->{extended_description_generator}) { + $OUT .= &{$section->{extended_description_generator}}($ext_desc); + } else { + if ( $ext_desc !~ /[^\\]&/ ) { + $ext_desc = substr($ext_desc, 0, 80) . '...' + if (length($ext_desc) > 80); + $ext_desc = '\multicolumn{6}{l}{\small{~~~'. $ext_desc. '}}'; + }else{ + $ext_desc = "~~~$ext_desc"; + } + $OUT .= '\FSextdesc{' . $ext_desc . '}' . "${rowbreak}\n"; + } } - $OUT .= '\FSextdesc{' . $ext_desc . '}' . "${rowbreak}\n"; + } + $OUT .= '\end{longtable}'; } - - $OUT .= '\end{longtable}'; - if ($section->{'posttotal'}) { $OUT .= '\begin{flushright}'; $OUT .= '\normalfont\large\bfseries\textsc{'. $section->{'posttotal'}. '}\\\\'; @@ -328,5 +349,14 @@ Terms: [@-- $terms --@]\\ --@] \vfill -[@-- $notes --@] +\begin{minipage}[t]{\textwidth} + [@-- length($summary) + ? '' + : ( $smallernotes + ? '\scriptsize{ '.$notes.' }' + : $notes + ) + --@] + [@-- $coupon ? '\ifthenelse{\equal{\thepage}{1}}{\rule{0pt}{\extracouponspace}}{}' : '' --@] +\end{minipage} \end{document}