aboutsummaryrefslogtreecommitdiffstats
path: root/server/src/main/java/com
diff options
context:
space:
mode:
authorTeemu Suo-Anttila <tsuoanttila@users.noreply.github.com>2018-06-19 10:49:40 +0300
committerIlia Motornyi <elmot@vaadin.com>2018-06-19 09:49:40 +0200
commitc99ac74e86d3545cb3b580d73abcb582660808b6 (patch)
tree654a0e7675573e46feba2e6ea1f89f8ab13050f4 /server/src/main/java/com
parent7294ab52fe8a5fd389bac22eeaeeb3cec4f82fbb (diff)
downloadvaadin-framework-c99ac74e86d3545cb3b580d73abcb582660808b6.tar.gz
vaadin-framework-c99ac74e86d3545cb3b580d73abcb582660808b6.zip
Fix TabSheet attaching and detaching components (#10988)
This patch reverts the fix #10557 and replaces it with a proper solution from Grid perspective. Fixes #10987 Fixes #10985
Diffstat (limited to 'server/src/main/java/com')
-rw-r--r--server/src/main/java/com/vaadin/data/provider/DataCommunicator.java10
-rw-r--r--server/src/main/java/com/vaadin/ui/Grid.java26
-rw-r--r--server/src/main/java/com/vaadin/ui/TabSheet.java6
3 files changed, 15 insertions, 27 deletions
diff --git a/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java b/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java
index 574ed99045..3df69d45f3 100644
--- a/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java
+++ b/server/src/main/java/com/vaadin/data/provider/DataCommunicator.java
@@ -220,11 +220,6 @@ public class DataCommunicator<T> extends AbstractExtension {
public void attach() {
super.attach();
attachDataProviderListener();
-
- if (getPushRows().isEmpty()) {
- // Make sure rows are pushed when component is attached.
- setPushRows(Range.withLength(0, getMinPushSize()));
- }
}
@Override
@@ -313,6 +308,11 @@ public class DataCommunicator<T> extends AbstractExtension {
public void beforeClientResponse(boolean initial) {
super.beforeClientResponse(initial);
+ if (initial && getPushRows().isEmpty()) {
+ // Make sure rows are pushed when component is attached.
+ setPushRows(Range.withLength(0, getMinPushSize()));
+ }
+
sendDataToClient(initial);
}
diff --git a/server/src/main/java/com/vaadin/ui/Grid.java b/server/src/main/java/com/vaadin/ui/Grid.java
index 956b81c3eb..40618074d8 100644
--- a/server/src/main/java/com/vaadin/ui/Grid.java
+++ b/server/src/main/java/com/vaadin/ui/Grid.java
@@ -2507,6 +2507,16 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
.forEach(this::addColumn);
}
+ @Override
+ public void beforeClientResponse(boolean initial) {
+ super.beforeClientResponse(initial);
+
+ if (initial && editor.isOpen()) {
+ // Re-attaching grid. Any old editor should be closed.
+ editor.cancel();
+ }
+ }
+
/**
* Sets the property set to use for this grid. Does not create or update
* columns in any way but will delete and re-create the editor.
@@ -4776,20 +4786,4 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents,
column.updateSortable();
}
}
-
- @Override
- public void setVisible(boolean visible) {
- if (getEditor().isOpen() && !visible) {
- getEditor().cancel();
- }
- super.setVisible(visible);
- }
-
- @Override
- public void detach() {
- if (getEditor().isOpen()) {
- getEditor().cancel();
- }
- super.detach();
- }
}
diff --git a/server/src/main/java/com/vaadin/ui/TabSheet.java b/server/src/main/java/com/vaadin/ui/TabSheet.java
index 8cb7243473..75b08bf5dc 100644
--- a/server/src/main/java/com/vaadin/ui/TabSheet.java
+++ b/server/src/main/java/com/vaadin/ui/TabSheet.java
@@ -585,12 +585,6 @@ public class TabSheet extends AbstractComponentContainer
*/
private void setSelected(Component component) {
Tab tab = tabs.get(selected);
- if (tab != null && !Objects.equals(tab.getComponent(), component)
- && tab.getComponent() != null
- && tab.getComponent().isAttached()) {
- tab.getComponent().detach();
- tab.getComponent().attach(); // ugly hack
- }
selected = component;
// Repaint of the selected component is needed as only the selected