#!/usr/bin/perl # Copyright 2005 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 3 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, see . =head1 NAME lateorders.pl =head1 DESCRIPTION this script shows late orders for a specific supplier, branch and delay given on input arg. =head1 CGI PARAMETERS =over 4 =item booksellerid To know on which supplier this script have to display late order. =item delay To know the time boundary. Default value is 30 days. =item branch To know on which branch this script have to display late order. =back =cut use Modern::Perl; use CGI qw ( -utf8 ); use C4::Auth; use C4::Koha; use C4::Output; use C4::Context; use C4::Acquisition; use C4::Letters; use Koha::DateUtils; use Koha::Acquisition::Orders; use Koha::CsvProfiles; my $input = new CGI; my ($template, $loggedinuser, $cookie) = get_template_and_user( { template_name => "acqui/lateorders.tt", query => $input, type => "intranet", authnotrequired => 0, flagsrequired => { acquisition => 'order_receive' }, debug => 1, } ); my $booksellerid = $input->param('booksellerid'); my $delay = $input->param('delay') // 0; # Get the "date from" param if !defined is today my $estimateddeliverydatefrom = $input->param('estimateddeliverydatefrom'); my $estimateddeliverydateto = $input->param('estimateddeliverydateto'); my $estimateddeliverydatefrom_dt = $estimateddeliverydatefrom ? dt_from_string($estimateddeliverydatefrom) : undef; # Get the "date to" param. If it is not defined and $delay is not defined too, it is the today's date. my $estimateddeliverydateto_dt = $estimateddeliverydateto ? dt_from_string($estimateddeliverydateto) : ( not defined $delay and not defined $estimateddeliverydatefrom) ? dt_from_string() : undef; # Format the output of "date from" and "date to" if ($estimateddeliverydatefrom_dt) { $estimateddeliverydatefrom = output_pref({dt => $estimateddeliverydatefrom_dt, dateonly => 1}); } if ($estimateddeliverydateto_dt) { $estimateddeliverydateto = output_pref({dt => $estimateddeliverydateto_dt, dateonly => 1}); } my $branch = $input->param('branch'); my $op = $input->param('op'); my @errors = (); if ( $delay and not $delay =~ /^\d{1,3}$/ ) { push @errors, {delay_digits => 1, bad_delay => $delay}; } if ($op and $op eq "send_alert"){ my @ordernums = $input->multi_param("ordernumber"); my $err; eval { $err = SendAlerts( 'claimacquisition', \@ordernums, $input->param("letter_code") ); if ( not ref $err or not exists $err->{error} ) { Koha::Acquisition::Orders->find($_)->claim() for @ordernums; } }; if ( ref $err and exists $err->{error} and $err->{error} eq "no_email" ) { $template->{VARS}->{'error_claim'} = "no_email"; } elsif ( ref $err and exists $err->{error} and $err->{error} eq "no_order_selected"){ $template->{VARS}->{'error_claim'} = "no_order_selected"; } elsif ( $@ or ref $err and exists $err->{error} ) { $template->param(error_claim => $@ || $err->{error}); } else { $template->{VARS}->{'info_claim'} = 1; } } my @parameters = ( $delay ); push @parameters, $estimateddeliverydatefrom_dt ? $estimateddeliverydatefrom_dt->ymd() : undef; push @parameters, $estimateddeliverydateto_dt ? $estimateddeliverydateto_dt->ymd() : undef; my @lateorders = Koha::Acquisition::Orders->filter_by_lates( { delay => $delay, ( $estimateddeliverydatefrom_dt ? ( estimated_from => $estimateddeliverydatefrom_dt ) : () ), ( $estimateddeliverydateto_dt ? ( estimated_to => $estimateddeliverydateto_dt ) : () ) }, )->as_list; my $booksellers = Koha::Acquisition::Booksellers->search( { id => { -in => [ map { $_->basket->booksellerid } @lateorders ] }, } ); @lateorders = grep { $_->basket->booksellerid eq $booksellerid } @lateorders if $booksellerid; my $letters = GetLetters({ module => "claimacquisition" }); $template->param(ERROR_LOOP => \@errors) if (@errors); $template->param( lateorders => \@lateorders, booksellers => $booksellers, bookseller_filter => ( $booksellerid ? $booksellers->find($booksellerid) : undef), delay => $delay, letters => $letters, estimateddeliverydatefrom => $estimateddeliverydatefrom, estimateddeliverydateto => $estimateddeliverydateto, intranetcolorstylesheet => C4::Context->preference("intranetcolorstylesheet"), csv_profiles => [ Koha::CsvProfiles->search({ type => 'sql', used_for => 'late_orders' }) ], ); output_html_with_http_headers $input, $cookie, $template->output;