aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorcaalador <mikael.grankvist@gmail.com>2017-02-07 15:31:05 +0200
committerHenri Sara <henri.sara@gmail.com>2017-02-07 15:31:05 +0200
commit19fdb91d4b8c926431995e157bdf440436209c2d (patch)
tree10b30f3ae77d2b8cfcf051378fb391689266bb62
parent5061d53a55be72d5cb8c7394342491aec6f4a10e (diff)
downloadvaadin-framework-19fdb91d4b8c926431995e157bdf440436209c2d.tar.gz
vaadin-framework-19fdb91d4b8c926431995e157bdf440436209c2d.zip
Fix toggling of WeekNumbers for DateTimeField. (#8468)
Fixes #8405
-rw-r--r--client/src/main/java/com/vaadin/client/ui/VAbstractCalendarPanel.java4
-rw-r--r--compatibility-client/src/main/java/com/vaadin/v7/client/ui/VCalendarPanel.java5
-rw-r--r--uitest/src/main/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDays.java56
-rw-r--r--uitest/src/test/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDaysTest.java108
4 files changed, 173 insertions, 0 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/VAbstractCalendarPanel.java b/client/src/main/java/com/vaadin/client/ui/VAbstractCalendarPanel.java
index 8a2ef4d8d5..e0ae7b9165 100644
--- a/client/src/main/java/com/vaadin/client/ui/VAbstractCalendarPanel.java
+++ b/client/src/main/java/com/vaadin/client/ui/VAbstractCalendarPanel.java
@@ -630,6 +630,10 @@ public abstract class VAbstractCalendarPanel<R extends Enum<R>>
public void setShowISOWeekNumbers(boolean showISOWeekNumbers) {
this.showISOWeekNumbers = showISOWeekNumbers;
+ if (initialRenderDone && isBelowMonth(resolution)) {
+ clearCalendarBody(false);
+ buildCalendarBody();
+ }
}
/**
diff --git a/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VCalendarPanel.java b/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VCalendarPanel.java
index bd0cab400a..a27f2c80cd 100644
--- a/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VCalendarPanel.java
+++ b/compatibility-client/src/main/java/com/vaadin/v7/client/ui/VCalendarPanel.java
@@ -533,6 +533,11 @@ public class VCalendarPanel extends FocusableFlexTable implements
public void setShowISOWeekNumbers(boolean showISOWeekNumbers) {
this.showISOWeekNumbers = showISOWeekNumbers;
+ if (initialRenderDone && getResolution()
+ .getCalendarField() >= Resolution.DAY.getCalendarField()) {
+ clearCalendarBody(false);
+ buildCalendarBody();
+ }
}
/**
diff --git a/uitest/src/main/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDays.java b/uitest/src/main/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDays.java
new file mode 100644
index 0000000000..113c2bd259
--- /dev/null
+++ b/uitest/src/main/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDays.java
@@ -0,0 +1,56 @@
+/*
+ * Copyright 2000-2016 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.datefield;
+
+import java.time.LocalDateTime;
+import java.util.Locale;
+
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.tests.components.AbstractTestUI;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.CheckBox;
+import com.vaadin.ui.DateTimeField;
+import com.vaadin.ui.HorizontalLayout;
+
+public class DateTimeFieldWeekDays extends AbstractTestUI {
+
+ private static final Locale localeFI = new Locale("fi", "FI");
+
+ @Override
+ protected void setup(VaadinRequest request) {
+
+ DateTimeField dateTimeField = new DateTimeField();
+ dateTimeField.setValue(LocalDateTime.of(1999, 12, 1, 12, 00));
+ dateTimeField.setShowISOWeekNumbers(true);
+ dateTimeField.setLocale(localeFI);
+
+ CheckBox weekNumbersToggle = new CheckBox("Toggle week numbers",
+ dateTimeField.isShowISOWeekNumbers());
+ weekNumbersToggle.addValueChangeListener(
+ e -> dateTimeField.setShowISOWeekNumbers(e.getValue()));
+
+ Button toEnglish = new Button("Change locale",
+ click -> dateTimeField.setLocale(Locale.ENGLISH));
+ toEnglish.setId("english");
+ Button toFinnish = new Button("Change locale",
+ click -> dateTimeField.setLocale(localeFI));
+ toFinnish.setId("finnish");
+
+ addComponent(dateTimeField);
+ addComponent(weekNumbersToggle);
+ addComponent(new HorizontalLayout(toEnglish, toFinnish));
+ }
+}
diff --git a/uitest/src/test/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDaysTest.java b/uitest/src/test/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDaysTest.java
new file mode 100644
index 0000000000..4b57b5663d
--- /dev/null
+++ b/uitest/src/test/java/com/vaadin/tests/components/datefield/DateTimeFieldWeekDaysTest.java
@@ -0,0 +1,108 @@
+/*
+ * Copyright 2000-2016 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.datefield;
+
+import org.junit.Assert;
+import org.junit.Test;
+import org.openqa.selenium.WebElement;
+import org.openqa.selenium.support.ui.ExpectedConditions;
+
+import com.vaadin.testbench.By;
+import com.vaadin.testbench.customelements.DateTimeFieldElement;
+import com.vaadin.testbench.elements.ButtonElement;
+import com.vaadin.testbench.elements.CheckBoxElement;
+import com.vaadin.tests.tb3.SingleBrowserTest;
+
+public class DateTimeFieldWeekDaysTest extends SingleBrowserTest {
+
+ @Test
+ public void testFiLocale_weekNumbersVisible() {
+ openTestURL();
+
+ openPopupAndValidateWeekNumbers();
+ }
+
+ @Test
+ public void testToggleWeekNumbers_renderedCorrectly() {
+ openTestURL();
+
+ openPopupAndValidateWeekNumbers();
+
+ $(CheckBoxElement.class).first().click();
+
+ Assert.assertFalse("Checkbox is selected even though should be unselected.", $(CheckBoxElement.class).first().isChecked());
+
+ openPopupAndValidateNoWeeknumbers();
+ }
+
+ @Test
+ public void testLocaleChangeToEnglish_removesWeekNumbers() {
+ openTestURL();
+
+ openPopupAndValidateWeekNumbers();
+
+ $(ButtonElement.class).id("english").click();
+
+ openPopupAndValidateNoWeeknumbers();
+ }
+
+ @Test
+ public void testChangeBackToFinnish_weekNumbersVisible() {
+ openTestURL();
+
+ $(ButtonElement.class).id("english").click();
+
+ openPopupAndValidateNoWeeknumbers();
+
+ $(ButtonElement.class).id("finnish").click();
+
+ openPopupAndValidateWeekNumbers();
+ }
+
+ private void openPopupAndValidateWeekNumbers() {
+ WebElement popupButton = $(DateTimeFieldElement.class).first()
+ .findElement(By.className("v-datefield-button"));
+ // Open date popup
+ popupButton.click();
+
+ waitUntil(ExpectedConditions.visibilityOfElementLocated(
+ org.openqa.selenium.By.className("v-datefield-popup")));
+
+ Assert.assertFalse("No week numbers found for date field!",
+ findElements(
+ By.className("v-datefield-calendarpanel-weeknumber"))
+ .isEmpty());
+ // Close popup
+ popupButton.click();
+ }
+
+ private void openPopupAndValidateNoWeeknumbers() {
+ WebElement popupButton = $(DateTimeFieldElement.class).first()
+ .findElement(By.className("v-datefield-button"));
+ // Open date popup
+ popupButton.click();
+
+ waitUntil(ExpectedConditions.visibilityOfElementLocated(
+ org.openqa.selenium.By.className("v-datefield-popup")));
+
+ Assert.assertTrue("Week numbers still found in calendar popup!",
+ findElements(
+ By.className("v-datefield-calendarpanel-weeknumber"))
+ .isEmpty());
+ // Close popup
+ popupButton.click();
+ }
+}