2019-12-31 14:46:02 +00:00
|
|
|
"""Support for Velbus light."""
|
|
|
|
import logging
|
|
|
|
|
|
|
|
from velbus.util import VelbusException
|
|
|
|
|
|
|
|
from homeassistant.components.light import (
|
|
|
|
ATTR_BRIGHTNESS,
|
2020-01-06 00:28:10 +00:00
|
|
|
ATTR_FLASH,
|
2019-12-31 14:46:02 +00:00
|
|
|
ATTR_TRANSITION,
|
2020-01-06 00:28:10 +00:00
|
|
|
FLASH_LONG,
|
|
|
|
FLASH_SHORT,
|
2019-12-31 14:46:02 +00:00
|
|
|
SUPPORT_BRIGHTNESS,
|
2020-01-06 00:28:10 +00:00
|
|
|
SUPPORT_FLASH,
|
2019-12-31 14:46:02 +00:00
|
|
|
SUPPORT_TRANSITION,
|
2020-04-26 16:49:41 +00:00
|
|
|
LightEntity,
|
2019-12-31 14:46:02 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
from . import VelbusEntity
|
|
|
|
from .const import DOMAIN
|
|
|
|
|
|
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_entry(hass, entry, async_add_entities):
|
|
|
|
"""Set up Velbus light based on config_entry."""
|
|
|
|
cntrl = hass.data[DOMAIN][entry.entry_id]["cntrl"]
|
|
|
|
modules_data = hass.data[DOMAIN][entry.entry_id]["light"]
|
|
|
|
entities = []
|
|
|
|
for address, channel in modules_data:
|
|
|
|
module = cntrl.get_module(address)
|
|
|
|
entities.append(VelbusLight(module, channel))
|
|
|
|
async_add_entities(entities)
|
|
|
|
|
|
|
|
|
2020-04-26 16:49:41 +00:00
|
|
|
class VelbusLight(VelbusEntity, LightEntity):
|
2019-12-31 14:46:02 +00:00
|
|
|
"""Representation of a Velbus light."""
|
|
|
|
|
2020-01-06 00:28:10 +00:00
|
|
|
@property
|
|
|
|
def name(self):
|
|
|
|
"""Return the display name of this entity."""
|
|
|
|
if self._module.light_is_buttonled(self._channel):
|
|
|
|
return f"LED {self._module.get_name(self._channel)}"
|
|
|
|
return self._module.get_name(self._channel)
|
|
|
|
|
2019-12-31 14:46:02 +00:00
|
|
|
@property
|
|
|
|
def supported_features(self):
|
|
|
|
"""Flag supported features."""
|
2020-01-06 00:28:10 +00:00
|
|
|
if self._module.light_is_buttonled(self._channel):
|
|
|
|
return SUPPORT_FLASH
|
2019-12-31 14:46:02 +00:00
|
|
|
return SUPPORT_BRIGHTNESS | SUPPORT_TRANSITION
|
|
|
|
|
2020-01-06 00:28:10 +00:00
|
|
|
@property
|
|
|
|
def entity_registry_enabled_default(self):
|
|
|
|
"""Disable Button LEDs by default."""
|
|
|
|
if self._module.light_is_buttonled(self._channel):
|
|
|
|
return False
|
|
|
|
return True
|
|
|
|
|
2019-12-31 14:46:02 +00:00
|
|
|
@property
|
|
|
|
def is_on(self):
|
|
|
|
"""Return true if the light is on."""
|
|
|
|
return self._module.is_on(self._channel)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def brightness(self):
|
|
|
|
"""Return the brightness of the light."""
|
2020-03-24 20:58:50 +00:00
|
|
|
return int((self._module.get_dimmer_state(self._channel) * 255) / 100)
|
2019-12-31 14:46:02 +00:00
|
|
|
|
|
|
|
def turn_on(self, **kwargs):
|
|
|
|
"""Instruct the Velbus light to turn on."""
|
2020-01-06 00:28:10 +00:00
|
|
|
if self._module.light_is_buttonled(self._channel):
|
|
|
|
if ATTR_FLASH in kwargs:
|
|
|
|
if kwargs[ATTR_FLASH] == FLASH_LONG:
|
|
|
|
attr, *args = "set_led_state", self._channel, "slow"
|
|
|
|
elif kwargs[ATTR_FLASH] == FLASH_SHORT:
|
|
|
|
attr, *args = "set_led_state", self._channel, "fast"
|
|
|
|
else:
|
|
|
|
attr, *args = "set_led_state", self._channel, "on"
|
|
|
|
else:
|
|
|
|
attr, *args = "set_led_state", self._channel, "on"
|
|
|
|
else:
|
2019-12-31 14:46:02 +00:00
|
|
|
if ATTR_BRIGHTNESS in kwargs:
|
2020-03-24 20:58:50 +00:00
|
|
|
# Make sure a low but non-zero value is not rounded down to zero
|
|
|
|
if kwargs[ATTR_BRIGHTNESS] == 0:
|
|
|
|
brightness = 0
|
|
|
|
else:
|
|
|
|
brightness = max(int((kwargs[ATTR_BRIGHTNESS] * 100) / 255), 1)
|
2020-01-06 00:28:10 +00:00
|
|
|
attr, *args = (
|
|
|
|
"set_dimmer_state",
|
2019-12-31 14:46:02 +00:00
|
|
|
self._channel,
|
2020-03-24 20:58:50 +00:00
|
|
|
brightness,
|
2019-12-31 14:46:02 +00:00
|
|
|
kwargs.get(ATTR_TRANSITION, 0),
|
|
|
|
)
|
|
|
|
else:
|
2020-01-06 00:28:10 +00:00
|
|
|
attr, *args = (
|
|
|
|
"restore_dimmer_state",
|
|
|
|
self._channel,
|
|
|
|
kwargs.get(ATTR_TRANSITION, 0),
|
2019-12-31 14:46:02 +00:00
|
|
|
)
|
2020-01-06 00:28:10 +00:00
|
|
|
try:
|
|
|
|
getattr(self._module, attr)(*args)
|
2019-12-31 14:46:02 +00:00
|
|
|
except VelbusException as err:
|
|
|
|
_LOGGER.error("A Velbus error occurred: %s", err)
|
|
|
|
|
|
|
|
def turn_off(self, **kwargs):
|
|
|
|
"""Instruct the velbus light to turn off."""
|
2020-01-06 00:28:10 +00:00
|
|
|
if self._module.light_is_buttonled(self._channel):
|
|
|
|
attr, *args = "set_led_state", self._channel, "off"
|
|
|
|
else:
|
|
|
|
attr, *args = (
|
|
|
|
"set_dimmer_state",
|
|
|
|
self._channel,
|
|
|
|
0,
|
|
|
|
kwargs.get(ATTR_TRANSITION, 0),
|
2019-12-31 14:46:02 +00:00
|
|
|
)
|
2020-01-06 00:28:10 +00:00
|
|
|
try:
|
|
|
|
getattr(self._module, attr)(*args)
|
2019-12-31 14:46:02 +00:00
|
|
|
except VelbusException as err:
|
|
|
|
_LOGGER.error("A Velbus error occurred: %s", err)
|