use strict;
use warnings;
-use C4::Biblio;
use CGI;
-use C4::VirtualShelves qw/:DEFAULT GetRecentShelves RefreshShelvesSummary/;
-use C4::Auth;
+use C4::Biblio;
+use C4::VirtualShelves qw/:DEFAULT GetAllShelves/;
use C4::Output;
-use C4::Auth qw/get_session/;
-use C4::Debug;
-
-#splits incoming biblionumber(s) to array and adds each to shelf.
-sub AddBibliosToShelf {
- my ($shelfnumber,@biblionumber)=@_;
-
- # multiple bibs might come in as '/' delimited string (from where, i don't see), or as array.
- if (scalar(@biblionumber) == 1) {
- @biblionumber = (split /\//,$biblionumber[0]);
- }
- for my $bib (@biblionumber){
- AddToShelf($bib, $shelfnumber);
- }
-}
+use C4::Auth;
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 $authorized = 1;
+my $errcode = 0;
+my @biblios;
my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
{
template_name => "opac-addbybiblionumber.tmpl",
query => $query,
type => "opac",
- authnotrequired =>( C4::Context->preference("OpacPublic") ? 1 : 0 ),
+ authnotrequired => 0,
}
);
-if ($newvirtualshelf) {
- $shelfnumber = AddShelf( $newvirtualshelf, $loggedinuser, $category );
- AddBibliosToShelf($shelfnumber, @biblionumber);
- RefreshShelvesSummary($query->cookie("CGISESSID"),$loggedinuser,($loggedinuser == -1 ? 20 : 10));
- print $query->header;
- print "<html><meta http-equiv=\"refresh\" content=\"0;url=opac-shelves.pl?display=privateshelves\" /><body onload=\"window.opener.location.reload(true);self.close();\"></body></html>";
- exit;
+if( $newvirtualshelf) {
+ HandleNewVirtualShelf();
+ exit if $authorized;
+ ShowTemplate(); #error message
+}
+elsif($shelfnumber) {
+ HandleShelfNumber();
+ exit if $authorized;
+ ShowTemplate(); #error message
}
+elsif($selectedshelf) {
+ HandleSelectedShelf();
+ LoadBib() if $authorized;
+ ShowTemplate();
+}
+else {
+ HandleSelect();
+ LoadBib() if $authorized;
+ ShowTemplate();
+}
+#end
+
+sub AddBibliosToShelf {
+ #splits incoming biblionumber(s) to array and adds each to shelf.
+ my ($shelfnumber,@biblionumber)=@_;
-# verify user is authorized to perform the action on the shelf...
-my $authorized = 1;
-if ($selectedshelf) {
- $authorized = 0 unless ShelfPossibleAction( $loggedinuser, $selectedshelf );
+ #multiple bibs might come in as '/' delimited string (from where, i don't see), or as array.
+ if (scalar(@biblionumber) == 1) {
+ @biblionumber = (split /\//,$biblionumber[0]);
+ }
+ for my $bib (@biblionumber) {
+ AddToShelf($bib, $shelfnumber, $loggedinuser);
+ }
}
-if ($shelfnumber && ($shelfnumber != -1)) {
- AddBibliosToShelf($shelfnumber,@biblionumber);
- RefreshShelvesSummary($query->cookie("CGISESSID"),$loggedinuser,($loggedinuser == -1 ? 20 : 10));
- print $query->header;
- print "<html><meta http-equiv=\"refresh\" content=\"0;url=opac-shelves.pl?display=privateshelves\" /><body onload=\"self.close();\"></body></html>";
- exit;
+sub HandleNewVirtualShelf {
+ if($authorized= ShelfPossibleAction($loggedinuser, undef, $category==1? 'new_private': 'new_public')) {
+ $shelfnumber = AddShelf( {
+ shelfname => $newvirtualshelf,
+ category => $category }, $loggedinuser);
+ if($shelfnumber == -1) {
+ $authorized=0;
+ $errcode=1;
+ return;
+ }
+ AddBibliosToShelf($shelfnumber, @biblionumber);
+ #Reload the page where you came from
+ print $query->header;
+ print "<html><meta http-equiv=\"refresh\" content=\"0\" /><body onload=\"window.opener.location.reload(true);self.close();\"></body></html>";
+ }
}
-else {
- if($selectedshelf){
- # adding to specific shelf
- my ( $singleshelf, $singleshelfname, $singlecategory ) = GetShelf( $query->param('selectedshelf') );
- $template->param(
- singleshelf => 1,
- shelfnumber => $singleshelf,
- shelfname => $singleshelfname,
- "category$singlecategory" => 1
- );
- } else {
- # offer choice of shelves
- my $limit = 10;
- my @shelvesloop;
- my %shelvesloop;
- #grab each type of shelf, open (type 3) should not be limited by user.
- foreach my $shelftype (1,2,3) {
- my ($shelflist) = GetRecentShelves($shelftype, $limit, $shelftype == 3 ? undef : $loggedinuser);
- for my $shelf (@{ $shelflist->[0] }) {
- push(@shelvesloop, $shelf->{shelfnumber});
- $shelvesloop{$shelf->{shelfnumber}} = $shelf->{shelfname};
- }
+
+sub HandleShelfNumber {
+ if($authorized= ShelfPossibleAction($loggedinuser, $shelfnumber, 'add')) {
+ AddBibliosToShelf($shelfnumber,@biblionumber);
+ #Close this page and return
+ print $query->header;
+ print "<html><meta http-equiv=\"refresh\" content=\"0\" /><body onload=\"self.close();\"></body></html>";
}
- my $CGIvirtualshelves;
- if ( @shelvesloop > 0 ) {
- $CGIvirtualshelves = CGI::scrolling_list (
- -name => 'shelfnumber',
- -id => 'shelfnumber',
- -values => \@shelvesloop,
- -labels => \%shelvesloop,
- -size => 1,
- -tabindex => '',
- -multiple => 0
+}
+
+sub HandleSelectedShelf {
+ if($authorized= ShelfPossibleAction( $loggedinuser, $selectedshelf, 'add')){
+ #adding to specific shelf
+ my ($singleshelf, $singleshelfname, $singlecategory)= GetShelf($query->param('selectedshelf'));
+ $template->param(
+ singleshelf => 1,
+ shelfnumber => $singleshelf,
+ shelfname => $singleshelfname,
+ "category$singlecategory" => 1
);
+ }
+}
- $template->param (
- CGIvirtualshelves => $CGIvirtualshelves,
- );
+sub HandleSelect {
+ return unless $authorized= $loggedinuser>0;
+ my $privateshelves = GetAllShelves(1,$loggedinuser,1);
+ if(@{$privateshelves}){
+ $template->param (
+ privatevirtualshelves => $privateshelves,
+ existingshelves => 1
+ );
}
- }
+ my $publicshelves = GetAllShelves(2,$loggedinuser,1);
+ if(@{$publicshelves}){
+ $template->param (
+ publicvirtualshelves => $publicshelves,
+ existingshelves => 1
+ );
+ }
+}
- my @biblios;
- for my $bib (@biblionumber) {
- my $data = GetBiblioData( $bib );
- push(@biblios,
- { biblionumber => $bib,
- title => $data->{'title'},
- author => $data->{'author'},
- } );
- }
- $template->param (
- newshelf => $newshelf,
- multiple => (scalar(@biblios) > 1),
- total => scalar @biblios,
- biblios => \@biblios,
- authorized => $authorized,
- );
+sub LoadBib {
+ for my $bib (@biblionumber) {
+ my $data = GetBiblioData( $bib );
+ push(@biblios,
+ { biblionumber => $bib,
+ title => $data->{'title'},
+ author => $data->{'author'},
+ } );
+ }
+ $template->param(
+ multiple => (scalar(@biblios) > 1),
+ total => scalar @biblios,
+ biblios => \@biblios,
+ );
+}
- output_html_with_http_headers $query, $cookie, $template->output;
+sub ShowTemplate {
+ $template->param (
+ newshelf => $newshelf||0,
+ authorized => $authorized,
+ errcode => $errcode,
+ OpacAllowPublicListCreation => C4::Context->preference('OpacAllowPublicListCreation'),
+ );
+ output_html_with_http_headers $query, $cookie, $template->output;
}