X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;ds=inline;f=virtualshelves%2Fshelves.pl;h=192580f857980294cecb675ab3b3ae8ff568d68a;hb=cbb5207c1cc5f196ad2682a24ae1db7fb9301876;hp=eab6c17f70cca5df070faad269d47a091f85b1c7;hpb=d6329e4f96e46a5e2fbe0ced4d385c42d47e2a84;p=koha.git diff --git a/virtualshelves/shelves.pl b/virtualshelves/shelves.pl index eab6c17f70..192580f857 100755 --- a/virtualshelves/shelves.pl +++ b/virtualshelves/shelves.pl @@ -21,14 +21,21 @@ use Modern::Perl; use CGI qw ( -utf8 ); use C4::Auth; use C4::Biblio; -use C4::Csv; use C4::Koha; use C4::Items; use C4::Members; use C4::Output; use C4::XSLT; + +use Koha::Biblios; +use Koha::Biblioitems; +use Koha::ItemTypes; +use Koha::CsvProfiles; +use Koha::Patrons; use Koha::Virtualshelves; +use constant ANYONE => 2; + my $query = new CGI; my ( $template, $loggedinuser, $cookie ) = get_template_and_user( @@ -46,31 +53,32 @@ my $category = $query->param('category') || 1; my ( $shelf, $shelfnumber, @messages ); if ( $op eq 'add_form' ) { - # Nothing to do + # Only pass default + $shelf = { allow_change_from_owner => 1 }; } 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 ); + my $patron = Koha::Patrons->find( $shelf->owner )->unblessed; $template->param( owner => $patron, ); unless ( $shelf->can_be_managed( $loggedinuser ) ) { - push @messages, { type => 'error', code => 'unauthorized_on_update' }; + push @messages, { type => 'alert', code => 'unauthorized_on_update' }; $op = 'list'; } } else { - push @messages, { type => 'error', code => 'does_not_exist' }; + push @messages, { type => 'alert', code => 'does_not_exist' }; } } elsif ( $op eq 'add' ) { + my $allow_changes_from = $query->param('allow_changes_from'); eval { $shelf = Koha::Virtualshelf->new( { shelfname => scalar $query->param('shelfname'), sortfield => scalar $query->param('sortfield'), category => scalar $query->param('category'), - 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'), + allow_change_from_owner => $allow_changes_from > 0, + allow_change_from_others => $allow_changes_from == ANYONE, owner => scalar $query->param('owner'), } ); @@ -78,9 +86,10 @@ if ( $op eq 'add_form' ) { $shelfnumber = $shelf->shelfnumber; }; if ($@) { - push @messages, { type => 'error', code => ref($@), msg => $@ }; + push @messages, { type => 'alert', code => ref($@), msg => $@ }; } elsif ( not $shelf ) { - push @messages, { type => 'error', code => 'error_on_insert' }; + push @messages, { type => 'alert', code => 'error_on_insert' }; + } else { push @messages, { type => 'message', code => 'success_on_insert' }; $op = 'view'; @@ -91,26 +100,28 @@ if ( $op eq 'add_form' ) { if ( $shelf ) { $op = $referer; + my $sortfield = $query->param('sortfield'); + $sortfield = 'title' unless grep {/^$sortfield$/}qw( title author copyrightdate itemcallnumber ); 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') ); + $shelf->shelfname( scalar $query->param('shelfname') ); + $shelf->sortfield( $sortfield ); + my $allow_changes_from = $query->param('allow_changes_from'); + $shelf->allow_change_from_owner( $allow_changes_from > 0 ); + $shelf->allow_change_from_others( $allow_changes_from == ANYONE ); + $shelf->category( scalar $query->param('category') ); eval { $shelf->store }; if ($@) { - push @messages, { type => 'error', code => 'error_on_update' }; + push @messages, { type => 'alert', 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' }; + push @messages, { type => 'alert', code => 'unauthorized_on_update' }; } } else { - push @messages, { type => 'error', code => 'does_not_exist' }; + push @messages, { type => 'alert', code => 'does_not_exist' }; } } elsif ( $op eq 'delete' ) { $shelfnumber = $query->param('shelfnumber'); @@ -119,49 +130,77 @@ if ( $op eq 'add_form' ) { if ( $shelf->can_be_deleted( $loggedinuser ) ) { eval { $shelf->delete; }; if ($@) { - push @messages, { type => 'error', code => ref($@), msg => $@ }; + push @messages, { type => 'alert', code => ref($@), msg => $@ }; } else { push @messages, { type => 'message', code => 'success_on_delete' }; } } else { - push @messages, { type => 'error', code => 'unauthorized_on_delete' }; + push @messages, { type => 'alert', code => 'unauthorized_on_delete' }; } } else { - push @messages, { type => 'error', code => 'does_not_exist' }; + push @messages, { type => 'alert', code => 'does_not_exist' }; } $op = 'list'; } 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' }; + if( my $barcodes = $query->param('barcodes') ) { + if ( $shelf->can_biblios_be_added( $loggedinuser ) ) { + my @barcodes = split /\n/, $barcodes; # Entries are effectively passed in as a separated list + foreach my $barcode (@barcodes){ + $barcode =~ s/\r$//; # strip any naughty return chars + next if $barcode eq ''; + my $item = GetItem( 0, $barcode); + if (defined $item && $item->{itemnumber}) { + my $added = eval { $shelf->add_biblio( $item->{biblionumber}, $loggedinuser ); }; + if ($@) { + push @messages, { item_barcode => $barcode, type => 'alert', code => ref($@), msg => $@ }; + } elsif ( $added ) { + push @messages, { item_barcode => $barcode, type => 'message', code => 'success_on_add_biblio' }; + } else { + push @messages, { item_barcode => $barcode, type => 'message', code => 'error_on_add_biblio' }; + } + } else { + push @messages, { item_barcode => $barcode, type => 'alert', code => 'item_does_not_exist' }; + } + } + } else { + push @messages, { type => 'alert', code => 'unauthorized_on_add_biblio' }; + } + } + if ( my $biblionumbers = $query->param('biblionumbers') ) { + if ( $shelf->can_biblios_be_added( $loggedinuser ) ) { + my @biblionumbers = split /\n/, $biblionumbers; + foreach my $biblionumber (@biblionumbers) { + $biblionumber =~ s/\r$//; # strip any naughty return chars + next if $biblionumber eq ''; + my $biblio = Koha::Biblios->find($biblionumber); + if (defined $biblio) { + my $added = eval { $shelf->add_biblio( $biblionumber, $loggedinuser ); }; + if ($@) { + push @messages, { bibnum => $biblionumber, type => 'alert', code => ref($@), msg => $@ }; + } elsif ( $added ) { + push @messages, { bibnum => $biblionumber, type => 'message', code => 'success_on_add_biblio' }; + } else { + push @messages, { bibnum => $biblionumber, type => 'message', code => 'error_on_add_biblio' }; + } } else { - push @messages, { type => 'message', code => 'error_on_add_biblio' }; + push @messages, { bibnum => $biblionumber, type => 'alert', code => 'item_does_not_exist' }; } - } else { - push @messages, { type => 'error', code => 'unauthorized_on_add_biblio' }; } } else { - push @messages, { type => 'error', code => 'item_does_not_exist' }; + push @messages, { type => 'alert', code => 'unauthorized_on_add_biblio' }; } } } else { - push @messages, { type => 'error', code => 'does_not_exist' }; + push @messages, { type => 'alert', code => 'does_not_exist' }; } $op = $referer; } elsif ( $op eq 'remove_biblios' ) { $shelfnumber = $query->param('shelfnumber'); $shelf = Koha::Virtualshelves->find($shelfnumber); - my @biblionumbers = $query->param('biblionumber'); + my @biblionumbers = $query->multi_param('biblionumber'); if ($shelf) { if ( $shelf->can_biblios_be_removed( $loggedinuser ) ) { my $number_of_biblios_removed = eval { @@ -173,17 +212,17 @@ if ( $op eq 'add_form' ) { ); }; if ($@) { - push @messages, { type => 'error', code => ref($@), msg => $@ }; + push @messages, { type => 'alert', 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' }; + push @messages, { type => 'alert', code => 'no_biblio_removed' }; } } else { - push @messages, { type => 'error', code => 'unauthorized_on_remove_biblios' }; + push @messages, { type => 'alert', code => 'unauthorized_on_remove_biblios' }; } } else { - push @messages, { type => 'error', code => 'does_not_exist' }; + push @messages, { type => 'alert', code => 'does_not_exist' }; } $op = $referer; } @@ -194,6 +233,7 @@ if ( $op eq 'view' ) { if ( $shelf ) { if ( $shelf->can_be_viewed( $loggedinuser ) ) { my $sortfield = $query->param('sortfield') || $shelf->sortfield || 'title'; # Passed in sorting overrides default sorting + $sortfield = 'title' unless grep {/^$sortfield$/}qw( title author copyrightdate itemcallnumber ); my $direction = $query->param('direction') || 'asc'; $direction = 'asc' if $direction ne 'asc' and $direction ne 'desc'; my ( $rows, $page ); @@ -213,25 +253,31 @@ if ( $op eq 'view' ) { } ); - my $borrower = GetMember( borrowernumber => $loggedinuser ); + my $xslfile = C4::Context->preference('XSLTListsDisplay'); + my $lang = $xslfile ? C4::Languages::getlanguage() : undef; + my $sysxml = $xslfile ? C4::XSLT::get_xslt_sysprefs() : undef; my @items; while ( my $content = $contents->next ) { my $this_item; - my $biblionumber = $content->biblionumber->biblionumber; - my $record = GetMarcBiblio($biblionumber); + my $biblionumber = $content->biblionumber; + my $record = GetMarcBiblio({ biblionumber => $biblionumber }); - if ( C4::Context->preference("XSLTResultsDisplay") ) { - $this_item->{XSLTBloc} = XSLTParse4Display( $biblionumber, $record, "XSLTResultsDisplay" ); + if ( $xslfile ) { + $this_item->{XSLTBloc} = XSLTParse4Display( $biblionumber, $record, "XSLTListsDisplay", + 1, undef, $sysxml, $xslfile, $lang); } my $marcflavour = C4::Context->preference("marcflavour"); - my $itemtypeinfo = getitemtypeinfo( $content->biblionumber->biblioitems->first->itemtype, 'intranet' ); - $this_item->{author} = $content->biblionumber->author; + my $itemtype = Koha::Biblioitems->search({ biblionumber => $content->biblionumber })->next->itemtype; + $itemtype = Koha::ItemTypes->find( $itemtype ); + my $biblio = Koha::Biblios->find( $content->biblionumber ); + $this_item->{title} = $biblio->title; + $this_item->{author} = $biblio->author; $this_item->{dateadded} = $content->dateadded; - $this_item->{imageurl} = $itemtypeinfo->{imageurl}; - $this_item->{description} = $itemtypeinfo->{description}; - $this_item->{notforloan} = $itemtypeinfo->{notforloan}; + $this_item->{imageurl} = $itemtype ? C4::Koha::getitemtypeimagelocation( 'intranet', $itemtype->imageurl ) : q{}; + $this_item->{description} = $itemtype ? $itemtype->description : q{}; #FIXME Should this be translated_description ? + $this_item->{notforloan} = $itemtype->notforloan if $itemtype; $this_item->{'coins'} = GetCOinSBiblio($record); $this_item->{'subtitle'} = GetRecordValue( 'subtitle', $record, GetFrameworkCode( $biblionumber ) ); $this_item->{'normalized_upc'} = GetNormalizedUPC( $record, $marcflavour ); @@ -290,9 +336,10 @@ if ( $op eq 'view' ) { } } else { push @messages, { type => 'error', code => 'unauthorized_on_view' }; + undef $shelf; } } else { - push @messages, { type => 'error', code => 'does_not_exist' }; + push @messages, { type => 'alert', code => 'does_not_exist' }; } } @@ -302,8 +349,8 @@ $template->param( shelf => $shelf, messages => \@messages, category => $category, - print => $query->param('print') || 0, - csv_profiles => GetCsvProfilesLoop('marc'), + print => scalar $query->param('print') || 0, + csv_profiles => [ Koha::CsvProfiles->search({ type => 'marc', used_for => 'export_records' }) ], ); output_html_with_http_headers $query, $cookie, $template->output;