core/homeassistant/components/wiz/light.py

127 lines
4.7 KiB
Python
Raw Normal View History

"""WiZ integration light platform."""
from __future__ import annotations
from typing import Any
from pywizlight import PilotBuilder
from pywizlight.bulblibrary import BulbClass, BulbType, Features
from pywizlight.scenes import get_id_from_scene_name
from homeassistant.components.light import (
ATTR_BRIGHTNESS,
ATTR_COLOR_TEMP,
ATTR_EFFECT,
2022-02-10 15:08:33 +00:00
ATTR_RGBW_COLOR,
ATTR_RGBWW_COLOR,
2022-04-23 20:59:21 +00:00
ColorMode,
LightEntity,
2022-04-26 12:33:02 +00:00
LightEntityFeature,
)
from homeassistant.config_entries import ConfigEntry
from homeassistant.core import HomeAssistant, callback
from homeassistant.helpers.entity_platform import AddEntitiesCallback
from homeassistant.util.color import (
color_temperature_kelvin_to_mired,
color_temperature_mired_to_kelvin,
)
from .const import DOMAIN
from .entity import WizToggleEntity
from .models import WizData
2022-04-23 20:59:21 +00:00
RGB_WHITE_CHANNELS_COLOR_MODE = {1: ColorMode.RGBW, 2: ColorMode.RGBWW}
2022-02-10 15:08:33 +00:00
def _async_pilot_builder(**kwargs: Any) -> PilotBuilder:
"""Create the PilotBuilder for turn on."""
brightness = kwargs.get(ATTR_BRIGHTNESS)
if ATTR_RGBWW_COLOR in kwargs:
return PilotBuilder(brightness=brightness, rgbww=kwargs[ATTR_RGBWW_COLOR])
if ATTR_RGBW_COLOR in kwargs:
return PilotBuilder(brightness=brightness, rgbw=kwargs[ATTR_RGBW_COLOR])
if ATTR_COLOR_TEMP in kwargs:
return PilotBuilder(
brightness=brightness,
colortemp=color_temperature_mired_to_kelvin(kwargs[ATTR_COLOR_TEMP]),
)
if ATTR_EFFECT in kwargs:
scene_id = get_id_from_scene_name(kwargs[ATTR_EFFECT])
if scene_id == 1000: # rhythm
return PilotBuilder()
return PilotBuilder(brightness=brightness, scene=scene_id)
return PilotBuilder(brightness=brightness)
async def async_setup_entry(
hass: HomeAssistant,
entry: ConfigEntry,
async_add_entities: AddEntitiesCallback,
) -> None:
"""Set up the WiZ Platform from config_flow."""
wiz_data: WizData = hass.data[DOMAIN][entry.entry_id]
if wiz_data.bulb.bulbtype.bulb_type != BulbClass.SOCKET:
async_add_entities([WizBulbEntity(wiz_data, entry.title)])
class WizBulbEntity(WizToggleEntity, LightEntity):
"""Representation of WiZ Light bulb."""
def __init__(self, wiz_data: WizData, name: str) -> None:
"""Initialize an WiZLight."""
super().__init__(wiz_data, name)
bulb_type: BulbType = self._device.bulbtype
features: Features = bulb_type.features
2022-04-23 20:59:21 +00:00
self._attr_supported_color_modes: set[ColorMode | str] = set()
if features.color:
2022-04-23 20:59:21 +00:00
self._attr_supported_color_modes.add(
RGB_WHITE_CHANNELS_COLOR_MODE[bulb_type.white_channels]
)
if features.color_tmp:
2022-04-23 20:59:21 +00:00
self._attr_supported_color_modes.add(ColorMode.COLOR_TEMP)
if not self._attr_supported_color_modes and features.brightness:
self._attr_supported_color_modes.add(ColorMode.BRIGHTNESS)
self._attr_effect_list = wiz_data.scenes
if bulb_type.bulb_type != BulbClass.DW:
kelvin = bulb_type.kelvin_range
self._attr_min_mireds = color_temperature_kelvin_to_mired(kelvin.max)
self._attr_max_mireds = color_temperature_kelvin_to_mired(kelvin.min)
if bulb_type.features.effect:
2022-04-26 12:33:02 +00:00
self._attr_supported_features = LightEntityFeature.EFFECT
self._async_update_attrs()
@callback
def _async_update_attrs(self) -> None:
"""Handle updating _attr values."""
state = self._device.state
color_modes = self.supported_color_modes
assert color_modes is not None
if (brightness := state.get_brightness()) is not None:
self._attr_brightness = max(0, min(255, brightness))
2022-04-23 20:59:21 +00:00
if ColorMode.COLOR_TEMP in color_modes and (
color_temp := state.get_colortemp()
2022-02-10 15:08:33 +00:00
):
2022-04-23 20:59:21 +00:00
self._attr_color_mode = ColorMode.COLOR_TEMP
2022-02-10 15:08:33 +00:00
self._attr_color_temp = color_temperature_kelvin_to_mired(color_temp)
elif (
2022-04-23 20:59:21 +00:00
ColorMode.RGBWW in color_modes and (rgbww := state.get_rgbww()) is not None
):
2022-02-10 15:08:33 +00:00
self._attr_rgbww_color = rgbww
2022-04-23 20:59:21 +00:00
self._attr_color_mode = ColorMode.RGBWW
elif ColorMode.RGBW in color_modes and (rgbw := state.get_rgbw()) is not None:
2022-02-10 15:08:33 +00:00
self._attr_rgbw_color = rgbw
2022-04-23 20:59:21 +00:00
self._attr_color_mode = ColorMode.RGBW
else:
2022-04-23 20:59:21 +00:00
self._attr_color_mode = ColorMode.BRIGHTNESS
self._attr_effect = state.get_scene()
super()._async_update_attrs()
async def async_turn_on(self, **kwargs: Any) -> None:
"""Instruct the light to turn on."""
2022-02-10 15:08:33 +00:00
await self._device.turn_on(_async_pilot_builder(**kwargs))
await self.coordinator.async_request_refresh()