diff options
Diffstat (limited to 'server')
-rw-r--r-- | server/src/main/java/com/vaadin/ui/ComboBox.java | 68 |
1 files changed, 54 insertions, 14 deletions
diff --git a/server/src/main/java/com/vaadin/ui/ComboBox.java b/server/src/main/java/com/vaadin/ui/ComboBox.java index c8f6907866..ef1e7cfa84 100644 --- a/server/src/main/java/com/vaadin/ui/ComboBox.java +++ b/server/src/main/java/com/vaadin/ui/ComboBox.java @@ -35,6 +35,7 @@ import com.vaadin.data.HasValue; import com.vaadin.data.ValueProvider; import com.vaadin.data.provider.CallbackDataProvider; import com.vaadin.data.provider.DataCommunicator; +import com.vaadin.data.provider.DataGenerator; import com.vaadin.data.provider.DataKeyMapper; import com.vaadin.data.provider.DataProvider; import com.vaadin.data.provider.ListDataProvider; @@ -44,6 +45,7 @@ import com.vaadin.event.FieldEvents.BlurListener; import com.vaadin.event.FieldEvents.FocusAndBlurServerRpcDecorator; import com.vaadin.event.FieldEvents.FocusEvent; import com.vaadin.event.FieldEvents.FocusListener; +import com.vaadin.server.ConnectorResource; import com.vaadin.server.KeyMapper; import com.vaadin.server.Resource; import com.vaadin.server.ResourceReference; @@ -288,21 +290,56 @@ public class ComboBox<T> extends AbstractSingleSelect<T> registerRpc(rpc); registerRpc(new FocusAndBlurServerRpcDecorator(this, this::fireEvent)); - addDataGenerator((T data, JsonObject jsonObject) -> { - String caption = getItemCaptionGenerator().apply(data); - if (caption == null) { - caption = ""; + addDataGenerator(new DataGenerator<T>() { + + /** + * Map for storing names for icons. + */ + private Map<Object, String> resourceKeyMap = new HashMap<>(); + private int counter = 0; + + @Override + public void generateData(T item, JsonObject jsonObject) { + String caption = getItemCaptionGenerator().apply(item); + if (caption == null) { + caption = ""; + } + jsonObject.put(DataCommunicatorConstants.NAME, caption); + String style = itemStyleGenerator.apply(item); + if (style != null) { + jsonObject.put(ComboBoxConstants.STYLE, style); + } + Resource icon = getItemIcon(item); + if (icon != null) { + String iconKey = resourceKeyMap + .get(getDataProvider().getId(item)); + String iconUrl = ResourceReference + .create(icon, ComboBox.this, iconKey).getURL(); + jsonObject.put(ComboBoxConstants.ICON, iconUrl); + } } - jsonObject.put(DataCommunicatorConstants.NAME, caption); - String style = itemStyleGenerator.apply(data); - if (style != null) { - jsonObject.put(ComboBoxConstants.STYLE, style); + + @Override + public void destroyData(T item) { + Object itemId = getDataProvider().getId(item); + if (resourceKeyMap.containsKey(itemId)) { + setResource(resourceKeyMap.get(itemId), null); + resourceKeyMap.remove(itemId); + } } - Resource icon = getItemIconGenerator().apply(data); - if (icon != null) { - String iconUrl = ResourceReference - .create(icon, ComboBox.this, null).getURL(); - jsonObject.put(ComboBoxConstants.ICON, iconUrl); + + private Resource getItemIcon(T item) { + Resource icon = getItemIconGenerator().apply(item); + if (icon == null || !(icon instanceof ConnectorResource)) { + return icon; + } + + Object itemId = getDataProvider().getId(item); + if (!resourceKeyMap.containsKey(itemId)) { + resourceKeyMap.put(itemId, "icon" + (counter++)); + } + setResource(resourceKeyMap.get(itemId), icon); + return icon; } }); } @@ -804,8 +841,11 @@ public class ComboBox<T> extends AbstractSingleSelect<T> if (value != null) { Resource icon = getItemIconGenerator().apply(value); if (icon != null) { + if (icon instanceof ConnectorResource) { + setResource("selected", icon); + } selectedItemIcon = ResourceReference - .create(icon, ComboBox.this, null).getURL(); + .create(icon, ComboBox.this, "selected").getURL(); } } getState().selectedItemIcon = selectedItemIcon; |