summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnastasia Smirnova <anasmi@utu.fi>2018-10-24 11:30:16 +0300
committerSun Zhe <31067185+ZheSun88@users.noreply.github.com>2018-10-24 11:30:16 +0300
commit5a9cd49321d57822ff8d603fea81ebd7746e1fba (patch)
tree966b331dffca04790fdf849dc4abb741e72ac226
parent6266f11b6d3cffdfdd56a3054367cbbf9b368e2c (diff)
downloadvaadin-framework-5a9cd49321d57822ff8d603fea81ebd7746e1fba.tar.gz
vaadin-framework-5a9cd49321d57822ff8d603fea81ebd7746e1fba.zip
Update time in ReadOnly state of DateTimeCalendar (#11269)
Fix https://github.com/vaadin/framework/issues/11268 ```buildTime()``` function re-initializes ListBoxes for hours,minutes and seconds values. We need to set correct values in those ListBoxes, before assigning value to the labels displayed instead of those ListBoxes in ReadOnly state, as , otherwise, the selectedItemIndex returns 0.
-rw-r--r--client/src/main/java/com/vaadin/client/ui/VDateTimeCalendarPanel.java6
-rw-r--r--uitest/src/main/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnly.java41
-rw-r--r--uitest/src/test/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnlyTest.java42
3 files changed, 86 insertions, 3 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/VDateTimeCalendarPanel.java b/client/src/main/java/com/vaadin/client/ui/VDateTimeCalendarPanel.java
index 3460cdfbbf..259502b98a 100644
--- a/client/src/main/java/com/vaadin/client/ui/VDateTimeCalendarPanel.java
+++ b/client/src/main/java/com/vaadin/client/ui/VDateTimeCalendarPanel.java
@@ -119,6 +119,9 @@ public class VDateTimeCalendarPanel
sec.addChangeHandler(this);
}
+ // Update times
+ updateTimes();
+
final String delimiter = getDateTimeService().getClockDelimeter();
if (isReadonly()) {
int h = 0;
@@ -171,9 +174,6 @@ public class VDateTimeCalendarPanel
return;
}
- // Update times
- updateTimes();
-
ListBox lastDropDown = getLastDropDown();
lastDropDown.addKeyDownHandler(event -> {
boolean shiftKey = event.getNativeEvent().getShiftKey();
diff --git a/uitest/src/main/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnly.java b/uitest/src/main/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnly.java
new file mode 100644
index 0000000000..39915096bf
--- /dev/null
+++ b/uitest/src/main/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnly.java
@@ -0,0 +1,41 @@
+package com.vaadin.tests.components.datefield;
+
+import com.vaadin.annotations.Widgetset;
+import com.vaadin.server.VaadinRequest;
+import com.vaadin.shared.ui.datefield.DateTimeResolution;
+import com.vaadin.tests.components.AbstractTestUI;
+import com.vaadin.ui.Button;
+import com.vaadin.ui.InlineDateTimeField;
+
+import java.time.LocalDateTime;
+import java.util.Locale;
+
+@Widgetset("com.vaadin.DefaultWidgetSet")
+public class InlineDateFieldReadOnly extends AbstractTestUI {
+ public static final int SEC = 33;
+ public static final int MIN = 15;
+ public static final int HOUR = 14;
+
+ @Override
+ protected void setup(VaadinRequest request) {
+ final InlineDateTimeField timeField = new InlineDateTimeField(
+ "A read-only datefield");
+ timeField.setResolution(DateTimeResolution.SECOND);
+ timeField.setLocale(new Locale("fi"));
+ timeField.setId("dF");
+ // Set date so that test always has same time
+ timeField.setValue(LocalDateTime.of(2018, 9, 15, HOUR, MIN, SEC));
+ timeField.setReadOnly(true);
+
+ addComponent(timeField);
+
+ Button b = new Button("Switch read-only");
+ b.addClickListener(event -> {
+ timeField.setReadOnly(!timeField.isReadOnly());
+ });
+ b.setId("readOnlySwitch");
+
+ addComponent(b);
+ }
+
+}
diff --git a/uitest/src/test/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnlyTest.java b/uitest/src/test/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnlyTest.java
new file mode 100644
index 0000000000..be337ee8f8
--- /dev/null
+++ b/uitest/src/test/java/com/vaadin/tests/components/datefield/InlineDateFieldReadOnlyTest.java
@@ -0,0 +1,42 @@
+package com.vaadin.tests.components.datefield;
+
+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.assertFalse;
+
+public class InlineDateFieldReadOnlyTest extends MultiBrowserTest {
+
+ @Test
+ public void minutesAndSecondsAreRenderedCorrectly() {
+ openTestURL();
+ WebElement divTime = findElement(By.className("v-datefield-time"));
+ List<WebElement> labels = divTime.findElements(By.className("v-label"));
+ assertEquals(5, labels.size());
+
+ // At positions 1 and 3 the delimeter label is set
+ assertEquals(InlineDateFieldReadOnly.HOUR,
+ convertToInt(labels.get(0).getText()));
+ assertEquals(InlineDateFieldReadOnly.MIN,
+ convertToInt(labels.get(2).getText()));
+ assertEquals(InlineDateFieldReadOnly.SEC,
+ convertToInt(labels.get(4).getText()));
+ }
+
+ private int convertToInt(String value) {
+ int converted = -1;
+ try {
+ converted = Integer.valueOf(value).intValue();
+ } catch (NumberFormatException e) {
+ assertFalse(
+ "NumberFormatException is thrown! Conversion was not possible",
+ e instanceof NumberFormatException);
+ }
+ return converted;
+ }
+}