ConfigDescriptionParameter: Change default format for datetime & Update context docs (#4428)

* ConfigDescriptionParameter: Change default format for datetime & Update context docs

This changes the default format for the datetime context to the ISO standard.
This context is not used by add-ons and supported by the UI, so it should be possible to change it (again after #4392.)

Also update the context docs from https://next.openhab.org/docs/developer/addons/config-xml.html#supported-contexts and the UI code.

Signed-off-by: Florian Hotze <dev@florianhotze.com>
This commit is contained in:
Florian Hotze 2024-10-26 20:31:08 +02:00 committed by GitHub
parent 63788b061b
commit ae1f763b62
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 34 additions and 28 deletions

View File

@ -21,7 +21,6 @@ import java.time.LocalDate;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.time.LocalTime; import java.time.LocalTime;
import java.time.ZonedDateTime; import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
import java.time.format.DateTimeParseException; import java.time.format.DateTimeParseException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
@ -258,11 +257,11 @@ public class ActionInputsHelper {
// Accepted format is: 10:15:30 // Accepted format is: 10:15:30
LocalTime.parse(valueString); LocalTime.parse(valueString);
case "java.time.LocalDateTime" -> case "java.time.LocalDateTime" ->
// Accepted format is: 2007-12-03 10:15:30 // Accepted format is: 2007-12-03T10:15:30
LocalDateTime.parse(valueString, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); LocalDateTime.parse(valueString);
case "java.util.Date" -> case "java.util.Date" ->
// Accepted format is: 2007-12-03 10:15:30 // Accepted format is: 2007-12-03T10:15:30
new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(valueString); new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss").parse(valueString);
case "java.time.ZonedDateTime" -> case "java.time.ZonedDateTime" ->
// Accepted format is: 2007-12-03T10:15:30+01:00[Europe/Paris] // Accepted format is: 2007-12-03T10:15:30+01:00[Europe/Paris]
ZonedDateTime.parse(valueString); ZonedDateTime.parse(valueString);

View File

@ -24,7 +24,6 @@ import java.time.LocalDate;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.time.LocalTime; import java.time.LocalTime;
import java.time.ZonedDateTime; import java.time.ZonedDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Collection; import java.util.Collection;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -411,13 +410,13 @@ public class ActionInputHelperTest {
@Test @Test
public void testMapSerializedInputToActionInputWhenLocalDateTime() { public void testMapSerializedInputToActionInputWhenLocalDateTime() {
String valAsString = "2024-07-01 20:30:45"; String valAsString = "2024-07-01T20:30:45";
LocalDateTime val = LocalDateTime.parse(valAsString, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")); LocalDateTime val = LocalDateTime.parse(valAsString);
Input input = buildInput("java.time.LocalDateTime"); Input input = buildInput("java.time.LocalDateTime");
assertThat(helper.mapSerializedInputToActionInput(input, val), is(val)); assertThat(helper.mapSerializedInputToActionInput(input, val), is(val));
assertThat(helper.mapSerializedInputToActionInput(input, valAsString), is(val)); assertThat(helper.mapSerializedInputToActionInput(input, valAsString), is(val));
assertThrows(IllegalArgumentException.class, assertThrows(IllegalArgumentException.class,
() -> helper.mapSerializedInputToActionInput(input, valAsString.replaceAll(" ", "T"))); () -> helper.mapSerializedInputToActionInput(input, valAsString.replaceAll("T", " ")));
} }
@Test @Test
@ -433,10 +432,10 @@ public class ActionInputHelperTest {
@Test @Test
public void testMapSerializedInputToActionInputWhenDate() { public void testMapSerializedInputToActionInputWhenDate() {
String valAsString = "2024-11-05 09:45:12"; String valAsString = "2024-11-05T09:45:12";
Date val; Date val;
try { try {
val = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(valAsString); val = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss").parse(valAsString);
} catch (IllegalArgumentException | ParseException e) { } catch (IllegalArgumentException | ParseException e) {
val = null; val = null;
} }
@ -445,7 +444,7 @@ public class ActionInputHelperTest {
assertThat(helper.mapSerializedInputToActionInput(input, val), is(val)); assertThat(helper.mapSerializedInputToActionInput(input, val), is(val));
assertThat(helper.mapSerializedInputToActionInput(input, valAsString), is(val)); assertThat(helper.mapSerializedInputToActionInput(input, valAsString), is(val));
assertThrows(IllegalArgumentException.class, assertThrows(IllegalArgumentException.class,
() -> helper.mapSerializedInputToActionInput(input, valAsString.replaceAll(" ", "T"))); () -> helper.mapSerializedInputToActionInput(input, valAsString.replaceAll("T", " ")));
} }
@Test @Test

View File

@ -309,31 +309,39 @@ public class ConfigDescriptionParameter {
* Any string can be used, but the following have a special meaning: * Any string can be used, but the following have a special meaning:
* </p> * </p>
* *
* - network-address: The configuration value represents an IPv4 or IPv6 address. * - network-address: The configuration value represents an IPv4 or IPv6 address or domain name.
* - password: A password value (a user-interface might obscure the visible value) * - network-interface: The configuration value represents a network interface name, e.g. eth0, wlan0.
* - password-create: A passwort generator widget might be shown * - serial-port: The configuration value represents a serial port name, e.g. COM1, /dev/ttyS0.
* - color: This value represents an RGB color value like #ffffff or 12,12,12. * - password: A alphanumeric password value (a user-interface might obscure the visible value)
* - date: A date string * - password-create: A alphanumeric passwort generator widget might be shown
* - time: A time string * - color: This value represents an RGB color value like #000000 - #ffffff or 12,12,12.
* - date: A date string in the format "YYYY-MM-DD"
* - datetime: A date and time string in the format "YYYY-MM-DD'T'hh:mm:ss", e.g. "2019-12-31T23:59:59"
* - cronexpression: A cron expression like "* * * * *". A user interface would probably show a cron expression * - cronexpression: A cron expression like "* * * * *". A user interface would probably show a cron expression
* generator. * generator.
* - datetime: A date and time string * - email: The configuration value represents an email address, e.g. username@domain.com
* - email: The configuration value represents an email address * - month: A month of year [1-12]
* - month: A number [1-12] * - week: A week of year [0-52]
* - week: A week [0-52] * - dayOfWeek: A day of week [MON, TUE, WED, THU, FRI, SAT, SUN]
* - tel: A tel no * - time: A time string in the format "hh:mm:ss" or as milliseconds since epoch
* - telephone: A tel no
* - url: A web address * - url: A web address
* - script: The configuration value represents a script (javascript, python etc). A user-interface would probably
* render a multi line editor.
* - location: A lat,long,alt GPS location. A user-interface would probably render a world map for selection.
* - tag: One tag or multiple tags separated by comma. * - tag: One tag or multiple tags separated by comma.
* - item: A valid item "name". A user-interface would probably show an item selection widget. * - item: A valid item "name". A user-interface would probably show an item selection widget.
* - thing: A valid thing UID. A user-interface would probably show a thing selection widget. * - thing: A valid thing UID. A user-interface would probably show a thing selection widget.
* - channel: A valid channel UID.
* - channeltype: A valid channel type UID. A user-interface would probably show a channel type selection widget.
* - group: A valid group item "name". A user-interface would probably show an item selection widget. * - group: A valid group item "name". A user-interface would probably show an item selection widget.
* - service: A valid service ID. A user-interface would probably show a service selection widget. * - service: A valid service ID. A user-interface would probably show a service selection widget.
* - persistenceService: A valid persistence service ID. A user-interface would probably show a persistence service
* selection widget.
* - channel: A valid channel UID. A user-interface would probably show a channel selection widget.
* - channeltype: A valid channel type UID. A user-interface would probably show a channel type selection widget.
* - rule: A valid rule uid. A user-interface would probably show a rule selection widget. * - rule: A valid rule uid. A user-interface would probably show a rule selection widget.
* - script: The configuration value represents a script (javascript, python etc). A user-interface would probably
* render a multi line editor.
* - page: A valid page UID. A user-interface would probably show a page selection widget.
* - widget: A valid widget UID. A user-interface would probably show a widget selection widget.
* - location: A latitude,longitude[,altitude] GPS location. A user-interface would probably render a world map for
* selection.
* *
* @return the context of the configuration parameter (could be null or * @return the context of the configuration parameter (could be null or
* empty) * empty)