383b2a75de
Test plan: - Create a CSV profile (or use the default one) with a type 'sql'. - Go to serials/claims.pl, select the wanted CSV profile and click on the "Export selected items data". - Verify the CSV file is correctly generated. Signed-off-by: Bernardo Gonzalez Kriegel <bgkriegel@gmail.com> Work as described. No koha-qa errors On top of 10853 (solving merge conflict) Need to do homework to test. Add subscription and serial claim notice. 1) Create a new CSV profile, type SQL, copy sample fields 2) Go to claims, select vendor 3) Go to Export selected items with created profile 4) CSV (in my case I use | as separator) download successfully 5) All fields present, file correct Signed-off-by: Katrin Fischer <Katrin.Fischer.83@web.de> Passes all tests and QA script. Works as advertised, keeps existing format by porting it to a SQL profile. Signed-off-by: Galen Charlton <gmc@esilibrary.com>
105 lines
3.4 KiB
Perl
Executable file
105 lines
3.4 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Parts Copyright 2010 Biblibre
|
|
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 2 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with Koha; if not, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
use strict;
|
|
use warnings;
|
|
use CGI;
|
|
use C4::Auth;
|
|
use C4::Serials;
|
|
use C4::Acquisition;
|
|
use C4::Output;
|
|
use C4::Bookseller qw( GetBookSeller );
|
|
use C4::Context;
|
|
use C4::Letters;
|
|
use C4::Branch; # GetBranches GetBranchesLoop
|
|
use C4::Csv qw( GetCsvProfiles );
|
|
|
|
my $input = CGI->new;
|
|
|
|
my $serialid = $input->param('serialid');
|
|
my $op = $input->param('op');
|
|
my $claimletter = $input->param('claimletter');
|
|
my $supplierid = $input->param('supplierid');
|
|
my $suppliername = $input->param('suppliername');
|
|
my $order = $input->param('order');
|
|
|
|
# open template first (security & userenv set here)
|
|
my ($template, $loggedinuser, $cookie)
|
|
= get_template_and_user({template_name => 'serials/claims.tmpl',
|
|
query => $input,
|
|
type => 'intranet',
|
|
authnotrequired => 0,
|
|
flagsrequired => {serials => 'claim_serials'},
|
|
debug => 1,
|
|
});
|
|
|
|
# supplierlist is returned in name order
|
|
my $supplierlist = GetSuppliersWithLateIssues();
|
|
for my $s (@{$supplierlist} ) {
|
|
$s->{count} = scalar GetLateOrMissingIssues($s->{id}, q{}, $order);
|
|
if ($supplierid && $s->{id} == $supplierid) {
|
|
$s->{selected} = 1;
|
|
}
|
|
}
|
|
|
|
my $letters = GetLetters('claimissues');
|
|
my @letters;
|
|
foreach (keys %{$letters}){
|
|
push @letters ,{code=>$_,name=> $letters->{$_}};
|
|
}
|
|
|
|
my $letter=((scalar(@letters)>1) || ($letters[0]->{name}||$letters[0]->{code}));
|
|
my @missingissues;
|
|
my @supplierinfo;
|
|
if ($supplierid) {
|
|
@missingissues = GetLateOrMissingIssues($supplierid,$serialid,$order);
|
|
@supplierinfo=GetBookSeller($supplierid);
|
|
}
|
|
|
|
my $branchloop = GetBranchesLoop();
|
|
unshift @$branchloop, {value=> 'all',name=>''};
|
|
|
|
my $preview=0;
|
|
if($op && $op eq 'preview'){
|
|
$preview = 1;
|
|
} else {
|
|
my @serialnums=$input->param('serialid');
|
|
if (@serialnums) { # i.e. they have been flagged to generate claims
|
|
SendAlerts('claimissues',\@serialnums,$input->param("letter_code"));
|
|
my $cntupdate=UpdateClaimdateIssues(\@serialnums);
|
|
### $cntupdate SHOULD be equal to scalar(@$serialnums)
|
|
}
|
|
}
|
|
$template->param('letters'=>\@letters,'letter'=>$letter);
|
|
$template->param(
|
|
order =>$order,
|
|
suploop => $supplierlist,
|
|
phone => $supplierinfo[0]->{phone},
|
|
booksellerfax => $supplierinfo[0]->{booksellerfax},
|
|
bookselleremail => $supplierinfo[0]->{bookselleremail},
|
|
preview => $preview,
|
|
missingissues => \@missingissues,
|
|
supplierid => $supplierid,
|
|
claimletter => $claimletter,
|
|
supplierloop => \@supplierinfo,
|
|
branchloop => $branchloop,
|
|
csv_profiles => C4::Csv::GetCsvProfiles( "sql" ),
|
|
(uc(C4::Context->preference("marcflavour"))) => 1
|
|
);
|
|
output_html_with_http_headers $input, $cookie, $template->output;
|