diff options
-rw-r--r-- | client/src/com/vaadin/client/ui/combobox/ComboBoxConnector.java | 33 | ||||
-rw-r--r-- | uitest/src/com/vaadin/tests/components/select/SelectItemCaptionRefresh.java | 4 |
2 files changed, 28 insertions, 9 deletions
diff --git a/client/src/com/vaadin/client/ui/combobox/ComboBoxConnector.java b/client/src/com/vaadin/client/ui/combobox/ComboBoxConnector.java index 24597d1d8c..8dec26cf90 100644 --- a/client/src/com/vaadin/client/ui/combobox/ComboBoxConnector.java +++ b/client/src/com/vaadin/client/ui/combobox/ComboBoxConnector.java @@ -37,6 +37,10 @@ import com.vaadin.ui.ComboBox; public class ComboBoxConnector extends AbstractFieldConnector implements Paintable, SimpleManagedLayout { + // oldSuggestionTextMatchTheOldSelection is used to detect when it's safe to + // update textbox text by a changed item caption. + private boolean oldSuggestionTextMatchTheOldSelection; + /* * (non-Javadoc) * @@ -117,7 +121,10 @@ public class ComboBoxConnector extends AbstractFieldConnector implements boolean suggestionsChanged = !getWidget().initDone || !newSuggestions.equals(getWidget().currentSuggestions); + oldSuggestionTextMatchTheOldSelection = false; + if (suggestionsChanged) { + oldSuggestionTextMatchTheOldSelection = isWidgetsCurrentSelectionTextInTextBox(); getWidget().currentSuggestions.clear(); if (!getWidget().waitingForFilteringResponse) { @@ -217,13 +224,19 @@ public class ComboBoxConnector extends AbstractFieldConnector implements } if (!getWidget().waitingForFilteringResponse || getWidget().popupOpenerClicked) { - // Update text field if we've got a new - // selection - // Also update if we've got the same text to - // retain old text selection behavior - // OR if selected item caption is changed. - getWidget().setPromptingOff(suggestion.getReplacementString()); - getWidget().selectedOptionKey = suggestionKey; + if (!suggestionKey.equals(getWidget().selectedOptionKey) + || suggestion.getReplacementString().equals( + getWidget().tb.getText()) + || oldSuggestionTextMatchTheOldSelection) { + // Update text field if we've got a new + // selection + // Also update if we've got the same text to + // retain old text selection behavior + // OR if selected item caption is changed. + getWidget().setPromptingOff( + suggestion.getReplacementString()); + getWidget().selectedOptionKey = suggestionKey; + } } getWidget().currentSuggestion = suggestion; getWidget().setSelectedItemIcon(suggestion.getIconUri()); @@ -232,6 +245,12 @@ public class ComboBoxConnector extends AbstractFieldConnector implements } } + private boolean isWidgetsCurrentSelectionTextInTextBox() { + return getWidget().currentSuggestion != null + && getWidget().currentSuggestion.getReplacementString().equals( + getWidget().tb.getText()); + } + private void resetSelection() { if (!getWidget().waitingForFilteringResponse || getWidget().popupOpenerClicked) { diff --git a/uitest/src/com/vaadin/tests/components/select/SelectItemCaptionRefresh.java b/uitest/src/com/vaadin/tests/components/select/SelectItemCaptionRefresh.java index 1a1a8fa642..de068ed230 100644 --- a/uitest/src/com/vaadin/tests/components/select/SelectItemCaptionRefresh.java +++ b/uitest/src/com/vaadin/tests/components/select/SelectItemCaptionRefresh.java @@ -49,7 +49,7 @@ public class SelectItemCaptionRefresh extends AbstractTestUI { select.setItemCaption(itemId, "start"); addComponent(select); - addComponent(new Button("click", clickListener)); + addComponent(new Button("Update item's caption", clickListener)); } /* @@ -59,7 +59,7 @@ public class SelectItemCaptionRefresh extends AbstractTestUI { */ @Override protected String getTestDescription() { - return "Selected option not updated when item caption changes in Select"; + return "Selected option should be updated when item caption changes in the Select."; } /* |