From 7a5eac3a51b3dc5b344c91a729b282a191bf2c8e Mon Sep 17 00:00:00 2001 From: Fridolyn SOMERS Date: Fri, 26 Jul 2013 17:02:01 +0200 Subject: [PATCH] Bug 10648 - In records merge greatest field can not be added 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 Signed-off-by: Kyle M Hall Signed-off-by: Tomas Cohen Arazi Works as described, no regressions. --- .../intranet-tmpl/prog/en/js/merge-record.js | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/koha-tmpl/intranet-tmpl/prog/en/js/merge-record.js b/koha-tmpl/intranet-tmpl/prog/en/js/merge-record.js index bf1f13aac1..80de5864d9 100644 --- a/koha-tmpl/intranet-tmpl/prog/en/js/merge-record.js +++ b/koha-tmpl/intranet-tmpl/prog/en/js/merge-record.js @@ -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 { -- 2.39.5