diff options
-rw-r--r-- | server/src/main/java/com/vaadin/ui/Grid.java | 5 | ||||
-rw-r--r-- | uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnHidingTest.java | 21 |
2 files changed, 22 insertions, 4 deletions
diff --git a/server/src/main/java/com/vaadin/ui/Grid.java b/server/src/main/java/com/vaadin/ui/Grid.java index 70e947ccd8..9a0c5e1aea 100644 --- a/server/src/main/java/com/vaadin/ui/Grid.java +++ b/server/src/main/java/com/vaadin/ui/Grid.java @@ -681,9 +681,8 @@ public class Grid<T> extends AbstractListing<T> implements HasComponents, @Override public void columnVisibilityChanged(String internalId, boolean hidden) { Column<T, ?> column = getColumnByInternalId(internalId); - ColumnState columnState = column.getState(false); - if (columnState.hidden != hidden) { - columnState.hidden = hidden; + if (column.isHidden() != hidden) { + column.setHidden(hidden); fireColumnVisibilityChangeEvent(column, hidden, true); } } diff --git a/uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnHidingTest.java b/uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnHidingTest.java index a8a1d8f229..e1b5939ead 100644 --- a/uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnHidingTest.java +++ b/uitest/src/test/java/com/vaadin/tests/components/grid/GridColumnHidingTest.java @@ -26,8 +26,8 @@ import org.openqa.selenium.WebElement; import org.openqa.selenium.interactions.Actions; import com.vaadin.testbench.By; -import com.vaadin.testbench.elements.GridElement; import com.vaadin.testbench.elements.ButtonElement; +import com.vaadin.testbench.elements.GridElement; import com.vaadin.testbench.elements.GridElement.GridCellElement; import com.vaadin.testbench.elements.LabelElement; import com.vaadin.tests.tb3.MultiBrowserTest; @@ -89,6 +89,25 @@ public class GridColumnHidingTest extends MultiBrowserTest { } @Test + public void clientHideServerShowColumns() { + openTestURL(); + GridElement grid = $(GridElement.class).first(); + + getSidebarOpenButton(grid).click(); + // Assuming client-side hiding works. See clientHideColumns() + getColumnHidingToggle(grid, "custom age column caption").click(); + getColumnHidingToggle(grid, "Name").click(); + + // Show from server + $(ButtonElement.class).caption("server side toggle age column").first() + .click(); + Assert.assertEquals("46", grid.getCell(0, 0).getText()); + Assert.assertEquals("18", grid.getCell(1, 0).getText()); + Assert.assertEquals("yeah@cool.com", grid.getCell(0, 1).getText()); + Assert.assertEquals("maya@foo.bar", grid.getCell(1, 1).getText()); + } + + @Test public void columnVisibilityChangeListener() { openTestURL(); GridElement grid = $(GridElement.class).first(); |