Migrate time channels from DateTime to Number:Time (#13841)

Fixes #13840

Signed-off-by: Jacob Laursen <jacob-github@vindvejr.dk>
This commit is contained in:
Jacob Laursen 2022-12-10 23:05:59 +01:00 committed by GitHub
parent 5e73936aa8
commit c09be1bfbe
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 62 additions and 102 deletions

View File

@ -126,9 +126,9 @@ Channels available for each appliance type are listed below.
| rawPhase | Number | Read | Current phase of the program running on the appliance as raw number | | rawPhase | Number | Read | Current phase of the program running on the appliance as raw number |
| start | DateTime | Read | Programmed start time of the program | | start | DateTime | Read | Programmed start time of the program |
| end | DateTime | Read | End time of the program (programmed or running) | | end | DateTime | Read | End time of the program (programmed or running) |
| duration | DateTime | Read | Duration of the program running on the appliance | | duration | Number:Time | Read | Duration of the program running on the appliance |
| elapsed | DateTime | Read | Time elapsed in the program running on the appliance | | elapsed | Number:Time | Read | Time elapsed in the program running on the appliance |
| finish | DateTime | Read | Time to finish the program running on the appliance | | finish | Number:Time | Read | Time to finish the program running on the appliance |
| door | Contact | Read | Current state of the door of the appliance | | door | Contact | Read | Current state of the door of the appliance |
| switch | Switch | Write | Switch the appliance on or off | | switch | Switch | Write | Switch the appliance on or off |
| powerConsumption | Number:Power | Read | Power consumption by the currently running program on the appliance | | powerConsumption | Number:Power | Read | Power consumption by the currently running program on the appliance |
@ -239,9 +239,9 @@ Channels available for each appliance type are listed below.
| rawPhase | Number | Read | Current phase of the program running on the appliance as raw number | | rawPhase | Number | Read | Current phase of the program running on the appliance as raw number |
| start | DateTime | Read | Programmed start time of the program | | start | DateTime | Read | Programmed start time of the program |
| end | DateTime | Read | End time of the program (programmed or running) | | end | DateTime | Read | End time of the program (programmed or running) |
| duration | DateTime | Read | Duration of the program running on the appliance | | duration | Number:Time | Read | Duration of the program running on the appliance |
| elapsed | DateTime | Read | Time elapsed in the program running on the appliance | | elapsed | Number:Time | Read | Time elapsed in the program running on the appliance |
| finish | DateTime | Read | Time to finish the program running on the appliance | | finish | Number:Time | Read | Time to finish the program running on the appliance |
| target | Number:Temperature | Read | Target temperature to be reached by the oven | | target | Number:Temperature | Read | Target temperature to be reached by the oven |
| measured | Number:Temperature | Read | Actual measured temperature in the oven | | measured | Number:Temperature | Read | Actual measured temperature in the oven |
| temp1 | Number:Temperature | Read | Program temperature in the oven 1 | | temp1 | Number:Temperature | Read | Program temperature in the oven 1 |
@ -282,9 +282,9 @@ See oven.
| rawPhase | Number | Read | Current phase of the program running on the appliance as raw number | | rawPhase | Number | Read | Current phase of the program running on the appliance as raw number |
| start | DateTime | Read | Programmed start time of the program | | start | DateTime | Read | Programmed start time of the program |
| end | DateTime | Read | End time of the program (programmed or running) | | end | DateTime | Read | End time of the program (programmed or running) |
| duration | DateTime | Read | Duration of the program running on the appliance | | duration | Number:Time | Read | Duration of the program running on the appliance |
| elapsed | DateTime | Read | Time elapsed in the program running on the appliance | | elapsed | Number:Time | Read | Time elapsed in the program running on the appliance |
| finish | DateTime | Read | Time to finish the program running on the appliance | | finish | Number:Time | Read | Time to finish the program running on the appliance |
| door | Contact | Read | Current state of the door of the appliance | | door | Contact | Read | Current state of the door of the appliance |
| switch | Switch | Write | Switch the appliance on or off | | switch | Switch | Write | Switch the appliance on or off |
| step | Number | Read | Current step in the program running on the appliance | | step | Number | Read | Current step in the program running on the appliance |
@ -347,9 +347,9 @@ See oven.
| rawPhase | Number | Read | Current phase of the program running on the appliance as raw number | | rawPhase | Number | Read | Current phase of the program running on the appliance as raw number |
| start | DateTime | Read | Programmed start time of the program | | start | DateTime | Read | Programmed start time of the program |
| end | DateTime | Read | End time of the program (programmed or running) | | end | DateTime | Read | End time of the program (programmed or running) |
| duration | DateTime | Read | Duration of the program running on the appliance | | duration | Number:Time | Read | Duration of the program running on the appliance |
| elapsed | DateTime | Read | Time elapsed in the program running on the appliance | | elapsed | Number:Time | Read | Time elapsed in the program running on the appliance |
| finish | DateTime | Read | Time to finish the program running on the appliance | | finish | Number:Time | Read | Time to finish the program running on the appliance |
| door | Contact | Read | Current state of the door of the appliance | | door | Contact | Read | Current state of the door of the appliance |
| switch | Switch | Write | Switch the appliance on or off | | switch | Switch | Write | Switch the appliance on or off |
| target | Number:Temperature | Read | Temperature of the selected program (10 °C = cold) | | target | Number:Temperature | Read | Temperature of the selected program (10 °C = cold) |

View File

@ -16,10 +16,7 @@ import static java.util.Map.entry;
import static org.openhab.binding.miele.internal.MieleBindingConstants.*; import static org.openhab.binding.miele.internal.MieleBindingConstants.*;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map; import java.util.Map;
import java.util.TimeZone;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable; import org.eclipse.jdt.annotation.Nullable;
@ -32,6 +29,7 @@ import org.openhab.core.library.types.OnOffType;
import org.openhab.core.library.types.OpenClosedType; import org.openhab.core.library.types.OpenClosedType;
import org.openhab.core.library.types.QuantityType; import org.openhab.core.library.types.QuantityType;
import org.openhab.core.library.types.StringType; import org.openhab.core.library.types.StringType;
import org.openhab.core.library.unit.Units;
import org.openhab.core.types.State; import org.openhab.core.types.State;
import org.openhab.core.types.Type; import org.openhab.core.types.Type;
import org.openhab.core.types.UnDefType; import org.openhab.core.types.UnDefType;
@ -75,35 +73,27 @@ public enum DishwasherChannelSelector implements ApplianceChannelSelector {
PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false, false), PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false, false),
START_TIME("", START_CHANNEL_ID, DateTimeType.class, false, false), START_TIME("", START_CHANNEL_ID, DateTimeType.class, false, false),
END_TIME("", END_CHANNEL_ID, DateTimeType.class, false, false), END_TIME("", END_CHANNEL_ID, DateTimeType.class, false, false),
DURATION("duration", "duration", DateTimeType.class, false, false) { DURATION("duration", "duration", QuantityType.class, false, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
ELAPSED_TIME("elapsedTime", "elapsed", DateTimeType.class, false, false) { ELAPSED_TIME("elapsedTime", "elapsed", QuantityType.class, false, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
FINISH_TIME("", FINISH_CHANNEL_ID, DateTimeType.class, false, false), FINISH_TIME("", FINISH_CHANNEL_ID, QuantityType.class, false, false),
DOOR("signalDoor", "door", OpenClosedType.class, false, false) { DOOR("signalDoor", "door", OpenClosedType.class, false, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {

View File

@ -15,7 +15,6 @@ package org.openhab.binding.miele.internal.handler;
import static org.openhab.binding.miele.internal.MieleBindingConstants.*; import static org.openhab.binding.miele.internal.MieleBindingConstants.*;
import java.time.Instant; import java.time.Instant;
import java.time.ZoneId;
import java.time.ZonedDateTime; import java.time.ZonedDateTime;
import java.time.temporal.ChronoUnit; import java.time.temporal.ChronoUnit;
import java.util.HashMap; import java.util.HashMap;
@ -38,6 +37,8 @@ import org.openhab.core.i18n.TimeZoneProvider;
import org.openhab.core.i18n.TranslationProvider; import org.openhab.core.i18n.TranslationProvider;
import org.openhab.core.library.types.DateTimeType; import org.openhab.core.library.types.DateTimeType;
import org.openhab.core.library.types.OnOffType; import org.openhab.core.library.types.OnOffType;
import org.openhab.core.library.types.QuantityType;
import org.openhab.core.library.unit.Units;
import org.openhab.core.thing.Bridge; import org.openhab.core.thing.Bridge;
import org.openhab.core.thing.ChannelUID; import org.openhab.core.thing.ChannelUID;
import org.openhab.core.thing.Thing; import org.openhab.core.thing.Thing;
@ -335,9 +336,7 @@ public abstract class MieleApplianceHandler<E extends Enum<E> & ApplianceChannel
try { try {
long minutesFromNow = Long.valueOf(value); long minutesFromNow = Long.valueOf(value);
if (minutesFromNow > 0) { if (minutesFromNow > 0) {
ZonedDateTime remaining = ZonedDateTime.ofInstant(Instant.ofEpochSecond(minutesFromNow * 60), updateState(channelUid, new QuantityType<>(minutesFromNow, Units.MINUTE));
ZoneId.of("UTC"));
updateState(channelUid, new DateTimeType(remaining.withZoneSameLocal(timeZoneProvider.getTimeZone())));
return; return;
} }
} catch (NumberFormatException e) { } catch (NumberFormatException e) {

View File

@ -16,10 +16,7 @@ import static java.util.Map.entry;
import static org.openhab.binding.miele.internal.MieleBindingConstants.*; import static org.openhab.binding.miele.internal.MieleBindingConstants.*;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map; import java.util.Map;
import java.util.TimeZone;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable; import org.eclipse.jdt.annotation.Nullable;
@ -32,6 +29,7 @@ import org.openhab.core.library.types.OnOffType;
import org.openhab.core.library.types.OpenClosedType; import org.openhab.core.library.types.OpenClosedType;
import org.openhab.core.library.types.QuantityType; import org.openhab.core.library.types.QuantityType;
import org.openhab.core.library.types.StringType; import org.openhab.core.library.types.StringType;
import org.openhab.core.library.unit.Units;
import org.openhab.core.types.State; import org.openhab.core.types.State;
import org.openhab.core.types.Type; import org.openhab.core.types.Type;
import org.openhab.core.types.UnDefType; import org.openhab.core.types.UnDefType;
@ -70,35 +68,27 @@ public enum OvenChannelSelector implements ApplianceChannelSelector {
PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false), PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false),
START_TIME("", START_CHANNEL_ID, DateTimeType.class, false), START_TIME("", START_CHANNEL_ID, DateTimeType.class, false),
END_TIME("", END_CHANNEL_ID, DateTimeType.class, false), END_TIME("", END_CHANNEL_ID, DateTimeType.class, false),
DURATION("duration", "duration", DateTimeType.class, false) { DURATION("duration", "duration", QuantityType.class, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
ELAPSED_TIME("elapsedTime", "elapsed", DateTimeType.class, false) { ELAPSED_TIME("elapsedTime", "elapsed", QuantityType.class, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
FINISH_TIME("", FINISH_CHANNEL_ID, DateTimeType.class, false), FINISH_TIME("", FINISH_CHANNEL_ID, QuantityType.class, false),
TARGET_TEMP("targetTemperature", "target", QuantityType.class, false) { TARGET_TEMP("targetTemperature", "target", QuantityType.class, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {

View File

@ -16,10 +16,7 @@ import static java.util.Map.entry;
import static org.openhab.binding.miele.internal.MieleBindingConstants.*; import static org.openhab.binding.miele.internal.MieleBindingConstants.*;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map; import java.util.Map;
import java.util.TimeZone;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable; import org.eclipse.jdt.annotation.Nullable;
@ -30,7 +27,9 @@ import org.openhab.core.library.types.DateTimeType;
import org.openhab.core.library.types.DecimalType; import org.openhab.core.library.types.DecimalType;
import org.openhab.core.library.types.OnOffType; import org.openhab.core.library.types.OnOffType;
import org.openhab.core.library.types.OpenClosedType; import org.openhab.core.library.types.OpenClosedType;
import org.openhab.core.library.types.QuantityType;
import org.openhab.core.library.types.StringType; import org.openhab.core.library.types.StringType;
import org.openhab.core.library.unit.Units;
import org.openhab.core.types.State; import org.openhab.core.types.State;
import org.openhab.core.types.Type; import org.openhab.core.types.Type;
import org.openhab.core.types.UnDefType; import org.openhab.core.types.UnDefType;
@ -75,35 +74,27 @@ public enum TumbleDryerChannelSelector implements ApplianceChannelSelector {
PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false), PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false),
START_TIME("", START_CHANNEL_ID, DateTimeType.class, false), START_TIME("", START_CHANNEL_ID, DateTimeType.class, false),
END_TIME("", END_CHANNEL_ID, DateTimeType.class, false), END_TIME("", END_CHANNEL_ID, DateTimeType.class, false),
DURATION("duration", "duration", DateTimeType.class, false) { DURATION("duration", "duration", QuantityType.class, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
ELAPSED_TIME("elapsedTime", "elapsed", DateTimeType.class, false) { ELAPSED_TIME("elapsedTime", "elapsed", QuantityType.class, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
FINISH_TIME("", FINISH_CHANNEL_ID, DateTimeType.class, false), FINISH_TIME("", FINISH_CHANNEL_ID, QuantityType.class, false),
DRYING_STEP("dryingStep", "step", DecimalType.class, false) { DRYING_STEP("dryingStep", "step", DecimalType.class, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {

View File

@ -16,10 +16,7 @@ import static java.util.Map.entry;
import static org.openhab.binding.miele.internal.MieleBindingConstants.*; import static org.openhab.binding.miele.internal.MieleBindingConstants.*;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Map; import java.util.Map;
import java.util.TimeZone;
import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.NonNullByDefault;
import org.eclipse.jdt.annotation.Nullable; import org.eclipse.jdt.annotation.Nullable;
@ -32,6 +29,7 @@ import org.openhab.core.library.types.OnOffType;
import org.openhab.core.library.types.OpenClosedType; import org.openhab.core.library.types.OpenClosedType;
import org.openhab.core.library.types.QuantityType; import org.openhab.core.library.types.QuantityType;
import org.openhab.core.library.types.StringType; import org.openhab.core.library.types.StringType;
import org.openhab.core.library.unit.Units;
import org.openhab.core.types.State; import org.openhab.core.types.State;
import org.openhab.core.types.Type; import org.openhab.core.types.Type;
import org.openhab.core.types.UnDefType; import org.openhab.core.types.UnDefType;
@ -76,35 +74,27 @@ public enum WashingMachineChannelSelector implements ApplianceChannelSelector {
PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false, false), PROGRAM_PHASE(RAW_PHASE_PROPERTY_NAME, PHASE_CHANNEL_ID, DecimalType.class, false, false),
START_TIME("", START_CHANNEL_ID, DateTimeType.class, false, false), START_TIME("", START_CHANNEL_ID, DateTimeType.class, false, false),
END_TIME("", END_CHANNEL_ID, DateTimeType.class, false, false), END_TIME("", END_CHANNEL_ID, DateTimeType.class, false, false),
DURATION("duration", "duration", DateTimeType.class, false, false) { DURATION("duration", "duration", QuantityType.class, false, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s.trim()) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
ELAPSED_TIME("elapsedTime", "elapsed", DateTimeType.class, false, false) { ELAPSED_TIME("elapsedTime", "elapsed", QuantityType.class, false, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {
Date date = new Date();
SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss");
dateFormatter.setTimeZone(TimeZone.getTimeZone("GMT+0"));
try { try {
date.setTime(Long.valueOf(s) * 60000); return new QuantityType<>(Long.valueOf(s), Units.MINUTE);
} catch (Exception e) { } catch (NumberFormatException e) {
date.setTime(0); return UnDefType.UNDEF;
} }
return getState(dateFormatter.format(date));
} }
}, },
FINISH_TIME("", FINISH_CHANNEL_ID, DateTimeType.class, false, false), FINISH_TIME("", FINISH_CHANNEL_ID, QuantityType.class, false, false),
TARGET_TEMP("targetTemperature", "target", QuantityType.class, false, false) { TARGET_TEMP("targetTemperature", "target", QuantityType.class, false, false) {
@Override @Override
public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) { public State getState(String s, @Nullable DeviceMetaData dmd, MieleTranslationProvider translationProvider) {

View File

@ -70,27 +70,27 @@
</channel-type> </channel-type>
<channel-type id="duration"> <channel-type id="duration">
<item-type>DateTime</item-type> <item-type>Number:Time</item-type>
<label>Duration</label> <label>Duration</label>
<description>Duration of the program running on the appliance</description> <description>Duration of the program running on the appliance</description>
<category>Time</category> <category>Time</category>
<state readOnly="true" pattern="%1$tH:%1$tM"></state> <state readOnly="true" pattern="%1$tR"></state>
</channel-type> </channel-type>
<channel-type id="elapsed"> <channel-type id="elapsed">
<item-type>DateTime</item-type> <item-type>Number:Time</item-type>
<label>Elapsed Time</label> <label>Elapsed Time</label>
<description>Time elapsed in the program running on the appliance</description> <description>Time elapsed in the program running on the appliance</description>
<category>Time</category> <category>Time</category>
<state readOnly="true" pattern="%1$tH:%1$tM"></state> <state readOnly="true" pattern="%1$tR"></state>
</channel-type> </channel-type>
<channel-type id="finish"> <channel-type id="finish">
<item-type>DateTime</item-type> <item-type>Number:Time</item-type>
<label>Finish Time</label> <label>Finish Time</label>
<description>Time to finish the program running on the appliance</description> <description>Time to finish the program running on the appliance</description>
<category>Time</category> <category>Time</category>
<state readOnly="true" pattern="%1$tH:%1$tM"></state> <state readOnly="true" pattern="%1$tR"></state>
</channel-type> </channel-type>
<channel-type id="door"> <channel-type id="door">