diff options
Diffstat (limited to 'server')
-rw-r--r-- | server/src/main/java/com/vaadin/ui/ComboBox.java | 97 |
1 files changed, 87 insertions, 10 deletions
diff --git a/server/src/main/java/com/vaadin/ui/ComboBox.java b/server/src/main/java/com/vaadin/ui/ComboBox.java index f8468d1acd..9500d08c96 100644 --- a/server/src/main/java/com/vaadin/ui/ComboBox.java +++ b/server/src/main/java/com/vaadin/ui/ComboBox.java @@ -22,7 +22,10 @@ import java.util.Collection; import java.util.HashMap; import java.util.Map; import java.util.Objects; +import java.util.Optional; import java.util.Set; +import java.util.logging.Level; +import java.util.logging.Logger; import java.util.stream.Stream; import org.jsoup.nodes.Element; @@ -70,8 +73,8 @@ import elemental.json.JsonObject; */ @SuppressWarnings("serial") public class ComboBox<T> extends AbstractSingleSelect<T> - implements FieldEvents.BlurNotifier, - FieldEvents.FocusNotifier, HasFilterableDataProvider<T, String> { + implements FieldEvents.BlurNotifier, FieldEvents.FocusNotifier, + HasFilterableDataProvider<T, String> { /** * A callback method for fetching items. The callback is provided with a @@ -118,12 +121,28 @@ public class ComboBox<T> extends AbstractSingleSelect<T> * </p> * * @since 8.0 + * @deprecated Since 8.4 replaced by {@link NewItemProvider}. */ + @Deprecated @FunctionalInterface public interface NewItemHandler extends SerializableConsumer<String> { } /** + * Provider function that adds a new item based on user input when the new + * items allowed mode is active. After the new item handling is complete, + * this function should return {@code Optional.of(text)} for the completion + * of automatic selection handling. If automatic selection is not wished + * for, always return {@code Optional.isEmpty()}. + * + * @since 8.4 + */ + @FunctionalInterface + public interface NewItemProvider<T> + extends SerializableFunction<String, Optional<T>> { + } + + /** * Item style generator class for declarative support. * <p> * Provides a straightforward mapping between an item and its style. @@ -166,7 +185,15 @@ public class ComboBox<T> extends AbstractSingleSelect<T> public void createNewItem(String itemValue) { // New option entered if (itemValue != null && !itemValue.isEmpty()) { - if (getNewItemHandler() != null) { + if (getNewItemProvider() != null) { + Optional<T> item = getNewItemProvider().apply(itemValue); + if (!item.isPresent()) { + // ensure the client resets the value to previous + // selection + getRpcProxy(ComboBoxClientRpc.class) + .newItemNotAdded(itemValue); + } + } else if (getNewItemHandler() != null) { getNewItemHandler().accept(itemValue); } else { // selection handling is needed at the client even if @@ -187,8 +214,14 @@ public class ComboBox<T> extends AbstractSingleSelect<T> /** * Handler for new items entered by the user. */ + @Deprecated private NewItemHandler newItemHandler; + /** + * Provider function for new items entered by the user. + */ + private NewItemProvider<T> newItemProvider; + private StyleGenerator<T> itemStyleGenerator = item -> null; private String currentFilterText; @@ -441,9 +474,11 @@ public class ComboBox<T> extends AbstractSingleSelect<T> /** * Returns true if the user can enter text into the field to either filter - * the selections or enter a new value if new item handler is set (see - * {@link #setNewItemHandler(NewItemHandler)}. If text input is disabled, - * the comboBox will work in the same way as a {@link NativeSelect} + * the selections or enter a new value if new item provider or handler is + * set (see {@link #setNewItemProvider(NewItemProvider)} (recommended) and + * {@link #setNewItemHandler(NewItemHandler)} (deprecated)). If text input + * is disabled, the comboBox will work in the same way as a + * {@link NativeSelect} * * @return true if text input is allowed */ @@ -667,17 +702,42 @@ public class ComboBox<T> extends AbstractSingleSelect<T> /** * Sets the handler that is called when user types a new item. The creation - * of new items is allowed when a new item handler has been set. + * of new items is allowed when a new item handler has been set. If new item + * provider is also set, the new item handler is ignored. * * @param newItemHandler * handler called for new items, null to only permit the - * selection of existing items + * selection of existing items, all options ignored if new item + * provider is set * @since 8.0 + * @deprecated Since 8.4 use {@link #setNewItemProvider(NewItemProvider)} + * instead. */ + @Deprecated public void setNewItemHandler(NewItemHandler newItemHandler) { + getLogger().log(Level.WARNING, + "NewItemHandler is deprecated. Please use NewItemProvider instead."); this.newItemHandler = newItemHandler; - getState().allowNewItems = newItemHandler != null; - markAsDirty(); + getState(true).allowNewItems = newItemProvider != null + || newItemHandler != null; + } + + /** + * Sets the provider function that is called when user types a new item. The + * creation of new items is allowed when a new item provider has been set. + * If a deprecated new item handler is also set it is ignored in favor of + * new item provider. + * + * @param newItemProvider + * provider function that is called for new items, null to only + * permit the selection of existing items or to use a deprecated + * new item handler if set + * @since 8.4 + */ + public void setNewItemProvider(NewItemProvider<T> newItemProvider) { + this.newItemProvider = newItemProvider; + getState(true).allowNewItems = newItemProvider != null + || newItemHandler != null; } /** @@ -685,11 +745,24 @@ public class ComboBox<T> extends AbstractSingleSelect<T> * in the data provider). * * @return new item handler or null if none specified + * @deprecated Since 8.4 use {@link #getNewItemProvider()} instead. */ + @Deprecated public NewItemHandler getNewItemHandler() { return newItemHandler; } + /** + * Returns the provider function that is called when the user enters a new + * item (not present in the data provider). + * + * @since 8.4 + * @return new item provider or null if none specified + */ + public NewItemProvider<T> getNewItemProvider() { + return newItemProvider; + } + // HasValue methods delegated to the selection model @Override @@ -871,4 +944,8 @@ public class ComboBox<T> extends AbstractSingleSelect<T> @Override public boolean test(String itemCaption, String filterText); } + + private static Logger getLogger() { + return Logger.getLogger(ComboBox.class.getName()); + } } |