Koha/serials/checkexpiration.pl
paul a5bd240321 FIX for Date calculation
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>
2007-10-11 11:51:12 -05:00

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;