[wled] Fix: FX and Palettes channel StateDescriptionProvider handling (#17277)

* [wled] Fix: FX and Palettes channel StateDescriptionProvider handling

Fixes #17276

Signed-off-by: Stefan Triller <github@stefantriller.de>
This commit is contained in:
Stefan Triller 2024-08-18 17:27:33 +02:00 committed by GitHub
parent 04d87ad599
commit d1582099ff
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -33,6 +33,7 @@ import org.openhab.core.thing.ChannelUID;
import org.openhab.core.thing.Thing; import org.openhab.core.thing.Thing;
import org.openhab.core.thing.ThingStatus; import org.openhab.core.thing.ThingStatus;
import org.openhab.core.thing.ThingStatusDetail; import org.openhab.core.thing.ThingStatusDetail;
import org.openhab.core.thing.ThingStatusInfo;
import org.openhab.core.thing.binding.BaseThingHandler; import org.openhab.core.thing.binding.BaseThingHandler;
import org.openhab.core.thing.binding.builder.ThingBuilder; import org.openhab.core.thing.binding.builder.ThingBuilder;
import org.openhab.core.types.Command; import org.openhab.core.types.Command;
@ -254,10 +255,7 @@ public class WLedSegmentHandler extends BaseThingHandler {
WledApi localAPI = localBridgeHandler.api; WledApi localAPI = localBridgeHandler.api;
if (localAPI != null) { if (localAPI != null) {
updateStatus(ThingStatus.ONLINE); updateStatus(ThingStatus.ONLINE);
localBridgeHandler.stateDescriptionProvider updateStateDescriptionProviders();
.setStateOptions(new ChannelUID(getThing().getUID(), CHANNEL_FX), localAPI.getUpdatedFxList());
localBridgeHandler.stateDescriptionProvider.setStateOptions(
new ChannelUID(getThing().getUID(), CHANNEL_PALETTES), localAPI.getUpdatedPaletteList());
if (!localBridgeHandler.hasWhite) { if (!localBridgeHandler.hasWhite) {
logger.debug("WLED is not setup to use RGBW, so removing un-needed white channels"); logger.debug("WLED is not setup to use RGBW, so removing un-needed white channels");
removeWhiteChannels(); removeWhiteChannels();
@ -267,4 +265,31 @@ public class WLedSegmentHandler extends BaseThingHandler {
} }
} }
} }
private void updateStateDescriptionProviders() {
Bridge bridge = getBridge();
if (bridge != null) {
WLedBridgeHandler localBridgeHandler = (WLedBridgeHandler) bridge.getHandler();
if (localBridgeHandler != null) {
WledApi localAPI = localBridgeHandler.api;
if (localAPI != null) {
localBridgeHandler.stateDescriptionProvider.setStateOptions(
new ChannelUID(getThing().getUID(), CHANNEL_FX), localAPI.getUpdatedFxList());
localBridgeHandler.stateDescriptionProvider.setStateOptions(
new ChannelUID(getThing().getUID(), CHANNEL_PALETTES), localAPI.getUpdatedPaletteList());
}
}
}
}
@Override
public void bridgeStatusChanged(ThingStatusInfo bridgeStatusInfo) {
super.bridgeStatusChanged(bridgeStatusInfo);
if (ThingStatus.ONLINE.equals(bridgeStatusInfo.getStatus())) {
// if the handler has been started before the WLED controller is available, we have to fill the providers
// again once the bridge goes ONLINE
updateStateDescriptionProviders();
}
}
} }