6378436089
Add an option for marcstd to the opac-export.pl and catalogue/export.pl scripts. This new format removes all 9XX, X9X, XX9 fields and subfield $9 (with the exception of 490 in flavours of MARC other than UNIMARC). The work is done in C4::Record::marc2marc. This patch adds the new export option 'marcstd' for exporting MARC records without 9xx, x9x and xx9 fields and subfields to the staff detail page. Testing plan: 1. Export a record in "MARC (Unicode/UTF-8)" format as a control 2. In the OPAC, run the following jQuery to add the marcstd option to the UI: > $("#export #format").append("<option value='marcstd'>MARC (no 9xx)</option>"); 3. Export the same record in "MARC (no 9xx)" format 4. Compare the two, noticing that any subfield $9 or fields including 9 (other than 490 in flavours of MARC other than UNIMARC) have been removed Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl> Works as advertised now. Signed-off-by: Katrin Fischer <Katrin.Fischer.83@web.de> Signed-off-by: Jared Camins-Esakov <jcamins@cpbibliography.com> This patch squashes both the original patch and Katrin's follow-up adding marcstd as an export option on the staff client. Feb 13, 2012 (marcel): Amended this patch to resolved two definitions of $error in catalogue/export script.
89 lines
2.4 KiB
Perl
Executable file
89 lines
2.4 KiB
Perl
Executable file
#!/usr/bin/perl
|
|
|
|
# Parts Copyright Catalyst IT 2011
|
|
#
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it under the
|
|
# terms of the GNU General Public License as published by the Free Software
|
|
# Foundation; either version 2 of the License, or (at your option) any later
|
|
# version.
|
|
#
|
|
# Koha is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
# 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.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
use strict;
|
|
use warnings;
|
|
|
|
use C4::Record;
|
|
use C4::Auth;
|
|
use C4::Output;
|
|
use C4::Biblio;
|
|
use CGI;
|
|
use C4::Auth;
|
|
use C4::Ris;
|
|
|
|
my $query = new CGI;
|
|
my $op=$query->param("op")||''; #op=export is currently the only use
|
|
my $format=$query->param("format")||'utf8';
|
|
my $biblionumber = $query->param("bib")||0;
|
|
my ($marc, $error)= ('','');
|
|
|
|
$marc = GetMarcBiblio($biblionumber, 1) if $biblionumber;
|
|
if(!$marc) {
|
|
print $query->redirect("/cgi-bin/koha/errors/404.pl");
|
|
exit;
|
|
}
|
|
elsif ($format =~ /endnote/) {
|
|
$marc = marc2endnote($marc);
|
|
}
|
|
elsif ($format =~ /marcxml/) {
|
|
$marc = marc2marcxml($marc);
|
|
}
|
|
elsif ($format=~ /mods/) {
|
|
$marc = marc2modsxml($marc);
|
|
}
|
|
elsif ($format =~ /ris/) {
|
|
$marc = marc2ris($marc);
|
|
}
|
|
elsif ($format =~ /bibtex/) {
|
|
$marc = marc2bibtex(C4::Biblio::GetMarcBiblio($biblionumber),$biblionumber);
|
|
}
|
|
elsif ($format =~ /dc/) {
|
|
($error,$marc) = marc2dcxml($marc,1);
|
|
$format = "dublin-core.xml";
|
|
}
|
|
elsif ($format =~ /marc8/) {
|
|
($error,$marc) = changeEncoding($marc,"MARC","MARC21","MARC-8");
|
|
$marc = $marc->as_usmarc() unless $error;
|
|
}
|
|
elsif ($format =~ /utf8/) {
|
|
C4::Charset::SetUTF8Flag($marc,1);
|
|
$marc = $marc->as_usmarc();
|
|
}
|
|
elsif ($format =~ /marcstd/) {
|
|
C4::Charset::SetUTF8Flag($marc,1);
|
|
($error,$marc) = marc2marc($marc, 'marcstd', C4::Context->preference('marcflavour'));
|
|
}
|
|
else {
|
|
$error= "Format $format is not supported.";
|
|
}
|
|
|
|
if ($error){
|
|
print $query->header();
|
|
print $query->start_html();
|
|
print "<h1>An error occurred </h1>";
|
|
print $error;
|
|
print $query->end_html();
|
|
}
|
|
else {
|
|
print $query->header(
|
|
-type => 'application/octet-stream',
|
|
-attachment=>"bib-$biblionumber.$format");
|
|
print $marc;
|
|
}
|