From 6d941605418127b82d3eb1c4b6ee96b63deca94f Mon Sep 17 00:00:00 2001 From: Kyle M Hall Date: Fri, 15 Mar 2024 11:49:34 +0000 Subject: [PATCH] Bug 33393: tidy layout1page.pm Signed-off-by: Kyle M Hall Signed-off-by: Katrin Fischer --- Koha/pdfformat/layout1page.pm | 217 ++++++++++++++++++---------------- 1 file changed, 118 insertions(+), 99 deletions(-) diff --git a/Koha/pdfformat/layout1page.pm b/Koha/pdfformat/layout1page.pm index 7539543117..b7e42ec6ef 100644 --- a/Koha/pdfformat/layout1page.pm +++ b/Koha/pdfformat/layout1page.pm @@ -27,13 +27,12 @@ use Koha::DateUtils qw( dt_from_string output_pref ); use Koha::Libraries; BEGIN { - use Exporter (); - our (@ISA, @EXPORT, @EXPORT_OK, %EXPORT_TAGS); + use Exporter (); + our ( @ISA, @EXPORT, @EXPORT_OK, %EXPORT_TAGS ); @ISA = qw(Exporter); @EXPORT = qw(printpdf); } - #be careful, all the sizes (height, width, etc...) are in mm, not PostScript points (the default measurement of PDF::API2). #The constants exported transform that into PostScript points (/mm for millimeter, /in for inch, pt is postscript point, and as so is there only to show what is happening. use constant mm => 25.4 / 72; @@ -41,85 +40,96 @@ use constant in => 1 / 72; use constant pt => 1; use PDF::API2; + #A4 paper specs -my ($height, $width) = (297, 210); +my ( $height, $width ) = ( 297, 210 ); use PDF::Table; sub printorders { - my ($pdf, $basketgroup, $baskets, $orders) = @_; + my ( $pdf, $basketgroup, $baskets, $orders ) = @_; my $cur_format = C4::Context->preference("CurrencyFormat"); - $pdf->mediabox($height/mm, $width/mm); + $pdf->mediabox( $height / mm, $width / mm ); my $page = $pdf->openpage(1); my $pdftable = PDF::Table->new(); my $abaskets; my $arrbasket; - my @keys = ('Qty', 'Document', 'RRP tax inc.', 'Discount', 'Tax', 'Total tax exc.', 'Total tax inc.'); + my @keys = ( 'Qty', 'Document', 'RRP tax inc.', 'Discount', 'Tax', 'Total tax exc.', 'Total tax inc.' ); for my $bkey (@keys) { - push(@$arrbasket, $bkey); + push( @$arrbasket, $bkey ); } - push(@$abaskets, $arrbasket); + push( @$abaskets, $arrbasket ); my $titleinfo; - for my $basket (@$baskets){ - for my $line (@{$orders->{$basket->{basketno}}}) { + for my $basket (@$baskets) { + for my $line ( @{ $orders->{ $basket->{basketno} } } ) { $arrbasket = undef; $titleinfo = ""; if ( C4::Context->preference("marcflavour") eq 'UNIMARC' ) { - $titleinfo = $line->{title} . " / " . $line->{author} . - ( $line->{isbn} ? " ISBN: " . $line->{isbn} : '' ) . - ( $line->{en} ? " EN: " . $line->{en} : '' ) . - ( $line->{itemtype} ? ", " . $line->{itemtype} : '' ) . - ( $line->{edition} ? ", " . $line->{edition} : '' ) . - ( $line->{publishercode} ? ' published by '. $line->{publishercode} : '') . - ( $line->{publicationyear} ? ', '. $line->{publicationyear} : ''); + $titleinfo = + $line->{title} . " / " + . $line->{author} + . ( $line->{isbn} ? " ISBN: " . $line->{isbn} : '' ) + . ( $line->{en} ? " EN: " . $line->{en} : '' ) + . ( $line->{itemtype} ? ", " . $line->{itemtype} : '' ) + . ( $line->{edition} ? ", " . $line->{edition} : '' ) + . ( $line->{publishercode} ? ' published by ' . $line->{publishercode} : '' ) + . ( $line->{publicationyear} ? ', ' . $line->{publicationyear} : '' ); + } else { # MARC21 + $titleinfo = + $line->{title} . " " + . $line->{author} + . ( $line->{isbn} ? " ISBN: " . $line->{isbn} : '' ) + . ( $line->{en} ? " EN: " . $line->{en} : '' ) + . ( $line->{itemtype} ? " " . $line->{itemtype} : '' ) + . ( $line->{edition} ? ", " . $line->{edition} : '' ) + . ( $line->{publishercode} ? ' published by ' . $line->{publishercode} : '' ) + . ( $line->{copyrightdate} ? ' ' . $line->{copyrightdate} : '' ); } - else { # MARC21 - $titleinfo = $line->{title} . " " . $line->{author} . - ( $line->{isbn} ? " ISBN: " . $line->{isbn} : '' ) . - ( $line->{en} ? " EN: " . $line->{en} : '' ) . - ( $line->{itemtype} ? " " . $line->{itemtype} : '' ) . - ( $line->{edition} ? ", " . $line->{edition} : '' ) . - ( $line->{publishercode} ? ' published by '. $line->{publishercode} : '') . - ( $line->{copyrightdate} ? ' '. $line->{copyrightdate} : ''); - } - push( @$arrbasket, + push( + @$arrbasket, $line->{quantity}, - $titleinfo. ($line->{order_vendornote} ? "\n----------------\nNote for vendor: " . $line->{order_vendornote} : '' ), + $titleinfo + . ( + $line->{order_vendornote} + ? "\n----------------\nNote for vendor: " . $line->{order_vendornote} + : '' + ), Koha::Number::Price->new( $line->{rrp_tax_included} )->format, Koha::Number::Price->new( $line->{discount} )->format . '%', Koha::Number::Price->new( $line->{tax_rate} * 100 )->format . '%', Koha::Number::Price->new( $line->{total_tax_excluded} )->format, Koha::Number::Price->new( $line->{total_tax_included} )->format, ); - push(@$abaskets, $arrbasket); + push( @$abaskets, $arrbasket ); } } - $pdftable->table($pdf, $page, $abaskets, - x => 10/mm, - w => ($width - 20)/mm, - start_y => 170/mm, - next_y => 280/mm, - start_h => 150/mm, - next_h => 260/mm, - padding => 5, - padding_right => 5, - background_color_odd => "lightgray", - font => $pdf->corefont("Times", -encoding => "utf8"), - font_size => 3/mm, - header_props => { - font => $pdf->corefont("Times", -encoding => "utf8"), - font_size => 10, - bg_color => 'gray', - repeat => 1, + $pdftable->table( + $pdf, $page, $abaskets, + x => 10 / mm, + w => ( $width - 20 ) / mm, + start_y => 170 / mm, + next_y => 280 / mm, + start_h => 150 / mm, + next_h => 260 / mm, + padding => 5, + padding_right => 5, + background_color_odd => "lightgray", + font => $pdf->corefont( "Times", -encoding => "utf8" ), + font_size => 3 / mm, + header_props => { + font => $pdf->corefont( "Times", -encoding => "utf8" ), + font_size => 10, + bg_color => 'gray', + repeat => 1, }, column_props => [ - { justify => 'left' }, - { min_w => 90/mm }, + { justify => 'left' }, + { min_w => 90 / mm }, { justify => 'right' }, { justify => 'right' }, { justify => 'right' }, @@ -129,79 +139,79 @@ sub printorders { ], ); - $pdf->mediabox($width/mm, $height/mm); + $pdf->mediabox( $width / mm, $height / mm ); } sub printhead { - my ($pdf, $basketgroup, $bookseller) = @_; + my ( $pdf, $basketgroup, $bookseller ) = @_; # get library name - my $libraryname = C4::Context->preference("LibraryName"); - my $billing_library = Koha::Libraries->find( $basketgroup->{billingplace} ); - my $delivery_library = Koha::Libraries->find( $basketgroup->{deliveryplace} ); + my $libraryname = C4::Context->preference("LibraryName"); + my $billing_library = Koha::Libraries->find( $basketgroup->{billingplace} ); + my $delivery_library = Koha::Libraries->find( $basketgroup->{deliveryplace} ); my $freedeliveryplace = $basketgroup->{freedeliveryplace}; - my $ordersentences = C4::Context->preference("1PageOrderPDFText"); + my $ordersentences = C4::Context->preference("1PageOrderPDFText"); # open 1st page (with the header) my $page = $pdf->openpage(1); # create a text my $text = $page->text; - $text->font( $pdf->corefont("Times", -encoding => "utf8"), 4/mm ); + $text->font( $pdf->corefont( "Times", -encoding => "utf8" ), 4 / mm ); # print order info, on the default PDF - $text->translate(42/mm, ($height-62)/mm); - $text->text($basketgroup->{'id'}); + $text->translate( 42 / mm, ( $height - 62 ) / mm ); + $text->text( $basketgroup->{'id'} ); # print the date - my $today = output_pref({ dt => dt_from_string, dateonly => 1 }); - $text->translate(41/mm, ($height-67)/mm); + my $today = output_pref( { dt => dt_from_string, dateonly => 1 } ); + $text->translate( 41 / mm, ( $height - 67 ) / mm ); $text->text($today); # print billing infos - $text->font( $pdf->corefont("Times-Bold", -encoding => "utf8"), 4/mm ); - $text->translate(107/mm, ($height-67)/mm); + $text->font( $pdf->corefont( "Times-Bold", -encoding => "utf8" ), 4 / mm ); + $text->translate( 107 / mm, ( $height - 67 ) / mm ); $text->text($libraryname); # print text defined in 1PageOrderPDFText syspref - $text->font( $pdf->corefont("Times", -encoding => "utf8"), 4/mm ); - my @allLines = split/\n+/, $ordersentences; - my $count = 0; - foreach my $ordersentence ( @allLines ) { - $count+=4; - $text->translate(15/mm, ($height-(105 + $count ))/mm); - $text->text( $ordersentence ); + $text->font( $pdf->corefont( "Times", -encoding => "utf8" ), 4 / mm ); + my @allLines = split /\n+/, $ordersentences; + my $count = 0; + foreach my $ordersentence (@allLines) { + $count += 4; + $text->translate( 15 / mm, ( $height - ( 105 + $count ) ) / mm ); + $text->text($ordersentence); } - $text->font( $pdf->corefont("Times", -encoding => "utf8"), 4/mm ); - $text->translate(107/mm, ($height-71)/mm); - $text->text($billing_library->branchname); - $text->translate(116/mm, ($height-97)/mm); - $text->text($billing_library->branchphone); - $text->translate(155/mm, ($height-97)/mm); - $text->text($billing_library->branchfax); + $text->font( $pdf->corefont( "Times", -encoding => "utf8" ), 4 / mm ); + $text->translate( 107 / mm, ( $height - 71 ) / mm ); + $text->text( $billing_library->branchname ); + $text->translate( 116 / mm, ( $height - 97 ) / mm ); + $text->text( $billing_library->branchphone ); + $text->translate( 155 / mm, ( $height - 97 ) / mm ); + $text->text( $billing_library->branchfax ); # print bookseller infos - $text->translate(20/mm, ($height-33)/mm); - $text->text($bookseller->name); - $text->translate(20/mm, ($height-37)/mm); + $text->translate( 20 / mm, ( $height - 33 ) / mm ); + $text->text( $bookseller->name ); + $text->translate( 20 / mm, ( $height - 37 ) / mm ); if ( $bookseller->postal ) { - my $start = 41; - my @postal = split('\n', $bookseller->postal); + my $start = 41; + my @postal = split( '\n', $bookseller->postal ); foreach (@postal) { $text->text($_); $text->translate( 20 / mm, ( $height - $start ) / mm ); $start += 4; } } - $text->translate(20/mm, ($height-57)/mm); - $text->text($bookseller->accountnumber); + $text->translate( 20 / mm, ( $height - 57 ) / mm ); + $text->text( $bookseller->accountnumber ); # print delivery infos - $text->translate(107/mm, ($height-75)/mm); + $text->translate( 107 / mm, ( $height - 75 ) / mm ); if ($freedeliveryplace) { my $start = 79; - my @fdp = split('\n', $freedeliveryplace); + my @fdp = split( '\n', $freedeliveryplace ); foreach (@fdp) { $text->text($_); $text->translate( 107 / mm, ( $height - $start ) / mm ); @@ -214,35 +224,44 @@ sub printhead { $text->translate( 107 / mm, ( $height - 79 ) / mm ); $text->text( $delivery_library->branchaddress3 ); $text->translate( 107 / mm, ( $height - 83 ) / mm ); - $text->text( join( ' ', $delivery_library->branchcity, $delivery_library->branchzip, $delivery_library->branchcountry ) ); + $text->text( + join( ' ', $delivery_library->branchcity, $delivery_library->branchzip, $delivery_library->branchcountry ) + ); } $text->translate( 20 / mm, ( $height - 120 ) / mm ); - $text->text($basketgroup->{deliverycomment}); + $text->text( $basketgroup->{deliverycomment} ); } sub printfooters { my $pdf = shift; - for ( 1..$pdf->pages ) { + for ( 1 .. $pdf->pages ) { my $page = $pdf->openpage($_); my $text = $page->text; - $text->font( $pdf->corefont("Times", -encoding => "utf8"), 3/mm ); - $text->translate(10/mm, 10/mm); - $text->text("Page $_ / ".$pdf->pages); + $text->font( $pdf->corefont( "Times", -encoding => "utf8" ), 3 / mm ); + $text->translate( 10 / mm, 10 / mm ); + $text->text( "Page $_ / " . $pdf->pages ); } } sub printpdf { - my ($basketgroup, $bookseller, $baskets, $orders, $GST) = @_; + my ( $basketgroup, $bookseller, $baskets, $orders, $GST ) = @_; + # open the default PDF that will be used for base (1st page already filled) - my $pdf_template = C4::Context->config('intrahtdocs') . '/' . C4::Context->preference('template') . '/pdf/layout1page.pdf'; + my $pdf_template = + C4::Context->config('intrahtdocs') . '/' . C4::Context->preference('template') . '/pdf/layout1page.pdf'; my $pdf = PDF::API2->open($pdf_template); - $pdf->pageLabel( 0, { - -style => 'roman', - } ); # start with roman numbering - # fill the 1st page (basketgroup information) - printhead($pdf, $basketgroup, $bookseller); + $pdf->pageLabel( + 0, + { + -style => 'roman', + } + ); # start with roman numbering + # fill the 1st page (basketgroup information) + printhead( $pdf, $basketgroup, $bookseller ); + # fill other pages (orders) - printorders($pdf, $basketgroup, $baskets, $orders); + printorders( $pdf, $basketgroup, $baskets, $orders ); + # print something on each page (usually the footer, but you could also put a header printfooters($pdf); return $pdf->stringify; -- 2.39.5