diff options
author | Artur Signell <artur@vaadin.com> | 2012-08-30 16:47:14 +0300 |
---|---|---|
committer | Artur Signell <artur@vaadin.com> | 2012-08-30 16:54:01 +0300 |
commit | c6112a24777ce7f6b708039e16909ed939014ca4 (patch) | |
tree | b1c31b0f3e898f01fcf5449ab501510cc81894af /server | |
parent | 51eb105ee6af55bc8972ab3e860c38a11194b5bd (diff) | |
download | vaadin-framework-c6112a24777ce7f6b708039e16909ed939014ca4.tar.gz vaadin-framework-c6112a24777ce7f6b708039e16909ed939014ca4.zip |
Removed multi select related hacks from ComboBox (#2869)
Diffstat (limited to 'server')
-rw-r--r-- | server/src/com/vaadin/ui/ComboBox.java | 86 |
1 files changed, 21 insertions, 65 deletions
diff --git a/server/src/com/vaadin/ui/ComboBox.java b/server/src/com/vaadin/ui/ComboBox.java index f4b55d964a..da3d2fd91d 100644 --- a/server/src/com/vaadin/ui/ComboBox.java +++ b/server/src/com/vaadin/ui/ComboBox.java @@ -18,12 +18,10 @@ package com.vaadin.ui; import java.util.ArrayList; import java.util.Collection; -import java.util.HashSet; import java.util.Iterator; import java.util.LinkedList; import java.util.List; import java.util.Map; -import java.util.Set; import com.vaadin.data.Container; import com.vaadin.data.util.filter.SimpleStringFilter; @@ -156,16 +154,6 @@ public class ComboBox extends AbstractSelect implements target.addAttribute(ComboBoxConstants.ATTR_NO_TEXT_INPUT, true); } - if (isMultiSelect()) { - // background compatibility hack. This object shouldn't be used for - // multiselect lists anymore (ListSelect instead). This fallbacks to - // a simpler paint method in super class. - super.paintContent(target); - // Fix for #4553 - target.addAttribute("type", "legacy-multi"); - return; - } - // clear caption change listeners getCaptionChangeListener().clear(); @@ -193,13 +181,8 @@ public class ComboBox extends AbstractSelect implements } // Constructs selected keys array - String[] selectedKeys; - if (isMultiSelect()) { - selectedKeys = new String[((Set<?>) getValue()).size()]; - } else { - selectedKeys = new String[(getValue() == null - && getNullSelectionItemId() == null ? 0 : 1)]; - } + String[] selectedKeys = new String[(getValue() == null + && getNullSelectionItemId() == null ? 0 : 1)]; target.addAttribute("pagelength", pageLength); @@ -383,8 +366,7 @@ public class ComboBox extends AbstractSelect implements // to page with the selected item after filtering if accepted by // filter Object selection = getValue(); - if (isScrollToSelectedItem() && !optionRequest && !isMultiSelect() - && selection != null) { + if (isScrollToSelectedItem() && !optionRequest && selection != null) { // ensure proper page indexToEnsureInView = indexed.indexOfId(selection); } @@ -475,8 +457,7 @@ public class ComboBox extends AbstractSelect implements // to page with the selected item after filtering if accepted by // filter Object selection = getValue(); - if (isScrollToSelectedItem() && !optionRequest && !isMultiSelect() - && selection != null) { + if (isScrollToSelectedItem() && !optionRequest && selection != null) { // ensure proper page indexToEnsureInView = options.indexOf(selection); } @@ -650,52 +631,21 @@ public class ComboBox extends AbstractSelect implements if (variables.containsKey("selected")) { final String[] ka = (String[]) variables.get("selected"); - if (isMultiSelect()) { - // Multiselect mode - - // TODO Optimize by adding repaintNotNeeded whan applicaple + // Single select mode + if (ka.length == 0) { - // Converts the key-array to id-set - final LinkedList<Object> s = new LinkedList<Object>(); - for (int i = 0; i < ka.length; i++) { - final Object id = itemIdMapper.get(ka[i]); - if (id != null && containsId(id)) { - s.add(id); - } - } - - // Limits the deselection to the set of visible items - // (non-visible items can not be deselected) + // Allows deselection only if the deselected item is visible + final Object current = getValue(); final Collection<?> visible = getVisibleItemIds(); - if (visible != null) { - @SuppressWarnings("unchecked") - Set<Object> newsel = (Set<Object>) getValue(); - if (newsel == null) { - newsel = new HashSet<Object>(); - } else { - newsel = new HashSet<Object>(newsel); - } - newsel.removeAll(visible); - newsel.addAll(s); - setValue(newsel, true); + if (visible != null && visible.contains(current)) { + setValue(null, true); } } else { - // Single select mode - if (ka.length == 0) { - - // Allows deselection only if the deselected item is visible - final Object current = getValue(); - final Collection<?> visible = getVisibleItemIds(); - if (visible != null && visible.contains(current)) { - setValue(null, true); - } + final Object id = itemIdMapper.get(ka[0]); + if (id != null && id.equals(getNullSelectionItemId())) { + setValue(null, true); } else { - final Object id = itemIdMapper.get(ka[0]); - if (id != null && id.equals(getNullSelectionItemId())) { - setValue(null, true); - } else { - setValue(id, true); - } + setValue(id, true); } } } @@ -802,6 +752,8 @@ public class ComboBox extends AbstractSelect implements } /** + * ComboBox does not support multi select mode. + * * @deprecated use {@link ListSelect}, {@link OptionGroup} or * {@link TwinColSelect} instead * @see com.vaadin.ui.AbstractSelect#setMultiSelect(boolean) @@ -817,15 +769,19 @@ public class ComboBox extends AbstractSelect implements } /** + * ComboBox does not support multi select mode. + * * @deprecated use {@link ListSelect}, {@link OptionGroup} or * {@link TwinColSelect} instead * * @see com.vaadin.ui.AbstractSelect#isMultiSelect() + * + * @return false */ @Deprecated @Override public boolean isMultiSelect() { - return super.isMultiSelect(); + return false; } /** |