X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=opac%2Fopac-shelves.pl;h=6e5052dfb838ae6049612884214a60fa996f57cb;hb=fd152d9e95a2236a00f3cb0284bdd2aa7cca6da2;hp=26bc355eb7d562ee2b128909a53f740557bedf62;hpb=93ff09d081d2fb6d2732ad8d6522517508ae31ed;p=koha.git diff --git a/opac/opac-shelves.pl b/opac/opac-shelves.pl index 26bc355eb7..6e5052dfb8 100755 --- a/opac/opac-shelves.pl +++ b/opac/opac-shelves.pl @@ -1,275 +1,367 @@ #!/usr/bin/perl -#script to provide bookshelf management -# WARNING: This file uses 4-character tabs! -# -# $Header$ -# -# Copyright 2000-2002 Katipo Communications + +# Copyright 2015 Koha Team # # This file is part of Koha. # -# Koha is free software; you can redistribute it and/or modify it under the -# terms of the GNU General Public License as published by the Free Software -# Foundation; either version 2 of the License, or (at your option) any later -# version. +# Koha is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 3 of the License, or +# (at your option) any later version. # -# Koha is distributed in the hope that it will be useful, but WITHOUT ANY -# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR -# A PARTICULAR PURPOSE. See the GNU General Public License for more details. +# Koha is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. # -# You should have received a copy of the GNU General Public License along with -# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place, -# Suite 330, Boston, MA 02111-1307 USA +# You should have received a copy of the GNU General Public License +# along with Koha; if not, see . -use strict; -use C4::Search; -use CGI; -use C4::Output; -use C4::BookShelves; -use C4::Circulation::Circ2; +use Modern::Perl; +use CGI qw ( -utf8 ); use C4::Auth; -use C4::Interface::CGI::Output; -use HTML::Template; +use C4::Biblio; +use C4::Koha; +use C4::Items; +use C4::Members; +use C4::Output; +use C4::Tags qw( get_tags ); +use C4::XSLT; +use Koha::Virtualshelves; -my $env; my $query = new CGI; -my ($template, $loggedinuser, $cookie) - = get_template_and_user({template_name => "opac-shelves.tmpl", - query => $query, - type => "opac", - authnotrequired => 1, - }); - -if ($query->param('modifyshelfcontents')) { - my $shelfnumber=$query->param('shelfnumber'); - my $barcode=$query->param('addbarcode'); - my ($item) = getiteminformation($env, 0, $barcode); - if (ShelfPossibleAction($loggedinuser,$shelfnumber,'manage')) { - AddToShelf($env, $item->{'itemnumber'}, $shelfnumber); - foreach ($query->param) { - if (/REM-(\d*)/) { - my $itemnumber=$1; - RemoveFromShelf($env, $itemnumber, $shelfnumber); - } - } - } -} -my ($shelflist) = GetShelfList($loggedinuser,2); - -$template->param({ loggedinuser => $loggedinuser, - }); -SWITCH: { - if ($query->param('op') eq 'modifsave') { - ModifShelf($query->param('shelfnumber'),$query->param('shelfname'),$loggedinuser,$query->param('category')); - last SWITCH; - } - if ($query->param('op') eq 'modif') { - my ($shelfnumber,$shelfname,$owner,$category) = GetShelf($query->param('shelf')); - $template->param(edit => 1, - shelfnumber => $shelfnumber, - shelfname => $shelfname, - "category$category" => 1); -# editshelf($query->param('shelf')); - last SWITCH; - } - if ($query->param('viewshelf')) { - viewshelf($query->param('viewshelf')); - last SWITCH; - } - if ($query->param('shelves')) { - shelves(); - last SWITCH; - } -} -($shelflist) = GetShelfList($loggedinuser,2); # rebuild shelflist in case a shelf has been added - -my $color=''; -my @shelvesloop; -foreach my $element (sort keys %$shelflist) { - my %line; - ($color eq 0) ? ($color=1) : ($color=0); - $line{'color'}= $color; - $line{'shelf'}=$element; - $line{'shelfname'}=$shelflist->{$element}->{'shelfname'}; - $line{"category".$shelflist->{$element}->{'category'}} = 1; - $line{'mine'} = 1 if $shelflist->{$element}->{'owner'} eq $loggedinuser; - $line{'shelfbookcount'}=$shelflist->{$element}->{'count'}; - $line{'canmanage'} = ShelfPossibleAction($loggedinuser,$element,'manage'); - $line{'firstname'}=$shelflist->{$element}->{'firstname'} unless $shelflist->{$element}->{'owner'} eq $loggedinuser; - $line{'surname'}=$shelflist->{$element}->{'surname'} unless $shelflist->{$element}->{'owner'} eq $loggedinuser; -; - push (@shelvesloop, \%line); +my $template_name = $query->param('rss') ? "opac-shelves-rss.tt" : "opac-shelves.tt"; + +# if virtualshelves is disabled, leave immediately +if ( ! C4::Context->preference('virtualshelves') ) { + print $query->redirect("/cgi-bin/koha/errors/404.pl"); + exit; } -$template->param(shelvesloop => \@shelvesloop); -output_html_with_http_headers $query, $cookie, $template->output; +my ( $template, $loggedinuser, $cookie ) = get_template_and_user({ + template_name => $template_name, + query => $query, + type => "opac", + authnotrequired => ( C4::Context->preference("OpacPublic") ? 1 : 0 ), + }); -# sub editshelf { -# my ($shelfnumber) = @_; -# my ($shelfnumber,$shelfname,$owner,$category) = GetShelf($shelfnumber); -# $template->param(edit => 1, -# shelfnumber => $shelfnumber, -# shelfname => $shelfname, -# "category$category" => 1); -# } -sub shelves { - if (my $newshelf=$query->param('addshelf')) { - my ($status, $string) = AddShelf($env,$newshelf,$query->param('owner'),$query->param('category')); - if ($status) { - $template->param(status1 => $status, string1 => $string); - } - } - my @paramsloop; - foreach ($query->param()) { - my %line; - if (/DEL-(\d+)/) { - my $delshelf=$1; - my ($status, $string) = RemoveShelf($env,$delshelf); - if ($status) { - $line{'status'}=$status; - $line{'string'} = $string; - } - } - #if the shelf is not deleted, %line points on null - push(@paramsloop,\%line); - } - $template->param(paramsloop => \@paramsloop); - my ($shelflist) = GetShelfList($loggedinuser,2); - my $color=''; - my @shelvesloop; - foreach my $element (sort keys %$shelflist) { - my %line; - ($color eq 0) ? ($color=1) : ($color=0); - $line{'color'}=$color; - $line{'shelf'}=$element; - $line{'shelfname'}=$shelflist->{$element}->{'shelfname'} ; - $line{'shelfbookcount'}=$shelflist->{$element}->{'count'} ; - push(@shelvesloop, \%line); - } - $template->param(shelvesloop=>\@shelvesloop, - shelves => 1, - ); -} +my $op = $query->param('op') || 'list'; +my $referer = $query->param('referer') || $op; +my $category = $query->param('category') || 1; +my ( $shelf, $shelfnumber, @messages ); + +if ( $op eq 'add_form' ) { + # Nothing to do +} elsif ( $op eq 'edit_form' ) { + $shelfnumber = $query->param('shelfnumber'); + $shelf = Koha::Virtualshelves->find($shelfnumber); + + if ( $shelf ) { + $category = $shelf->category; + my $patron = GetMember( 'borrowernumber' => $shelf->owner ); + $template->param( owner => $patron, ); + unless ( $shelf->can_be_managed( $loggedinuser ) ) { + push @messages, { type => 'error', code => 'unauthorized_on_update' }; + $op = 'list'; + } + } else { + push @messages, { type => 'error', code => 'does_not_exist' }; + } +} elsif ( $op eq 'add' ) { + if ( $loggedinuser ) { + eval { + $shelf = Koha::Virtualshelf->new( + { shelfname => scalar $query->param('shelfname'), + sortfield => scalar $query->param('sortfield'), + category => scalar $query->param('category') || 1, + allow_add => scalar $query->param('allow_add'), + allow_delete_own => scalar $query->param('allow_delete_own'), + allow_delete_other => scalar $query->param('allow_delete_other'), + owner => scalar $loggedinuser, + } + ); + $shelf->store; + $shelfnumber = $shelf->shelfnumber; + }; + if ($@) { + push @messages, { type => 'error', code => ref($@), msg => $@ }; + } elsif ( not $shelf ) { + push @messages, { type => 'error', code => 'error_on_insert' }; + } else { + push @messages, { type => 'message', code => 'success_on_insert' }; + $op = 'view'; + } + } else { + push @messages, { type => 'error', code => 'unauthorized_on_insert' }; + $op = 'list'; + } +} elsif ( $op eq 'edit' ) { + $shelfnumber = $query->param('shelfnumber'); + $shelf = Koha::Virtualshelves->find($shelfnumber); + if ( $shelf ) { + $op = $referer; + if ( $shelf->can_be_managed( $loggedinuser ) ) { + $shelf->shelfname( $query->param('shelfname') ); + $shelf->sortfield( $query->param('sortfield') ); + $shelf->allow_add( $query->param('allow_add') ); + $shelf->allow_delete_own( $query->param('allow_delete_own') ); + $shelf->allow_delete_other( $query->param('allow_delete_other') ); + $shelf->category( $query->param('category') ); + eval { $shelf->store }; -sub viewshelf { - my $shelfnumber=shift; - #check that the user can view the shelf - return unless (ShelfPossibleAction($loggedinuser,$shelfnumber,'view')); - my ($itemlist) = GetShelfContents($env, $shelfnumber); - my $item=''; - my $color=''; - my @itemsloop; - foreach $item (sort {$a->{'barcode'} cmp $b->{'barcode'}} @$itemlist) { - my %line; - ($color eq 0) ? ($color=1) : ($color=0); - $line{'color'}=$color; - $line{'itemnumber'}=$item->{'itemnumber'}; - $line{'barcode'}=$item->{'barcode'}; - $line{'title'}=$item->{'title'}; - $line{'author'}=$item->{'author'}; - $line{'classification'}=$item->{'classification'}; - $line{'itemtype'}=$item->{'itemtype'}; - $line{biblionumber} = $item->{biblionumber}; - push(@itemsloop, \%line); - } - $template->param( itemsloop => \@itemsloop, - shelfname => $shelflist->{$shelfnumber}->{'shelfname'}, - shelfnumber => $shelfnumber, - viewshelf => $query->param('viewshelf'), - manageshelf => &ShelfPossibleAction($loggedinuser,$shelfnumber,'manage'), - ); + if ($@) { + push @messages, { type => 'error', code => 'error_on_update' }; + $op = 'edit_form'; + } else { + push @messages, { type => 'message', code => 'success_on_update' }; + } + } else { + push @messages, { type => 'error', code => 'unauthorized_on_update' }; + } + } else { + push @messages, { type => 'error', code => 'does_not_exist' }; + } +} elsif ( $op eq 'delete' ) { + $shelfnumber = $query->param('shelfnumber'); + $shelf = Koha::Virtualshelves->find($shelfnumber); + if ($shelf) { + if ( $shelf->can_be_deleted( $loggedinuser ) ) { + eval { $shelf->delete; }; + if ($@) { + push @messages, { type => 'error', code => ref($@), msg => $@ }; + } else { + push @messages, { type => 'message', code => 'success_on_delete' }; + } + } else { + push @messages, { type => 'error', code => 'unauthorized_on_delete' }; + } + } else { + push @messages, { type => 'error', code => 'does_not_exist' }; + } + $op = $referer; +} elsif ( $op eq 'remove_share' ) { + $shelfnumber = $query->param('shelfnumber'); + $shelf = Koha::Virtualshelves->find($shelfnumber); + if ($shelf) { + my $removed = eval { $shelf->remove_share( $loggedinuser ); }; + if ($@) { + push @messages, { type => 'error', code => ref($@), msg => $@ }; + } elsif ( $removed ) { + push @messages, { type => 'message', code => 'success_on_remove_share' }; + } else { + push @messages, { type => 'error', code => 'error_on_remove_share' }; + } + } else { + push @messages, { type => 'error', code => 'does_not_exist' }; + } + $op = $referer; + +} elsif ( $op eq 'add_biblio' ) { + $shelfnumber = $query->param('shelfnumber'); + $shelf = Koha::Virtualshelves->find($shelfnumber); + if ($shelf) { + if( my $barcode = $query->param('barcode') ) { + my $item = GetItem( 0, $barcode); + if (defined $item && $item->{itemnumber}) { + my $biblio = GetBiblioFromItemNumber( $item->{itemnumber} ); + if ( $shelf->can_biblios_be_added( $loggedinuser ) ) { + my $added = eval { $shelf->add_biblio( $biblio->{biblionumber}, $loggedinuser ); }; + if ($@) { + push @messages, { type => 'error', code => ref($@), msg => $@ }; + } elsif ( $added ) { + push @messages, { type => 'message', code => 'success_on_add_biblio' }; + } else { + push @messages, { type => 'message', code => 'error_on_add_biblio' }; + } + } else { + push @messages, { type => 'error', code => 'unauthorized_on_add_biblio' }; + } + } else { + push @messages, { type => 'error', code => 'item_does_not_exist' }; + } + } + } else { + push @messages, { type => 'error', code => 'does_not_exist' }; + } + $op = $referer; +} elsif ( $op eq 'remove_biblios' ) { + $shelfnumber = $query->param('shelfnumber'); + $shelf = Koha::Virtualshelves->find($shelfnumber); + my @biblionumber = $query->multi_param('biblionumber'); + if ($shelf) { + if ( $shelf->can_biblios_be_removed( $loggedinuser ) ) { + my $number_of_biblios_removed = eval { + $shelf->remove_biblios( + { + biblionumbers => \@biblionumber, + borrowernumber => $loggedinuser, + } + ); + }; + if ($@) { + push @messages, { type => 'error', code => ref($@), msg => $@ }; + } elsif ( $number_of_biblios_removed ) { + push @messages, { type => 'message', code => 'success_on_remove_biblios' }; + } else { + push @messages, { type => 'error', code => 'no_biblio_removed' }; + } + } else { + push @messages, { type => 'error', code => 'unauthorized_on_remove_biblios' }; + } + } else { + push @messages, { type => 'error', code => 'does_not_exist' }; + } + $op = 'view'; } -# -# $Log$ -# Revision 1.6 2005/03/01 13:41:32 tipaul -# merging 2.2 branch with head. Sorry for not making it before, many many commits done here -# -# Revision 1.5 2005/01/27 17:27:11 oleonard -# Taking table cell background color information out of the script and moving it into the template (requires update to opac-shelves.tmpl) -# -# Revision 1.4 2005/01/13 20:41:07 oleonard -# Adding call number and item type to list of returned variables -# -# Revision 1.3 2005/01/03 11:09:34 tipaul -# synch'ing virtual shelves management in opac with the librarian one, that has more features -# -# Revision 1.5 2004/12/16 11:30:57 tipaul -# adding bookshelf features : -# * create bookshelf on the fly -# * modify a bookshelf name & status -# -# Revision 1.4 2004/12/15 17:28:23 tipaul -# adding bookshelf features : -# * create bookshelf on the fly -# * modify a bookshelf (this being not finished, will commit the rest soon) -# -# Revision 1.3 2004/12/02 16:38:50 tipaul -# improvement in book shelves -# -# Revision 1.2 2004/11/19 16:31:30 tipaul -# bugfix for bookshelves not in official CVS -# -# Revision 1.1.2.1 2004/03/10 15:08:18 tipaul -# modifying shelves : introducing category of shelf : private, public, free for all -# -# Revision 1.13 2004/02/11 08:35:31 tipaul -# synch'ing 2.0.0 branch and head -# -# Revision 1.12.2.1 2004/02/06 14:22:19 tipaul -# fixing bugs in bookshelves management. -# -# Revision 1.12 2003/02/05 10:04:14 acli -# Worked around weirdness with HTML::Template; without the {}, it complains -# of being passed an odd number of arguments even though we are not -# -# Revision 1.11 2003/02/05 09:23:03 acli -# Fixed a few minor errors to make it run -# Noted correct tab size -# -# Revision 1.10 2003/02/02 07:18:37 acli -# Moved C4/Charset.pm to C4/Interface/CGI/Output.pm -# -# Create output_html_with_http_headers function to contain the "print $query -# ->header(-type => guesstype...),..." call. This is in preparation for -# non-HTML output (e.g., text/xml) and charset conversion before output in -# the future. -# -# Created C4/Interface/CGI/Template.pm to hold convenience functions specific -# to the CGI interface using HTML::Template -# -# Modified moremembers.pl to make the "sex" field localizable for languages -# where M and F doesn't make sense -# -# Revision 1.9 2002/12/19 18:55:40 hdl -# Templating reservereport et shelves. -# -# Revision 1.9 2002/08/14 18:12:51 hdl -# Templating files -# -# Revision 1.8 2002/08/14 18:12:51 tonnesen -# Added copyright statement to all .pl and .pm files -# -# Revision 1.7 2002/07/05 05:03:37 tonnesen -# Minor changes to authentication routines. -# -# Revision 1.5 2002/07/04 19:42:48 tonnesen -# Minor changes -# -# Revision 1.4 2002/07/04 19:21:29 tonnesen -# Beginning of authentication api. Applied to shelves.pl for now as a test case. -# -# Revision 1.2.2.1 2002/06/26 20:28:15 tonnesen -# Some udpates that I made here locally a while ago. Still won't be useful, but -# should be functional -# -# -# +if ( $op eq 'view' ) { + $shelfnumber ||= $query->param('shelfnumber'); + $shelf = Koha::Virtualshelves->find($shelfnumber); + if ( $shelf ) { + if ( $shelf->can_be_viewed( $loggedinuser ) ) { + $category = $shelf->category; + my $sortfield = $query->param('sortfield') || $shelf->sortfield; # Passed in sorting overrides default sorting + my $direction = $query->param('direction') || 'asc'; + $direction = 'asc' if $direction ne 'asc' and $direction ne 'desc'; + my ( $page, $rows ); + unless ( $query->param('print') or $query->param('rss') ) { + $rows = C4::Context->preference('OPACnumSearchResults') || 20; + $page = ( $query->param('page') ? $query->param('page') : 1 ); + } + my $order_by = $sortfield eq 'itemcallnumber' ? 'items.itemcallnumber' : $sortfield; + my $contents = $shelf->get_contents->search( + {}, + { + prefetch => [ { 'biblionumber' => { 'biblioitems' => 'items' } } ], + page => $page, + rows => $rows, + order_by => { "-$direction" => $order_by }, + } + ); + + # get biblionumbers stored in the cart + my @cart_list; + if(my $cart_list = $query->cookie('bib_list')){ + @cart_list = split(/\//, $cart_list); + } + + my $borrower = GetMember( borrowernumber => $loggedinuser ); + + my $xslfile = C4::Context->preference('OPACXSLTResultsDisplay'); + my $lang = $xslfile ? C4::Languages::getlanguage() : undef; + my $sysxml = $xslfile ? C4::XSLT::get_xslt_sysprefs() : undef; + + my @items; + while ( my $content = $contents->next ) { + my $biblionumber = $content->biblionumber->biblionumber; + my $this_item = GetBiblioData($biblionumber); + my $record = GetMarcBiblio($biblionumber); + + if ( $xslfile ) { + $this_item->{XSLTBloc} = XSLTParse4Display( $biblionumber, $record, "OPACXSLTResultsDisplay", + 1, undef, $sysxml, $xslfile, $lang); + } + my $marcflavour = C4::Context->preference("marcflavour"); + my $itemtypeinfo = getitemtypeinfo( $content->biblionumber->biblioitems->first->itemtype, 'opac' ); + $this_item->{imageurl} = $itemtypeinfo->{imageurl}; + $this_item->{description} = $itemtypeinfo->{description}; + $this_item->{notforloan} = $itemtypeinfo->{notforloan}; + $this_item->{'coins'} = GetCOinSBiblio($record); + $this_item->{'subtitle'} = GetRecordValue( 'subtitle', $record, GetFrameworkCode( $biblionumber ) ); + $this_item->{'normalized_upc'} = GetNormalizedUPC( $record, $marcflavour ); + $this_item->{'normalized_ean'} = GetNormalizedEAN( $record, $marcflavour ); + $this_item->{'normalized_oclc'} = GetNormalizedOCLCNumber( $record, $marcflavour ); + $this_item->{'normalized_isbn'} = GetNormalizedISBN( undef, $record, $marcflavour ); + unless ( defined $this_item->{size} ) { + #TT has problems with size + $this_item->{size} = q||; + } -# Local Variables: -# tab-width: 4 -# End: + # Getting items infos for location display + my @items_infos = &GetItemsLocationInfo( $biblionumber ); + $this_item->{'ITEM_RESULTS'} = \@items_infos; + + if (C4::Context->preference('TagsEnabled') and C4::Context->preference('TagsShowOnList')) { + $this_item->{TagLoop} = get_tags({ + biblionumber => $biblionumber, approved=>1, 'sort'=>'-weight', + limit => C4::Context->preference('TagsShowOnList'), + }); + } + + $this_item->{allow_onshelf_holds} = C4::Reserves::OnShelfHoldsAllowed($this_item, $borrower); + + + if ( grep {$_ eq $biblionumber} @cart_list) { + $this_item->{incart} = 1; + } + + if ( $query->param('rss') ) { + $this_item->{title} = $content->biblionumber->title; + $this_item->{author} = $content->biblionumber->author; + } + + $this_item->{biblionumber} = $biblionumber; + push @items, $this_item; + } + + $template->param( + can_manage_shelf => $shelf->can_be_managed($loggedinuser), + can_delete_shelf => $shelf->can_be_deleted($loggedinuser), + can_remove_biblios => $shelf->can_biblios_be_removed($loggedinuser), + can_add_biblios => $shelf->can_biblios_be_added($loggedinuser), + sortfield => $sortfield, + itemsloop => \@items, + sortfield => $sortfield, + direction => $direction, + ); + if ( $page ) { + my $pager = $contents->pager; + $template->param( + pagination_bar => pagination_bar( + q||, $pager->last_page - $pager->first_page + 1, + $page, "page", { op => 'view', shelfnumber => $shelf->shelfnumber, sortfield => $sortfield, direction => $direction, } + ), + ); + } + } else { + push @messages, { type => 'error', code => 'unauthorized_on_view' }; + } + } else { + push @messages, { type => 'error', code => 'does_not_exist' }; + } +} + +if ( $op eq 'list' ) { + my $shelves; + my ( $page, $rows ) = ( $query->param('page') || 1, 20 ); + if ( $category == 1 ) { + $shelves = Koha::Virtualshelves->get_private_shelves({ page => $page, rows => $rows, borrowernumber => $loggedinuser, }); + } else { + $shelves = Koha::Virtualshelves->get_public_shelves({ page => $page, rows => $rows, }); + } + + my $pager = $shelves->pager; + $template->param( + shelves => $shelves, + pagination_bar => pagination_bar( + q||, $pager->last_page - $pager->first_page + 1, + $page, "page", { op => 'list', category => $category, } + ), + ); +} + +$template->param( + op => $op, + referer => $referer, + shelf => $shelf, + messages => \@messages, + category => $category, + print => scalar $query->param('print') || 0, + listsview => 1, +); + +output_html_with_http_headers $query, $cookie, $template->output;