X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FHelper%2FCreatePDF.pm;h=8d36eb74920a1871460e139379e8082bb7618b4b;hb=fb03d191f53516cbf1022e755665556e7f1acb82;hp=92349d4d6c2ad4d075e070c81484dbb8943297ec;hpb=7d993563e3e5f2dc4f6f98c837a6f172c7edd3e1;p=kivitendo-erp.git diff --git a/SL/Helper/CreatePDF.pm b/SL/Helper/CreatePDF.pm index 92349d4d6..8d36eb749 100644 --- a/SL/Helper/CreatePDF.pm +++ b/SL/Helper/CreatePDF.pm @@ -2,20 +2,25 @@ package SL::Helper::CreatePDF; use strict; +use Carp; use Cwd; use English qw(-no_match_vars); use File::Slurp (); use File::Temp (); +use List::MoreUtils qw(uniq); +use List::Util qw(first); use String::ShellQuote (); use SL::Form; use SL::Common; +use SL::DB::Language; +use SL::DB::Printer; use SL::MoreCommon; use SL::Template; use SL::Template::LaTeX; use Exporter 'import'; -our @EXPORT_OK = qw(create_pdf merge_pdfs); +our @EXPORT_OK = qw(create_pdf merge_pdfs find_template); our %EXPORT_TAGS = ( all => \@EXPORT_OK, ); @@ -28,8 +33,9 @@ sub create_pdf { $form->{format} = 'pdf'; $form->{cwd} = getcwd(); $form->{templates} = $::instance_conf->get_templates; - $form->{IN} = $params{template} . '.tex'; + $form->{IN} = $params{template}; $form->{tmpdir} = $form->{cwd} . '/' . $userspath; + my ($suffix) = $params{template} =~ m{\.(.+)}; my $vars = $params{variables} || {}; $form->{$_} = $vars->{$_} for keys %{ $vars }; @@ -37,7 +43,7 @@ sub create_pdf { my $temp_fh; ($temp_fh, $form->{tmpfile}) = File::Temp::tempfile( 'kivitendo-printXXXXXX', - SUFFIX => '.tex', + SUFFIX => ".${suffix}", DIR => $userspath, UNLINK => ($::lx_office_conf{debug} && $::lx_office_conf{debug}->{keep_temp_files})? 0 : 1, ); @@ -98,4 +104,184 @@ sub merge_pdfs { return scalar File::Slurp::read_file($temp_name); } +sub find_template { + my ($class, %params) = @_; + + $params{name} or croak "Missing parameter 'name'"; + + my $path = $::instance_conf->get_templates; + my $extension = $params{extension} || "tex"; + my ($printer, $language) = ('', ''); + + if ($params{printer} || $params{printer_id}) { + if ($params{printer} && !ref $params{printer}) { + $printer = '_' . $params{printer}; + } else { + $printer = $params{printer} || SL::DB::Printer->new(id => $params{printer_id})->load; + $printer = $printer->template_code ? '_' . $printer->template_code : ''; + } + } + + if ($params{language} || $params{language_id}) { + if ($params{language} && !ref $params{language}) { + $language = '_' . $params{language}; + } else { + $language = $params{language} || SL::DB::Language->new(id => $params{language_id})->load; + $language = $language->template_code ? '_' . $language->template_code : ''; + } + } + + my @template_files = ( + $params{name} . "${language}${printer}", + $params{name} . "${language}", + $params{name}, + "default", + ); + + if ($params{email}) { + unshift @template_files, ( + $params{name} . "_email${language}${printer}", + $params{name} . "_email${language}", + ); + } + + @template_files = map { "${_}.${extension}" } uniq grep { $_ } @template_files; + + my $template = first { -f ($path . "/$_") } @template_files; + + return wantarray ? ($template, @template_files) : $template; +} + 1; +__END__ + +=pod + +=encoding utf8 + +=head1 NAME + +SL::Helper::CreatePDF - A helper for creating PDFs from template files + +=head1 SYNOPSIS + + # Retrieve a sales order from the database and create a PDF for + # it: + my $order = SL::DB::Order->new(id => …)->load; + my $print_form = Form->new(''); + $print_form->{type} = 'invoice'; + $print_form->{formname} = 'invoice', + $print_form->{format} = 'pdf', + $print_form->{media} = 'file'; + + $order->flatten_to_form($print_form, format_amounts => 1); + $print_form->prepare_for_printing; + + my $pdf = SL::Helper::CreatePDF->create_pdf( + template => 'sales_order', + variables => $print_form, + ); + +=head1 FUNCTIONS + +=over 4 + +=item C + +Parses a LaTeX template file, creates a PDF for it and returns either +its content or its file name. The recognized parameters are: + +=over 2 + +=item * C