diff options
author | Anastasia Smirnova <anasmi@utu.fi> | 2018-12-13 16:59:35 +0200 |
---|---|---|
committer | Sun Zhe <31067185+ZheSun88@users.noreply.github.com> | 2018-12-13 16:59:35 +0200 |
commit | 891bb534de30ed39e463af88f67e7f5bbf94e3f1 (patch) | |
tree | 105e552080f3905eacf16dc8a57f2e37ae67134c | |
parent | f60d431c7cbf0689f74c5ba230681c4ab5171463 (diff) | |
download | vaadin-framework-891bb534de30ed39e463af88f67e7f5bbf94e3f1.tar.gz vaadin-framework-891bb534de30ed39e463af88f67e7f5bbf94e3f1.zip |
Apply missing v-readonly style to CheckBoxGroup, when component is readOnly (#11370)
Setting read-only state to CheckBoxGroup should disable adding clicking effect. Missing v-readonly style is added to every CheckBox in the component, if it's set to read-only.
Fixes: https://github.com/vaadin/framework/issues/11113
* Add file missed from initial commit
* Verifying that option is enabled
Some of the options might be disabled on there own. Verify that option is not disabled, before removing disabled styles.
* Add missing test file
3 files changed, 90 insertions, 1 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/VCheckBoxGroup.java b/client/src/main/java/com/vaadin/client/ui/VCheckBoxGroup.java index 9e213dfd4d..f6759111b0 100644 --- a/client/src/main/java/com/vaadin/client/ui/VCheckBoxGroup.java +++ b/client/src/main/java/com/vaadin/client/ui/VCheckBoxGroup.java @@ -137,6 +137,7 @@ public class VCheckBoxGroup extends FocusableFlowPanelComposite widget.setValue( item.getBoolean(ListingJsonConstants.JSONKEY_ITEM_SELECTED)); setOptionEnabled(widget, item); + setOptionReadOnly(widget, item); widget.setStyleName(CLASSNAME_OPTION_SELECTED, widget.getValue()); if (requireInitialization) { @@ -197,6 +198,18 @@ public class VCheckBoxGroup extends FocusableFlowPanelComposite !isEnabled() || !optionEnabled); } + protected void setOptionReadOnly(VCheckBox checkBox, JsonObject item) { + if (isReadonly()) { + checkBox.addStyleName("v-readonly"); + checkBox.setEnabled(false); + } else { + checkBox.removeStyleName("v-readonly"); + boolean optionEnabled = !item + .getBoolean(ListingJsonConstants.JSONKEY_ITEM_DISABLED); + checkBox.setEnabled(isEnabled() && optionEnabled); + } + } + public boolean isHtmlContentAllowed() { return htmlContentAllowed; } @@ -217,7 +230,7 @@ public class VCheckBoxGroup extends FocusableFlowPanelComposite public void setReadonly(boolean readonly) { if (this.readonly != readonly) { this.readonly = readonly; - optionsToItems.forEach(this::setOptionEnabled); + optionsToItems.forEach(this::setOptionReadOnly); } } diff --git a/uitest/src/main/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupReadOnly.java b/uitest/src/main/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupReadOnly.java new file mode 100644 index 0000000000..8c0caf3ac3 --- /dev/null +++ b/uitest/src/main/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupReadOnly.java @@ -0,0 +1,30 @@ +package com.vaadin.tests.components.checkboxgroup; + +import com.vaadin.annotations.Widgetset; +import com.vaadin.server.VaadinRequest; +import com.vaadin.tests.components.AbstractTestUI; +import com.vaadin.ui.CheckBoxGroup; +import com.vaadin.ui.Button; + +@Widgetset("com.vaadin.DefaultWidgetSet") +public class CheckBoxGroupReadOnly extends AbstractTestUI { + @Override + protected void setup(VaadinRequest request) { + CheckBoxGroup<Integer> cbg = new CheckBoxGroup<>(); + cbg.setId("cbg"); + cbg.setItems(1, 2, 3, 4); + cbg.setReadOnly(true); + addComponent(cbg); + + Button changeReadOnly = new Button("Change Read-Only", e -> { + cbg.setReadOnly(!cbg.isReadOnly()); + }); + changeReadOnly.setId("changeReadOnly"); + Button changeEnabled = new Button("Change Enabled", e -> { + cbg.setEnabled(!cbg.isEnabled()); + }); + changeEnabled.setId("changeEnabled"); + addComponent(changeReadOnly); + addComponent(changeEnabled); + } +} diff --git a/uitest/src/test/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupReadOnlyTest.java b/uitest/src/test/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupReadOnlyTest.java new file mode 100644 index 0000000000..ad0fb4fbac --- /dev/null +++ b/uitest/src/test/java/com/vaadin/tests/components/checkboxgroup/CheckBoxGroupReadOnlyTest.java @@ -0,0 +1,46 @@ +package com.vaadin.tests.components.checkboxgroup; + +import com.vaadin.testbench.elements.CheckBoxGroupElement; +import com.vaadin.tests.tb3.MultiBrowserTest; +import org.junit.Test; +import org.openqa.selenium.By; +import org.openqa.selenium.WebElement; + +import java.util.List; + +import static junit.framework.TestCase.assertEquals; +import static junit.framework.TestCase.assertTrue; + +public class CheckBoxGroupReadOnlyTest extends MultiBrowserTest { + + @Test + public void itemsAreReadOnly() { + openTestURL(); + // Initially components are read-only + assertTrue(getSelect().isReadOnly()); + assertEquals(4, findReadOnlyCheckboxes().size()); + // Should not contain v-readonly + findElement(By.id("changeReadOnly")).click(); + assertEquals(0, findReadOnlyCheckboxes().size()); + + // Should not contain v-readonly + findElement(By.id("changeEnabled")).click(); + assertEquals(0, findReadOnlyCheckboxes().size()); + + // make read-only + findElement(By.id("changeReadOnly")).click(); + // enable + findElement(By.id("changeEnabled")).click(); + // Should contain v-readonly + assertEquals(4, findReadOnlyCheckboxes().size()); + } + + protected CheckBoxGroupElement getSelect() { + return $(CheckBoxGroupElement.class).first(); + } + + private List<WebElement> findReadOnlyCheckboxes() { + return findElement(By.id("cbg")) + .findElements(By.cssSelector("span.v-readonly.v-checkbox")); + } +} |