To test:
1. Go to cataloging search and enter something like "7th Heaven".
2. Get an error when searching, Koha thinks you entered an ISBN
3. Apply patch
4. Try the same search, it should be a proper title search now
5. Find some stuff in the catalog with ISBN numbers in them.
6. The search should properly return ISBN13/ISBN10 searches, without with out the '-'.
Signed-off-by: David Nind <david@davidnind.com>
Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de>
Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
use Koha::SearchEngine::Search;
use Koha::SearchEngine::QueryBuilder;
use Koha::Z3950Servers;
+use Business::ISBN;
my $input = CGI->new;
my $countbr = 0;
my @resultsbr;
if ($query) {
-# fill isbn or title, depending on what has been entered
-#u must do check on isbn because u can find number in beginning of title
-#check is on isbn legnth 13 for new isbn and 10 for old isbn
my ( $title, $isbn );
- if ($query=~/\d/) {
- my $clean_query = $query;
- $clean_query =~ s/-//g; # remove hyphens
- my $querylength = length $clean_query;
- if ( $querylength == 13 || $querylength == 10 ) {
- $isbn = $query;
- }
- }
- if (!$isbn) {
+ my $isbn_valid = Business::ISBN->new($query);
+ if ( $isbn_valid && $isbn_valid->is_valid() ) {
+ $isbn = $query;
+ } else {
$title = $query;
}
( $countbr, @resultsbr ) = BreedingSearch( $title, $isbn );