Nick Clemens
6b6a68525c
This does a few things: * We fetch the cn_sort from the DB and use this rather than calculating based on DefaultClassificationSource We were already pulling based on the items source, so this should not change things * Rather than using JS to submit the form, it submits via html * Fix subtitle display and add barcode (it was retrieved in one query but not used) * Add option to apply different classification scheme to the search To test: 1 - Add cn_browser.pl to the 'plugin' field in a framework for 952$o 2 - Edit an item on a record in that framework 3 - Enter an itemcallnumber 4 - Click the two dots to launch the callnumber browser 5 - Note the results 6 - Apply patch 7 - Repeat 8 - Note subtitles and barcodes are displayed in results 9 - Note callnumbers are appropriate 10 - Try changing the class source used 11 - Try this with differing dewey,lcc, and other callnumbers 12 - Ensure results are as expected Signed-off-by: Myka Kennedy Stephens <mkstephens@lancasterseminary.edu> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
171 lines
5.2 KiB
Perl
Executable file
171 lines
5.2 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Converted to new plugin style (Bug 13437)
|
|
|
|
# Copyright 2015 Koha Development 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, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
use Modern::Perl;
|
|
use CGI;
|
|
|
|
use C4::Auth;
|
|
use C4::ClassSource;
|
|
use C4::Output;
|
|
|
|
use Koha::ClassSources;
|
|
|
|
my $builder = sub {
|
|
my ( $params ) = @_;
|
|
my $function_name = $params->{id};
|
|
my $res = "
|
|
<script type=\"text/javascript\">
|
|
//<![CDATA[
|
|
|
|
function Click$function_name(i) {
|
|
q = document.getElementById('$params->{id}');
|
|
window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=cn_browser.pl&popup&q=\"+q.value,\"cnbrowser\",\"width=500,height=400,toolbar=false,scrollbars=yes\");
|
|
}
|
|
|
|
//]]>
|
|
</script>
|
|
";
|
|
return $res;
|
|
};
|
|
|
|
my $launcher = sub {
|
|
my ( $params ) = @_;
|
|
my $cgi = $params->{cgi};
|
|
my $results_per_page = 30;
|
|
my $current_page = $cgi->param('page') || 1;
|
|
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{ template_name => "cataloguing/value_builder/cn_browser.tt",
|
|
query => $cgi,
|
|
type => "intranet",
|
|
authnotrequired => 0,
|
|
flagsrequired => { catalogue => 1 },
|
|
}
|
|
);
|
|
|
|
my $dbh = C4::Context->dbh;
|
|
my $sth;
|
|
my @cn;
|
|
my $query;
|
|
my $real_limit = $results_per_page / 2;
|
|
my $rows_lt = 999;
|
|
my $rows_gt = 999;
|
|
my $search;
|
|
my $globalGreen = 0;
|
|
my $lt = '';
|
|
my $gt = '';
|
|
my $q;
|
|
|
|
if ( $q = $cgi->param('q') ) {
|
|
$search = $q;
|
|
}
|
|
if ( $cgi->param('lt') ) {
|
|
$lt = $cgi->param('lt');
|
|
$search = $lt;
|
|
}
|
|
if ( $cgi->param('gt') ) {
|
|
$gt = $cgi->param('gt');
|
|
$search = $gt;
|
|
}
|
|
|
|
my $cn_source = $cgi->param('cn_source') || C4::Context->preference("DefaultClassificationSource");
|
|
my @class_sources = Koha::ClassSources->search({ used => 1});
|
|
|
|
#Don't show half the results of show lt or gt
|
|
$real_limit = $results_per_page if $search ne $q;
|
|
my $cn_sort = GetClassSort( $cn_source, undef, $search );
|
|
|
|
my $red = 0;
|
|
if ( $search ne $gt ) {
|
|
my $green = 0;
|
|
|
|
#Results before the cn_sort
|
|
$query = "SELECT b.title, b.subtitle, itemcallnumber, biblionumber, barcode, cn_sort, branchname, author
|
|
FROM items AS i
|
|
JOIN biblio AS b USING (biblionumber)
|
|
LEFT OUTER JOIN branches ON (branches.branchcode = homebranch)
|
|
WHERE cn_sort < ?
|
|
AND itemcallnumber != ''
|
|
ORDER BY cn_sort DESC, itemnumber
|
|
LIMIT $real_limit;";
|
|
$sth = $dbh->prepare($query);
|
|
$sth->execute($cn_sort);
|
|
while ( my $data = $sth->fetchrow_hashref ) {
|
|
if ( $data->{itemcallnumber} eq $q ) {
|
|
$data->{background} = 'red';
|
|
$red = 1;
|
|
} elsif ( $data->{cn_sort} lt $cn_sort && !$green && !$red ) {
|
|
if ( $#cn != -1 ) {
|
|
unshift @cn, { 'background' => 'green' };
|
|
$globalGreen = 1;
|
|
}
|
|
$green = 1;
|
|
}
|
|
unshift @cn, $data;
|
|
}
|
|
$rows_lt = $sth->rows;
|
|
}
|
|
|
|
if ( $search ne $lt ) {
|
|
my $green = 0;
|
|
|
|
#Results after the cn_sort
|
|
$query = "SELECT b.title, b.subtitle, itemcallnumber, biblionumber, barcode, cn_sort, branchname, author
|
|
FROM items AS i
|
|
JOIN biblio AS b USING (biblionumber)
|
|
LEFT OUTER JOIN branches ON (branches.branchcode = homebranch)
|
|
WHERE i.cn_sort >= '$cn_sort'
|
|
AND itemcallnumber != ''
|
|
ORDER BY cn_sort, itemnumber
|
|
LIMIT $real_limit";
|
|
$sth = $dbh->prepare($query);
|
|
$sth->execute();
|
|
|
|
while ( my $data = $sth->fetchrow_hashref ) {
|
|
if ( $data->{itemcallnumber} eq $q ) {
|
|
$data->{background} = 'red';
|
|
$red = 1;
|
|
} elsif ( $data->{cn_sort} gt $cn_sort && !$green && !$red && !$globalGreen ) {
|
|
push @cn, { 'background' => 'green' };
|
|
$green = 1;
|
|
}
|
|
push @cn, $data;
|
|
}
|
|
$rows_gt = $sth->rows;
|
|
|
|
if ( !$green && !$red && !$globalGreen ) {
|
|
push @cn, { 'background' => 'green' };
|
|
}
|
|
|
|
$sth->finish;
|
|
}
|
|
|
|
$template->param( 'q' => $q );
|
|
$template->param( 'cn_loop' => \@cn ) if $#cn != -1;
|
|
$template->param( 'popup' => defined( $cgi->param('popup') ) );
|
|
$template->param( 'cn_source' => $cn_source ) if $cn_source;
|
|
$template->param( 'class_sources' => \@class_sources );
|
|
|
|
|
|
output_html_with_http_headers $cgi, $cookie, $template->output;
|
|
};
|
|
|
|
return { builder => $builder, launcher => $launcher };
|