Fix Shelly RGBW (#47116)
parent
7c2545af6e
commit
e9b8e035b4
|
@ -74,5 +74,5 @@ INPUTS_EVENTS_SUBTYPES = {
|
|||
|
||||
# Kelvin value for colorTemp
|
||||
KELVIN_MAX_VALUE = 6500
|
||||
KELVIN_MIN_VALUE = 2700
|
||||
KELVIN_MIN_VALUE_SHBLB_1 = 3000
|
||||
KELVIN_MIN_VALUE_WHITE = 2700
|
||||
KELVIN_MIN_VALUE_COLOR = 3000
|
||||
|
|
|
@ -28,20 +28,13 @@ from .const import (
|
|||
DATA_CONFIG_ENTRY,
|
||||
DOMAIN,
|
||||
KELVIN_MAX_VALUE,
|
||||
KELVIN_MIN_VALUE,
|
||||
KELVIN_MIN_VALUE_SHBLB_1,
|
||||
KELVIN_MIN_VALUE_COLOR,
|
||||
KELVIN_MIN_VALUE_WHITE,
|
||||
)
|
||||
from .entity import ShellyBlockEntity
|
||||
from .utils import async_remove_shelly_entity
|
||||
|
||||
|
||||
def min_kelvin(model: str):
|
||||
"""Kelvin (min) for colorTemp."""
|
||||
if model in ["SHBLB-1"]:
|
||||
return KELVIN_MIN_VALUE_SHBLB_1
|
||||
return KELVIN_MIN_VALUE
|
||||
|
||||
|
||||
async def async_setup_entry(hass, config_entry, async_add_entities):
|
||||
"""Set up lights for device."""
|
||||
wrapper = hass.data[DOMAIN][DATA_CONFIG_ENTRY][config_entry.entry_id][COAP]
|
||||
|
@ -76,6 +69,8 @@ class ShellyLight(ShellyBlockEntity, LightEntity):
|
|||
self.control_result = None
|
||||
self.mode_result = None
|
||||
self._supported_features = 0
|
||||
self._min_kelvin = KELVIN_MIN_VALUE_WHITE
|
||||
self._max_kelvin = KELVIN_MAX_VALUE
|
||||
|
||||
if hasattr(block, "brightness") or hasattr(block, "gain"):
|
||||
self._supported_features |= SUPPORT_BRIGHTNESS
|
||||
|
@ -85,6 +80,7 @@ class ShellyLight(ShellyBlockEntity, LightEntity):
|
|||
self._supported_features |= SUPPORT_WHITE_VALUE
|
||||
if hasattr(block, "red") and hasattr(block, "green") and hasattr(block, "blue"):
|
||||
self._supported_features |= SUPPORT_COLOR
|
||||
self._min_kelvin = KELVIN_MIN_VALUE_COLOR
|
||||
|
||||
@property
|
||||
def supported_features(self) -> int:
|
||||
|
@ -168,22 +164,19 @@ class ShellyLight(ShellyBlockEntity, LightEntity):
|
|||
else:
|
||||
color_temp = self.block.colorTemp
|
||||
|
||||
# If you set DUO to max mireds in Shelly app, 2700K,
|
||||
# It reports 0 temp
|
||||
if color_temp == 0:
|
||||
return min_kelvin(self.wrapper.model)
|
||||
color_temp = min(self._max_kelvin, max(self._min_kelvin, color_temp))
|
||||
|
||||
return int(color_temperature_kelvin_to_mired(color_temp))
|
||||
|
||||
@property
|
||||
def min_mireds(self) -> int:
|
||||
"""Return the coldest color_temp that this light supports."""
|
||||
return int(color_temperature_kelvin_to_mired(KELVIN_MAX_VALUE))
|
||||
return int(color_temperature_kelvin_to_mired(self._max_kelvin))
|
||||
|
||||
@property
|
||||
def max_mireds(self) -> int:
|
||||
"""Return the warmest color_temp that this light supports."""
|
||||
return int(color_temperature_kelvin_to_mired(min_kelvin(self.wrapper.model)))
|
||||
return int(color_temperature_kelvin_to_mired(self._min_kelvin))
|
||||
|
||||
async def async_turn_on(self, **kwargs) -> None:
|
||||
"""Turn on light."""
|
||||
|
@ -192,6 +185,7 @@ class ShellyLight(ShellyBlockEntity, LightEntity):
|
|||
self.async_write_ha_state()
|
||||
return
|
||||
|
||||
set_mode = None
|
||||
params = {"turn": "on"}
|
||||
if ATTR_BRIGHTNESS in kwargs:
|
||||
tmp_brightness = int(kwargs[ATTR_BRIGHTNESS] / 255 * 100)
|
||||
|
@ -201,27 +195,26 @@ class ShellyLight(ShellyBlockEntity, LightEntity):
|
|||
params["brightness"] = tmp_brightness
|
||||
if ATTR_COLOR_TEMP in kwargs:
|
||||
color_temp = color_temperature_mired_to_kelvin(kwargs[ATTR_COLOR_TEMP])
|
||||
color_temp = min(
|
||||
KELVIN_MAX_VALUE, max(min_kelvin(self.wrapper.model), color_temp)
|
||||
)
|
||||
color_temp = min(self._max_kelvin, max(self._min_kelvin, color_temp))
|
||||
# Color temperature change - used only in white mode, switch device mode to white
|
||||
if self.mode == "color":
|
||||
self.mode_result = await self.wrapper.device.switch_light_mode("white")
|
||||
params["red"] = params["green"] = params["blue"] = 255
|
||||
set_mode = "white"
|
||||
params["red"] = params["green"] = params["blue"] = 255
|
||||
params["temp"] = int(color_temp)
|
||||
elif ATTR_HS_COLOR in kwargs:
|
||||
if ATTR_HS_COLOR in kwargs:
|
||||
red, green, blue = color_hs_to_RGB(*kwargs[ATTR_HS_COLOR])
|
||||
# Color channels change - used only in color mode, switch device mode to color
|
||||
if self.mode == "white":
|
||||
self.mode_result = await self.wrapper.device.switch_light_mode("color")
|
||||
set_mode = "color"
|
||||
params["red"] = red
|
||||
params["green"] = green
|
||||
params["blue"] = blue
|
||||
elif ATTR_WHITE_VALUE in kwargs:
|
||||
if ATTR_WHITE_VALUE in kwargs:
|
||||
# White channel change - used only in color mode, switch device mode device to color
|
||||
if self.mode == "white":
|
||||
self.mode_result = await self.wrapper.device.switch_light_mode("color")
|
||||
set_mode = "color"
|
||||
params["white"] = int(kwargs[ATTR_WHITE_VALUE])
|
||||
|
||||
if set_mode and self.mode != set_mode:
|
||||
self.mode_result = await self.wrapper.device.switch_light_mode(set_mode)
|
||||
|
||||
self.control_result = await self.block.set_state(**params)
|
||||
self.async_write_ha_state()
|
||||
|
||||
|
|
Loading…
Reference in New Issue