danyonsewell
ac5084641e
Adds a search option to the advanced search in the serials module that allows to limit search on subscriptions with routing lists. Test plan: 1. Apply this patch 2. Create two subscriptions, one with a routing list and one without 3. Navigate to Serials home and tick the checkbox labeled "Search routing lists only:" 4. Confirm that the only search result to appear is the subscription you added the routing list to 5. Run unit tests: prove t/db_dependent/Serials.t Sponsored by: Bibliotheksservice-Zentrum Baden-Wuerttemberg Signed-off-by: Christian Stelzenmüller <christian.stelzenmueller@bsz-bw.de> Signed-off-by: Katrin Fischer <katrin.fischer@bsz-bw.de> Perltidied changes to make QA test tools pass. Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl> Signed-off-by: Katrin Fischer <katrin.fischer@bsz-bw.de>
207 lines
7.1 KiB
Perl
Executable file
207 lines
7.1 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 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
|
|
|
|
serials-search.pl
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
this script is the search page for serials
|
|
|
|
=cut
|
|
|
|
use Modern::Perl;
|
|
use CGI qw ( -utf8 );
|
|
use C4::Auth qw( get_template_and_user );
|
|
use C4::Context;
|
|
use C4::Output qw( output_html_with_http_headers );
|
|
use C4::Serials qw( CloseSubscription ReopenSubscription SearchSubscriptions check_routing );
|
|
use Koha::AdditionalFields;
|
|
|
|
use Koha::DateUtils qw( dt_from_string );
|
|
use Koha::SharedContent;
|
|
|
|
my $query = CGI->new;
|
|
my $title = $query->param('title_filter') || '';
|
|
my $ISSN = $query->param('ISSN_filter') || '';
|
|
my $EAN = $query->param('EAN_filter') || '';
|
|
my $callnumber = $query->param('callnumber_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 $location = $query->param('location_filter') || '';
|
|
my $expiration_date = $query->param('expiration_date_filter') || '';
|
|
my $routing = $query->param('routing') || C4::Context->preference("RoutingSerials");
|
|
my $searched = $query->param('searched') || 0;
|
|
my $routinglist = $query->param('routinglist');
|
|
my $mana = $query->param('mana') || 0;
|
|
my @subscriptionids = $query->multi_param('subscriptionid');
|
|
my $op = $query->param('op');
|
|
my $orig_total;
|
|
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "serials/serials-search.tt",
|
|
query => $query,
|
|
type => "intranet",
|
|
flagsrequired => { serials => '*' },
|
|
}
|
|
);
|
|
|
|
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 @additional_fields = Koha::AdditionalFields->search( { tablename => 'subscription', searchable => 1 } )->as_list;
|
|
my @additional_field_filters;
|
|
for my $field ( @additional_fields ) {
|
|
my $value = $query->param( 'additional_field_' . $field->id );
|
|
if ( defined $value and $value ne '' ) {
|
|
push @additional_field_filters, {
|
|
id => $field->id,
|
|
value => $value,
|
|
};
|
|
}
|
|
}
|
|
|
|
my @subscriptions;
|
|
my $mana_statuscode;
|
|
if ($searched) {
|
|
if ($mana) {
|
|
my $result = Koha::SharedContent::search_entities("subscription",{
|
|
title => $title,
|
|
issn => $ISSN,
|
|
ean => $EAN,
|
|
publisher => $publisher
|
|
});
|
|
$mana_statuscode = $result->{code};
|
|
@subscriptions = @{ $result->{data} };
|
|
}
|
|
else {
|
|
my $subscriptions = SearchSubscriptions(
|
|
{
|
|
biblionumber => $biblionumber,
|
|
title => $title,
|
|
issn => $ISSN,
|
|
ean => $EAN,
|
|
callnumber => $callnumber,
|
|
publisher => $publisher,
|
|
bookseller => $bookseller,
|
|
branch => $branch,
|
|
additional_fields => \@additional_field_filters,
|
|
location => $location,
|
|
expiration_date => $expiration_date,
|
|
routinglist => $routinglist,
|
|
},
|
|
{ results_limit => C4::Context->preference('SerialsSearchResultsLimit') }
|
|
);
|
|
@subscriptions = @{$subscriptions->{results}};
|
|
$orig_total = $subscriptions->{total};
|
|
|
|
}
|
|
}
|
|
|
|
if ($mana) {
|
|
$template->param(
|
|
subscriptions => \@subscriptions,
|
|
statuscode => $mana_statuscode,
|
|
total => scalar @subscriptions,
|
|
title_filter => $title,
|
|
ISSN_filter => $ISSN,
|
|
EAN_filter => $EAN,
|
|
callnumber_filter => $callnumber,
|
|
publisher_filter => $publisher,
|
|
bookseller_filter => $bookseller,
|
|
branch_filter => $branch,
|
|
location_filter => $location,
|
|
expiration_date_filter => $expiration_date,
|
|
done_searched => $searched,
|
|
routing => $routing,
|
|
additional_field_filters => \@additional_field_filters,
|
|
additional_fields_for_subscription => \@additional_fields,
|
|
marcflavour => (uc(C4::Context->preference("marcflavour"))),
|
|
mana => $mana,
|
|
search_only => 1
|
|
);
|
|
}
|
|
else {
|
|
# to toggle between create or edit routing list options
|
|
if ($routing) {
|
|
for my $subscription ( @subscriptions) {
|
|
$subscription->{routingedit} = check_routing( $subscription->{subscriptionid} );
|
|
}
|
|
}
|
|
|
|
my (@openedsubscriptions, @closedsubscriptions);
|
|
for my $sub ( @subscriptions ) {
|
|
unless ( $sub->{closed} ) {
|
|
push @openedsubscriptions, $sub
|
|
unless $sub->{cannotdisplay};
|
|
} else {
|
|
push @closedsubscriptions, $sub
|
|
unless $sub->{cannotdisplay};
|
|
}
|
|
}
|
|
|
|
my @branches = Koha::Libraries->search( {}, { order_by => ['branchcode'] } )->as_list;
|
|
my @branches_loop;
|
|
foreach my $b ( @branches ) {
|
|
my $selected = 0;
|
|
$selected = 1 if( defined $branch and $branch eq $b->branchcode );
|
|
push @branches_loop, {
|
|
branchcode => $b->branchcode,
|
|
branchname => $b->branchname,
|
|
selected => $selected,
|
|
};
|
|
}
|
|
|
|
$template->param(
|
|
openedsubscriptions => \@openedsubscriptions,
|
|
closedsubscriptions => \@closedsubscriptions,
|
|
total => @openedsubscriptions + @closedsubscriptions,
|
|
orig_total => $orig_total,
|
|
title_filter => $title,
|
|
ISSN_filter => $ISSN,
|
|
EAN_filter => $EAN,
|
|
callnumber_filter => $callnumber,
|
|
publisher_filter => $publisher,
|
|
bookseller_filter => $bookseller,
|
|
branch_filter => $branch,
|
|
location_filter => $location,
|
|
expiration_date_filter => $expiration_date,
|
|
branches_loop => \@branches_loop,
|
|
done_searched => $searched,
|
|
routing => $routing,
|
|
additional_field_filters => { map { $_->{id} => $_->{value} } @additional_field_filters },
|
|
additional_fields_for_subscription => \@additional_fields,
|
|
marcflavour => (uc(C4::Context->preference("marcflavour"))),
|
|
mana => $mana
|
|
);
|
|
}
|
|
output_html_with_http_headers $query, $cookie, $template->output;
|