Bug 13437: Perltidy some plugin files before conversion
[koha.git] / cataloguing / value_builder / marc21_linking_section.pl
1 #!/usr/bin/perl
2
3 # Copyright Biblibre 2007 - CILEA 2011
4 #
5 # This file is part of Koha.
6 #
7 # Koha is free software; you can redistribute it and/or modify it
8 # under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 3 of the License, or
10 # (at your option) any later version.
11 #
12 # Koha is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU General Public License for more details.
16 #
17 # You should have received a copy of the GNU General Public License
18 # along with Koha; if not, see <http://www.gnu.org/licenses>.
19
20 use strict;
21 use warnings;
22
23 use CGI qw ( -utf8 );
24 use C4::Output;
25 use C4::Context;
26 use C4::Search;
27 use C4::Auth;
28 use C4::Output;
29
30 use C4::Biblio;
31 use C4::Koha;
32 use MARC::Record;
33 use C4::Branch;
34 use C4::ItemType;
35
36 sub plugin_javascript {
37     my ( $dbh, $record, $tagslib, $field_number, $tabloop ) = @_;
38     my $function_name = $field_number;
39     my $res           = "
40   <script type='text/javascript'>
41              function Clic$function_name(i) {
42                        defaultvalue=document.getElementById(\"$field_number\").value;
43                  window.open(\"/cgi-bin/koha/cataloguing/plugin_launcher.pl?plugin_name=marc21_linking_section.pl&index=\" + i + \"&result=\"+defaultvalue,\"marc21_field_7\"+i+\"\",'width=900,height=700,toolbar=false,scrollbars=yes');
44
45              }
46       </script>
47       ";
48
49     return ( $function_name, $res );
50 }
51
52 # sub plugin
53 #
54 # input arg :
55 # -- op could be equals to
56 # * fillinput :
57 # * do_search :
58 #
59
60 sub plugin {
61     my ($input)   = @_;
62     my $dbh       = C4::Context->dbh;
63     my $query     = new CGI;
64     my $op        = $query->param('op');
65     my $type      = $query->param('type');
66     my $startfrom = $query->param('startfrom');
67     $startfrom = 0 if ( !defined $startfrom );
68     my ( $template, $loggedinuser, $cookie );
69     my $resultsperpage;
70     my $searchdesc;
71
72     if ( $op eq "fillinput" ) {
73         my $biblionumber = $query->param('biblionumber');
74         my $index        = $query->param('index');
75         my $marcrecord;
76
77         # open template
78         ( $template, $loggedinuser, $cookie ) = get_template_and_user(
79             {   template_name   => "cataloguing/value_builder/marc21_linking_section.tt",
80                 query           => $query,
81                 type            => "intranet",
82                 authnotrequired => 0,
83                 flagsrequired   => { editcatalogue => '*' },
84                 debug           => 1,
85             }
86         );
87
88         #get marc record
89         $marcrecord = GetMarcBiblio($biblionumber);
90
91         my $subfield_value_9 = $biblionumber;
92         my $subfield_value_0 = $biblionumber;
93
94         #my $subfield_value_0;
95         #$subfield_value_0 = $marcrecord->field('001')->data
96         #  if $marcrecord->field('001');
97         my $subfield_value_w;
98         if ( $marcrecord->field('001') ) {
99             $subfield_value_w = $marcrecord->field('001')->data;
100         } else {
101             $subfield_value_w = $biblionumber;
102         }
103
104         my $subfield_value_a;
105         my $subfield_value_c;
106         my $subfield_value_d;
107         my $subfield_value_e;
108
109         my $subfield_value_h;
110
111         my $subfield_value_i;
112
113         my $subfield_value_p;
114
115         my $subfield_value_t;
116         if ( $marcrecord->field('245') ) {
117             $subfield_value_t = $marcrecord->title();
118         }
119
120         my $subfield_value_u;
121         my $subfield_value_v;
122         my $subfield_value_x;
123         my $subfield_value_y;
124         my $subfield_value_z;
125
126         $subfield_value_x = $marcrecord->field('022')->subfield("a")
127           if ( $marcrecord->field('022') );
128         $subfield_value_z = $marcrecord->field('020')->subfield("a")
129           if ( $marcrecord->field('020') );
130
131         # escape the 's
132         $subfield_value_9 =~ s/'/\\'/g;
133         $subfield_value_0 =~ s/'/\\'/g;
134         $subfield_value_a =~ s/'/\\'/g;
135         $subfield_value_c =~ s/'/\\'/g;
136         $subfield_value_d =~ s/'/\\'/g;
137         $subfield_value_e =~ s/'/\\'/g;
138         $subfield_value_h =~ s/'/\\'/g;
139         $subfield_value_i =~ s/'/\\'/g;
140         $subfield_value_p =~ s/'/\\'/g;
141         $subfield_value_t =~ s/'/\\'/g;
142         $subfield_value_u =~ s/'/\\'/g;
143         $subfield_value_v =~ s/'/\\'/g;
144         $subfield_value_w =~ s/'/\\'/g;
145         $subfield_value_x =~ s/'/\\'/g;
146         $subfield_value_y =~ s/'/\\'/g;
147         $subfield_value_z =~ s/'/\\'/g;
148         $template->param(
149             fillinput        => 1,
150             index            => $query->param('index') . "",
151             biblionumber     => $biblionumber ? $biblionumber : "",
152             subfield_value_9 => "$subfield_value_9",
153             subfield_value_0 => "$subfield_value_0",
154             subfield_value_a => "$subfield_value_a",
155             subfield_value_c => "$subfield_value_c",
156             subfield_value_d => "$subfield_value_d",
157             subfield_value_e => "$subfield_value_e",
158             subfield_value_h => "$subfield_value_h",
159             subfield_value_i => "$subfield_value_i",
160             subfield_value_p => "$subfield_value_p",
161             subfield_value_t => "$subfield_value_t",
162             subfield_value_u => "$subfield_value_u",
163             subfield_value_v => "$subfield_value_v",
164             subfield_value_w => "$subfield_value_w",
165             subfield_value_x => "$subfield_value_x",
166             subfield_value_y => "$subfield_value_y",
167             subfield_value_z => "$subfield_value_z",
168         );
169 ###############################################################
170     } elsif ( $op eq "do_search" ) {
171         my $search         = $query->param('search');
172         my $itype          = $query->param('itype');
173         my $startfrom      = $query->param('startfrom');
174         my $resultsperpage = $query->param('resultsperpage') || 20;
175         my $orderby;
176         my $QParser;
177         $QParser = C4::Context->queryparser if ( C4::Context->preference('UseQueryParser') );
178         my $op;
179
180         if ($QParser) {
181             $op = '&&';
182         } else {
183             $op = 'and';
184         }
185         $search = 'kw:' . $search . " $op mc-itemtype:" . $itype if $itype;
186         my ( $errors, $results, $total_hits ) = SimpleSearch( $search, $startfrom * $resultsperpage, $resultsperpage );
187         if ( defined $errors ) {
188             $results = [];
189         }
190         my $total = @{$results};
191
192         #        warn " biblio count : ".$total;
193
194         ( $template, $loggedinuser, $cookie ) = get_template_and_user(
195             {   template_name   => "cataloguing/value_builder/marc21_linking_section.tt",
196                 query           => $query,
197                 type            => 'intranet',
198                 authnotrequired => 0,
199                 debug           => 1,
200             }
201         );
202
203         # multi page display gestion
204         my $displaynext = 0;
205         my $displayprev = $startfrom;
206
207         if ( ( $total_hits - ( ( $startfrom + 1 ) * ($resultsperpage) ) ) > 0 ) {
208             $displaynext = 1;
209         }
210         my @arrayresults;
211         my @field_data = ($search);
212         for ( my $i = 0 ; $i < $resultsperpage ; $i++ ) {
213             my $record = C4::Search::new_record_from_zebra( 'biblioserver', $results->[$i] );
214             my $rechash = TransformMarcToKoha( $dbh, $record );
215             my $pos;
216             my $countitems = $rechash->{itembumber} ? 1 : 0;
217             while ( index( $rechash->{itemnumber}, '|', $pos ) > 0 ) {
218                 $countitems += 1;
219                 $pos = index( $rechash->{itemnumber}, '|', $pos ) + 1;
220             }
221             $rechash->{totitem} = $countitems;
222             my @holdingbranches = split /\|/, $rechash->{holdingbranch};
223             my @itemcallnumbers = split /\|/, $rechash->{itemcallnumber};
224             my $CN;
225             for ( my $i = 0 ; $i < @holdingbranches ; $i++ ) {
226                 $CN .= $holdingbranches[$i] . " ( " . $itemcallnumbers[$i] . " ) |";
227             }
228             $CN =~ s/ \|$//;
229             $rechash->{CN} = $CN;
230             push @arrayresults, $rechash;
231         }
232
233         #         for(my $i = 0 ; $i <= $#marclist ; $i++)
234         #         {
235         #             push @field_data, { term => "marclist", val=>$marclist[$i] };
236         #             push @field_data, { term => "and_or", val=>$and_or[$i] };
237         #             push @field_data, { term => "excluding", val=>$excluding[$i] };
238         #             push @field_data, { term => "operator", val=>$operator[$i] };
239         #             push @field_data, { term => "value", val=>$value[$i] };
240         #         }
241
242         my @numbers = ();
243
244         if ( $total > $resultsperpage ) {
245             for ( my $i = 1 ; $i < $total / $resultsperpage + 1 ; $i++ ) {
246                 if ( $i < 16 ) {
247                     my $highlight = 0;
248                     ( $startfrom == ( $i - 1 ) ) && ( $highlight = 1 );
249                     push @numbers,
250                       { number     => $i,
251                         highlight  => $highlight,
252                         searchdata => \@field_data,
253                         startfrom  => ( $i - 1 )
254                       };
255                 }
256             }
257         }
258
259         my $from = $startfrom * $resultsperpage + 1;
260         my $to;
261
262         if ( $total_hits < $from + $resultsperpage ) {
263             $to = $total_hits;
264         } else {
265             $to = $from + $resultsperpage;
266         }
267         my $defaultview = 'BiblioDefaultView' . C4::Context->preference('BiblioDefaultView');
268
269         #         my $link="/cgi-bin/koha/cataloguing/value_builder/unimarc4XX.pl?op=do_search&q=$search_desc&resultsperpage=$resultsperpage&startfrom=$startfrom&search=$search";
270         #           foreach my $sort (@sort_by){
271         #             $link.="&sort_by=".$sort."&";
272         #           }
273         #           $template->param(
274         #             pagination_bar => pagination_bar(
275         #                     $link,
276         #                     getnbpages($hits, $results_per_page),
277         #                     $page,
278         #                     'page'
279         #             ),
280         #           );
281         $template->param(
282             result         => \@arrayresults,
283             index          => $query->param('index') . "",
284             startfrom      => $startfrom,
285             displaynext    => $displaynext,
286             displayprev    => $displayprev,
287             resultsperpage => $resultsperpage,
288             orderby        => $orderby,
289             startfromnext  => $startfrom + 1,
290             startfromprev  => $startfrom - 1,
291             searchdata     => \@field_data,
292             total          => $total_hits,
293             from           => $from,
294             to             => $to,
295             numbers        => \@numbers,
296             search         => $search,
297             $defaultview   => 1,
298             Search         => 0
299         );
300
301     } else {
302         ( $template, $loggedinuser, $cookie ) = get_template_and_user(
303             {   template_name   => "cataloguing/value_builder/marc21_linking_section.tt",
304                 query           => $query,
305                 type            => "intranet",
306                 authnotrequired => 0,
307             }
308         );
309
310         my @itemtypes = C4::ItemType->all;
311
312         $template->param(
313             itypeloop => \@itemtypes,
314             index     => $query->param('index'),
315             Search    => 1,
316         );
317     }
318     output_html_with_http_headers $query, $cookie, $template->output;
319 }