X-Git-Url: http://koha-dev.rot13.org:8081/gitweb/?a=blobdiff_plain;f=opac%2Fopac-downloadcart.pl;h=12d6777c57874dfd8f9adc785cfe3e77bc46779d;hb=d07df7d51250bb5a40bb556aab48afb18a67a396;hp=fe80f3008c0ac333ff2ab14b89eb81d27b0c485e;hpb=8ad2c7d7acc3cb0033426bd78928214a22ad9dd1;p=koha_fer diff --git a/opac/opac-downloadcart.pl b/opac/opac-downloadcart.pl index fe80f3008c..12d6777c57 100755 --- a/opac/opac-downloadcart.pl +++ b/opac/opac-downloadcart.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; @@ -33,7 +32,6 @@ 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 ( @@ -57,21 +55,28 @@ if ($bib_list && $format) { my $marcflavour = C4::Context->preference('marcflavour'); my $output; - # retrieve biblios from shelf - my $firstpass = 1; - foreach my $biblio (@bibs) { + # CSV + if ($format =~ /^\d+$/) { - my $record = GetMarcBiblio($biblio); + $output = marc2csv(\@bibs, $format); - switch ($format) { - case "iso2709" { $output .= $record->as_usmarc(); } - case "ris" { $output .= marc2ris($record); } - case "bibtex" { $output .= marc2bibtex($record, $biblio); } - # We're in the case of a csv profile (firstpass is used for headers printing) : - case /^\d+$/ { $output .= marc2csv($record, $format, $firstpass); } - } - $firstpass = 0; + # Other formats + } else { + foreach my $biblio (@bibs) { + my $record = GetMarcBiblio($biblio, 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, $biblio); + } + } } # If it was a CSV export we change the format after the export so the file extension is fine @@ -84,7 +89,7 @@ if ($bib_list && $format) { print $output; } else { - $template->param(csv_profiles => GetCsvProfilesLoop()); + $template->param(csv_profiles => GetCsvProfilesLoop('marc')); $template->param(bib_list => $bib_list); output_html_with_http_headers $query, $cookie, $template->output; }