c39380ed4e
If a subscription is no longer enough published (or we are not waiting for a new periodical) we are allowed to close it. If a subscription is closed, we are not able to receive or generate a new serial. On the serial module, we can now - close a subscriptionn - reopen a closed subscription On serial search 2 tabs is displayed (opened and closed subscriptions). This patch adds: - a new field subscription.closed in DB - a new status for serials (8 = stopped) Test plan: - search subscriptions - close a subscription and check that you cannot receive or generate a new serial - launch another search and check that the closed serial is into the "closed" tab. - You are allowed to reopen a subscription on the subscription detail page and on the subscription result page. A javascript alert ask you if are certain to do this operation. - Check the serial status "stopped" everywhere the status is displayed (catalogue/detail.pl, serials/claims.pl, serials/serial-issues-full.pl, serials/serials-collection.pl, serials/serials-edit.pl, serials/serials-recieve.pl, serials/subscription-detail.pl and opac-full-serial-issues.pl) - The report statistics does not include the closed subscriptions if you don't check the "Include expired subscriptions" checkbox. Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com> Bug 8782: Followup: add some minor modifications - Show 'closed' information in biblio detail page - Add a column in serials report table - Search subscriptions on title words instead of string - Prevent serials editing when subscription is closed - Don't change status of "disabled" serials Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com> Bug 8782 - Close a subscription - Followup - Fix updatedatabase.pl Signed-off-by: Jonathan Druart <jonathan.druart@biblibre.com> Signed-off-by: Paul Poulain <paul.poulain@biblibre.com> Signed-off-by: Jared Camins-Esakov <jcamins@cpbibliography.com>
133 lines
4 KiB
Perl
Executable file
133 lines
4 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Copyright 2012 Koha Team
|
|
#
|
|
# 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.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
|
|
=head1 NAME
|
|
|
|
serials-search.pl
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
this script is the search page for serials
|
|
|
|
=cut
|
|
|
|
use Modern::Perl;
|
|
use CGI;
|
|
use C4::Auth;
|
|
use C4::Branch;
|
|
use C4::Context;
|
|
use C4::Output;
|
|
use C4::Serials;
|
|
|
|
my $query = new CGI;
|
|
my $title = $query->param('title_filter') || '';
|
|
my $ISSN = $query->param('ISSN_filter') || '';
|
|
my $EAN = $query->param('EAN_filter') || '';
|
|
my $publisher = $query->param('publisher_filter') || '';
|
|
my $bookseller = $query->param('bookseller_filter') || '';
|
|
my $biblionumber = $query->param('biblionumber') || '';
|
|
my $branch = $query->param('branch_filter') || '';
|
|
my $routing = $query->param('routing') || C4::Context->preference("RoutingSerials");
|
|
my $searched = $query->param('searched') || 0;
|
|
my @subscriptionids = $query ->param('subscriptionid');
|
|
my $op = $query->param('op');
|
|
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "serials/serials-search.tmpl",
|
|
query => $query,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { serials => '*' },
|
|
debug => 1,
|
|
}
|
|
);
|
|
|
|
if ( $op and $op eq "close" ) {
|
|
for my $subscriptionid ( @subscriptionids ) {
|
|
C4::Serials::CloseSubscription( $subscriptionid );
|
|
}
|
|
} elsif ( $op and $op eq "reopen" ) {
|
|
for my $subscriptionid ( @subscriptionids ) {
|
|
C4::Serials::ReopenSubscription( $subscriptionid );
|
|
}
|
|
}
|
|
|
|
my @subscriptions;
|
|
if ($searched){
|
|
@subscriptions = SearchSubscriptions(
|
|
{
|
|
biblionumber => $biblionumber,
|
|
title => $title,
|
|
issn => $ISSN,
|
|
ean => $EAN,
|
|
publisher => $publisher,
|
|
bookseller => $bookseller,
|
|
branch => $branch,
|
|
}
|
|
);
|
|
}
|
|
|
|
# to toggle between create or edit routing list options
|
|
if ($routing) {
|
|
for my $subscription ( @subscriptions) {
|
|
$subscription->{routingedit} = check_routing( $subscription->{subscriptionid} );
|
|
$subscription->{branchname} = GetBranchName ( $subscription->{branchcode} );
|
|
}
|
|
}
|
|
|
|
my (@openedsubscriptions, @closedsubscriptions);
|
|
for my $sub ( @subscriptions ) {
|
|
unless ( $sub->{closed} ) {
|
|
push @openedsubscriptions, $sub;
|
|
} else {
|
|
push @closedsubscriptions, $sub;
|
|
}
|
|
}
|
|
|
|
my $branches = GetBranches();
|
|
my @branches_loop;
|
|
foreach (sort keys %$branches){
|
|
my $selected = 0;
|
|
$selected = 1 if( $branch eq $_ );
|
|
push @branches_loop, {
|
|
branchcode => $_,
|
|
branchname => $branches->{$_}->{'branchname'},
|
|
selected => $selected,
|
|
};
|
|
}
|
|
|
|
$template->param(
|
|
openedsubscriptions => \@openedsubscriptions,
|
|
closedsubscriptions => \@closedsubscriptions,
|
|
total => @openedsubscriptions + @closedsubscriptions,
|
|
title_filter => $title,
|
|
ISSN_filter => $ISSN,
|
|
EAN_filter => $EAN,
|
|
publisher_filter => $publisher,
|
|
bookseller_filter => $bookseller,
|
|
branch_filter => $branch,
|
|
branches_loop => \@branches_loop,
|
|
done_searched => $searched,
|
|
routing => $routing,
|
|
marcflavour => (uc(C4::Context->preference("marcflavour")))
|
|
);
|
|
|
|
output_html_with_http_headers $query, $cookie, $template->output;
|