Koha/cataloguing/value_builder/marc21_field_008.pl
Marcel de Rooy 716f9c4ea2 Bug 27461: Right pad with default elements for too short 008s
Note that we treat the elements 18-34 as one block of elements,
since its subdivision may vary.
E.g. if you pass 24 characters to the form, it will use the first
18 chars (until the last complete element) and pad with default
elements from position 18-39.

Test plan:
[1] Go to addbiblio. Make sure that 008 is connected to the plugin.
[2] Backspace field 008 a bit, click on the plugin button.
[3] Verify that the last elements come from the default.
[4] Repeat for a few different lengths.

Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl>
Signed-off-by: Phil Ringnalda <phil@chetcolibrary.org>
Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>

Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
2021-09-28 15:12:45 +02:00

157 lines
5.3 KiB
Perl
Executable file

#!/usr/bin/perl
# Converted to new plugin style (Bug 13437)
# Copyright 2000-2002 Katipo Communications
#
# 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 3 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, see <http://www.gnu.org/licenses>.
use Modern::Perl;
use C4::Auth qw( get_template_and_user );
use CGI qw ( -utf8 );
use C4::Context;
use C4::Search;
use C4::Output qw( output_html_with_http_headers );
use XML::LibXML;
use Koha::Util::FrameworkPlugin qw( biblio_008 );
my $builder = sub {
my ( $params ) = @_;
my $function_name = $params->{id};
my $default008 = biblio_008();
my $res = "
<script>
function Focus$function_name(event) {
if( !document.getElementById(event.data.id).value ) {
document.getElementById(event.data.id).value='$default008';
}
return 1;
}
function Click$function_name(event) {
defaultvalue=document.getElementById(event.data.id).value;
//Retrieve full leader string and pass it to the 008 tag editor
var leader_value = \$(\"input[id^='tag_000']\").val();
var leader_parameter = \"\";
if (leader_value){
//Only add the parameter to the URL if there is a value to add
leader_parameter = \"&leader=\"+leader_value;
}
newin=window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=marc21_field_008.pl&index=\"+ event.data.id +\"&result=\"+encodeURIComponent(defaultvalue)+leader_parameter,\"tag_editor\",'width=1000,height=600,toolbar=false,scrollbars=yes');
}
</script>
";
return $res;
};
my $launcher = sub {
my ( $params ) = @_;
my $input = $params->{cgi};
my $default008 = biblio_008();
my $index = $input->param('index');
my $result = $input->param('result') || $default008;
my $leader = $input->param('leader');
my $material_configuration;
if ($leader && length($leader) == '24') {
#MARC 21 Material Type Configuration
#Field 008/18-34 Configuration
#If Leader/06 = a and Leader/07 = a, c, d, or m: Books
#If Leader/06 = a and Leader/07 = b, i, or s: Continuing Resources
#If Leader/06 = t: Books
#If Leader/06 = c, d, i, or j: Music
#If Leader/06 = e, or f: Maps
#If Leader/06 = g, k, o, or r: Visual Materials
#If Leader/06 = m: Computer Files
#If Leader/06 = p: Mixed Materials
#http://www.loc.gov/marc/bibliographic/bdleader.html
my $material_configuration_mapping = {
a => {
a => 'BKS',
c => 'BKS',
d => 'BKS',
m => 'BKS',
b => 'CR',
i => 'CR',
s => 'CR',
},
t => 'BKS',
c => 'MU',
d => 'MU',
i => 'MU',
j => 'MU',
e => 'MP',
f => 'MP',
g => 'VM',
k => 'VM',
o => 'VM',
r => 'VM',
m => 'CF',
p => 'MX',
};
my $leader06 = substr($leader, 6, 1);
my $leader07 = substr($leader, 7, 1);
#Retrieve material type using leader06
$material_configuration = $material_configuration_mapping->{$leader06};
#If the value returned is a ref (i.e. leader06 is 'a'), then use leader07 to get the actual material type
if ( ($material_configuration) && (ref($material_configuration) eq 'HASH') ){
$material_configuration = $material_configuration->{$leader07};
}
}
my $dbh = C4::Context->dbh;
my ($template, $loggedinuser, $cookie) = get_template_and_user(
{ template_name => "cataloguing/value_builder/marc21_field_008.tt",
query => $input,
type => "intranet",
flagsrequired => { editcatalogue => '*' },
}
);
my $errorXml = '';
# Check if the xml, xsd exists and is validated
my $dir = C4::Context->config('intrahtdocs') . '/prog/' . $template->{lang} . '/data/';
if (-r $dir . 'marc21_field_008.xml') {
my $doc = XML::LibXML->new->parse_file($dir . 'marc21_field_008.xml');
if (-r $dir . 'marc21_field_CF.xsd') {
my $xmlschema = XML::LibXML::Schema->new(location => $dir . 'marc21_field_CF.xsd');
eval {
$xmlschema->validate( $doc );
};
$errorXml = 'Can\'t validate the xml data from ' . $dir . 'marc21_field_008.xml' if ($@);
}
} else {
$errorXml = 'Can\'t read the xml file ' . $dir . 'marc21_field_008.xml';
}
$template->param(tagfield => '008',
index => $index,
result => $result,
errorXml => $errorXml,
material_configuration => $material_configuration,
default008 => $default008,
);
output_html_with_http_headers $input, $cookie, $template->output;
};
return { builder => $builder, launcher => $launcher };