From 508e6f963ac09b4f2049efc4d0f5b7d5d03eba54 Mon Sep 17 00:00:00 2001 From: Colin <12702068+ckeehan@users.noreply.github.com> Date: Sat, 17 Jul 2021 01:51:44 -0500 Subject: [PATCH] Add support for group item type to window covering (#10936) Add support for setting TARGET_POSITION of Window Covering accessories from groups with a baseItem type Closes #10812 Signed-off-by: Colin Keehan Signed-off-by: dw-8 --- .../accessories/AbstractHomekitPositionAccessoryImpl.java | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/accessories/AbstractHomekitPositionAccessoryImpl.java b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/accessories/AbstractHomekitPositionAccessoryImpl.java index 516e305e564b9..aa307fdffe979 100644 --- a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/accessories/AbstractHomekitPositionAccessoryImpl.java +++ b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/accessories/AbstractHomekitPositionAccessoryImpl.java @@ -24,6 +24,7 @@ import org.eclipse.jdt.annotation.NonNullByDefault; import org.eclipse.jdt.annotation.Nullable; +import org.openhab.core.items.GroupItem; import org.openhab.core.items.Item; import org.openhab.core.library.items.DimmerItem; import org.openhab.core.library.items.NumberItem; @@ -84,12 +85,19 @@ public CompletableFuture setTargetPosition(int value) { getCharacteristic(TARGET_POSITION).ifPresentOrElse(taggedItem -> { final Item item = taggedItem.getItem(); final int targetPosition = convertPosition(value, openPosition); + if (item instanceof RollershutterItem) { ((RollershutterItem) item).send(new PercentType(targetPosition)); } else if (item instanceof DimmerItem) { ((DimmerItem) item).send(new PercentType(targetPosition)); } else if (item instanceof NumberItem) { ((NumberItem) item).send(new DecimalType(targetPosition)); + } else if (item instanceof GroupItem && ((GroupItem) item).getBaseItem() instanceof RollershutterItem) { + ((GroupItem) item).send(new PercentType(targetPosition)); + } else if (item instanceof GroupItem && ((GroupItem) item).getBaseItem() instanceof DimmerItem) { + ((GroupItem) item).send(new PercentType(targetPosition)); + } else if (item instanceof GroupItem && ((GroupItem) item).getBaseItem() instanceof NumberItem) { + ((GroupItem) item).send(new DecimalType(targetPosition)); } else { logger.warn( "Unsupported item type for characteristic {} at accessory {}. Expected Rollershutter, Dimmer or Number item, got {}",