Fixing the thai double up
[koha.git] / cataloguing / value_builder / unimarc_field_225a.pl
index 16ca286..25d9419 100755 (executable)
@@ -1,6 +1,5 @@
 #!/usr/bin/perl
 
-# $Id$
 
 # Copyright 2000-2002 Katipo Communications
 #
@@ -18,6 +17,7 @@
 # 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
+
 =head1 SYNOPSIS
 
 This plugin is used to map isbn/editor with collection.
@@ -27,11 +27,11 @@ It need :
   isbn separator editor separator collection.
   for example :
   2204 -- Cerf -- Cogitatio fidei
-  2204 -- Cerf -- Le Magistre de l'Eglise
+  2204 -- Cerf -- Le Magistere de l'Eglise
   2204 -- Cerf -- Lectio divina
   2204 -- Cerf -- Lire la Bible
   2204 -- Cerf -- Pour lire
-  2204 -- Cerf -- Sources chrtiennes
+  2204 -- Cerf -- Sources chretiennes
 
   when the user clic on ... on 225a line, the popup shows the list of collections from the selected editor
   if the biblio has no isbn, then the search if done on editor only
@@ -46,7 +46,7 @@ use C4::Auth;
 use CGI;
 use C4::Context;
 
-use C4::Search;
+use C4::AuthoritiesMarc;
 use C4::Output;
 
 =head1
@@ -54,105 +54,106 @@ use C4::Output;
 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 "";
+    my ( $dbh, $record, $tagslib, $i, $tabloop ) = @_;
+    return "";
 }
 
 sub plugin_javascript {
-my ($dbh,$record,$tagslib,$field_number,$tabloop) = @_;
-my $function_name= "100".(int(rand(100000))+1);
-my $res="
-<script>
-function Focus$function_name(subfield_managed) {
-return 1;
-}
-
-function Blur$function_name(subfield_managed) {
-       return 1;
-}
-
-function Clic$function_name(index) {
-// find the 010a value and the 210c. it will be used in the popup to find possibles collections
-       var isbn_found;
-       for (i=0 ; i<document.f.field_value.length ; i++) {
-               if (document.f.tag[i].value == '010' && document.f.subfield[i].value == 'a') {
-                       isbn_found=document.f.field_value[i].value;
-               }
-       }
-       var editor_found;
-       for (i=0 ; i<document.f.field_value.length ; i++) {
-               if (document.f.tag[i].value == '210' && document.f.subfield[i].value == 'c') {
-                       editor_found=document.f.field_value[i].value;
-               }
-       }
-
-       defaultvalue=document.f.field_value[index].value;
-       newin=window.open(\"plugin_launcher.pl?plugin_name=unimarc_field_225a.pl&index=\"+index+\"&result=\"+defaultvalue+\"&isbn_found=\"+isbn_found+\"&editor_found=\"+editor_found,\"unimarc 225a\",'width=500,height=200,toolbar=false,scrollbars=no');
-
-}
-</script>
+    my ( $dbh, $record, $tagslib, $field_number, $tabloop ) = @_;
+    my $function_name = $field_number;
+    my $res = "
+    <script type=\"text/javascript\">
+        function Focus$function_name(subfield_managed) {
+            return 1;
+        }
+    
+        function Blur$function_name(subfield_managed) {
+            return 1;
+        }
+    
+        function Clic$function_name(index) {
+        // find the 010a value and the 210c. it will be used in the popup to find possibles collections
+            var isbn_found   = 0;
+            var editor_found = 0;
+            
+            var inputs = document.getElementsByTagName('input');
+            
+            for(var i=0 , len=inputs.length ; i \< len ; i++ ){
+                if(inputs[i].id.match(/^tag_210_subfield_c_.*/)){
+                    editor_found = inputs[i].value;
+                }
+                if(editor_found && isbn_found){
+                    break;
+                }
+            }
+                    
+            defaultvalue = document.getElementById(\"$field_number\").value;
+            window.open(\"../cataloguing/plugin_launcher.pl?plugin_name=unimarc_field_225a.pl&index=\"+index+\"&result=\"+defaultvalue+\"&editor_found=\"+editor_found,\"unimarc225a\",'width=500,height=200,toolbar=false,scrollbars=no');
+    
+        }
+    </script>
 ";
 
-return ($function_name,$res);
+    return ( $function_name, $res );
 }
+
 sub plugin {
-my ($input) = @_;
-       my $index= $input->param('index');
-       my $result= $input->param('result');
-       my $editor_found = $input->param('editor_found');
-       my $isbn_found = $input->param('isbn_found');
-       my $dbh = C4::Context->dbh;
-       my $authoritysep = C4::Context->preference("authoritysep");
-       my ($template, $loggedinuser, $cookie)
-       = get_template_and_user({template_name => "cataloguing/value_builder/unimarc_field_225a.tmpl",
-                                       query => $input,
-                                       type => "intranet",
-                                       authnotrequired => 0,
-                                       flagsrequired => {editcatalogue => 1},
-                                       debug => 1,
-                                       });
+    my ($input)      = @_;
+    my $index        = $input->param('index');
+    my $result       = $input->param('result');
+    my $editor_found = $input->param('editor_found');
+    my $authoritysep = C4::Context->preference("authoritysep");
+    
+    my ( $template, $loggedinuser, $cookie ) = get_template_and_user(
+        {
+            template_name =>
+              "cataloguing/value_builder/unimarc_field_225a.tmpl",
+            query           => $input,
+            type            => "intranet",
+            authnotrequired => 0,
+            flagsrequired   => { editcatalogue => 1 },
+            debug           => 1,
+        }
+    );
+
 # builds collection list : search isbn and editor, in parent, then load collections from bibliothesaurus table
-       # if there is an isbn, complete search
-               my @collections;
-               if ($isbn_found) {
-                       my $sth = $dbh->prepare("select auth_subfield_table.authid,subfieldvalue from auth_subfield_table 
-                                                       left join auth_header on auth_subfield_table.authid=auth_header.authid 
-                                                       where authtypecode='EDITORS' and tag='200' and subfieldcode='a' and subfieldvalue=?");
-                       my $sth2 = $dbh->prepare("select subfieldvalue from auth_subfield_table where tag='200' and subfieldcode='c' and authid=? order by subfieldvalue");
-                       my @splited = split //, $isbn_found;
-                       my $isbn_rebuild='';
-                       foreach my $x (@splited) {
-                               $isbn_rebuild.=$x;
-                               $sth->execute($isbn_rebuild);
-                               my ($authid) = $sth->fetchrow;
-                               $sth2->execute($authid);
-                               while (my ($line)= $sth2->fetchrow) {
-                                       push @collections,$line;
-                               }
-                       }
-               } else {
-                       my $sth = $dbh->prepare("select auth_subfield_table.authid,subfieldvalue from auth_subfield_table 
-                                                       left join auth_header on auth_subfield_table.authid=auth_header.authid 
-                                                       where authtypecode='EDITORS' and tag='200' and subfieldcode='b' and subfieldvalue=?");
-                       my $sth2 = $dbh->prepare("select subfieldvalue from auth_subfield_table where tag='200' and subfieldcode='c' and authid=? order by subfieldvalue");
-                       $sth->execute($editor_found);
-                       my ($authid) = $sth->fetchrow;
-                       $sth2->execute($authid);
-                       while (my ($line)= $sth2->fetchrow) {
-                               push @collections,$line;
-                       }
-               }
-#      my @collections = ["test"];
-       my $collection =CGI::scrolling_list(-name=>'f1',
-                                                                                               -values=> \@collections,
-                                                                                               -default=>"$result",
-                                                                                               -size=>1,
-                                                                                               -multiple=>0,
-                                                                                               );
-       $template->param(index => $index,
-                                                       collection => $collection);
-        output_html_with_http_headers $input, $cookie, $template->output;
+# if there is an isbn, complete search
+    my @collections;
+    
+    my @value     = ($editor_found,"","");
+    my @tags      = ("mainentry","","");
+    my @and_or    = ('and','','');
+    my @operator  = ('is','','');
+    my @excluding = ('','','');
+    
+    
+    my ($results,$total) = SearchAuthorities( \@tags,\@and_or,
+                                            \@excluding, \@operator, \@value,
+                                            0, 20,"EDITORS", "HeadingAsc");
+    foreach my $editor (@$results){
+        my $authority = GetAuthority($editor->{authid});
+        foreach my $col ($authority->subfield('200','c')){
+            push @collections, $col;
+        }
+            
+    } 
+    @collections = sort @collections;
+
+    #  my @collections = ["test"];
+    my $collection = CGI::scrolling_list(
+        -name     => 'f1',
+        -values   => \@collections,
+        -default  => "$result",
+        -size     => 1,
+        -multiple => 0,
+    );
+    $template->param(
+        index      => $index,
+        collection => $collection
+    );
+    output_html_with_http_headers $input, $cookie, $template->output;
 }
 
 1;