2 # WARNING: 4-character tab stops here
4 # Copyright 2000-2002 Katipo Communications
6 # This file is part of Koha.
8 # Koha is free software; you can redistribute it and/or modify it under the
9 # terms of the GNU General Public License as published by the Free Software
10 # Foundation; either version 2 of the License, or (at your option) any later
13 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
14 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
15 # A PARTICULAR PURPOSE. See the GNU General Public License for more details.
17 # You should have received a copy of the GNU General Public License along
18 # with Koha; if not, write to the Free Software Foundation, Inc.,
19 # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
28 use C4::AuthoritiesMarc;
33 my $op = $query->param('op') || '';
34 my $authtypecode = $query->param('authtypecode') || '';
35 my $index = $query->param('index') || '';
36 my $tagid = $query->param('tagid') || '';
37 my $source = $query->param('source') || '';
38 my $relationship = $query->param('relationship') || '';
40 my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
42 template_name => ( $op eq 'do_search' )
43 ? 'authorities/searchresultlist-auth.tt'
44 : 'authorities/auth_finder.tt',
48 flagsrequired => { catalogue => 1 },
52 # Authority types loop
53 my $authtypes = C4::Koha::getauthtypes();
55 foreach my $thisauthtype ( keys %$authtypes ) {
57 value => $thisauthtype,
58 selected => ( $thisauthtype eq $authtypecode ),
59 authtypetext => $authtypes->{$thisauthtype}{'authtypetext'},
62 push @authtypesloop, \%row;
65 # If search form posted
66 if ( $op eq "do_search" ) {
67 my @marclist = $query->param('marclist');
68 my @and_or = $query->param('and_or');
69 my @excluding = $query->param('excluding');
70 my @operator = $query->param('operator');
72 $query->param('value_mainstr') || undef,
73 $query->param('value_main') || undef,
74 $query->param('value_any') || undef,
75 $query->param('value_match') || undef
77 my $orderby = $query->param('orderby') || '';
78 my $startfrom = $query->param('startfrom') || 0;
79 my $resultsperpage = $query->param('resultsperpage') || 20;
81 my ( $results, $total ) =
82 SearchAuthorities( \@marclist, \@and_or, \@excluding, \@operator, \@value,
83 $startfrom * $resultsperpage,
84 $resultsperpage, $authtypecode, $orderby );
86 # If an authority heading is repeated, add an arrayref to those repetions
87 # First heading -- Second heading
88 for my $heading (@$results) {
89 my @repets = split / -- /, $heading->{summary};
92 for ( my $i = 0 ; $i < @repets ; $i++ ) {
94 { index => $index, repet => $i + 1, value => $repets[$i] };
96 $heading->{repets} = \@repets_loop;
100 # multi page display gestion
102 my $displayprev = $startfrom;
103 if ( ( $total - ( ( $startfrom + 1 ) * ($resultsperpage) ) ) > 0 ) {
109 # get marclist again, as the previous one has been modified by catalogsearch (mainentry replaced by field name)
110 my @marclist_ini = $query->param('marclist');
111 for ( my $i = 0 ; $i <= $#marclist ; $i++ ) {
112 push @field_data, { term => "marclist", val => $marclist_ini[$i] };
113 push @field_data, { term => "and_or", val => $and_or[$i] };
114 push @field_data, { term => "excluding", val => $excluding[$i] };
115 push @field_data, { term => "operator", val => $operator[$i] };
119 { term => "value_mainstr", val => $query->param('value_mainstr') || "" };
121 { term => "value_main", val => $query->param('value_main') || "" };
123 { term => "value_any", val => $query->param('value_any') || "" };
125 { term => "value_match", val => $query->param('value_match') || "" };
128 if ( $total > $resultsperpage ) {
129 for ( my $i = 1 ; $i < $total / $resultsperpage + 1 ; $i++ ) {
132 ( $startfrom == ( $i - 1 ) ) && ( $highlight = 1 );
136 highlight => $highlight,
137 searchdata => \@field_data,
138 startfrom => ( $i - 1 )
144 my $from = $startfrom * $resultsperpage + 1;
146 if ( $total < ( ( $startfrom + 1 ) * $resultsperpage ) ) {
150 $to = ( ( $startfrom + 1 ) * $resultsperpage );
153 $template->param( result => $results ) if $results;
156 startfrom => $startfrom,
157 displaynext => $displaynext,
158 displayprev => $displayprev,
159 resultsperpage => $resultsperpage,
160 startfromnext => $startfrom + 1,
161 startfromprev => $startfrom - 1,
162 searchdata => \@field_data,
166 numbers => \@numbers,
167 operator_mainstr => ( @operator > 0 && $operator[0] )
170 operator_main => ( @operator > 1 && $operator[1] ) ? $operator[1] : '',
171 operator_any => ( @operator > 2 && $operator[2] ) ? $operator[2] : '',
172 operator_match => ( @operator > 3 && $operator[3] ) ? $operator[3] : '',
177 # special case for UNIMARC field 210c builder
178 my $resultstring = $query->param('result') || '';
179 $template->param( resultstring => $resultstring, );
184 value_mainstr => $query->param('value_mainstr') || '',
185 value_main => $query->param('value_main') || '',
186 value_any => $query->param('value_any') || '',
187 value_match => $query->param('value_match') || '',
190 authtypesloop => \@authtypesloop,
191 authtypecode => $authtypecode,
193 relationship => $relationship,
197 output_html_with_http_headers $query, $cookie, $template->output;