core/homeassistant/components/abode/light.py

126 lines
4.0 KiB
Python
Raw Normal View History

"""Support for Abode Security System lights."""
2022-01-10 14:54:09 +00:00
from __future__ import annotations
from math import ceil
2022-01-10 14:54:09 +00:00
from typing import Any
2022-01-10 14:54:09 +00:00
from abodepy.devices.light import AbodeLight as AbodeLT
2019-10-12 20:02:12 +00:00
import abodepy.helpers.constants as CONST
from homeassistant.components.light import (
2019-07-31 19:25:30 +00:00
ATTR_BRIGHTNESS,
ATTR_COLOR_TEMP,
ATTR_HS_COLOR,
ColorMode,
2020-04-26 16:49:41 +00:00
LightEntity,
2019-07-31 19:25:30 +00:00
)
from homeassistant.config_entries import ConfigEntry
from homeassistant.core import HomeAssistant
from homeassistant.helpers.entity_platform import AddEntitiesCallback
from homeassistant.util.color import (
2019-07-31 19:25:30 +00:00
color_temperature_kelvin_to_mired,
color_temperature_mired_to_kelvin,
)
2022-01-10 14:54:09 +00:00
from . import AbodeDevice, AbodeSystem
from .const import DOMAIN
async def async_setup_entry(
2022-01-10 14:54:09 +00:00
hass: HomeAssistant, entry: ConfigEntry, async_add_entities: AddEntitiesCallback
) -> None:
"""Set up Abode light devices."""
2022-01-10 14:54:09 +00:00
data: AbodeSystem = hass.data[DOMAIN]
entities = []
for device in data.abode.get_devices(generic_type=CONST.TYPE_LIGHT):
entities.append(AbodeLight(data, device))
async_add_entities(entities)
2020-04-26 16:49:41 +00:00
class AbodeLight(AbodeDevice, LightEntity):
"""Representation of an Abode light."""
2022-01-10 14:54:09 +00:00
_device: AbodeLT
def turn_on(self, **kwargs: Any) -> None:
"""Turn on the light."""
if ATTR_COLOR_TEMP in kwargs and self._device.is_color_capable:
self._device.set_color_temp(
2019-07-31 19:25:30 +00:00
int(color_temperature_mired_to_kelvin(kwargs[ATTR_COLOR_TEMP]))
)
2020-03-07 15:13:39 +00:00
return
if ATTR_HS_COLOR in kwargs and self._device.is_color_capable:
self._device.set_color(kwargs[ATTR_HS_COLOR])
2020-03-07 15:13:39 +00:00
return
if ATTR_BRIGHTNESS in kwargs and self._device.is_dimmable:
# Convert Home Assistant brightness (0-255) to Abode brightness (0-99)
# If 100 is sent to Abode, response is 99 causing an error
self._device.set_level(ceil(kwargs[ATTR_BRIGHTNESS] * 99 / 255.0))
2020-03-07 15:13:39 +00:00
return
self._device.switch_on()
2022-01-10 14:54:09 +00:00
def turn_off(self, **kwargs: Any) -> None:
"""Turn off the light."""
self._device.switch_off()
@property
2022-01-10 14:54:09 +00:00
def is_on(self) -> bool:
"""Return true if device is on."""
2022-01-10 14:54:09 +00:00
return bool(self._device.is_on)
@property
2022-01-10 14:54:09 +00:00
def brightness(self) -> int | None:
"""Return the brightness of the light."""
if self._device.is_dimmable and self._device.has_brightness:
brightness = int(self._device.brightness)
# Abode returns 100 during device initialization and device refresh
# Convert Abode brightness (0-99) to Home Assistant brightness (0-255)
2022-01-10 14:54:09 +00:00
return 255 if brightness == 100 else ceil(brightness * 255 / 99.0)
return None
@property
2022-01-10 14:54:09 +00:00
def color_temp(self) -> int | None:
"""Return the color temp of the light."""
if self._device.has_color:
return color_temperature_kelvin_to_mired(self._device.color_temp)
2022-01-10 14:54:09 +00:00
return None
@property
2022-01-10 14:54:09 +00:00
def hs_color(self) -> tuple[float, float] | None:
"""Return the color of the light."""
2022-01-10 14:54:09 +00:00
_hs = None
if self._device.has_color:
2022-01-10 14:54:09 +00:00
_hs = self._device.color
return _hs
@property
def color_mode(self) -> str | None:
"""Return the color mode of the light."""
if self._device.is_dimmable and self._device.is_color_capable:
if self.hs_color is not None:
return ColorMode.HS
return ColorMode.COLOR_TEMP
if self._device.is_dimmable:
return ColorMode.BRIGHTNESS
return ColorMode.ONOFF
@property
def supported_color_modes(self) -> set[str] | None:
"""Flag supported color modes."""
if self._device.is_dimmable and self._device.is_color_capable:
return {ColorMode.COLOR_TEMP, ColorMode.HS}
if self._device.is_dimmable:
return {ColorMode.BRIGHTNESS}
return {ColorMode.ONOFF}
@property
def supported_features(self) -> int:
"""Flag supported features."""
return 0