# Koha; if not, write to the Free Software Foundation, Inc., 59 Temple Place,
# Suite 330, Boston, MA 02111-1307 USA
-# $Id$
=head1 NAME
- addvirtualbybiblionumber.pl
+ addbybiblionumber.pl
=head1 DESCRIPTION
use C4::Biblio;
use CGI;
use C4::Output;
-use C4::BookShelves;
+use C4::VirtualShelves qw/:DEFAULT GetRecentShelves/;
use C4::Circulation;
use C4::Auth;
-
#use it only to debug !
use CGI::Carp qw/fatalsToBrowser/;
use warnings;
-my $query = new CGI;
-my $biblionumber = $query->param('biblionumber');
-my $shelfnumber = $query->param('shelfnumber');
-my $newvirtualshelf = $query->param('newvirtualshelf');
-my $category = $query->param('category');
+my $query = new CGI;
-my ($template, $loggedinuser, $cookie)
-= get_template_and_user({template_name => "virtualshelves/addvirtualbybiblionumber.tmpl",
- query => $query,
- type => "intranet",
- authnotrequired => 0,
- flagsrequired => {catalogue => 1},
- });
+# If set, then single item case.
+my $biblionumber = $query->param('biblionumber');
-$shelfnumber = AddShelf($newvirtualshelf,$loggedinuser,$category) if $newvirtualshelf;
+# If set, then multiple item case.
+my $biblionumbers = $query->param('biblionumbers');
-if ($shelfnumber || ($shelfnumber == -1)) { # the shelf already exist.
- &AddToShelfFromBiblio($biblionumber, $shelfnumber);
- print "Content-Type: text/html\n\n<html><body onload=\"window.close()\"></body></html>";
- exit;
-} else { # this shelf doesn't already exist.
- my ( $bibliocount, @biblios ) = GetBiblio($biblionumber);
+my $shelfnumber = $query->param('shelfnumber');
+my $newvirtualshelf = $query->param('newvirtualshelf');
+my $category = $query->param('category');
+my $sortfield = $query->param('sortfield');
+
+my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
+ {
+ template_name => "virtualshelves/addbybiblionumber.tmpl",
+ query => $query,
+ type => "intranet",
+ authnotrequired => 0,
+ flagsrequired => { catalogue => 1 },
+ }
+);
+
+my @biblionumbers;
+if ($biblionumbers) {
+ @biblionumbers = split '/', $biblionumbers;
+} else {
+ @biblionumbers = ($biblionumber);
+}
- my ($shelflist) = GetShelves($loggedinuser,3);
+$shelfnumber = AddShelf( $newvirtualshelf, $loggedinuser, $category, $sortfield )
+ if $newvirtualshelf;
+if ( $shelfnumber || ( $shelfnumber == -1 ) ) { # the shelf already exist.
+ foreach my $biblionumber (@biblionumbers) {
+ AddToShelfFromBiblio( $biblionumber, $shelfnumber );
+ }
+ print
+"Content-Type: text/html\n\n<html><body onload=\"window.close()\"></body></html>";
+ exit;
+}
+else { # this shelf doesn't already exist.
+ my $limit = 10;
+ my ($shelflist) = GetRecentShelves(1, $limit, $loggedinuser);
my @shelvesloop;
my %shelvesloop;
- foreach my $element (sort keys %$shelflist) {
- push (@shelvesloop, $element);
- $shelvesloop{$element} = $shelflist->{$element}->{'shelfname'};
+ for my $shelf ( @{ $shelflist->[0] } ) {
+ push( @shelvesloop, $shelf->{shelfnumber} );
+ $shelvesloop{$shelf->{shelfnumber}} = $shelf->{shelfname};
}
-
- my $CGIvirtualshelves=CGI::scrolling_list(
- -name => 'shelfnumber',
- -values => \@shelvesloop,
- -labels => \%shelvesloop,
- -size => 1,
- -tabindex=>'',
- -multiple => 0 );
-
- $template->param(
- biblionumber => $biblionumber,
- title => $biblios[0]->{'title'},
- author => $biblios[0]->{'author'},
- CGIvirtualshelves => $CGIvirtualshelves,
- intranetcolorstylesheet => C4::Context->preference("intranetcolorstylesheet"),
- intranetstylesheet => C4::Context->preference("intranetstylesheet"),
- IntranetNav => C4::Context->preference("IntranetNav"),
- );
-
+ # then open shelves...
+ my ($shelflist) = GetRecentShelves(3, $limit, undef);
+ for my $shelf ( @{ $shelflist->[0] } ) {
+ push( @shelvesloop, $shelf->{shelfnumber} );
+ $shelvesloop{$shelf->{shelfnumber}} = $shelf->{shelfname};
+ }
+ if(@shelvesloop gt 0){
+ my $CGIvirtualshelves = CGI::scrolling_list
+ (
+ -name => 'shelfnumber',
+ -values => \@shelvesloop,
+ -labels => \%shelvesloop,
+ -size => 1,
+ -tabindex => '',
+ -multiple => 0
+ );
+ $template->param
+ (
+ CGIvirtualshelves => $CGIvirtualshelves,
+ );
+ }
+
+ unless ($biblionumbers) {
+ my ( $bibliocount, @biblios ) = GetBiblio($biblionumber);
+
+ $template->param
+ (
+ biblionumber => $biblionumber,
+ title => $biblios[0]->{'title'},
+ author => $biblios[0]->{'author'},
+ );
+ } else {
+ my @biblioloop = ();
+ foreach my $biblionumber (@biblionumbers) {
+ my ( $bibliocount, @biblios ) = GetBiblio($biblionumber);
+ my %biblioiter = (
+ title=>$biblios[0]->{'title'},
+ author=>$biblios[0]->{'author'}
+ );
+ push @biblioloop, \%biblioiter;
+ }
+ $template->param
+ (
+ biblioloop => \@biblioloop,
+ biblionumbers => $biblionumbers
+ );
+ }
+
output_html_with_http_headers $query, $cookie, $template->output;
}
-
-# $Log$
-# Revision 1.8 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.7 2007/04/04 16:46:22 tipaul
-# HUGE COMMIT : code cleaning circulation.
-#
-# some stuff to do, i'll write a mail on koha-devel NOW !
-#
-# Revision 1.6 2007/03/09 14:32:26 tipaul
-# rel_3_0 moved to HEAD
-#
-# Revision 1.4.2.6 2006/12/18 16:35:17 toins
-# removing use HTML::Template from *.pl.
-#
-# Revision 1.4.2.5 2006/12/05 11:35:29 toins
-# Biblio.pm cleaned.
-# additionalauthors, bibliosubject, bibliosubtitle tables are now unused.
-# Some functions renamed according to the coding guidelines.
-#
-# Revision 1.4.2.4 2006/11/30 18:23:51 toins
-# theses scripts don't need to use C4::Search.
-#
-# Revision 1.4.2.3 2006/10/30 09:48:19 tipaul
-# samll bugfix to create a virtualshelf correctly
-#
-# Revision 1.4.2.2 2006/08/30 16:13:54 toins
-# correct an error in the "if condition".
-#
-# Revision 1.4.2.1 2006/08/30 15:59:14 toins
-# Code cleaned according to coding guide lines.
-#
-# Revision 1.4 2006/07/04 14:36:51 toins
-# Head & rel_2_2 merged
-#
-# Revision 1.3.2.4 2006/06/20 16:21:42 oleonard
-# Adding "tabindex=''" to CGI:scrolling_lists to prevent incorrect tabbing. See Bug 1098
-#
-# Revision 1.3.2.3 2006/02/05 21:59:21 kados
-# Adds script support for IntranetNav ... see mail to koha-devel for
-# details
-#
-# Revision 1.3.2.2 2006/02/05 21:45:25 kados
-# Adds support for intranetstylesheet system pref in Koha scripts
-#
-
-# Local Variables:
-# tab-width: 4
-# End: