Bug 5698: Add date picker option to SQL Runtime Parameters
[koha.git] / catalogue / moredetail.pl
blobf5bb90452b5ebc0928f4bf069e906689088c27fa
1 #!/usr/bin/perl
3 # Copyright 2000-2003 Katipo Communications
4 # parts copyright 2010 BibLibre
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
11 # version.
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.
22 use strict;
23 #use warnings; FIXME - Bug 2505
24 use C4::Koha;
25 use CGI;
26 use C4::Biblio;
27 use C4::Items;
28 use C4::Branch;
29 use C4::Acquisition;
30 use C4::Output;
31 use C4::Auth;
32 use C4::Serials;
33 use C4::Dates qw/format_date/;
34 use C4::Circulation; # to use itemissues
35 use C4::Members; # to use GetMember
36 use C4::Search; # enabled_staff_search_views
37 use C4::Members qw/GetHideLostItemsPreference/;
39 my $query=new CGI;
41 # FIXME subject is not exported to the template?
42 my $subject=$query->param('subject');
44 # if its a subject we need to use the subject.tmpl
45 my ($template, $loggedinuser, $cookie) = get_template_and_user({
46 template_name => ($subject? 'catalogue/subject.tmpl':
47 'catalogue/moredetail.tmpl'),
48 query => $query,
49 type => "intranet",
50 authnotrequired => 0,
51 flagsrequired => {catalogue => 1},
52 });
54 if($query->cookie("holdfor")){
55 my $holdfor_patron = GetMember('borrowernumber' => $query->cookie("holdfor"));
56 $template->param(
57 holdfor => $query->cookie("holdfor"),
58 holdfor_surname => $holdfor_patron->{'surname'},
59 holdfor_firstname => $holdfor_patron->{'firstname'},
60 holdfor_cardnumber => $holdfor_patron->{'cardnumber'},
64 # get variables
66 my $biblionumber=$query->param('biblionumber');
67 my $title=$query->param('title');
68 my $bi=$query->param('bi');
69 $bi = $biblionumber unless $bi;
70 my $itemnumber = $query->param('itemnumber');
71 my $data = &GetBiblioData($biblionumber);
72 my $dewey = $data->{'dewey'};
73 my $showallitems = $query->param('showallitems');
75 #coping with subscriptions
76 my $subscriptionsnumber = CountSubscriptionFromBiblionumber($biblionumber);
78 # FIXME Dewey is a string, not a number, & we should use a function
79 # $dewey =~ s/0+$//;
80 # if ($dewey eq "000.") { $dewey = "";};
81 # if ($dewey < 10){$dewey='00'.$dewey;}
82 # if ($dewey < 100 && $dewey > 10){$dewey='0'.$dewey;}
83 # if ($dewey <= 0){
84 # $dewey='';
85 # }
86 # $dewey=~ s/\.$//;
87 # $data->{'dewey'}=$dewey;
89 my $fw = GetFrameworkCode($biblionumber);
90 my @all_items= GetItemsInfo($biblionumber);
91 my @items;
92 for my $itm (@all_items) {
93 push @items, $itm unless ( $itm->{itemlost} &&
94 GetHideLostItemsPreference($loggedinuser) &&
95 !$showallitems &&
96 ($itemnumber != $itm->{itemnumber}));
99 my $record=GetMarcBiblio($biblionumber);
101 my $hostrecords;
102 # adding items linked via host biblios
103 my @hostitems = GetHostItemsInfo($record);
104 if (@hostitems){
105 $hostrecords =1;
106 push (@items,@hostitems);
109 my $subtitle = GetRecordValue('subtitle', $record, $fw);
111 my $totalcount=@all_items;
112 my $showncount=@items;
113 my $hiddencount = $totalcount - $showncount;
114 $data->{'count'}=$totalcount;
115 $data->{'showncount'}=$showncount;
116 $data->{'hiddencount'}=$hiddencount; # can be zero
118 my $ccodes= GetKohaAuthorisedValues('items.ccode',$fw);
119 my $itemtypes = GetItemTypes;
121 $data->{'itemtypename'} = $itemtypes->{$data->{'itemtype'}}->{'description'};
123 foreach ( keys %{$data} ) {
124 $template->param( "$_" => defined $data->{$_} ? $data->{$_} : '' );
127 ($itemnumber) and @items = (grep {$_->{'itemnumber'} == $itemnumber} @items);
128 foreach my $item (@items){
129 $item->{itemlostloop}= GetAuthorisedValues(GetAuthValCode('items.itemlost',$fw),$item->{itemlost}) if GetAuthValCode('items.itemlost',$fw);
130 $item->{itemdamagedloop}= GetAuthorisedValues(GetAuthValCode('items.damaged',$fw),$item->{damaged}) if GetAuthValCode('items.damaged',$fw);
131 $item->{'collection'} = $ccodes->{ $item->{ccode} } if ($ccodes);
132 $item->{'itype'} = $itemtypes->{ $item->{'itype'} }->{'description'};
133 $item->{'replacementprice'} = sprintf( "%.2f", $item->{'replacementprice'} );
134 $item->{$_} = format_date( $item->{$_} ) foreach qw/datelastborrowed dateaccessioned datelastseen lastreneweddate/;
135 $item->{'copyvol'} = $item->{'copynumber'};
138 # item has a host number if its biblio number does not match the current bib
139 if ($item->{biblionumber} ne $biblionumber){
140 $item->{hostbiblionumber} = $item->{biblionumber};
141 $item->{hosttitle} = GetBiblioData($item->{biblionumber})->{title};
144 my $order = GetOrderFromItemnumber( $item->{'itemnumber'} );
145 my $basket = GetBasket( $order->{'basketno'} );
146 $item->{'booksellerid'} = $basket->{'booksellerid'};
147 $item->{'ordernumber'} = $order->{'ordernumber'};
148 $item->{'basketno'} = $order->{'basketno'};
149 $item->{'booksellerinvoicenumber'} = $order->{'booksellerinvoicenumber'};
150 $item->{'datereceived'} = $order->{'datereceived'};
152 if ($item->{notforloantext} or $item->{itemlost} or $item->{damaged} or $item->{wthdrawn}) {
153 $item->{status_advisory} = 1;
156 if (C4::Context->preference("IndependantBranches")) {
157 #verifying rights
158 my $userenv = C4::Context->userenv();
159 unless (($userenv->{'flags'} == 1) or ($userenv->{'branch'} eq $item->{'homebranch'})) {
160 $item->{'nomod'}=1;
163 $item->{'homebranchname'} = GetBranchName($item->{'homebranch'});
164 $item->{'holdingbranchname'} = GetBranchName($item->{'holdingbranch'});
165 if ($item->{'datedue'}) {
166 $item->{'datedue'} = format_date($item->{'datedue'});
167 $item->{'issue'}= 1;
168 } else {
169 $item->{'issue'}= 0;
172 $template->param(count => $data->{'count'},
173 subscriptionsnumber => $subscriptionsnumber,
174 subscriptiontitle => $data->{title},
175 C4::Search::enabled_staff_search_views,
178 $template->param(
179 ITEM_DATA => \@items,
180 moredetailview => 1,
181 loggedinuser => $loggedinuser,
182 biblionumber => $biblionumber,
183 biblioitemnumber => $bi,
184 itemnumber => $itemnumber,
185 z3950_search_params => C4::Search::z3950_search_args(GetBiblioData($biblionumber)),
186 subtitle => $subtitle,
188 $template->param(ONLY_ONE => 1) if ( $itemnumber && $showncount != @items );
190 output_html_with_http_headers $query, $cookie, $template->output;