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
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.
27 use C4
::Bookseller
qw( GetBookSeller );
30 use C4
::Branch
; # GetBranches GetBranchesLoop
31 use C4
::Csv
qw( GetCsvProfiles );
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',
48 flagsrequired
=> {serials
=> 'claim_serials'},
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) {
61 my $letters = GetLetters
('claimissues');
63 foreach (keys %{$letters}){
64 push @letters ,{code
=>$_,name
=> $letters->{$_}};
67 my $letter=((scalar(@letters)>1) || ($letters[0]->{name
}||$letters[0]->{code
}));
71 @missingissues = GetLateOrMissingIssues
($supplierid,$serialid,$order);
72 @supplierinfo=GetBookSeller
($supplierid);
75 my $branchloop = GetBranchesLoop
();
78 if($op && $op eq 'preview'){
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);
91 suploop
=> $supplierlist,
92 phone
=> $supplierinfo[0]->{phone
},
93 booksellerfax
=> $supplierinfo[0]->{booksellerfax
},
94 bookselleremail
=> $supplierinfo[0]->{bookselleremail
},
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;