X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=opac%2Fopac-shelves.pl;h=dbd598c92e69d2907f13190e41aa7cefa2c7b910;hb=37ca03479c2c3cfb04fc15214176f92bca2b6551;hp=683610c60f00e12191d91a2a9b79a79eb8d89c85;hpb=6cdf0832e2ad3739a42fa811cc08363908c0dec2;p=koha.git diff --git a/opac/opac-shelves.pl b/opac/opac-shelves.pl index 683610c60f..dbd598c92e 100755 --- a/opac/opac-shelves.pl +++ b/opac/opac-shelves.pl @@ -17,269 +17,24 @@ # Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place, # Suite 330, Boston, MA 02111-1307 USA -# $Id$ - -=head1 NAME - - opac-shelves.pl - -=head1 DESCRIPTION - - this script is used to script to provide virtualshelf management - -=head1 CGI PARAMETERS - -=over 4 - -=item C - - if this script has to modify the shelve content. - -=item C - - to know on which shelve this script has to work. - -=item C - -=item C - - op can be equals to: - * modifsave to save change on the shelves - * modif to change the template to allow to modify the shelves. - -=item C - - to load the template with 'viewshelves param' which allow to read the shelves information. - -=item C - - if equals to 1. then call the function shelves which add - or delete a shelf. - -=item C - - if the param shelves = 1 then addshelf must be equals to the name of the shelf to add. - -=back - -=cut - use strict; +use warnings; use CGI; -use C4::Output; -use C4::VirtualShelves; -use C4::Circulation; +use C4::VirtualShelves::Page; use C4::Auth; -use C4::Output; -use C4::Biblio; -my $query = new CGI; +my $query = CGI->new(); -my ( $template, $loggedinuser, $cookie ) = get_template_and_user( - { +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('viewshelf'); - my $barcode = $query->param('addbarcode'); - my ($item) = GetItemnumberFromBarcode($barcode); - my ($biblio) = GetBiblioFromItemNumber($item->{'itemnumber'}); - if ( ShelfPossibleAction( $loggedinuser, $shelfnumber, 'manage' ) ) { - AddToShelf( $biblio->{'biblionumber'}, $shelfnumber ); - foreach ( $query->param ) { - if (/MOD-(\d*)/) { - my $biblionumber = $1; - if ( $query->param('remove') eq "on" ) { - DelFromShelf( $biblionumber, $shelfnumber ); - } - } - } - } -} - -# getting the Shelves list -my $shelflist = GetShelves( $loggedinuser, 2 ); -$template->param( { loggedinuser => $loggedinuser } ); -my $op = $query->param('op'); - -SWITCH: { - if ( $op && ( $op eq 'modifsave' ) ) { - ModShelf( - $query->param('shelfnumber'), $query->param('shelfname'), - $loggedinuser, $query->param('category') - ); - last SWITCH; - } - if ( $op && ( $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') ) { - #check that the user can view the shelf - my $shelfnumber = $query->param('viewshelf'); - if ( ShelfPossibleAction( $loggedinuser, $shelfnumber, 'view' ) ) { - my $items = GetShelfContents($shelfnumber); - $template->param( - shelfname => $shelflist->{$shelfnumber}->{'shelfname'}, - shelfnumber => $shelfnumber, - viewshelf => $query->param('viewshelf'), - manageshelf => &ShelfPossibleAction( $loggedinuser, $shelfnumber, 'manage' ), - itemsloop => $items, - ); - } - last SWITCH; - } - if ( $query->param('shelves') ) { - if ( my $newshelf = $query->param('addshelf') ) { - my $shelfnumber = AddShelf( - $newshelf, - $query->param('owner'), - $query->param('category') - ); - - if ( $shelfnumber == -1 ) { #shelf already exists. - $template->param( - { - shelfnumber => $shelfnumber, - already => 1 - } - ); - } - } - my @paramsloop; - foreach ( $query->param() ) { - my %line; - if (/DEL-(\d+)/) { - my $delshelf = $1; - my ( $status, $count ) = DelShelf($delshelf); - if ($status) { - $line{'status'} = $status; - $line{'count'} = $count; - } - } - - #if the shelf is not deleted, %line points on null - push( @paramsloop, \%line ); - } - $template->param( paramsloop => \@paramsloop ); - my ($shelflist) = GetShelves( $loggedinuser, 2 ); - my $color = ''; - my @shelvesloop; - foreach my $element ( sort keys %$shelflist ) { - my %line; - ( $color eq 1 ) ? ( $color = 0 ) : ( $color = 1 ); - $line{'toggle'} = $color; - $line{'shelf'} = $element; - $line{'shelfname'} = $shelflist->{$element}->{'shelfname'}; - $line{'shelfvirtualcount'} = $shelflist->{$element}->{'count'}; - push( @shelvesloop, \%line ); - } - $template->param( - shelvesloop => \@shelvesloop, - shelves => 1, - ); - last SWITCH; - } -} - -($shelflist) = - GetShelves( $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 1 ) ? ( $color = 0 ) : ( $color = 1 ); - $line{'toggle'} = $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{'shelfvirtualcount'} = $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 ); - } - -$template->param( - shelvesloop => \@shelvesloop, - "BiblioDefaultView".C4::Context->preference("BiblioDefaultView") => 1, -); - -output_html_with_http_headers $query, $cookie, $template->output; - - - -# -# $Log$ -# Revision 1.12 2007/04/24 13:54:29 hdl -# functions that were in C4::Interface::CGI::Output are now in C4::Output. -# So this implies quite a change for files. -# Sorry about conflicts which will be caused. -# directory Interface::CGI should now be dropped. -# I noticed that many scripts (reports ones, but also some circ/stats.pl or opac-topissues) still use Date::Manip. -# -# Revision 1.11 2007/04/17 08:52:19 tipaul -# circulation cleaning continued: bufixing -# -# Revision 1.10 2007/04/04 16:46:23 tipaul -# HUGE COMMIT : code cleaning circulation. -# -# some stuff to do, i'll write a mail on koha-devel NOW ! -# -# Revision 1.9 2007/03/09 15:12:54 tipaul -# rel_3_0 moved to HEAD -# -# Revision 1.8.2.12 2007/01/15 17:19:30 toins -# enable to add checked items to a shelf. -# Some display enhancements. -# -# Revision 1.8.2.11 2007/01/10 10:52:58 toins -# adding syspref directly to Auth.pm instead of to the template. -# -# Revision 1.8.2.10 2007/01/10 10:12:48 toins -# Adding OpacTopissue, OpacCloud, OpacAuthorithies to the template->param. -# + Some cleanup. -# -# Revision 1.8.2.9 2006/12/15 17:43:24 toins -# sync with intranet. -# -# Revision 1.8.2.8 2006/12/14 17:59:17 toins -# add the link to "BiblioDefaultView systempref" and not to opac-detail.pl -# -# Revision 1.8.2.7 2006/12/14 17:22:55 toins -# virtualshelves work perfectly with mod_perl and are cleaned. -# -# Revision 1.8.2.6 2006/12/14 16:04:25 toins -# sync with intranet. -# -# Revision 1.8.2.5 2006/12/11 17:10:06 toins -# fixing some bugs on virtualshelves. -# -# Revision 1.8.2.4 2006/12/07 15:42:15 toins -# synching opac & intranet. -# fix some broken link & bugs. -# removing warn compilation. -# -# Revision 1.8.2.3 2006/11/30 18:23:51 toins -# theses scripts don't need to use C4::Search. -# + }); +$template->param(listsview => 1); +# if $loggedinuser is not defined, set it to -1, which should +# not correspond to any real borrowernumber. +# FIXME: this is a hack to temporarily avoid changing several +# routines in C4::VirtualShelves and C4::VirtualShelves::page +# to deal with lists accessed during an anonymous OPAC session +shelfpage('opac', $query, $template, (defined($loggedinuser) ? $loggedinuser : -1), $cookie);