MT 1587 : CSV export for cart and shelves, with the ability to define different expor...
[koha.git] / catalogue / moredetail.pl
1 #!/usr/bin/perl
2
3 # Copyright 2000-2003 Katipo Communications
4 #
5 # This file is part of Koha.
6 #
7 # Koha is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU General Public License as published by the Free Software
9 # Foundation; either version 2 of the License, or (at your option) any later
10 # version.
11 #
12 # Koha is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
14 # A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
15 #
16 # You should have received a copy of the GNU General Public License along with
17 # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
18 # Suite 330, Boston, MA  02111-1307 USA
19
20
21 use strict;
22 use C4::Koha;
23 use CGI;
24 use C4::Biblio;
25 use C4::Items;
26 use C4::Branch;
27 use C4::Acquisition;
28 use C4::Output;             # contains gettemplate
29 use C4::Auth;
30 use C4::Serials;
31 use C4::Dates qw/format_date/;
32 use C4::Circulation;  # to use itemissues
33 use C4::Search;         # enabled_staff_search_views
34
35 my $query=new CGI;
36
37 # FIXME  subject is not exported to the template?
38 my $subject=$query->param('subject');
39
40 # if its a subject we need to use the subject.tmpl
41 my ($template, $loggedinuser, $cookie) = get_template_and_user({
42     template_name   => ($subject? 'catalogue/subject.tmpl':
43                       'catalogue/moredetail.tmpl'),
44     query           => $query,
45     type            => "intranet",
46     authnotrequired => 0,
47     flagsrequired   => {catalogue => 1},
48     });
49
50 # get variables
51
52 my $biblionumber=$query->param('biblionumber');
53 my $title=$query->param('title');
54 my $bi=$query->param('bi');
55 $bi = $biblionumber unless $bi;
56 my $data=GetBiblioData($biblionumber);
57 my $dewey = $data->{'dewey'};
58
59 #coping with subscriptions
60 my $subscriptionsnumber = CountSubscriptionFromBiblionumber($biblionumber);
61
62 # FIXME Dewey is a string, not a number, & we should use a function
63 # $dewey =~ s/0+$//;
64 # if ($dewey eq "000.") { $dewey = "";};
65 # if ($dewey < 10){$dewey='00'.$dewey;}
66 # if ($dewey < 100 && $dewey > 10){$dewey='0'.$dewey;}
67 # if ($dewey <= 0){
68 #      $dewey='';
69 # }
70 # $dewey=~ s/\.$//;
71 # $data->{'dewey'}=$dewey;
72
73 my @results;
74 my $fw = GetFrameworkCode($biblionumber);
75 my @items= GetItemsInfo($biblionumber);
76 my $count=@items;
77 $data->{'count'}=$count;
78
79 my $ccodes= GetKohaAuthorisedValues('items.ccode',$fw);
80 my $itemtypes = GetItemTypes;
81
82 $data->{'itemtypename'} = $itemtypes->{$data->{'itemtype'}}->{'description'};
83 $results[0]=$data;
84 my $itemnumber;
85 ($itemnumber) and @items = (grep {$_->{'itemnumber'} == $itemnumber} @items);
86 foreach my $item (@items){
87     $item->{itemlostloop}= GetAuthorisedValues(GetAuthValCode('items.itemlost',$fw),$item->{itemlost}) if GetAuthValCode('items.itemlost',$fw);
88     $item->{itemdamagedloop}= GetAuthorisedValues(GetAuthValCode('items.damaged',$fw),$item->{damaged}) if GetAuthValCode('items.damaged',$fw);
89     $item->{'collection'}              = $ccodes->{ $item->{ccode} };
90     $item->{'itype'}                   = $itemtypes->{ $item->{'itype'} }->{'description'};
91     $item->{'replacementprice'}        = sprintf( "%.2f", $item->{'replacementprice'} );
92     $item->{'datelastborrowed'}        = format_date( $item->{'datelastborrowed'} );
93     $item->{'dateaccessioned'}         = format_date( $item->{'dateaccessioned'} );
94     $item->{'datelastseen'}            = format_date( $item->{'datelastseen'} );
95     $item->{'copyvol'}                 = $item->{'copynumber'};
96
97     my $order = GetOrderFromItemnumber( $item->{'itemnumber'} );
98     $item->{'ordernumber'}             = $order->{'ordernumber'};
99     $item->{'basketno'}                = $order->{'basketno'};
100     $item->{'booksellerinvoicenumber'} = $order->{'booksellerinvoicenumber'};
101
102     if ($item->{notforloantext} or $item->{itemlost} or $item->{damaged} or $item->{wthdrawn}) {
103         $item->{status_advisory} = 1;
104     }
105
106     if (C4::Context->preference("IndependantBranches")) {
107         #verifying rights
108         my $userenv = C4::Context->userenv();
109         unless (($userenv->{'flags'} == 1) or ($userenv->{'branch'} eq $item->{'homebranch'})) {
110                 $item->{'nomod'}=1;
111         }
112     }
113     $item->{'homebranchname'} = GetBranchName($item->{'homebranch'});
114     $item->{'holdingbranchname'} = GetBranchName($item->{'holdingbranch'});
115     if ($item->{'datedue'}) {
116         $item->{'datedue'} = format_date($item->{'datedue'});
117         $item->{'issue'}= 1;
118     } else {
119         $item->{'issue'}= 0;
120     }
121 }
122 $template->param(count => $data->{'count'},
123         subscriptionsnumber => $subscriptionsnumber,
124     subscriptiontitle   => $data->{title},
125         C4::Search::enabled_staff_search_views,
126 );
127 $template->param(BIBITEM_DATA => \@results);
128 $template->param(ITEM_DATA => \@items);
129 $template->param(moredetailview => 1);
130 $template->param(loggedinuser => $loggedinuser);
131 $template->param(biblionumber => $biblionumber);
132 $template->param(biblioitemnumber => $bi);
133 $template->param(itemnumber => $itemnumber);
134 $template->param(ONLY_ONE => 1) if ( $itemnumber && $count != @items );
135 $template->param(z3950_search_params => C4::Search::z3950_search_args(GetBiblioData($biblionumber)));
136
137 output_html_with_http_headers $query, $cookie, $template->output;
138