core/homeassistant/components/evil_genius_labs/light.py

121 lines
3.9 KiB
Python

"""Light platform for Evil Genius Light."""
from __future__ import annotations
from typing import Any, cast
from async_timeout import timeout
from homeassistant.components import light
from homeassistant.config_entries import ConfigEntry
from homeassistant.core import HomeAssistant
from homeassistant.helpers.entity_platform import AddEntitiesCallback
from . import EvilGeniusEntity, EvilGeniusUpdateCoordinator
from .const import DOMAIN
from .util import update_when_done
HA_NO_EFFECT = "None"
FIB_NO_EFFECT = "Solid Color"
async def async_setup_entry(
hass: HomeAssistant,
config_entry: ConfigEntry,
async_add_entities: AddEntitiesCallback,
) -> None:
"""Set up the Evil Genius light platform."""
coordinator: EvilGeniusUpdateCoordinator = hass.data[DOMAIN][config_entry.entry_id]
async_add_entities([EvilGeniusLight(coordinator)])
class EvilGeniusLight(EvilGeniusEntity, light.LightEntity):
"""Evil Genius Labs light."""
_attr_supported_features = (
light.SUPPORT_BRIGHTNESS | light.SUPPORT_EFFECT | light.SUPPORT_COLOR
)
_attr_supported_color_modes = {light.COLOR_MODE_RGB}
_attr_color_mode = light.COLOR_MODE_RGB
def __init__(self, coordinator: EvilGeniusUpdateCoordinator) -> None:
"""Initialize the Evil Genius light."""
super().__init__(coordinator)
self._attr_unique_id = self.coordinator.info["wiFiChipId"]
self._attr_effect_list = [
pattern
for pattern in self.coordinator.data["pattern"]["options"]
if pattern != FIB_NO_EFFECT
]
self._attr_effect_list.insert(0, HA_NO_EFFECT)
@property
def name(self) -> str:
"""Return name."""
return cast(str, self.coordinator.data["name"]["value"])
@property
def is_on(self) -> bool:
"""Return if light is on."""
return cast(int, self.coordinator.data["power"]["value"]) == 1
@property
def brightness(self) -> int:
"""Return brightness."""
return cast(int, self.coordinator.data["brightness"]["value"])
@property
def rgb_color(self) -> tuple[int, int, int]:
"""Return the rgb color value [int, int, int]."""
return cast(
"tuple[int, int, int]",
tuple(
int(val)
for val in self.coordinator.data["solidColor"]["value"].split(",")
),
)
@property
def effect(self) -> str:
"""Return current effect."""
value = cast(
str,
self.coordinator.data["pattern"]["options"][
self.coordinator.data["pattern"]["value"]
],
)
if value == FIB_NO_EFFECT:
return HA_NO_EFFECT
return value
@update_when_done
async def async_turn_on(
self,
**kwargs: Any,
) -> None:
"""Turn light on."""
if (brightness := kwargs.get(light.ATTR_BRIGHTNESS)) is not None:
async with timeout(5):
await self.coordinator.client.set_path_value("brightness", brightness)
# Setting a color will change the effect to "Solid Color" so skip setting effect
if (rgb_color := kwargs.get(light.ATTR_RGB_COLOR)) is not None:
async with timeout(5):
await self.coordinator.client.set_rgb_color(*rgb_color)
elif (effect := kwargs.get(light.ATTR_EFFECT)) is not None:
if effect == HA_NO_EFFECT:
effect = FIB_NO_EFFECT
async with timeout(5):
await self.coordinator.client.set_path_value(
"pattern", self.coordinator.data["pattern"]["options"].index(effect)
)
async with timeout(5):
await self.coordinator.client.set_path_value("power", 1)
@update_when_done
async def async_turn_off(self, **kwargs: Any) -> None:
"""Turn light off."""
async with timeout(5):
await self.coordinator.client.set_path_value("power", 0)