summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--client/src/main/java/com/vaadin/client/ui/dd/DragHandle.java2
-rw-r--r--client/src/main/java/com/vaadin/client/ui/textfield/AbstractTextFieldConnector.java8
-rw-r--r--client/src/main/java/com/vaadin/client/ui/textfield/ValueChangeHandler.java13
-rw-r--r--client/src/main/java/com/vaadin/client/widgets/Grid.java3
-rw-r--r--compatibility-client/src/main/java/com/vaadin/v7/client/ui/VTextField.java5
-rw-r--r--compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java2
-rw-r--r--compatibility-server/src/main/java/com/vaadin/v7/data/fieldgroup/FieldGroup.java3
-rw-r--r--compatibility-server/src/main/java/com/vaadin/v7/ui/Grid.java6
-rw-r--r--compatibility-shared/src/main/java/com/vaadin/v7/shared/AbstractFieldState.java2
-rw-r--r--compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/ColumnResizeMode.java2
-rw-r--r--compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/GridState.java2
-rw-r--r--server/src/main/java/com/vaadin/ui/Grid.java2
-rw-r--r--shared/src/main/java/com/vaadin/shared/ui/grid/ColumnResizeMode.java2
-rw-r--r--shared/src/main/java/com/vaadin/shared/ui/grid/GridState.java2
-rw-r--r--uitest/src/test/java/com/vaadin/tests/components/textfield/TextChangeEventsTest.java17
15 files changed, 59 insertions, 12 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/dd/DragHandle.java b/client/src/main/java/com/vaadin/client/ui/dd/DragHandle.java
index c5a9475d39..000966bde7 100644
--- a/client/src/main/java/com/vaadin/client/ui/dd/DragHandle.java
+++ b/client/src/main/java/com/vaadin/client/ui/dd/DragHandle.java
@@ -87,6 +87,7 @@ public class DragHandle {
* later) both to provide the "-dragged" style and to make sure
* that the drag handle can be properly styled (it's otherwise
* invisible)
+ * @since 7.7.5
*/
public DragHandle(String baseName) {
this(baseName, null);
@@ -185,6 +186,7 @@ public class DragHandle {
*
* @param dragHandleCallback
* the callback object to use (can be null)
+ * @since 7.7.5
*/
public void setCallback(DragHandleCallback dragHandleCallback) {
userCallback = dragHandleCallback;
diff --git a/client/src/main/java/com/vaadin/client/ui/textfield/AbstractTextFieldConnector.java b/client/src/main/java/com/vaadin/client/ui/textfield/AbstractTextFieldConnector.java
index 251a5c7a97..50aa186bb1 100644
--- a/client/src/main/java/com/vaadin/client/ui/textfield/AbstractTextFieldConnector.java
+++ b/client/src/main/java/com/vaadin/client/ui/textfield/AbstractTextFieldConnector.java
@@ -16,6 +16,7 @@
package com.vaadin.client.ui.textfield;
import com.google.gwt.user.client.ui.Widget;
+import com.vaadin.client.DeferredWorker;
import com.vaadin.client.annotations.OnStateChange;
import com.vaadin.client.ui.AbstractFieldConnector;
import com.vaadin.client.ui.AbstractTextFieldWidget;
@@ -29,7 +30,7 @@ import com.vaadin.ui.AbstractTextField;
* Connector class for AbstractTextField.
*/
public abstract class AbstractTextFieldConnector extends AbstractFieldConnector
- implements ValueChangeHandler.Owner {
+ implements ValueChangeHandler.Owner, DeferredWorker {
private class AbstractTextFieldClientRpcImpl
implements AbstractTextFieldClientRpc {
@@ -134,4 +135,9 @@ public abstract class AbstractTextFieldConnector extends AbstractFieldConnector
sendValueChange();
}
+ @Override
+ public boolean isWorkPending() {
+ return getValueChangeHandler().isScheduled();
+ }
+
}
diff --git a/client/src/main/java/com/vaadin/client/ui/textfield/ValueChangeHandler.java b/client/src/main/java/com/vaadin/client/ui/textfield/ValueChangeHandler.java
index 89cca2394f..65d820c19a 100644
--- a/client/src/main/java/com/vaadin/client/ui/textfield/ValueChangeHandler.java
+++ b/client/src/main/java/com/vaadin/client/ui/textfield/ValueChangeHandler.java
@@ -38,10 +38,15 @@ public class ValueChangeHandler {
private Owner owner;
+ private boolean scheduled;
+
private Timer valueChangeTrigger = new Timer() {
@Override
public void run() {
- Scheduler.get().scheduleDeferred(() -> owner.sendValueChange());
+ Scheduler.get().scheduleDeferred(() -> {
+ owner.sendValueChange();
+ scheduled = false;
+ });
}
};
@@ -88,6 +93,7 @@ public class ValueChangeHandler {
}
private void lazyTextChange() {
+ scheduled = true;
valueChangeTrigger.schedule(valueChangeTimeout);
}
@@ -95,10 +101,12 @@ public class ValueChangeHandler {
if (valueChangeTrigger.isRunning()) {
return;
}
+ scheduled = true;
valueChangeTrigger.schedule(valueChangeTimeout);
}
private void eagerTextChange() {
+ scheduled = true;
valueChangeTrigger.run();
}
@@ -126,4 +134,7 @@ public class ValueChangeHandler {
this.valueChangeTimeout = valueChangeTimeout;
}
+ public boolean isScheduled() {
+ return scheduled;
+ }
}
diff --git a/client/src/main/java/com/vaadin/client/widgets/Grid.java b/client/src/main/java/com/vaadin/client/widgets/Grid.java
index 1ffda08ef7..2cac853ea1 100644
--- a/client/src/main/java/com/vaadin/client/widgets/Grid.java
+++ b/client/src/main/java/com/vaadin/client/widgets/Grid.java
@@ -6107,6 +6107,8 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param mode
* a ColumnResizeMode value
+ *
+ * @since 7.7.5
*/
public void setColumnResizeMode(ColumnResizeMode mode) {
columnResizeMode = mode;
@@ -6117,6 +6119,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* {@link ColumnResizeMode.ANIMATED}.
*
* @return a ColumnResizeMode value
+ * @since 7.7.5
*/
public ColumnResizeMode getColumnResizeMode() {
return columnResizeMode;
diff --git a/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VTextField.java b/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VTextField.java
index 8357a7649a..a5e75a3c15 100644
--- a/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VTextField.java
+++ b/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VTextField.java
@@ -532,6 +532,11 @@ public class VTextField extends TextBoxBase implements Field, ChangeHandler,
possibleInputError = false;
}
+ /**
+ * {@inheritDoc}
+ *
+ * @since 7.7.5
+ */
@Override
public boolean isWorkPending() {
return scheduled;
diff --git a/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java b/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java
index 0ea348553a..a6fbfb4e76 100644
--- a/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java
+++ b/compatibility-client/src/main/java/com/vaadin/v7/client/widgets/Grid.java
@@ -6090,6 +6090,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
*
* @param mode
* a ColumnResizeMode value
+ * @since 7.7.5
*/
public void setColumnResizeMode(ColumnResizeMode mode) {
columnResizeMode = mode;
@@ -6100,6 +6101,7 @@ public class Grid<T> extends ResizeComposite implements HasSelectionHandlers<T>,
* {@link ColumnResizeMode.ANIMATED}.
*
* @return a ColumnResizeMode value
+ * @since 7.7.5
*/
public ColumnResizeMode getColumnResizeMode() {
return columnResizeMode;
diff --git a/compatibility-server/src/main/java/com/vaadin/v7/data/fieldgroup/FieldGroup.java b/compatibility-server/src/main/java/com/vaadin/v7/data/fieldgroup/FieldGroup.java
index 553bbc753c..e2e6b64f32 100644
--- a/compatibility-server/src/main/java/com/vaadin/v7/data/fieldgroup/FieldGroup.java
+++ b/compatibility-server/src/main/java/com/vaadin/v7/data/fieldgroup/FieldGroup.java
@@ -104,6 +104,8 @@ public class FieldGroup implements Serializable {
/**
* Binds all fields to the properties in the item in use.
+ *
+ * @since 7.7.5
*/
protected void bindFields() {
for (Field<?> f : fieldToPropertyId.keySet()) {
@@ -277,6 +279,7 @@ public class FieldGroup implements Serializable {
*
* @param field
* The field to be cleared
+ * @since 7.7.5
*/
protected void clearField(Field<?> field) {
// Clear any possible existing binding to clear the field
diff --git a/compatibility-server/src/main/java/com/vaadin/v7/ui/Grid.java b/compatibility-server/src/main/java/com/vaadin/v7/ui/Grid.java
index 75915e1bc6..18e47883ce 100644
--- a/compatibility-server/src/main/java/com/vaadin/v7/ui/Grid.java
+++ b/compatibility-server/src/main/java/com/vaadin/v7/ui/Grid.java
@@ -85,9 +85,9 @@ import com.vaadin.v7.data.Validator.InvalidValueException;
import com.vaadin.v7.data.fieldgroup.DefaultFieldGroupFieldFactory;
import com.vaadin.v7.data.fieldgroup.FieldGroup;
import com.vaadin.v7.data.fieldgroup.FieldGroup.CommitException;
+import com.vaadin.v7.data.fieldgroup.FieldGroupFieldFactory;
import com.vaadin.v7.data.sort.Sort;
import com.vaadin.v7.data.sort.SortOrder;
-import com.vaadin.v7.data.fieldgroup.FieldGroupFieldFactory;
import com.vaadin.v7.data.util.IndexedContainer;
import com.vaadin.v7.data.util.converter.Converter;
import com.vaadin.v7.data.util.converter.ConverterUtil;
@@ -97,9 +97,9 @@ import com.vaadin.v7.event.ItemClickEvent;
import com.vaadin.v7.event.ItemClickEvent.ItemClickListener;
import com.vaadin.v7.event.ItemClickEvent.ItemClickNotifier;
import com.vaadin.v7.event.SelectionEvent;
-import com.vaadin.v7.event.SortEvent;
import com.vaadin.v7.event.SelectionEvent.SelectionListener;
import com.vaadin.v7.event.SelectionEvent.SelectionNotifier;
+import com.vaadin.v7.event.SortEvent;
import com.vaadin.v7.event.SortEvent.SortListener;
import com.vaadin.v7.event.SortEvent.SortNotifier;
import com.vaadin.v7.server.communication.data.DataGenerator;
@@ -5328,6 +5328,7 @@ public class Grid extends AbstractComponent
*
* @param mode
* a ColumnResizeMode value
+ * @since 7.7.5
*/
public void setColumnResizeMode(ColumnResizeMode mode) {
getState().columnResizeMode = mode;
@@ -5338,6 +5339,7 @@ public class Grid extends AbstractComponent
* {@link ColumnResizeMode#ANIMATED}.
*
* @return a ColumnResizeMode value
+ * @since 7.7.5
*/
public ColumnResizeMode getColumnResizeMode() {
return getState(false).columnResizeMode;
diff --git a/compatibility-shared/src/main/java/com/vaadin/v7/shared/AbstractFieldState.java b/compatibility-shared/src/main/java/com/vaadin/v7/shared/AbstractFieldState.java
index 8f69abc302..fa15e5fa55 100644
--- a/compatibility-shared/src/main/java/com/vaadin/v7/shared/AbstractFieldState.java
+++ b/compatibility-shared/src/main/java/com/vaadin/v7/shared/AbstractFieldState.java
@@ -42,6 +42,8 @@ public class AbstractFieldState extends AbstractLegacyComponentState {
* <p>
* This is not used in all fields, but needs to be here for the time being
* (#20468).
+ *
+ * @since 7.7.5
*/
public Connector focusDelegate;
}
diff --git a/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/ColumnResizeMode.java b/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/ColumnResizeMode.java
index 6f3de6a185..63eacd1fc1 100644
--- a/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/ColumnResizeMode.java
+++ b/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/ColumnResizeMode.java
@@ -17,6 +17,8 @@ package com.vaadin.v7.shared.ui.grid;
/**
* Collection of modes used for resizing columns in the Grid.
+ *
+ * @since 7.7.5
*/
public enum ColumnResizeMode {
diff --git a/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/GridState.java b/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/GridState.java
index a4c701c64b..577d177d6a 100644
--- a/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/GridState.java
+++ b/compatibility-shared/src/main/java/com/vaadin/v7/shared/ui/grid/GridState.java
@@ -143,6 +143,8 @@ public class GridState extends TabIndexState {
/**
* Column resize mode in grid.
+ *
+ * @since 7.7.5
*/
public ColumnResizeMode columnResizeMode = ColumnResizeMode.ANIMATED;
diff --git a/server/src/main/java/com/vaadin/ui/Grid.java b/server/src/main/java/com/vaadin/ui/Grid.java
index 9c426567b3..203cf5e521 100644
--- a/server/src/main/java/com/vaadin/ui/Grid.java
+++ b/server/src/main/java/com/vaadin/ui/Grid.java
@@ -2844,6 +2844,7 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
*
* @param mode
* a ColumnResizeMode value
+ * @since 7.7.5
*/
public void setColumnResizeMode(ColumnResizeMode mode) {
getState().columnResizeMode = mode;
@@ -2854,6 +2855,7 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
* {@link ColumnResizeMode#ANIMATED}.
*
* @return a ColumnResizeMode value
+ * @since 7.7.5
*/
public ColumnResizeMode getColumnResizeMode() {
return getState(false).columnResizeMode;
diff --git a/shared/src/main/java/com/vaadin/shared/ui/grid/ColumnResizeMode.java b/shared/src/main/java/com/vaadin/shared/ui/grid/ColumnResizeMode.java
index cae4845900..c8a75d56e2 100644
--- a/shared/src/main/java/com/vaadin/shared/ui/grid/ColumnResizeMode.java
+++ b/shared/src/main/java/com/vaadin/shared/ui/grid/ColumnResizeMode.java
@@ -17,6 +17,8 @@ package com.vaadin.shared.ui.grid;
/**
* Collection of modes used for resizing columns in the Grid.
+ *
+ * @since 7.7.5
*/
public enum ColumnResizeMode {
diff --git a/shared/src/main/java/com/vaadin/shared/ui/grid/GridState.java b/shared/src/main/java/com/vaadin/shared/ui/grid/GridState.java
index 62dee006f7..6725d01137 100644
--- a/shared/src/main/java/com/vaadin/shared/ui/grid/GridState.java
+++ b/shared/src/main/java/com/vaadin/shared/ui/grid/GridState.java
@@ -102,6 +102,8 @@ public class GridState extends AbstractSingleSelectState {
/**
* Column resize mode in grid.
+ *
+ * @since 7.7.5
*/
public ColumnResizeMode columnResizeMode = ColumnResizeMode.ANIMATED;
diff --git a/uitest/src/test/java/com/vaadin/tests/components/textfield/TextChangeEventsTest.java b/uitest/src/test/java/com/vaadin/tests/components/textfield/TextChangeEventsTest.java
index 5693400eba..1d01c35409 100644
--- a/uitest/src/test/java/com/vaadin/tests/components/textfield/TextChangeEventsTest.java
+++ b/uitest/src/test/java/com/vaadin/tests/components/textfield/TextChangeEventsTest.java
@@ -1,5 +1,6 @@
package com.vaadin.tests.components.textfield;
+import org.junit.Assert;
import org.junit.Test;
import com.vaadin.testbench.elements.TextAreaElement;
@@ -15,14 +16,14 @@ public class TextChangeEventsTest extends SingleBrowserTest {
TextAreaElement taDefault = $(TextAreaElement.class)
.caption("Default text area").first();
taDefault.sendKeys("abc");
- waitUntil(driver -> getLogRow(0).equals(
- "1. Text change event for Default text area, text content currently:'abc' Cursor at index:3"));
+ Assert.assertEquals(getLogRow(0),
+ "1. Text change event for Default text area, text content currently:'abc' Cursor at index:3");
TextAreaElement taTimeout = $(TextAreaElement.class)
.caption("Timeout 3s").first();
taTimeout.sendKeys("abc");
- waitUntil(driver -> getLogRow(0).equals(
- "2. Text change event for Timeout 3s, text content currently:'abc' Cursor at index:3"));
+ Assert.assertEquals(getLogRow(0),
+ "2. Text change event for Timeout 3s, text content currently:'abc' Cursor at index:3");
}
@Test
@@ -32,19 +33,19 @@ public class TextChangeEventsTest extends SingleBrowserTest {
TextFieldElement tfDefault = $(TextFieldElement.class)
.caption("Default").first();
tfDefault.sendKeys("abc");
- waitUntil(driver -> getLogRow(0).equals(
- "1. Text change event for Default, text content currently:'abc' Cursor at index:3"));
+ Assert.assertEquals(getLogRow(0),
+ "1. Text change event for Default, text content currently:'abc' Cursor at index:3");
TextFieldElement tfEager = $(TextFieldElement.class).caption("Eager")
.first();
tfEager.sendKeys("abc");
- waitUntil(driver -> getLogRow(0).contains(
+ Assert.assertTrue(getLogRow(0).contains(
"Text change event for Eager, text content currently:'abc' Cursor at index:3"));
TextFieldElement tfTimeout = $(TextFieldElement.class)
.caption("Timeout 3s").first();
tfTimeout.sendKeys("abc");
- waitUntil(driver -> getLogRow(0).contains(
+ Assert.assertTrue(getLogRow(0).contains(
"Text change event for Timeout 3s, text content currently:'abc' Cursor at index:3"));
}
}