X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;ds=inline;f=serials%2Fcheckexpiration.pl;h=ae888414444f5d3970be28a628f3c8511da0708f;hb=refs%2Fheads%2Fkoha_ffzg;hp=de711b4a5f4b4ac321f4a99b6da5f54b712c2c04;hpb=cefeb583ad0069a15df8489c3b10b9ec72877e70;p=koha.git diff --git a/serials/checkexpiration.pl b/serials/checkexpiration.pl index de711b4a5f..ae88841444 100755 --- a/serials/checkexpiration.pl +++ b/serials/checkexpiration.pl @@ -3,20 +3,19 @@ # # 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 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. +# 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 +# You should have received a copy of the GNU General Public License +# along with Koha; if not, see . -# $Id$ =head1 NAME @@ -43,35 +42,37 @@ The date to filter on. =cut -use strict; -use CGI; +use Modern::Perl; +use CGI qw ( -utf8 ); use C4::Auth; use C4::Serials; # GetExpirationDate use C4::Output; use C4::Context; -use Date::Calc qw/Today Date_to_Days/; +use Koha::DateUtils; + +use DateTime; my $query = new CGI; -my ( $template, $loggedinuser, $cookie ) = get_template_and_user ( +my ( $template, $loggedinuser, $cookie, $flags ) = get_template_and_user ( { - template_name => "serials/checkexpiration.tmpl", + template_name => "serials/checkexpiration.tt", query => $query, type => "intranet", authnotrequired => 0, - flagsrequired => { serials => 1 }, + flagsrequired => { serials => 'check_expiration' }, debug => 1, } ); my $title = $query->param('title'); my $issn = $query->param('issn'); -my $date = $query->param('date'); -my $today = join "-",&Today; +my $branch = $query->param('branch'); +my $date = $query->param('date'); +$date = eval { dt_from_string( scalar $query->param('date') ) } if $date; if ($date) { - - my @subscriptions = GetSubscriptions( $title, $issn ); + my @subscriptions = SearchSubscriptions({ title => $title, issn => $issn, orderby => 'title' }); my @subscriptions_loop; foreach my $subscription ( @subscriptions ) { @@ -79,13 +80,26 @@ if ($date) { 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) ) { - push @subscriptions_loop,$subscription; + + next if $expirationdate !~ /\d{4}-\d{2}-\d{2}/; # next if not in ISO format. + + next if $subscription->{closed}; + if ( !C4::Context->preference("IndependentBranches") + or C4::Context->IsSuperLibrarian() + or ( ref $flags->{serials} and $flags->{serials}->{superserials} ) + or ( !ref $flags->{serials} and $flags->{serials} == 1 ) ) + { + $subscription->{cannotedit} = 0; + } + next if $subscription->{cannotedit}; + + my $expirationdate_dt = dt_from_string( $expirationdate, 'iso' ); + if ( DateTime->compare( $date, $expirationdate_dt ) == 1 + && ( !$branch || ( $subscription->{'branchcode'} eq $branch ) ) ) { + push @subscriptions_loop, $subscription; } } - + $template->param ( title => $title, issn => $issn, @@ -93,7 +107,23 @@ if ($date) { date => $date, subscriptions_loop => \@subscriptions_loop, "BiblioDefaultView".C4::Context->preference("BiblioDefaultView") => 1, + searched => 1, ); } +my $can_change_library;; +if ( !C4::Context->preference("IndependentBranches") + or C4::Context->IsSuperLibrarian() + or ( ref $flags->{serials} and $flags->{serials}->{superserials} ) + or ( !ref $flags->{serials} and $flags->{serials} == 1 ) ) +{ + $can_change_library = 1; +} + +$template->param ( + (uc(C4::Context->preference("marcflavour"))) => 1, + can_change_library => $can_change_library, + branch => $branch, +); + output_html_with_http_headers $query, $cookie, $template->output;