Bug 10648 - In records merge greatest field can not be added
authorFridolyn SOMERS <fridolyn.somers@biblibre.com>
Fri, 26 Jul 2013 15:02:01 +0000 (17:02 +0200)
committerTomas Cohen Arazi <tomascohen@gmail.com>
Tue, 5 Aug 2014 23:17:17 +0000 (20:17 -0300)
When merging 2 records (/cgi-bin/koha/cataloguing/merge.pl), the destination record is build using the fields and subfields checked in source records.
When a field is checked, the javascript code searches in destination record a field with a greater tag number to insert new field before.
When the new field tag number is greater than all existing field tag numbers, the field is not added.

This patch corrects this by adding at end if no greater field tag number exists. Also adds a sort of fields by tag number because all mergo code is based on this.

Test plan :
- Add to a framework a repeatable field with the greater non existing tag number. For example 998.
- Edit 2 records with this framework and add them a value in this tag.
- Put those records is a list
- Go to this list and check the two records
- Click on "Merge selected"
- Click on next
- Go to second source record
- Click on the greatest tag number. for example 998.
=> The field is added at the end of destination record

Signed-off-by: Nick Clemens <nick@quecheelibrary.org>
Signed-off-by: Kyle M Hall <kyle@bywatersolutions.com>
Signed-off-by: Tomas Cohen Arazi <tomascohen@gmail.com>
Works as described, no regressions.

koha-tmpl/intranet-tmpl/prog/en/js/merge-record.js

index bf1f13a..80de586 100644 (file)
@@ -79,8 +79,9 @@ function toggleField(pField) {
                     // If not, we add the subfield to the first matching field
                     var where = 0;
                     $("#resultul li span.field").each(function() {
-                        if (where == 0 && $(this).text() == field) {
+                        if ($(this).text() == field) {
                             where = this;
+                            return false; // break each()
                         }
                     });
 
@@ -102,14 +103,19 @@ function toggleField(pField) {
             } else {
                 // If we are a field
                 var where = 0;
-                // Find where to add the field
+                // Find a greater field to add before
                 $("#resultul li span.field").each(function() {
-                    if (where == 0 && $(this).text() > field) {
+                    if ($(this).text() > field) {
                         where = this;
+                        return false; // break each()
                     }
                 });
-
-                $(where).parent().before(clone);
+                if (where) {
+                    $(where).parent().before(clone);
+                } else {
+                    // No greater field, add to the end
+                    $("#resultul").append(clone);
+                }
             }
         }
     } else {