Bug 11856: Add publication year and edition to French acq PDF template
[koha.git] / serials / claims.pl
blobc826804add1f73b94bcf19698b359fda9d2a4026
1 #!/usr/bin/perl
3 # Parts Copyright 2010 Biblibre
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU General Public License as published by the Free Software
9 # Foundation; either version 2 of the License, or (at your option) any later
10 # version.
12 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License along
17 # with Koha; if not, write to the Free Software Foundation, Inc.,
18 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20 use strict;
21 use warnings;
22 use CGI;
23 use C4::Auth;
24 use C4::Serials;
25 use C4::Acquisition;
26 use C4::Output;
27 use C4::Bookseller qw( GetBookSeller );
28 use C4::Context;
29 use C4::Letters;
30 use C4::Branch; # GetBranches GetBranchesLoop
31 use C4::Csv qw( GetCsvProfiles );
33 my $input = CGI->new;
35 my $serialid = $input->param('serialid');
36 my $op = $input->param('op');
37 my $claimletter = $input->param('claimletter');
38 my $supplierid = $input->param('supplierid');
39 my $suppliername = $input->param('suppliername');
40 my $order = $input->param('order');
42 # open template first (security & userenv set here)
43 my ($template, $loggedinuser, $cookie)
44 = get_template_and_user({template_name => 'serials/claims.tmpl',
45 query => $input,
46 type => 'intranet',
47 authnotrequired => 0,
48 flagsrequired => {serials => 'claim_serials'},
49 debug => 1,
50 });
52 # supplierlist is returned in name order
53 my $supplierlist = GetSuppliersWithLateIssues();
54 for my $s (@{$supplierlist} ) {
55 $s->{count} = scalar GetLateOrMissingIssues($s->{id}, q{}, $order);
56 if ($supplierid && $s->{id} == $supplierid) {
57 $s->{selected} = 1;
61 my $letters = GetLetters('claimissues');
62 my @letters;
63 foreach (keys %{$letters}){
64 push @letters ,{code=>$_,name=> $letters->{$_}};
67 my $letter=((scalar(@letters)>1) || ($letters[0]->{name}||$letters[0]->{code}));
68 my @missingissues;
69 my @supplierinfo;
70 if ($supplierid) {
71 @missingissues = GetLateOrMissingIssues($supplierid,$serialid,$order);
72 @supplierinfo=GetBookSeller($supplierid);
75 my $branchloop = GetBranchesLoop();
77 my $preview=0;
78 if($op && $op eq 'preview'){
79 $preview = 1;
80 } else {
81 my @serialnums=$input->param('serialid');
82 if (@serialnums) { # i.e. they have been flagged to generate claims
83 SendAlerts('claimissues',\@serialnums,$input->param("letter_code"));
84 my $cntupdate=UpdateClaimdateIssues(\@serialnums);
85 ### $cntupdate SHOULD be equal to scalar(@$serialnums)
88 $template->param('letters'=>\@letters,'letter'=>$letter);
89 $template->param(
90 order =>$order,
91 suploop => $supplierlist,
92 phone => $supplierinfo[0]->{phone},
93 booksellerfax => $supplierinfo[0]->{booksellerfax},
94 bookselleremail => $supplierinfo[0]->{bookselleremail},
95 preview => $preview,
96 missingissues => \@missingissues,
97 supplierid => $supplierid,
98 claimletter => $claimletter,
99 supplierloop => \@supplierinfo,
100 branchloop => $branchloop,
101 csv_profiles => C4::Csv::GetCsvProfiles( "sql" ),
102 (uc(C4::Context->preference("marcflavour"))) => 1
104 output_html_with_http_headers $input, $cookie, $template->output;