X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;ds=sidebyside;f=opac%2Fopac-downloadshelf.pl;h=e94b76c505e7c861b0875d3f8a8252293ef1a2ba;hb=51a6f0958926fcbdf48e97d386a2463a9c113d73;hp=b377109ca290b174e2b636399d4d394bba96b240;hpb=5ade5292849ae56ede6a8f90f3b37aedc0915608;p=koha.git diff --git a/opac/opac-downloadshelf.pl b/opac/opac-downloadshelf.pl index b377109ca2..e94b76c505 100755 --- a/opac/opac-downloadshelf.pl +++ b/opac/opac-downloadshelf.pl @@ -13,16 +13,15 @@ # 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, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. use strict; use warnings; use CGI; use Encode qw(encode); -use Switch; use C4::Auth; use C4::Biblio; @@ -31,8 +30,8 @@ use C4::Output; use C4::VirtualShelves; use C4::Record; use C4::Ris; +use C4::Csv; use utf8; -use open qw( :std :utf8); my $query = new CGI; my ( $template, $borrowernumber, $cookie ) = get_template_and_user ( @@ -49,33 +48,58 @@ my $shelfid = $query->param('shelfid'); my $format = $query->param('format'); my $dbh = C4::Context->dbh; -if ($shelfid && $format) { +if ( ShelfPossibleAction( (defined($borrowernumber) ? $borrowernumber : -1), $shelfid, 'view' ) ) { - my @shelf = GetShelf($shelfid); - my ($items, $totitems) = GetShelfContents($shelfid); - my $marcflavour = C4::Context->preference('marcflavour'); - my $output; + if ($shelfid && $format) { - # retrieve biblios from shelf - foreach my $biblio (@$items) { - my $biblionumber = $biblio->{biblionumber}; + my ($items, $totitems) = GetShelfContents($shelfid); + my $marcflavour = C4::Context->preference('marcflavour'); + my $output; - my $record = GetMarcBiblio($biblionumber); + # CSV + if ($format =~ /^\d+$/) { + my @biblios; + foreach (@$items) { + push @biblios, $_->{biblionumber}; + } + $output = marc2csv(\@biblios, $format); + + # Other formats + } else { + foreach my $biblio (@$items) { + my $biblionumber = $biblio->{biblionumber}; - switch ($format) { - case "iso2709" { $output .= $record->as_usmarc(); } - case "ris" { $output .= marc2ris($record); } - case "bibtex" { $output .= marc2bibtex($record, $biblionumber); } - } - } + my $record = GetMarcBiblio($biblionumber, 1); + next unless $record; + + if ($format eq 'iso2709') { + $output .= $record->as_usmarc(); + } + elsif ($format eq 'ris' ) { + $output .= marc2ris($record); + } + elsif ($format eq 'bibtex') { + $output .= marc2bibtex($record, $biblionumber); + } + } + } + + # If it was a CSV export we change the format after the export so the file extension is fine + $format = "csv" if ($format =~ m/^\d+$/); - print $query->header( - -type => 'application/octet-stream', - -'Content-Transfer-Encoding' => 'binary', - -attachment=>"shelf.$format"); - print $output; + print $query->header( + -type => 'application/octet-stream', + -'Content-Transfer-Encoding' => 'binary', + -attachment=>"shelf.$format"); + print $output; + + } else { + $template->param(csv_profiles => GetCsvProfilesLoop('marc')); + $template->param(shelfid => $shelfid); + output_html_with_http_headers $query, $cookie, $template->output; + } -} else { - $template->param(shelfid => $shelfid); +} else { + $template->param(invalidlist => 1); output_html_with_http_headers $query, $cookie, $template->output; }