From f581a49356684b1332c5ee759fcb57a519a05a02 Mon Sep 17 00:00:00 2001 From: jimtng <2554958+jimtng@users.noreply.github.com> Date: Mon, 9 Sep 2024 02:31:37 +1000 Subject: [PATCH] Support space separator between date and time (#329) --- lib/openhab/core/items/date_time_item.rb | 10 +++++++++- lib/openhab/dsl.rb | 2 +- spec/openhab/core/items/date_time_item_spec.rb | 10 ++++++++++ 3 files changed, 20 insertions(+), 2 deletions(-) diff --git a/lib/openhab/core/items/date_time_item.rb b/lib/openhab/core/items/date_time_item.rb index 806c94c4d0..01e7830814 100644 --- a/lib/openhab/core/items/date_time_item.rb +++ b/lib/openhab/core/items/date_time_item.rb @@ -47,7 +47,15 @@ class DateTimeItem < GenericItem def format_type(command) return command if command.is_a?(Types::DateTimeType) return Types::DateTimeType.new(command.to_zoned_date_time) if command.respond_to?(:to_zoned_date_time) - return Types::DateTimeType.new(DSL.try_parse_time_like(command.to_str)) if command.respond_to?(:to_str) + + if command.respond_to?(:to_str) + command = command.to_str + begin + return Types::DateTimeType.new(DSL.try_parse_time_like(command)) + rescue ArgumentError + return Types::DateTimeType.new(command) + end + end super end diff --git a/lib/openhab/dsl.rb b/lib/openhab/dsl.rb index d757a43f1c..89dae9ba87 100644 --- a/lib/openhab/dsl.rb +++ b/lib/openhab/dsl.rb @@ -1077,7 +1077,7 @@ def try_parse_time_like(string) return string unless string.is_a?(String) exception = nil - [java.time.LocalTime, java.time.LocalDate, java.time.MonthDay, java.time.ZonedDateTime].each do |klass| + [java.time.LocalTime, java.time.LocalDate, java.time.MonthDay, java.time.ZonedDateTime, Time].each do |klass| return klass.parse(string) rescue ArgumentError => e exception ||= e diff --git a/spec/openhab/core/items/date_time_item_spec.rb b/spec/openhab/core/items/date_time_item_spec.rb index 5e590c8ac9..efde29cfab 100644 --- a/spec/openhab/core/items/date_time_item_spec.rb +++ b/spec/openhab/core/items/date_time_item_spec.rb @@ -29,4 +29,14 @@ item.update("3:30pm") expect(item.state).to eq LocalTime.parse("3:30pm").to_zoned_date_time end + + it "can be updated by a string that looks like a date" do + item.update("2021-01-01") + expect(item.state).to eq LocalDate.parse("2021-01-01").to_zoned_date_time + end + + it "can be updated by a string that looks like a date and time" do + item.update("2021-01-01 15:40Z") + expect(item.state).to eq ZonedDateTime.parse("2021-01-01T15:40Z") + end end