diff options
-rw-r--r-- | client/src/main/java/com/vaadin/client/ui/VComboBox.java | 12 | ||||
-rw-r--r-- | uitest/src/test/java/com/vaadin/tests/components/combobox/ComboBoxSelectingWithNewItemsAllowedTest.java | 16 |
2 files changed, 26 insertions, 2 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/VComboBox.java b/client/src/main/java/com/vaadin/client/ui/VComboBox.java index 45e69cee01..61e9b46e68 100644 --- a/client/src/main/java/com/vaadin/client/ui/VComboBox.java +++ b/client/src/main/java/com/vaadin/client/ui/VComboBox.java @@ -2489,11 +2489,19 @@ public class VComboBox extends Composite implements Field, KeyDownHandler, focused = false; updatePlaceholder(); + removeStyleDependentName("focus"); + + // Send new items when clicking out with the mouse. if (!readonly) { - reset(); + if (textInputEnabled && allowNewItems + && (currentSuggestion == null || tb.getText().equals( + currentSuggestion.getReplacementString()))) { + dataReceivedHandler.reactOnInputWhenReady(tb.getText()); + } else { + reset(); + } suggestionPopup.hide(); } - removeStyleDependentName("focus"); connector.sendBlurEvent(); } diff --git a/uitest/src/test/java/com/vaadin/tests/components/combobox/ComboBoxSelectingWithNewItemsAllowedTest.java b/uitest/src/test/java/com/vaadin/tests/components/combobox/ComboBoxSelectingWithNewItemsAllowedTest.java index 0765c2781a..d61bb26dad 100644 --- a/uitest/src/test/java/com/vaadin/tests/components/combobox/ComboBoxSelectingWithNewItemsAllowedTest.java +++ b/uitest/src/test/java/com/vaadin/tests/components/combobox/ComboBoxSelectingWithNewItemsAllowedTest.java @@ -21,6 +21,7 @@ import static org.hamcrest.MatcherAssert.assertThat; import org.junit.Test; import org.openqa.selenium.Keys; import org.openqa.selenium.WebDriver; +import org.openqa.selenium.interactions.Actions; import org.openqa.selenium.support.ui.ExpectedCondition; import com.vaadin.testbench.By; @@ -65,6 +66,14 @@ public class ComboBoxSelectingWithNewItemsAllowedTest extends MultiBrowserTest { } @Test + public void itemIsAddedWithClickOut() { + typeInputAndClickOut("a"); + + assertOneMoreThanInitial(); + assertThatSelectedValueIs("a"); + } + + @Test public void matchingSuggestionIsSelectedWithEnter() { typeInputAndHitEnter("a0"); @@ -204,6 +213,13 @@ public class ComboBoxSelectingWithNewItemsAllowedTest extends MultiBrowserTest { sendKeysToInput(Keys.TAB); } + private void typeInputAndClickOut(String input) { + clearInputAndType(input); + new Actions(getDriver()).moveToElement(comboBoxElement, 10, 10) + .moveByOffset(comboBoxElement.getSize().getWidth(), 0).click() + .perform(); + } + private void clearInputAndType(String input) { comboBoxElement.clear(); sendKeysToInput(input); |