Bug 14202: Unexpected parameter for window.open in marc21_linking_section.pl
[koha.git] / cataloguing / value_builder / marc21_field_008.pl
index fcb2844..e47a20d 100755 (executable)
 #!/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 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);
+use XML::LibXML;
+use Koha::Util::FrameworkPlugin qw|date_entered|;
 
-$year += 1900;
-$mon  += 1;
-my $dateentered = substr($year, 2, 2) . sprintf("%0.2d", $mon) . sprintf("%0.2d", $mday);
+my $builder = sub {
+    my ( $params ) = @_;
 
-sub plugin_parameters {
-    my ($dbh, $record, $tagslib, $i, $tabloop) = @_;
-    return "";
-}
+    my $lang = C4::Context->preference('DefaultLanguageField008' );
+    $lang = "eng" unless $lang;
+    $lang = pack("A3", $lang);
 
-sub plugin_javascript {
-    my ($dbh, $record, $tagslib, $field_number, $tabloop) = @_;
-    my $function_name = $field_number;
+    my $function_name = $params->{id};
+    my $dateentered = date_entered();
     my $res           = "
 <script type=\"text/javascript\">
 //<![CDATA[
 
-function Focus$function_name(subfield_managed) {
-
-       if ( document.getElementById(\"$field_number\").value ) {
+function Focus$function_name(event) {
+    if ( document.getElementById(event.data.id).value ) {
        }
        else {
-               document.getElementById(\"$field_number\").value='$dateentered' + 't        xxu||||| |||| 00| 0 eng d';
+        document.getElementById(event.data.id).value='$dateentered' + 'b        xxu||||| |||| 00| 0 $lang d';
        }
     return 1;
 }
 
-function Blur$function_name(subfield_managed) {
-       return 1;
-}
-
-function Clic$function_name(i) {
-       defaultvalue=document.getElementById(\"$field_number\").value;
-       newin=window.open(\"../cataloguing/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');
+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=\"+defaultvalue+leader_parameter,\"tag_editor\",'width=1000,height=600,toolbar=false,scrollbars=yes');
 
 }
 //]]>
 </script>
 ";
 
-    return ($function_name, $res);
-}
+    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);
 
-sub plugin {
-    my ($input) = @_;
     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};
+        }
+    }
 
     my $dbh = C4::Context->dbh;
 
     my ($template, $loggedinuser, $cookie) = get_template_and_user(
-        {   template_name   => "cataloguing/value_builder/marc21_field_008.tmpl",
+        {   template_name   => "cataloguing/value_builder/marc21_field_008.tt",
             query           => $input,
             type            => "intranet",
             authnotrequired => 0,
@@ -93,69 +141,30 @@ sub plugin {
         }
     );
 
-    #  $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);
-
-    # bug 2563
-    $f710  = "" if ($f710  =~ /^\s*$/);
-    $f1114 = "" if ($f1114 =~ /^\s*$/);
-
-    if ((!$f1) || ($f1 =~ m/ /)) {
-        $f1 = $dateentered;
+    my $dateentered = date_entered();
+    $result = "$dateentered" . "b        xxu||||| |||| 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(
-        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,
+    $template->param(tagfield => '008',
+            index => $index,
+            result => $result,
+            errorXml => $errorXml,
+            material_configuration => $material_configuration,
     );
     output_html_with_http_headers $input, $cookie, $template->output;
-}
+};
 
-1;
+return { builder => $builder, launcher => $launcher };