e4860aeeed
Replace inputs to edit notes by a link opening a modal, similar to the basket summary page. This makes it possible for the notes to appear in the datatable exports. Also fix exporting with the export as csv button at the bottom of the page to export notes. Test plan : 1) In the late orders table (acqui/lateorders.pl), a link should appear in both the internal and vendor note column, following the current value if it exist. -> This link should read "Add ..." if there is no existing note or "Edit ..." if there is. 2) Click on the link. A modal should appear. Confirm that saving a note works as expected. 3) Try exporting to any format using either the button at the top of the table or the one at the bottom of the page. -> The three new columns and their values should appear in the export. Signed-off-by: Séverine QUEUNE <severine.queune@bulac.fr> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
178 lines
5.3 KiB
Perl
Executable file
178 lines
5.3 KiB
Perl
Executable file
#!/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 <http://www.gnu.org/licenses>.
|
|
|
|
=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::Bookseller qw( GetBooksellersWithLateOrders );
|
|
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;
|
|
|
|
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') || undef; # we don't want "" or 0
|
|
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} ) {
|
|
AddClaim ( $_ ) for @ordernums;
|
|
}
|
|
};
|
|
|
|
if ( $@ ) {
|
|
$template->param(error_claim => $@);
|
|
} elsif ( 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";
|
|
} 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 %supplierlist = GetBooksellersWithLateOrders(@parameters);
|
|
|
|
my (@sloopy); # supplier loop
|
|
foreach( sort { $supplierlist{$a} cmp $supplierlist{$b} } keys %supplierlist ) {
|
|
push @sloopy, (($booksellerid and $booksellerid eq $_ ) ?
|
|
{id=>$_, name=>$supplierlist{$_}, selected=>1} :
|
|
{id=>$_, name=>$supplierlist{$_}} ) ;
|
|
}
|
|
$template->param(SUPPLIER_LOOP => \@sloopy);
|
|
|
|
$template->param(Supplier=>$supplierlist{$booksellerid}) if ($booksellerid);
|
|
$template->param(booksellerid=>$booksellerid) if ($booksellerid);
|
|
|
|
@parameters =
|
|
( $delay, $booksellerid, $branch );
|
|
if ($estimateddeliverydatefrom_dt) {
|
|
push @parameters, $estimateddeliverydatefrom_dt->ymd();
|
|
}
|
|
else {
|
|
push @parameters, undef;
|
|
}
|
|
if ($estimateddeliverydateto_dt) {
|
|
push @parameters, $estimateddeliverydateto_dt->ymd();
|
|
}
|
|
my @lateorders = GetLateOrders( @parameters );
|
|
|
|
my $total;
|
|
foreach (@lateorders){
|
|
$total += $_->{subtotal};
|
|
}
|
|
|
|
my $letters = GetLetters({ module => "claimacquisition" });
|
|
|
|
$template->param(ERROR_LOOP => \@errors) if (@errors);
|
|
$template->param(
|
|
lateorders => \@lateorders,
|
|
delay => $delay,
|
|
letters => $letters,
|
|
estimateddeliverydatefrom => $estimateddeliverydatefrom,
|
|
estimateddeliverydateto => $estimateddeliverydateto,
|
|
total => $total,
|
|
intranetcolorstylesheet => C4::Context->preference("intranetcolorstylesheet"),
|
|
);
|
|
output_html_with_http_headers $input, $cookie, $template->output;
|