Bug 32437: Add Objects for ImportAuths
[koha-ffzg.git] / cataloguing / value_builder / marc21_field_007.pl
index d65c33e..093653d 100755 (executable)
@@ -1,5 +1,7 @@
 #!/usr/bin/perl
 
+# Converted to new plugin style (Bug 13437)
+
 # Copyright 2000-2002 Katipo Communications
 #
 # This file is part of Koha.
 # 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 warnings; FIXME - Bug 2505
-use C4::Auth;
+use C4::Auth qw( get_template_and_user );
 use CGI qw ( -utf8 );
 use C4::Context;
 
 use C4::Search;
-use C4::Output;
-
-=head1 DESCRIPTION
-
-plugin_parameters : other parameters added when the plugin is called by the dopop function
+use C4::Output qw( output_html_with_http_headers );
 
-=cut
-
-sub plugin_javascript {
-    my ( $dbh, $record, $tagslib, $field_number, $tabloop ) = @_;
-    my $function_name = $field_number;
+my $builder = sub {
+    my ( $params ) = @_;
+    my $function_name = $params->{id};
     my $res           = "
-<script type=\"text/javascript\">
-//<![CDATA[
+<script>
 
-function Clic$function_name(i) {
-       defaultvalue=document.getElementById(\"$field_number\").value;
-       newin=window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=marc21_field_007.pl&index=$field_number&result=\"+defaultvalue,\"tag_editor\",'width=1000,height=600,toolbar=false,scrollbars=yes');
+function Click$function_name(event) {
+    defaultvalue=document.getElementById(event.data.id).value;
+    newin=window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=marc21_field_007.pl&index=\"+ event.data.id +\"&result=\"+defaultvalue,\"tag_editor\",'width=1000,height=600,toolbar=false,scrollbars=yes');
 
 }
-//]]>
 </script>
 ";
 
-    return ( $function_name, $res );
-}
+    return $res;
+};
 
-sub plugin {
-    my ($input) = @_;
+my $launcher = sub {
+    my ( $params ) = @_;
+    my $input = $params->{cgi};
     my $index   = $input->param('index');
     my $result  = $input->param('result');
 
@@ -63,91 +57,40 @@ sub plugin {
         {   template_name   => "cataloguing/value_builder/marc21_field_007.tt",
             query           => $input,
             type            => "intranet",
-            authnotrequired => 0,
             flagsrequired   => { editcatalogue => '*' },
-            debug           => 1,
         }
     );
-    $result = "ta" unless $result;
-    my $f0 = substr( $result, 0, 1 );
-    my $f1 = substr( $result, 1, 1 );
 
-    #added new parameters to allow for all material types
-    my $f2  = substr( $result, 2,  1 );
-    my $f3  = substr( $result, 3,  1 );
-    my $f4  = substr( $result, 4,  1 );
-    my $f5  = substr( $result, 5,  1 );
-    my $f6  = substr( $result, 6,  1 );
-    my $f7  = substr( $result, 7,  1 );
-    my $f8  = substr( $result, 8,  1 );
-    my $f9  = substr( $result, 9,  1 );
-    my $f10 = substr( $result, 10, 1 );
-    my $f11 = substr( $result, 11, 1 );
-    my $f12 = substr( $result, 12, 1 );
-    my $f13 = substr( $result, 13, 1 );
-    my $f14 = substr( $result, 14, 1 );
-    my $f15 = substr( $result, 15, 1 );
-    my $f16 = substr( $result, 16, 1 );
-    my $f17 = substr( $result, 17, 1 );
-    my $f18 = substr( $result, 18, 1 );
-    my $f19 = substr( $result, 19, 1 );
-    my $f20 = substr( $result, 20, 1 );
-    my $f21 = substr( $result, 21, 1 );
-    my $f22 = substr( $result, 22, 1 );
+    $result = "ta" unless $result;
+    my $pad_length = 23 - length $result;
+    my @fvalues = split //, $result;
+    if ($pad_length>0) {
+        push @fvalues, (undef)x($pad_length);
+    }
+    my @fnames = map { "f$_" } (0..22);
 
-    #FIXME:  There is probably a more-elegant way to do this!
     #FIXME:  Two of the material types treat position 06, 07, and 08 as a single
     #three-char field.  This script works fine for creating values and sending them
     #back to the MARC, but if there is already a value in the 007, it won't send
     #it properly to the value builder for those two instances.  Not sure how to solve.
-    $template->param(
-        index     => $index,
-        f0        => $f0,
-        "f0$f0"   => $f0,
-        f1        => $f1,
-        "f1$f1"   => $f1,
-        f2        => $f2,
-        "f2$f2"   => $f2,
-        f3        => $f3,
-        "f3$f3"   => $f3,
-        f4        => $f4,
-        "f4$f4"   => $f4,
-        f5        => $f5,
-        "f5$f5"   => $f5,
-        f6        => $f6,
-        "f6$f6"   => $f6,
-        f7        => $f7,
-        "f7$f7"   => $f7,
-        f8        => $f8,
-        "f8$f8"   => $f8,
-        f9        => $f9,
-        "f9$f9"   => $f9,
-        f10       => $f10,
-        "f10$f10" => $f10,
-        f11       => $f11,
-        "f11$f11" => $f11,
-        f12       => $f12,
-        "f12$f12" => $f12,
-        f13       => $f13,
-        "f13$f13" => $f13,
-        f14       => $f14,
-        "f14$f14" => $f14,
-        f15       => $f15,
-        "f15$f15" => $f15,
-        f16       => $f16,
-        "f16$f16" => $f16,
-        f17       => $f17,
-        "f17$f17" => $f17,
-        f18       => $f18,
-        "f18$f18" => $f18,
-        f19       => $f19,
-        "f19$f19" => $f19,
-        f20       => $f20,
-        "f20$f20" => $f20,
-        f21       => $f21,
-        "f21$f21" => $f21,
-        f22       => $f22,
-        "f22$f22" => $f22,
-    );
+    $template->param( index => $index );
+    foreach my $count ( 0..22 ) {
+        if (defined $fvalues[$count]) {
+            # template uses f##pipe variables.
+            my $key2;
+            if ($fvalues[$count] eq q{|}) {
+                $key2 = $fnames[$count] . 'pipe';
+            }
+            else {
+                $key2 = $fnames[$count] . $fvalues[$count];
+            }
+            $template->param(
+                $fnames[$count] => $fvalues[$count],
+                $key2           => $fvalues[$count]
+            );
+        }
+    }
     output_html_with_http_headers $input, $cookie, $template->output;
-}
+};
+
+return { builder => $builder, launcher => $launcher };