diff options
4 files changed, 130 insertions, 1 deletions
diff --git a/WebContent/VAADIN/themes/base/grid/grid.scss b/WebContent/VAADIN/themes/base/grid/grid.scss index 6b3b017070..a5fb27f7d7 100644 --- a/WebContent/VAADIN/themes/base/grid/grid.scss +++ b/WebContent/VAADIN/themes/base/grid/grid.scss @@ -110,6 +110,10 @@ $v-grid-details-border-bottom-stripe: 1px solid darken($v-grid-row-background-co text-align: right; line-height: 1; + &[disabled] { + cursor: default; + } + &::-moz-focus-inner { border: 0; } diff --git a/client/src/com/vaadin/client/widgets/Grid.java b/client/src/com/vaadin/client/widgets/Grid.java index 4d1788639c..449cb60cc7 100644 --- a/client/src/com/vaadin/client/widgets/Grid.java +++ b/client/src/com/vaadin/client/widgets/Grid.java @@ -3487,7 +3487,7 @@ public class Grid<T> extends ResizeComposite implements * * @since 7.5.0 */ - private static class Sidebar extends Composite { + private static class Sidebar extends Composite implements HasEnabled { private final ClickHandler openCloseButtonHandler = new ClickHandler() { @@ -3538,6 +3538,9 @@ public class Grid<T> extends ResizeComposite implements initWidget(rootContainer); openCloseButton = new Button(); + + setEnabled(grid.isEnabled()); + openCloseButton.addClickHandler(openCloseButtonHandler); rootContainer.add(openCloseButton); @@ -3719,6 +3722,20 @@ public class Grid<T> extends ResizeComposite implements } }); } + + @Override + public boolean isEnabled() { + return openCloseButton.isEnabled(); + } + + @Override + public void setEnabled(boolean enabled) { + if(!enabled && isOpen()) { + close(); + } + + openCloseButton.setEnabled(enabled); + } } /** @@ -5625,6 +5642,8 @@ public class Grid<T> extends ResizeComposite implements editor.setGridEnabled(enabled); } + sidebar.setEnabled(enabled); + getEscalator().setScrollLocked(Direction.VERTICAL, !enabled || editorOpen); getEscalator().setScrollLocked(Direction.HORIZONTAL, !enabled); diff --git a/uitest/src/com/vaadin/tests/components/grid/GridDisabledSideBarTest.java b/uitest/src/com/vaadin/tests/components/grid/GridDisabledSideBarTest.java new file mode 100644 index 0000000000..0f207b68f2 --- /dev/null +++ b/uitest/src/com/vaadin/tests/components/grid/GridDisabledSideBarTest.java @@ -0,0 +1,85 @@ +package com.vaadin.tests.components.grid; + +import static org.hamcrest.CoreMatchers.containsString; +import static org.hamcrest.MatcherAssert.assertThat; + +import org.junit.Test; +import org.openqa.selenium.WebDriver; +import org.openqa.selenium.support.ui.ExpectedCondition; + +import com.vaadin.testbench.By; +import com.vaadin.tests.components.grid.basicfeatures.GridBasicClientFeaturesTest; + +public class GridDisabledSideBarTest extends GridBasicClientFeaturesTest { + + @Override + public void setup() throws Exception { + super.setup(); + + openTestURL(); + } + + private void makeColumnHidable() { + selectMenuPath("Component", "Columns", "Column 0", "Hidable"); + } + + private void toggleSideBarMenuAndDisable() { + selectMenuPath("Component", "Sidebar", "Open sidebar and disable grid"); + waitUntil(new ExpectedCondition<Boolean>() { + + @Override + public Boolean apply(WebDriver input) { + return !findElement(By.className("v-grid-sidebar-button")).isEnabled(); + } + }); + } + private void clickSideBarButton() { + findElement(By.cssSelector(".v-grid-sidebar-button")).click(); + } + + private void toggleEnabled() { + selectMenuPath("Component", "State", "Enabled"); + } + + private void assertSideBarContainsClass(String cssClass) { + assertThat(findElement(By.cssSelector(".v-grid-sidebar")).getAttribute("class"), containsString(cssClass)); + } + + @Test + public void sidebarButtonIsDisabledOnCreation() { + selectMenuPath("Component", "State", "Enabled"); + makeColumnHidable(); + + clickSideBarButton(); + + assertSideBarContainsClass("closed"); + } + + @Test + public void sidebarButtonCanBeEnabled() { + makeColumnHidable(); + + clickSideBarButton(); + + assertSideBarContainsClass("open"); + } + + @Test + public void sidebarButtonCanBeDisabled() { + makeColumnHidable(); + toggleEnabled(); + + clickSideBarButton(); + + assertSideBarContainsClass("closed"); + } + + @Test + public void sidebarIsClosedOnDisable() { + makeColumnHidable(); + + toggleSideBarMenuAndDisable(); + + assertSideBarContainsClass("closed"); + } +}
\ No newline at end of file diff --git a/uitest/src/com/vaadin/tests/widgetset/client/grid/GridBasicClientFeaturesWidget.java b/uitest/src/com/vaadin/tests/widgetset/client/grid/GridBasicClientFeaturesWidget.java index aa1d7d60a4..b6386afe44 100644 --- a/uitest/src/com/vaadin/tests/widgetset/client/grid/GridBasicClientFeaturesWidget.java +++ b/uitest/src/com/vaadin/tests/widgetset/client/grid/GridBasicClientFeaturesWidget.java @@ -24,6 +24,7 @@ import java.util.Map; import java.util.Random; import java.util.logging.Logger; +import com.google.gwt.core.client.Scheduler; import com.google.gwt.core.client.Scheduler.ScheduledCommand; import com.google.gwt.dom.client.Style.Unit; import com.google.gwt.event.dom.client.ClickEvent; @@ -1593,6 +1594,26 @@ public class GridBasicClientFeaturesWidget extends grid.setSidebarOpen(!grid.isSidebarOpen()); } }, menupath); + + addMenuCommand("Open sidebar and disable grid", new ScheduledCommand() { + @Override + public void execute() { + grid.setSidebarOpen(true); + + Scheduler.get().scheduleFixedDelay(new Scheduler.RepeatingCommand() { + @Override + public boolean execute() { + if(grid.isSidebarOpen()) { + grid.setEnabled(false); + + return false; + } + + return true; + } + }, 250); + } + }, menupath); } private MenuItem createSidebarMenuItem(final int index) { |