X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=js%2Fjquery.multiselect2side.js;h=de74b64322f6ee307b6050878382ec24f6a37c03;hb=f4da9593b8f91ae5d57437ed124f9c9d859bc698;hp=36e56b02b112b3111e17ed3e8457c9e777b8c091;hpb=bbb24781296854d6be87195f51d84d0f977df72f;p=kivitendo-erp.git
diff --git a/js/jquery.multiselect2side.js b/js/jquery.multiselect2side.js
index 36e56b02b..de74b6432 100644
--- a/js/jquery.multiselect2side.js
+++ b/js/jquery.multiselect2side.js
@@ -22,19 +22,32 @@
labelSort: 'Sort',
labelsx: 'Available',
labeldx: 'Selected',
- maxSelected: -1
+ maxSelected: -1,
+ leftSel: null,
+ rightSel: null,
+
+ sortOptions: function() {
+ o.leftSel.sortOptions();
+ o.rightSel.sortOptions();
+ }
}, o);
return this.each(function () {
var el = $(this);
- var originalName = $(this).attr("name");
- if (originalName.indexOf('[') != -1)
- originalName = originalName.substring(0, originalName.indexOf('['));
-
- var nameDx = originalName + "ms2side__dx";
- var nameSx = originalName + "ms2side__sx";
- var size = $(this).attr("size");
+ var hiddenName = $(this).attr("name");
+ var originalID = $(this).attr("id");
+ if (!originalID)
+ originalID = hiddenName;
+ if (originalID.indexOf('[') != -1)
+ originalID = originalID.substring(0, originalID.indexOf('['));
+
+ var nameDx = originalID + "ms2side__dx";
+ var idDx = originalID + "ms2side__dx";
+ var nameSx = originalID + "ms2side__sx";
+ var hiddenId = originalID + "ms2side_hidden";
+ var size = $(this).attr("size");
+ $(this).attr("name", originalID + "ms2side__orig");
// SIZE MIN
if (size < 6) {
$(this).attr("size", "6");
@@ -75,11 +88,13 @@
"" +
"
" +
(o.labeldx ? ("") : "") +
- "" +
+ "" +
"
" +
+ "" +
((o.selectedPosition == 'right' && o.moveOptions) ? divUpDown : "") +
"";
$(this).after(htmlToAdd).hide();
+ $("#" + hiddenId).hide();
// ELEMENTS
var allSel = $(this).next().find("select");
@@ -87,6 +102,8 @@
var rightSel = (o.selectedPosition == 'right') ? allSel.eq(1) : allSel.eq(0);
// HEIGHT DIV
var heightDiv = $(".ms2side__select").eq(0).height();
+ o.leftSel = leftSel;
+ o.rightSel = rightSel;
// CENTER MOVE OPTIONS AND UPDOWN OPTIONS
$(this).next().find('.ms2side__options, .ms2side__updown').each(function(){
@@ -109,6 +126,7 @@
var selectDx = rightSel.children();
var selectedSx = leftSel.find("option:selected");
var selectedDx = rightSel.find("option:selected");
+ var hiddenCont = $("#" + hiddenId);
if (selectedSx.size() == 0 || (o.maxSelected >= 0 && (selectedSx.size() + selectDx.size()) > o.maxSelected))
div.find(".AddOne").addClass('ms2side__hide');
@@ -140,8 +158,11 @@
else
div.find(".RemoveAll").removeClass('ms2side__hide');
- leftSel.sortOptions();
- rightSel.sortOptions();
+ // Rebuild hidden inputs...
+ hiddenCont.empty();
+ rightSel.find("option").each(function(idx, option) {
+ $('').attr("name", hiddenName).attr("value", $(option).attr("value")).appendTo(hiddenCont);
+ });
});
// DOUBLE CLICK ON LEFT SELECT OPTION
@@ -154,6 +175,7 @@
}
});
$(this).trigger('change');
+ o.sortOptions();
});
// DOUBLE CLICK ON RIGHT SELECT OPTION
@@ -163,6 +185,7 @@
el.find("[value=" + $(selected).val() + "]").attr("selected", false).remove().appendTo(el);
});
$(this).trigger('change');
+ o.sortOptions();
});
// CLICK ON OPTION
@@ -173,24 +196,28 @@
$(this).remove().appendTo(rightSel);
el.find("[value=" + $(selected).val() + "]").attr("selected", true).remove().appendTo(el);
});
+ o.sortOptions();
} else if ($(this).hasClass("AddAll")) { // ALL SELECTED
leftSel.children().appendTo(rightSel);
leftSel.children().remove();
el.find('option').attr("selected", true);
// el.children().attr("selected", true); -- PROBLEM WITH OPTGROUP
+ o.sortOptions();
} else if ($(this).hasClass("RemoveOne")) {
rightSel.find("option:selected").each(function(i, selected){
$(this).remove().appendTo(leftSel);
el.find("[value=" + $(selected).val() + "]").attr("selected", false).remove().appendTo(el);
});
+ o.sortOptions();
} else if ($(this).hasClass("RemoveAll")) { // ALL REMOVED
rightSel.children().appendTo(leftSel);
rightSel.children().remove();
el.find('option').attr("selected", false);
//el.children().attr("selected", false); -- PROBLEM WITH OPTGROUP
+ o.sortOptions();
}
}
@@ -271,6 +298,7 @@
// UPDATE BUTTON ON START
leftSel.trigger('change');
+ o.sortOptions();
// SHOW WHEN ALL READY
$(this).next().show();
});