From c83af2c66d753fd4d567ccad16eddd3fc8aebfa2 Mon Sep 17 00:00:00 2001 From: Christian Niessner Date: Sun, 22 Nov 2020 10:32:04 +0100 Subject: [PATCH] [tacmi] TA-CMI: Fixed some issues when percent values are received or updated (#9061) Fixes #8927 Signed-off-by: Christian Niessner --- .../binding/tacmi/internal/schema/ApiPageParser.java | 3 ++- .../tacmi/internal/schema/TACmiSchemaHandler.java | 11 +++++++++++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/ApiPageParser.java b/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/ApiPageParser.java index c6d9a7a1512..cd5c955a81f 100644 --- a/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/ApiPageParser.java +++ b/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/ApiPageParser.java @@ -342,7 +342,8 @@ public class ApiPageParser extends AbstractSimpleMarkupHandler { channelType = "Number:Temperature"; state = new QuantityType<>(bd, SIUnits.CELSIUS); } else if ("%".equals(valParts[1])) { - channelType = "Number:Percent"; + // channelType = "Number:Percent"; Number:Percent is currently not handled... + channelType = "Number:Dimensionless"; state = new QuantityType<>(bd, SmartHomeUnits.PERCENT); } else if ("Imp".equals(valParts[1])) { // impulses - no idea how to map this to something useful here? diff --git a/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/TACmiSchemaHandler.java b/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/TACmiSchemaHandler.java index 2288a3b1add..9070cc1a83f 100644 --- a/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/TACmiSchemaHandler.java +++ b/bundles/org.openhab.binding.tacmi/src/main/java/org/openhab/binding/tacmi/internal/schema/TACmiSchemaHandler.java @@ -250,6 +250,17 @@ public class TACmiSchemaHandler extends BaseThingHandler { return; } break; + case NUMERIC_FORM: + ChangerX2Entry cx2en = e.changerX2Entry; + if (cx2en != null) { + reqUpdate = prepareRequest(buildUri("INCLUDE/change.cgi?changeadrx2=" + cx2en.address + + "&changetox2=" + command.format("%.2f"))); + reqUpdate.header(HttpHeader.REFERER, this.serverBase + "schema.html"); // required... + } else { + logger.debug("Got command for uninitalized channel {}: {}", channelUID, command); + return; + } + break; case READ_ONLY_NUMERIC: case READ_ONLY_STATE: case READ_ONLY_SWITCH: