a5bd240321
Rule : - always format_date() before sending date to template - always format_date_in_iso immediatly after reading a date coming from a parameter - deal internally only with dates in iso Note that : - I could not test things related to issues stats due to the my DB -issues.issuedate not filled, see commit about 3.00.00.006 - acquisitions_stats does not work when you filter on date Signed-off-by: Joshua Ferraro <jmf@liblime.com>
103 lines
2.9 KiB
Perl
Executable file
103 lines
2.9 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
#
|
|
# 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., 59 Temple Place,
|
|
# Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
# $Id$
|
|
|
|
=head1 NAME
|
|
|
|
checkexpiration.pl
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
This script check what subscription will expire before C<$datenumber $datelimit>
|
|
|
|
=head1 PARAMETERS
|
|
|
|
=over 4
|
|
|
|
=item title
|
|
To filter subscription on title
|
|
|
|
=item issn
|
|
To filter subscription on issn
|
|
|
|
=item date
|
|
The date to filter on.
|
|
|
|
=back
|
|
|
|
=cut
|
|
|
|
use strict;
|
|
use CGI;
|
|
use C4::Auth;
|
|
use C4::Serials; # GetExpirationDate
|
|
use C4::Output;
|
|
use C4::Context;
|
|
use C4::Date;
|
|
use Date::Calc qw/Today Date_to_Days/;
|
|
|
|
my $query = new CGI;
|
|
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user (
|
|
{
|
|
template_name => "serials/checkexpiration.tmpl",
|
|
query => $query,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { serials => 1 },
|
|
debug => 1,
|
|
}
|
|
);
|
|
|
|
my $title = $query->param('title');
|
|
my $issn = $query->param('issn');
|
|
my $date = format_date_in_iso($query->param('date'));
|
|
my $today = join "-",&Today;
|
|
|
|
if ($date) {
|
|
|
|
my @subscriptions = GetSubscriptions( $title, $issn );
|
|
my @subscriptions_loop;
|
|
|
|
foreach my $subscription ( @subscriptions ) {
|
|
my $subscriptionid = $subscription->{'subscriptionid'};
|
|
my $expirationdate = GetExpirationDate($subscriptionid);
|
|
|
|
$subscription->{expirationdate} = $expirationdate;
|
|
next if $expirationdate !~ /\d{4}-\d{2}-\d{2}/; # next if not in good format.
|
|
if ( Date_to_Days(split "-",$expirationdate) < Date_to_Days(split "-",$date) &&
|
|
Date_to_Days(split "-",$expirationdate) > Date_to_Days(split "-",$today) ) {
|
|
$subscription->{expirationdate}=format_date($subscription->{expirationdate});
|
|
push @subscriptions_loop,$subscription;
|
|
}
|
|
}
|
|
|
|
$template->param (
|
|
title => $title,
|
|
issn => $issn,
|
|
numsubscription => scalar @subscriptions_loop,
|
|
date => format_date($date),
|
|
subscriptions_loop => \@subscriptions_loop,
|
|
"BiblioDefaultView".C4::Context->preference("BiblioDefaultView") => 1,
|
|
);
|
|
}
|
|
$template->param (
|
|
DHTMLcalendar_dateformat => get_date_format_string_for_DHTMLcalendar(),
|
|
);
|
|
output_html_with_http_headers $query, $cookie, $template->output;
|