diff options
author | Anna Koskinen <anna@vaadin.com> | 2012-12-21 15:25:40 +0200 |
---|---|---|
committer | Anna Koskinen <anna@vaadin.com> | 2012-12-21 15:25:40 +0200 |
commit | 52ccef6debd4e26b8249d1a00569f8b8b7e611cb (patch) | |
tree | 1129b9a252a850e73f47d3ef3f86a56111e0b42b | |
parent | 3f4c7a849dc219b3d458248bb812fa827ba2c898 (diff) | |
download | vaadin-framework-52ccef6debd4e26b8249d1a00569f8b8b7e611cb.tar.gz vaadin-framework-52ccef6debd4e26b8249d1a00569f8b8b7e611cb.zip |
Merge of (#9986) to Vaadin 7.
It should be possible to clear Table's value after container changes.
Change-Id: Ibacdae2b303375fc8303abd63a5673542a80ad38
-rw-r--r-- | server/src/com/vaadin/ui/AbstractSelect.java | 59 | ||||
-rw-r--r-- | uitest/src/com/vaadin/tests/components/table/ValueAfterClearingContainer.java | 121 |
2 files changed, 170 insertions, 10 deletions
diff --git a/server/src/com/vaadin/ui/AbstractSelect.java b/server/src/com/vaadin/ui/AbstractSelect.java index ac80dfbb74..5a674d4b89 100644 --- a/server/src/com/vaadin/ui/AbstractSelect.java +++ b/server/src/com/vaadin/ui/AbstractSelect.java @@ -17,6 +17,7 @@ package com.vaadin.ui; import java.io.Serializable; +import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.EventObject; @@ -25,6 +26,7 @@ import java.util.HashSet; import java.util.Iterator; import java.util.LinkedHashSet; import java.util.LinkedList; +import java.util.List; import java.util.Map; import java.util.Set; @@ -896,6 +898,42 @@ public abstract class AbstractSelect extends AbstractField<Object> implements } /** + * Checks that the current selection is valid, i.e. the selected item ids + * exist in the container. Updates the selection if one or several selected + * item ids are no longer available in the container. + */ + @SuppressWarnings("unchecked") + public void sanitizeSelection() { + Object value = getValue(); + if (value == null) { + return; + } + + boolean changed = false; + + if (isMultiSelect()) { + Collection<Object> valueAsCollection = (Collection<Object>) value; + List<Object> newSelection = new ArrayList<Object>( + valueAsCollection.size()); + for (Object subValue : valueAsCollection) { + if (containsId(subValue)) { + newSelection.add(subValue); + } else { + changed = true; + } + } + if (changed) { + setValue(newSelection); + } + } else { + if (!containsId(value)) { + setValue(null); + } + } + + } + + /** * Removes the property from all items. Removes a property with given id * from all the items in the container. * @@ -943,11 +981,11 @@ public abstract class AbstractSelect extends AbstractField<Object> implements if (items != null) { if (items instanceof Container.ItemSetChangeNotifier) { ((Container.ItemSetChangeNotifier) items) - .removeListener(this); + .removeItemSetChangeListener(this); } if (items instanceof Container.PropertySetChangeNotifier) { ((Container.PropertySetChangeNotifier) items) - .removeListener(this); + .removePropertySetChangeListener(this); } } @@ -960,11 +998,12 @@ public abstract class AbstractSelect extends AbstractField<Object> implements // Adds listeners if (items != null) { if (items instanceof Container.ItemSetChangeNotifier) { - ((Container.ItemSetChangeNotifier) items).addListener(this); + ((Container.ItemSetChangeNotifier) items) + .addItemSetChangeListener(this); } if (items instanceof Container.PropertySetChangeNotifier) { ((Container.PropertySetChangeNotifier) items) - .addListener(this); + .addPropertySetChangeListener(this); } } @@ -1829,7 +1868,7 @@ public abstract class AbstractSelect extends AbstractField<Object> implements } if (i instanceof Item.PropertySetChangeNotifier) { ((Item.PropertySetChangeNotifier) i) - .addListener(getCaptionChangeListener()); + .addPropertySetChangeListener(getCaptionChangeListener()); captionChangeNotifiers.add(i); } Collection<?> pids = i.getItemPropertyIds(); @@ -1839,7 +1878,7 @@ public abstract class AbstractSelect extends AbstractField<Object> implements if (p != null && p instanceof Property.ValueChangeNotifier) { ((Property.ValueChangeNotifier) p) - .addListener(getCaptionChangeListener()); + .addValueChangeListener(getCaptionChangeListener()); captionChangeNotifiers.add(p); } } @@ -1851,7 +1890,7 @@ public abstract class AbstractSelect extends AbstractField<Object> implements getItemCaptionPropertyId()); if (p != null && p instanceof Property.ValueChangeNotifier) { ((Property.ValueChangeNotifier) p) - .addListener(getCaptionChangeListener()); + .addValueChangeListener(getCaptionChangeListener()); captionChangeNotifiers.add(p); } break; @@ -1862,7 +1901,7 @@ public abstract class AbstractSelect extends AbstractField<Object> implements getItemIconPropertyId()); if (p != null && p instanceof Property.ValueChangeNotifier) { ((Property.ValueChangeNotifier) p) - .addListener(getCaptionChangeListener()); + .addValueChangeListener(getCaptionChangeListener()); captionChangeNotifiers.add(p); } } @@ -1874,10 +1913,10 @@ public abstract class AbstractSelect extends AbstractField<Object> implements Object notifier = it.next(); if (notifier instanceof Item.PropertySetChangeNotifier) { ((Item.PropertySetChangeNotifier) notifier) - .removeListener(getCaptionChangeListener()); + .removePropertySetChangeListener(getCaptionChangeListener()); } else { ((Property.ValueChangeNotifier) notifier) - .removeListener(getCaptionChangeListener()); + .removeValueChangeListener(getCaptionChangeListener()); } } captionChangeNotifiers.clear(); diff --git a/uitest/src/com/vaadin/tests/components/table/ValueAfterClearingContainer.java b/uitest/src/com/vaadin/tests/components/table/ValueAfterClearingContainer.java new file mode 100644 index 0000000000..93e7cafa99 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/table/ValueAfterClearingContainer.java @@ -0,0 +1,121 @@ +package com.vaadin.tests.components.table; + +import com.vaadin.data.Property.ValueChangeEvent; +import com.vaadin.data.Property.ValueChangeListener; +import com.vaadin.tests.components.TestBase; +import com.vaadin.tests.util.Log; +import com.vaadin.ui.Button; +import com.vaadin.ui.Button.ClickEvent; +import com.vaadin.ui.CheckBox; +import com.vaadin.ui.Notification; +import com.vaadin.ui.Table; + +public class ValueAfterClearingContainer extends TestBase { + + private static final String PROPERTY_ID = "property"; + + private Log log = new Log(5); + private final Table table = new Table(); + + @Override + protected void setup() { + table.setSelectable(true); + table.addContainerProperty(PROPERTY_ID, Integer.class, null); + table.setImmediate(true); + table.addValueChangeListener(new ValueChangeListener() { + + public void valueChange(ValueChangeEvent event) { + log.log("Value changed to " + event.getProperty().getValue()); + } + }); + addComponent(log); + + addComponent(table); + final CheckBox multiselect = new CheckBox("Multiselect"); + multiselect.setImmediate(true); + multiselect.addValueChangeListener(new ValueChangeListener() { + + public void valueChange(ValueChangeEvent event) { + Boolean value = multiselect.getValue(); + table.setMultiSelect(value == null ? false : value); + } + }); + addComponent(multiselect); + addComponent(new Button("Add table items", new Button.ClickListener() { + public void buttonClick(ClickEvent event) { + if (!table.getItemIds().isEmpty()) { + Notification.show("Only possible when the table is empty"); + return; + } else { + for (int i = 0; i < 5; i++) { + table.addItem(new Object[] { Integer.valueOf(i) }, + Integer.valueOf(i)); + } + } + } + })); + + addComponent(new Button("Show value", new Button.ClickListener() { + public void buttonClick(ClickEvent event) { + log.log("Table selection: " + table.getValue()); + } + })); + + addComponent(new Button("Remove items from table", + new Button.ClickListener() { + public void buttonClick(ClickEvent event) { + table.removeAllItems(); + } + })); + + addComponent(new Button("Remove items from container", + new Button.ClickListener() { + public void buttonClick(ClickEvent event) { + table.getContainerDataSource().removeAllItems(); + } + })); + addComponent(new Button("Remove items from container and sanitize", + new Button.ClickListener() { + public void buttonClick(ClickEvent event) { + table.getContainerDataSource().removeAllItems(); + table.sanitizeSelection(); + } + })); + addComponent(new Button("Remove selected item from table", + new Button.ClickListener() { + public void buttonClick(ClickEvent event) { + Object selection = table.getValue(); + if (selection == null) { + Notification.show("There is no selection"); + return; + } else { + table.removeItem(selection); + } + } + })); + addComponent(new Button("Remove selected item from container", + new Button.ClickListener() { + public void buttonClick(ClickEvent event) { + Object selection = table.getValue(); + if (selection == null) { + Notification.show("There is no selection"); + return; + } else { + table.getContainerDataSource() + .removeItem(selection); + } + } + })); + } + + @Override + protected String getDescription() { + return "Table value should be cleared when the selected item is removed from the container."; + } + + @Override + protected Integer getTicketNumber() { + return Integer.valueOf(9986); + } + +} |