summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorThomas Tanghus <thomas@tanghus.net>2012-12-04 21:21:54 +0100
committerThomas Tanghus <thomas@tanghus.net>2012-12-04 21:21:54 +0100
commit6d643f9e74c32bbcb84d03404ee1cfd4613b6e2a (patch)
tree291a201db438b17ad9cedfc9a4ed8e6e2e948c94 /core
parent95bdfdb3199f2d2b368e7ded27c09acfc00cdd00 (diff)
downloadnextcloud-server-6d643f9e74c32bbcb84d03404ee1cfd4613b6e2a.tar.gz
nextcloud-server-6d643f9e74c32bbcb84d03404ee1cfd4613b6e2a.zip
multiSelect.js: Give each select a unique msid to prevent double adding in users.js
Diffstat (limited to 'core')
-rw-r--r--core/js/multiselect.js29
1 files changed, 19 insertions, 10 deletions
diff --git a/core/js/multiselect.js b/core/js/multiselect.js
index d41b5d552ab..9e808a2bb72 100644
--- a/core/js/multiselect.js
+++ b/core/js/multiselect.js
@@ -1,5 +1,7 @@
/**
- * @param 'createCallback' A function to be called when a new entry is created. Only argument to the function is the value of the option.
+ * @param 'createCallback' A function to be called when a new entry is created. Two arguments are supplied to this function:
+ * The select element used and the value of the option. If the function returns false addition will be cancelled. If it returns
+ * anything else it will be used as the value of the newly added option.
* @param 'createText' The placeholder text for the create action.
* @param 'title' The title to show if no options are selected.
* @param 'checked' An array containing values for options that should be checked. Any options which are already selected will be added to this array.
@@ -23,6 +25,7 @@
'onuncheck':false,
'minWidth': 'default;',
};
+ $(this).attr('data-msid', multiSelectId);
$.extend(settings,options);
$.each(this.children(),function(i,option) {
// If the option is selected, but not in the checked array, add it.
@@ -189,30 +192,36 @@
if (exists) {
return false;
}
+ var li=$(this).parent();
+ var val = $(this).val()
+ var select=button.parent().next();
+ if(typeof settings.createCallback === 'function') {
+ var response = settings.createCallback(select, val);
+ if(response === false) {
+ return false;
+ } else if(typeof response !== 'undefined') {
+ val = response;
+ }
+ }
if(settings.singleSelect) {
$.each(select.find('option:selected'), function() {
$(this).removeAttr('selected');
});
}
- var li=$(this).parent();
$(this).remove();
li.text('+ '+settings.createText);
li.before(createItem(this));
- if(self.menuDirection === 'up') {
- var list = li.parent();
- list.css('top', list.position().top-li.outerHeight());
- }
- var select=button.parent().next();
var option=$('<option selected="selected"/>');
+ option.text($(this).val()).val(val).attr('selected', 'selected');
select.append(option);
- option.text($(this).val()).val($(this).val()).attr('selected', 'selected');
li.prev().children('input').prop('checked', true).trigger('change');
button.parent().data('preventHide',false);
button.children('span').first().text(settings.labels.length > 0
? settings.labels.join(', ')
: settings.title);
- if(typeof settings.createCallback === 'function') {
- settings.createCallback($(this).val());
+ if(self.menuDirection === 'up') {
+ var list = li.parent();
+ list.css('top', list.position().top-li.outerHeight());
}
}
});