-
#!/usr/bin/perl
-# $Id$
+# 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 2 of the License, or (at your option) any later
-# version.
+# 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.
+# 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., 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, see <http://www.gnu.org/licenses>.
-use strict;
+use Modern::Perl;
use C4::Auth;
-use CGI;
+use CGI qw ( -utf8 );
use C4::Context;
use C4::Search;
use C4::Output;
-=head1
-
-plugin_parameters : other parameters added when the plugin is called by the dopop function
-
-=cut
-
-# find today's date
-my ($sec,$min,$hour,$mday,$mon,$year,$wday,$yday,$isdst) = localtime(time);
-
-$year +=1900; $mon +=1;
-my $dateentered = substr($year,2,2).sprintf ("%0.2d", $mon).sprintf ("%0.2d",$mday);
-sub plugin_parameters {
- my ($dbh,$record,$tagslib,$i,$tabloop) = @_;
- return "";
+use XML::LibXML;
+use Koha::Util::FrameworkPlugin qw|date_entered|;
+
+my $builder = sub {
+ my ( $params ) = @_;
+
+ my $lang = C4::Context->preference('DefaultLanguageField008' );
+ $lang = "eng" unless $lang;
+ $lang = pack("A3", $lang);
+ my $country = C4::Context->preference('DefaultCountryField008') // "xxu";
+ $country = pack("A3", $country);
+
+ my $function_name = $params->{id};
+ my $dateentered = date_entered();
+ my $res = "
+<script type=\"text/javascript\">
+//<![CDATA[
+
+function Focus$function_name(event) {
+ if ( document.getElementById(event.data.id).value ) {
+ }
+ else {
+ document.getElementById(event.data.id).value='$dateentered' + 'b $country||||| |||| 00| 0 $lang d';
+ }
+ return 1;
}
-sub plugin_javascript {
- my ($dbh,$record,$tagslib,$field_number,$tabloop) = @_;
- my $function_name= $field_number;
- my $res="
-<script>
-function Focus$function_name(subfield_managed) {
- // TODO FIXME :: HTML code has changed
-
- for (i=0 ; i<document.f.field_value.length ; i++) {
- if (document.f.tag[i].value == '008') {
- if (!document.f.field_value[i].value) {
- document.f.field_value[i].value = '$dateentered' + 't xxu||||| |||| 00| 0 eng d';
- }
- }
+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;
}
-return 1;
-}
-
-function Blur$function_name(subfield_managed) {
- return 1;
-}
-
-function Clic$function_name(i) {
- defaultvalue=document.getElementById(\"$field_number\").value;
- newin=window.open(\"plugin_launcher.pl?plugin_name=marc21_field_008.pl&index=$field_number&result=\"+defaultvalue,\"unimarc field 100\",'width=1000,height=600,toolbar=false,scrollbars=yes');
+ 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 ($function_name,$res);
-}
-sub plugin {
- my ($input) = @_;
- my $index= $input->param('index');
- my $result= $input->param('result');
-
-
- my $dbh = C4::Context->dbh;
-
- my ($template, $loggedinuser, $cookie)
- = get_template_and_user({template_name => "value_builder/marc21_field_008.tmpl",
- query => $input,
- type => "intranet",
- authnotrequired => 0,
- flagsrequired => {editcatalogue => 1},
- debug => 1,
- });
-# $result = " t xxu 00 0 eng d" unless $result;
- $result = "$dateentered"."t xxu||||| |||| 00| 0 eng d" unless $result;
- my $f1 = substr($result,0,6);
- my $f6 = substr($result,6,1);
- my $f710 = substr($result,7,4);
- my $f1114 = substr($result,11,4);
- my $f1517 = substr($result,15,3);
- my $f1821 = substr($result,18,4);
- my $f22 = substr($result,22,1);
- my $f23 = substr($result,23,1);
- my $f2427 = substr($result,24,4);
- my $f28 = substr($result,28,1);
- my $f29 = substr($result,29,1);
- my $f30 = substr($result,30,1);
- my $f31 = substr($result,31,1);
- my $f33 = substr($result,33,1);
- my $f34 = substr($result,34,1);
- my $f3537 = substr($result,35,3);
- my $f38 = substr($result,38,1);
- my $f39 = substr($result,39,1);
-
-if ((!$f1) ||($f1 =~ m/ /)){
- $f1=$dateentered;
-}
+ return $res;
+};
+
+my $launcher = sub {
+ my ( $params ) = @_;
+ my $input = $params->{cgi};
+ my $lang = C4::Context->preference('DefaultLanguageField008' );
+ $lang = "eng" unless $lang;
+ $lang = pack("A3", $lang);
+ my $country = C4::Context->preference('DefaultCountryField008') // "xxu";
+ $country = pack("A3", $country);
+
+ my $index = $input->param('index');
+ my $result = $input->param('result');
+ 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};
+ }
+ }
- $template->param( index => $index,
- f1 => $f1,
- f6 => $f6,
- "f6$f6" => $f6,
- f710 => $f710,
- f1114 => $f1114,
- f1517 => $f1517,
- f1821 => $f1821,
- f22 => $f22,
- "f22$f22" => $f22,
- f23 => $f23,
- "f23$f23" => $f23,
- f2427 => $f2427,
- "f24$f2427" => $f2427,
- f28 => $f28,
- "f28$f28" => $f28,
- f29 => $f29,
- "f29$f29" => $f29,
- f30 => $f30,
- "f230$f30" => $f30,
- f31 => $f31,
- "f31$f31" => $f31,
- f33 => $f33,
- "f33$f33" => $f33,
- f34 => $f34,
- "f34$f34" => $f34,
- f3537 => $f3537,
- f38 => $f38,
- "f38$f38" => $f38,
- f39 => $f39,
- "f39$f39" => $f39,
- );
- output_html_with_http_headers $input, $cookie, $template->output;
-}
+ my $dbh = C4::Context->dbh;
-1;
+ my ($template, $loggedinuser, $cookie) = get_template_and_user(
+ { template_name => "cataloguing/value_builder/marc21_field_008.tt",
+ query => $input,
+ type => "intranet",
+ authnotrequired => 0,
+ flagsrequired => { editcatalogue => '*' },
+ debug => 1,
+ }
+ );
+
+ my $dateentered = date_entered();
+ $result = "$dateentered" . "b $country||||| |||| 00| 0 $lang d" unless $result;
+ 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,
+ );
+ output_html_with_http_headers $input, $cookie, $template->output;
+};
+
+return { builder => $builder, launcher => $launcher };