]> source.dussan.org Git - vaadin-framework.git/commitdiff
Change selection model before selecting rows (#15488)
authorLeif Åstrand <leif@vaadin.com>
Wed, 31 Dec 2014 11:03:03 +0000 (13:03 +0200)
committerTeemu Suo-Anttila <teemusa@vaadin.com>
Wed, 31 Dec 2014 11:28:48 +0000 (11:28 +0000)
Change-Id: I2697367626ca0b469e06e3707a3868f4abfdddd9

client/src/com/vaadin/client/connectors/GridConnector.java
uitest/src/com/vaadin/tests/components/grid/SelectDuringInit.java [new file with mode: 0644]
uitest/src/com/vaadin/tests/components/grid/SelectDuringInitTest.java [new file with mode: 0644]

index 44aa2763822ff7ab241b7a2bf87d508d105fb0a1..0044025d40641b8a73e935a37926d499ba2361e2 100644 (file)
@@ -442,6 +442,13 @@ public class GridConnector extends AbstractHasComponentsConnector implements
     public void onStateChanged(final StateChangeEvent stateChangeEvent) {
         super.onStateChanged(stateChangeEvent);
 
+        if (stateChangeEvent.hasPropertyChanged("selectionMode")) {
+            onSelectionModeChange();
+        }
+        if (stateChangeEvent.hasPropertyChanged("selectedKeys")) {
+            updateSelectionFromState();
+        }
+
         /*
          * The operations in here have been made deferred.
          * 
@@ -736,7 +743,6 @@ public class GridConnector extends AbstractHasComponentsConnector implements
         getWidget().setDataSource(this.dataSource);
     }
 
-    @OnStateChange("selectionMode")
     private void onSelectionModeChange() {
         SharedSelectionMode mode = getState().selectionMode;
         if (mode == null) {
@@ -770,7 +776,6 @@ public class GridConnector extends AbstractHasComponentsConnector implements
         }
     }
 
-    @OnStateChange("selectedKeys")
     private void updateSelectionFromState() {
         boolean changed = false;
 
diff --git a/uitest/src/com/vaadin/tests/components/grid/SelectDuringInit.java b/uitest/src/com/vaadin/tests/components/grid/SelectDuringInit.java
new file mode 100644 (file)
index 0000000..d8394ac
--- /dev/null
@@ -0,0 +1,40 @@
+/*
+ * Copyright 2000-2014 Vaadin Ltd.
+ * 
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
+ * use this file except in compliance with the License. You may obtain a copy of
+ * the License at
+ * 
+ * http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations under
+ * the License.
+ */
+package com.vaadin.tests.components.grid;
+
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.tests.components.AbstractTestUI;
+import com.vaadin.ui.Grid;
+import com.vaadin.ui.Grid.SelectionMode;
+
+public class SelectDuringInit extends AbstractTestUI {
+
+    @Override
+    protected void setup(VaadinRequest request) {
+        Grid grid = new Grid();
+        grid.setSelectionMode(SelectionMode.MULTI);
+
+        grid.addColumn("value");
+        grid.addRow("row 1");
+        grid.addRow("row 2");
+        grid.addRow("row 3");
+
+        grid.select(Integer.valueOf(2));
+
+        addComponent(grid);
+    }
+
+}
diff --git a/uitest/src/com/vaadin/tests/components/grid/SelectDuringInitTest.java b/uitest/src/com/vaadin/tests/components/grid/SelectDuringInitTest.java
new file mode 100644 (file)
index 0000000..edfc803
--- /dev/null
@@ -0,0 +1,35 @@
+/*
+ * Copyright 2000-2014 Vaadin Ltd.
+ * 
+ * Licensed under the Apache License, Version 2.0 (the "License"); you may not
+ * use this file except in compliance with the License. You may obtain a copy of
+ * the License at
+ * 
+ * http://www.apache.org/licenses/LICENSE-2.0
+ * 
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+ * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+ * License for the specific language governing permissions and limitations under
+ * the License.
+ */
+package com.vaadin.tests.components.grid;
+
+import org.junit.Assert;
+import org.junit.Test;
+
+import com.vaadin.testbench.elements.GridElement;
+import com.vaadin.tests.tb3.SingleBrowserTest;
+
+public class SelectDuringInitTest extends SingleBrowserTest {
+
+    @Test
+    public void testSelectDuringInit() {
+        openTestURL();
+
+        GridElement grid = $(GridElement.class).first();
+
+        Assert.assertTrue(grid.getRow(1).isSelected());
+    }
+
+}