0e7f7ab051
This is an interface for quick and efficient browsing through records. It presents a page at /cgi-bin/koha/opac-browse.pl that allows you to enter the prefix of an author, title, or subject and it'll give you a list of the options that match that. You can then scroll through these and select the one you're after. Selecting it provides a list of records that match that particular search. To Test: 1 - Apply patches 2 - Update database (updatedatabase on kohadevbox) 3 - Compile the CSS https://wiki.koha-community.org/wiki/Working_with_SCSS_in_the_OPAC_and_staff_client yarn build --view=opac on kohadevbox 4 - Enable the new syspref OpacBrowseSearch 5 - Have ES running and some records in it SearchEngine syspref set to Elasticsearch 6 - Browse to opac home, click 'Browse search' link for your site) 7 - Test searching for author, title, and subject 8 - Verify that results are returned in expected order 9 - Experiment with fuzziness https://www.elastic.co/guide/en/elasticsearch/reference/5.6/common-options.html#fuzziness Options are: exact (0 edits), fuzzy (1 edit), very fuzzy (2 edits) 10 - Click any result and verify specific titles are correct 11 - Click through title to record and verify it is the correct record 12 - Test that disabling pref removes the link on the opac home Signed-off-by: David Nind <david@davidnind.com> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
112 lines
3.5 KiB
Perl
Executable file
112 lines
3.5 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# This is a CGI script that handles the browse feature.
|
|
|
|
# Copyright 2015 Catalyst IT
|
|
#
|
|
# 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 qw ( -utf8 );
|
|
|
|
use C4::Auth;
|
|
use C4::Context;
|
|
use C4::Output;
|
|
|
|
use Koha::SearchEngine::Elasticsearch;
|
|
use Koha::SearchEngine::Elasticsearch::Browse;
|
|
use Koha::SearchEngine::Elasticsearch::QueryBuilder;
|
|
use Koha::SearchEngine::Elasticsearch::Search;
|
|
|
|
use JSON;
|
|
use Unicode::Collate;
|
|
|
|
my $query = new CGI;
|
|
binmode STDOUT, ':encoding(UTF-8)';
|
|
|
|
# If calling via JS, 'api' is used to route to correct step in process
|
|
my $api = $query->param('api');
|
|
|
|
if ( !$api ) {
|
|
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
|
|
{
|
|
template_name => "opac-browse.tt",
|
|
query => $query,
|
|
type => "opac",
|
|
authnotrequired => ( C4::Context->preference("OpacPublic") ? 1 : 0 ),
|
|
}
|
|
);
|
|
$template->param();
|
|
output_html_with_http_headers $query, $cookie, $template->output;
|
|
|
|
|
|
}
|
|
elsif ( $api eq 'GetSuggestions' ) {
|
|
my $fuzzie = $query->param('fuzziness');
|
|
my $prefix = $query->param('prefix');
|
|
my $field = $query->param('field');
|
|
|
|
# Under a persistent environment, we should probably not reinit this every time.
|
|
my $browser = Koha::SearchEngine::Elasticsearch::Browse->new( { index => 'biblios' } );
|
|
my $res = $browser->browse( $prefix, $field, { fuzziness => $fuzzie } );
|
|
|
|
my %seen;
|
|
my @sorted =
|
|
grep { !$seen{$_->{text}}++ }
|
|
sort { lc($a->{text}) cmp lc($b->{text}) } @$res;
|
|
print CGI::header(
|
|
-type => 'application/json',
|
|
-charset => 'utf-8'
|
|
);
|
|
print to_json( \@sorted );
|
|
}
|
|
elsif ( $api eq 'GetResults' ) {
|
|
my $term = $query->param('term');
|
|
my $field = $query->param('field');
|
|
|
|
my $builder = Koha::SearchEngine::Elasticsearch::QueryBuilder->new( { index => 'biblios' } );
|
|
my $searcher = Koha::SearchEngine::Elasticsearch::Search->new(
|
|
{ index => $Koha::SearchEngine::Elasticsearch::BIBLIOS_INDEX } );
|
|
|
|
my $query = { query => { term => { $field.".raw" => $term } } } ;
|
|
my $results = $searcher->search( $query, undef, 500 );
|
|
my @output = _filter_for_output( $results->{hits}->{hits} );
|
|
print CGI::header(
|
|
-type => 'application/json',
|
|
-charset => 'utf-8'
|
|
);
|
|
print to_json( \@output );
|
|
}
|
|
|
|
# This should probably be done with some templatey gizmo
|
|
# in the future.
|
|
sub _filter_for_output {
|
|
my ($records) = @_;
|
|
my @output;
|
|
foreach my $rec (@$records) {
|
|
my $biblionumber = $rec->{_id};
|
|
my $biblio = Koha::Biblios->find( $biblionumber );
|
|
next unless $biblio;
|
|
push @output,
|
|
{
|
|
id => $biblionumber,
|
|
title => $biblio->title,
|
|
author => $biblio->author,
|
|
};
|
|
};
|
|
my @sorted = sort { lc($a->{title}) cmp lc($b->{title}) } @output;
|
|
return @sorted;
|
|
}
|