Browse Source

#2689 #2690 Fixes issues with restore defaults. Fixes issues with confusion over set selected

pull/2710/head
jlukic 9 years ago
parent
commit
46b5d53cc5
1 changed files with 19 additions and 22 deletions
  1. 41
      src/definitions/modules/dropdown.js

41
src/definitions/modules/dropdown.js

@ -1441,10 +1441,16 @@ $.fn.dropdown = function(parameters) {
}; };
}, },
value: function() { value: function() {
return ($input.length > 0)
? $input.val()
: $module.data(metadata.value)
var
value = ($input.length > 0)
? $input.val()
: $module.data(metadata.value)
; ;
// prevents placeholder element from being selected when multiple
if($.isArray(value) && value.length === 1 && value[0] === '') {
return '';
}
return value;
}, },
values: function() { values: function() {
var var
@ -2099,7 +2105,6 @@ $.fn.dropdown = function(parameters) {
module.debug('Adding user option', value); module.debug('Adding user option', value);
module.add.optionValue(value); module.add.optionValue(value);
} }
module.debug('Updating input value', value, currentValue); module.debug('Updating input value', value, currentValue);
$input $input
.val(value) .val(value)
@ -2130,6 +2135,11 @@ $.fn.dropdown = function(parameters) {
visible: function() { visible: function() {
$module.addClass(className.visible); $module.addClass(className.visible);
}, },
exactly: function(value, $selectedItem) {
module.debug('Setting selected to exact values');
module.clear();
module.set.selected(value, $selectedItem);
},
selected: function(value, $selectedItem) { selected: function(value, $selectedItem) {
var var
isMultiple = module.is.multiple(), isMultiple = module.is.multiple(),
@ -2529,26 +2539,13 @@ $.fn.dropdown = function(parameters) {
module.verbose('Removed value from delimited string', removedValue, values); module.verbose('Removed value from delimited string', removedValue, values);
return values; return values;
}, },
label: function(value) {
label: function(value, shouldAnimate) {
var var
$labels = $module.find(selector.label), $labels = $module.find(selector.label),
$removedLabel = $labels.filter('[data-value="' + value +'"]'),
labelCount = $labels.length,
isLastLabel = ($labels.index($removedLabel) + 1 == labelCount),
shouldAnimate = ( (!module.is.searchSelection() || !module.is.focusedOnSearch()) && isLastLabel)
;
if(shouldAnimate) {
module.verbose('Animating and removing label', $removedLabel);
$removedLabel
.transition(settings.label.transition, settings.label.duration, function() {
$removedLabel.remove();
})
;
}
else {
module.verbose('Removing label', $removedLabel);
$removedLabel.remove();
}
$removedLabel = $labels.filter('[data-value="' + value +'"]')
;
module.verbose('Removing label', $removedLabel);
$removedLabel.remove();
}, },
activeLabels: function($activeLabels) { activeLabels: function($activeLabels) {
$activeLabels = $activeLabels || $module.find(selector.label).filter('.' + className.active); $activeLabels = $activeLabels || $module.find(selector.label).filter('.' + className.active);

Loading…
Cancel
Save