4 # Copyright 2005 Biblibre
5 # This file is part of Koha.
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
26 this script shows late orders for a specific supplier, branch and delay
34 To know on which supplier this script have to display late order.
37 To know the time boundary. Default value is 30 days.
40 To know on which branch this script have to display late order.
55 use Koha
::Acquisition
::Orders
;
56 use Koha
::CsvProfiles
;
59 my ($template, $loggedinuser, $cookie) = get_template_and_user
(
61 template_name
=> "acqui/lateorders.tt",
65 flagsrequired
=> { acquisition
=> 'order_receive' },
70 my $booksellerid = $input->param('booksellerid');
71 my $delay = $input->param('delay') // 0;
73 # Get the "date from" param if !defined is today
74 my $estimateddeliverydatefrom = $input->param('estimateddeliverydatefrom');
75 my $estimateddeliverydateto = $input->param('estimateddeliverydateto');
77 my $estimateddeliverydatefrom_dt =
78 $estimateddeliverydatefrom
79 ? dt_from_string
($estimateddeliverydatefrom)
82 # Get the "date to" param. If it is not defined and $delay is not defined too, it is the today's date.
83 my $estimateddeliverydateto_dt = $estimateddeliverydateto
84 ? dt_from_string
($estimateddeliverydateto)
85 : ( not defined $delay and not defined $estimateddeliverydatefrom)
89 # Format the output of "date from" and "date to"
90 if ($estimateddeliverydatefrom_dt) {
91 $estimateddeliverydatefrom = output_pref
({dt
=> $estimateddeliverydatefrom_dt, dateonly
=> 1});
93 if ($estimateddeliverydateto_dt) {
94 $estimateddeliverydateto = output_pref
({dt
=> $estimateddeliverydateto_dt, dateonly
=> 1});
97 my $branch = $input->param('branch');
98 my $op = $input->param('op');
101 if ( $delay and not $delay =~ /^\d{1,3}$/ ) {
102 push @errors, {delay_digits
=> 1, bad_delay
=> $delay};
105 if ($op and $op eq "send_alert"){
106 my @ordernums = $input->multi_param("ordernumber");
109 $err = SendAlerts
( 'claimacquisition', \
@ordernums, $input->param("letter_code") );
110 if ( not ref $err or not exists $err->{error
} ) {
111 Koha
::Acquisition
::Orders
->find($_)->claim() for @ordernums;
115 if ( ref $err and exists $err->{error
} and $err->{error
} eq "no_email" ) {
116 $template->{VARS
}->{'error_claim'} = "no_email";
117 } elsif ( ref $err and exists $err->{error
} and $err->{error
} eq "no_order_selected"){
118 $template->{VARS
}->{'error_claim'} = "no_order_selected";
119 } elsif ( $@
or ref $err and exists $err->{error
} ) {
120 $template->param(error_claim
=> $@
|| $err->{error
});
122 $template->{VARS
}->{'info_claim'} = 1;
126 my @lateorders = Koha
::Acquisition
::Orders
->filter_by_lates(
130 $estimateddeliverydatefrom_dt
131 ?
( estimated_from
=> $estimateddeliverydatefrom_dt )
135 $estimateddeliverydateto_dt
136 ?
( estimated_to
=> $estimateddeliverydateto_dt )
142 my $booksellers = Koha
::Acquisition
::Booksellers
->search(
145 -in => [ map { $_->basket->booksellerid } @lateorders ]
150 @lateorders = grep { $_->basket->booksellerid eq $booksellerid } @lateorders if $booksellerid;
152 my $letters = GetLetters
({ module
=> "claimacquisition" });
154 $template->param(ERROR_LOOP
=> \
@errors) if (@errors);
156 lateorders
=> \
@lateorders,
157 booksellers
=> $booksellers,
158 bookseller_filter
=> ( $booksellerid ?
$booksellers->find($booksellerid) : undef),
161 estimateddeliverydatefrom
=> $estimateddeliverydatefrom,
162 estimateddeliverydateto
=> $estimateddeliverydateto,
163 intranetcolorstylesheet
=> C4
::Context
->preference("intranetcolorstylesheet"),
164 csv_profiles
=> [ Koha
::CsvProfiles
->search({ type
=> 'sql', used_for
=> 'late_orders' }) ],
166 output_html_with_http_headers
$input, $cookie, $template->output;