From 73689bad1740b99d7d1db2d58289ed2f09dac32b Mon Sep 17 00:00:00 2001 From: Jonathan Druart Date: Wed, 6 Nov 2019 12:19:11 +0100 Subject: [PATCH] Bug 21249: Code cleaning Trying to make the code a bit more readable removing unecessary variables and parenthesis. Code is duplicated but no idea where we could move it to. Signed-off-by: Jonathan Druart Signed-off-by: Victor Grousset/tuxayo Signed-off-by: David Cook Signed-off-by: Jonathan Druart --- catalogue/search.pl | 30 ++++++++++++++++-------------- opac/opac-search.pl | 29 +++++++++++++++++------------ 2 files changed, 33 insertions(+), 26 deletions(-) diff --git a/catalogue/search.pl b/catalogue/search.pl index 7c1265e220..2da010e001 100755 --- a/catalogue/search.pl +++ b/catalogue/search.pl @@ -379,21 +379,23 @@ my @nolimits = map uri_unescape($_), $cgi->multi_param('nolimit'); my %is_nolimit = map { $_ => 1 } @nolimits; @limits = grep { not $is_nolimit{$_} } @limits; -my $branchfield = C4::Context->preference('AdvancedSearchBranchFieldToUse'); - -if($params->{'multibranchlimit'}) { +if ( $params->{'multibranchlimit'} ) { + my $branchfield = C4::Context->preference('AdvancedSearchBranchFieldToUse'); my $search_group = Koha::Library::Groups->find( $params->{multibranchlimit} ); - my @libraries = $search_group->all_libraries; - - if ( $branchfield eq "homebranch") { - my $multihomebranch = '('.join( " OR ", map { 'homebranch: ' . $_->branchcode } @libraries ) .')'; - push @limits, $multihomebranch if ( $multihomebranch ne '()'); - } elsif ( $branchfield eq "holdingbranch") { - my $multiholdingbranch = '('.join( " OR ", map { 'holdingbranch: ' . $_->branchcode } @libraries ) .')'; - push @limits, $multiholdingbranch if ( $multiholdingbranch ne '()'); - } else { - my $multihomeandholdingbranch = '('.join( " OR ", map { 'homebranch: ' . $_->branchcode, 'holdingbranch: ' . $_->branchcode} @libraries ) .')'; - push @limits, $multihomeandholdingbranch if ($multihomeandholdingbranch ne '()'); + my @branchcodes = map { $_->branchcode } $search_group->all_libraries; + + if (@branchcodes) { + if ( $branchfield eq "homebranch" ) { + push @limits, sprintf "(%s)", join " or ", map { 'homebranch: ' . $_ } @branchcodes; + } + elsif ( $branchfield eq "holdingbranch" ) { + push @limits, sprintf "(%s)", join " or ", map { 'holdingbranch: ' . $_ } @branchcodes; + } + else { + push @limits, sprintf "(%s or %s)", + join( " or ", map { 'homebranch: ' . $_ } @branchcodes ), + join( " or ", map { 'holdingbranch: ' . $_ } @branchcodes ); + } } } diff --git a/opac/opac-search.pl b/opac/opac-search.pl index d4694e105d..410f3f37c5 100755 --- a/opac/opac-search.pl +++ b/opac/opac-search.pl @@ -486,19 +486,24 @@ if (@searchCategories > 0) { my $branchfield = C4::Context->preference('AdvancedSearchBranchFieldToUse'); -if($params->{'multibranchlimit'}) { +if ( $params->{'multibranchlimit'} ) { + my $branchfield = C4::Context->preference('AdvancedSearchBranchFieldToUse'); my $search_group = Koha::Library::Groups->find( $params->{multibranchlimit} ); - my @libraries = $search_group->all_libraries; - - if ( $branchfield eq "homebranch" ) { - my $multihomebranch = '('.join( " OR ", map { 'homebranch: ' . $_->branchcode } @libraries ) .')'; - push @limits, $multihomebranch if ( $multihomebranch ne '()'); - } elsif ( $branchfield eq "holdingbranch") { - my $multiholdingbranch = '('.join( " OR ", map { 'holdingbranch: ' . $_->branchcode } @libraries ) .')'; - push @limits, $multiholdingbranch if ( $multiholdingbranch ne '()'); - } else { - my $multihomeandholdingbranch = '('.join( " OR ", map { 'homebranch: ' . $_->branchcode, 'holdingbranch: ' . $_->branchcode} @libraries ) .')'; - push @limits, $multihomeandholdingbranch if ($multihomeandholdingbranch ne '()'); + + my @branchcodes = map { $_->branchcode } $search_group->all_libraries; + + if (@branchcodes) { + if ( $branchfield eq "homebranch" ) { + push @limits, sprintf "(%s)", join " or ", map { 'homebranch: ' . $_ } @branchcodes; + } + elsif ( $branchfield eq "holdingbranch" ) { + push @limits, sprintf "(%s)", join " or ", map { 'holdingbranch: ' . $_ } @branchcodes; + } + else { + push @limits, sprintf "(%s or %s)", + join( " or ", map { 'homebranch: ' . $_ } @branchcodes ), + join( " or ", map { 'holdingbranch: ' . $_ } @branchcodes ); + } } } -- 2.39.5