Merge remote-tracking branch 'origin/new/bug_7889'
[srvgit] / cataloguing / value_builder / unimarc_field_120.pl
index 58fe8ae..f140fce 100755 (executable)
@@ -1,6 +1,5 @@
 #!/usr/bin/perl
 
-# $Id$
 
 # Copyright 2000-2002 Katipo Communications
 #
 # 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, write to the Free Software Foundation, Inc.,
+# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 
 use strict;
+#use warnings; FIXME - Bug 2505
 use C4::Auth;
 use CGI;
 use C4::Context;
@@ -27,11 +27,14 @@ use C4::Context;
 use C4::Search;
 use C4::Output;
 
-=head1
+=head1 FUNCTIONS
 
-plugin_parameters : other parameters added when the plugin is called by the dopop function
+=head2 plugin_parameters
+
+Other parameters added when the plugin is called by the dopop function
 
 =cut
+
 sub plugin_parameters {
 my ($dbh,$record,$tagslib,$i,$tabloop) = @_;
 return "";
@@ -39,7 +42,7 @@ return "";
 
 sub plugin_javascript {
 my ($dbh,$record,$tagslib,$field_number,$tabloop) = @_;
-my $function_name= "120".(int(rand(100000))+1);
+my $function_name=$field_number;
 my $res="
 <script>
 function Focus$function_name(subfield_managed) {
@@ -51,8 +54,8 @@ function Blur$function_name(subfield_managed) {
 }
 
 function Clic$function_name(i) {
-       defaultvalue=document.forms[0].field_value[i].value;
-       newin=window.open(\"plugin_launcher.pl?plugin_name=unimarc_field_120.pl&index=\"+i+\"&result=\"+defaultvalue,\"unimarc field 120\",'width=1200,height=750,toolbar=false,scrollbars=yes');
+       defaultvalue=document.getElementById(\"$field_number\").value;
+       newin=window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=unimarc_field_120.pl&index=$field_number&result=\"+defaultvalue,\"unimarc_field_120\",'width=1200,height=750,toolbar=false,scrollbars=yes');
 
 }
 </script>
@@ -60,11 +63,17 @@ function Clic$function_name(i) {
 
 return ($function_name,$res);
 }
+
+sub wrapper {
+    my ($char) = @_;
+    return "space" if $char eq " ";
+    return "dblspace" if $char eq "  ";
+    return "pipe" if $char eq "|";
+    return $char;
+}
+
 sub plugin {
 my ($input) = @_;
-       my %env;
-
-#      my $input = new CGI;
        my $index= $input->param('index');
        my $result= $input->param('result');
 
@@ -76,19 +85,19 @@ my ($template, $loggedinuser, $cookie)
                             query => $input,
                             type => "intranet",
                             authnotrequired => 0,
-                            flagsrequired => {editcatalogue => 1},
+                            flagsrequired => {editcatalogue => '*'},
                             debug => 1,
                             });
        my $f1 = substr($result,0,1);
        my $f2 = substr($result,1,1);
        my $f3 = substr($result,2,1);
-       my $f4 = substr($result,3,1);
-       my $f5 = substr($result,4,1);
-       my $f6 = substr($result,5,1);
-       my $f7 = substr($result,6,1);
+       my $f4 = substr($result,3,1); $f4 = wrapper( $f4 ) if $f4;
+       my $f5 = substr($result,4,1); $f5 = wrapper( $f5 ) if $f5;
+       my $f6 = substr($result,5,1); $f6 = wrapper( $f6 ) if $f6;
+       my $f7 = substr($result,6,1); $f7 = wrapper( $f7 ) if $f7;
        my $f8 = substr($result,7,2);
-       my $f9 = substr($result,9,2);
-       my $f10 = substr($result,11,2);
+       my $f9 = substr($result,9,2); $f9 = wrapper( $f9 ) if $f9;
+       my $f10 = substr($result,11,2); $f10 = wrapper( $f10 ) if $f10;
        $template->param(index => $index,
                                                        "f1$f1" => 1,
                                                        "f2$f2" => 1,
@@ -100,7 +109,7 @@ my ($template, $loggedinuser, $cookie)
                                                        "f8$f8" => 1,
                                                        "f9$f9" => 1,
                                                        "f10$f10" => 1);
-       print $input->header(-cookie => $cookie),$template->output;
+        output_html_with_http_headers $input, $cookie, $template->output;
 }
 
 1;