143 lines
4.0 KiB
Python
143 lines
4.0 KiB
Python
"""Platform for light integration."""
|
|
import logging
|
|
|
|
from smarttub import SpaLight
|
|
|
|
from homeassistant.components.light import (
|
|
ATTR_BRIGHTNESS,
|
|
ATTR_EFFECT,
|
|
EFFECT_COLORLOOP,
|
|
SUPPORT_BRIGHTNESS,
|
|
SUPPORT_EFFECT,
|
|
LightEntity,
|
|
)
|
|
|
|
from .const import (
|
|
ATTR_LIGHTS,
|
|
DEFAULT_LIGHT_BRIGHTNESS,
|
|
DEFAULT_LIGHT_EFFECT,
|
|
DOMAIN,
|
|
SMARTTUB_CONTROLLER,
|
|
)
|
|
from .entity import SmartTubEntity
|
|
from .helpers import get_spa_name
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
async def async_setup_entry(hass, entry, async_add_entities):
|
|
"""Set up entities for any lights in the tub."""
|
|
|
|
controller = hass.data[DOMAIN][entry.entry_id][SMARTTUB_CONTROLLER]
|
|
|
|
entities = [
|
|
SmartTubLight(controller.coordinator, light)
|
|
for spa in controller.spas
|
|
for light in controller.coordinator.data[spa.id][ATTR_LIGHTS].values()
|
|
]
|
|
|
|
async_add_entities(entities)
|
|
|
|
|
|
class SmartTubLight(SmartTubEntity, LightEntity):
|
|
"""A light on a spa."""
|
|
|
|
def __init__(self, coordinator, light):
|
|
"""Initialize the entity."""
|
|
super().__init__(coordinator, light.spa, "light")
|
|
self.light_zone = light.zone
|
|
|
|
@property
|
|
def light(self) -> SpaLight:
|
|
"""Return the underlying SpaLight object for this entity."""
|
|
return self.coordinator.data[self.spa.id]["lights"][self.light_zone]
|
|
|
|
@property
|
|
def unique_id(self) -> str:
|
|
"""Return a unique ID for this light entity."""
|
|
return f"{super().unique_id}-{self.light_zone}"
|
|
|
|
@property
|
|
def name(self) -> str:
|
|
"""Return a name for this light entity."""
|
|
spa_name = get_spa_name(self.spa)
|
|
return f"{spa_name} Light {self.light_zone}"
|
|
|
|
@property
|
|
def brightness(self):
|
|
"""Return the brightness of this light between 0..255."""
|
|
|
|
# SmartTub intensity is 0..100
|
|
return self._smarttub_to_hass_brightness(self.light.intensity)
|
|
|
|
@staticmethod
|
|
def _smarttub_to_hass_brightness(intensity):
|
|
if intensity in (0, 1):
|
|
return 0
|
|
return round(intensity * 255 / 100)
|
|
|
|
@staticmethod
|
|
def _hass_to_smarttub_brightness(brightness):
|
|
return round(brightness * 100 / 255)
|
|
|
|
@property
|
|
def is_on(self):
|
|
"""Return true if the light is on."""
|
|
return self.light.mode != SpaLight.LightMode.OFF
|
|
|
|
@property
|
|
def supported_features(self):
|
|
"""Flag supported features."""
|
|
return SUPPORT_BRIGHTNESS | SUPPORT_EFFECT
|
|
|
|
@property
|
|
def effect(self):
|
|
"""Return the current effect."""
|
|
mode = self.light.mode.name.lower()
|
|
if mode in self.effect_list:
|
|
return mode
|
|
return None
|
|
|
|
@property
|
|
def effect_list(self):
|
|
"""Return the list of supported effects."""
|
|
effects = [
|
|
effect
|
|
for effect in map(self._light_mode_to_effect, SpaLight.LightMode)
|
|
if effect is not None
|
|
]
|
|
|
|
return effects
|
|
|
|
@staticmethod
|
|
def _light_mode_to_effect(light_mode: SpaLight.LightMode):
|
|
if light_mode == SpaLight.LightMode.OFF:
|
|
return None
|
|
if light_mode == SpaLight.LightMode.HIGH_SPEED_COLOR_WHEEL:
|
|
return EFFECT_COLORLOOP
|
|
|
|
return light_mode.name.lower()
|
|
|
|
@staticmethod
|
|
def _effect_to_light_mode(effect):
|
|
if effect == EFFECT_COLORLOOP:
|
|
return SpaLight.LightMode.HIGH_SPEED_COLOR_WHEEL
|
|
|
|
return SpaLight.LightMode[effect.upper()]
|
|
|
|
async def async_turn_on(self, **kwargs):
|
|
"""Turn the light on."""
|
|
|
|
mode = self._effect_to_light_mode(kwargs.get(ATTR_EFFECT, DEFAULT_LIGHT_EFFECT))
|
|
intensity = self._hass_to_smarttub_brightness(
|
|
kwargs.get(ATTR_BRIGHTNESS, DEFAULT_LIGHT_BRIGHTNESS)
|
|
)
|
|
|
|
await self.light.set_mode(mode, intensity)
|
|
await self.coordinator.async_request_refresh()
|
|
|
|
async def async_turn_off(self, **kwargs):
|
|
"""Turn the light off."""
|
|
await self.light.set_mode(SpaLight.LightMode.OFF, 0)
|
|
await self.coordinator.async_request_refresh()
|