2019-02-14 15:01:46 +00:00
|
|
|
"""Support for ISY994 switches."""
|
2015-04-12 21:18:14 +00:00
|
|
|
import logging
|
2018-06-25 17:05:07 +00:00
|
|
|
from typing import Callable
|
2015-04-12 21:18:14 +00:00
|
|
|
|
2019-02-14 15:01:46 +00:00
|
|
|
from homeassistant.components.switch import DOMAIN, SwitchDevice
|
2018-06-25 17:05:07 +00:00
|
|
|
from homeassistant.helpers.typing import ConfigType
|
2016-02-19 05:27:50 +00:00
|
|
|
|
2019-03-21 05:56:46 +00:00
|
|
|
from . import ISY994_NODES, ISY994_PROGRAMS, ISYDevice
|
|
|
|
|
2016-09-11 18:18:53 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
2016-02-19 05:27:50 +00:00
|
|
|
|
2016-09-11 18:18:53 +00:00
|
|
|
|
2019-07-31 19:25:30 +00:00
|
|
|
def setup_platform(
|
|
|
|
hass, config: ConfigType, add_entities: Callable[[list], None], discovery_info=None
|
|
|
|
):
|
2016-09-11 18:18:53 +00:00
|
|
|
"""Set up the ISY994 switch platform."""
|
|
|
|
devices = []
|
2017-12-26 08:26:37 +00:00
|
|
|
for node in hass.data[ISY994_NODES][DOMAIN]:
|
2016-09-11 18:18:53 +00:00
|
|
|
if not node.dimmable:
|
|
|
|
devices.append(ISYSwitchDevice(node))
|
|
|
|
|
2017-12-26 08:26:37 +00:00
|
|
|
for name, status, actions in hass.data[ISY994_PROGRAMS][DOMAIN]:
|
|
|
|
devices.append(ISYSwitchProgram(name, status, actions))
|
2015-04-12 21:18:14 +00:00
|
|
|
|
2018-08-24 14:37:30 +00:00
|
|
|
add_entities(devices)
|
2015-04-12 21:18:14 +00:00
|
|
|
|
|
|
|
|
2017-12-26 08:26:37 +00:00
|
|
|
class ISYSwitchDevice(ISYDevice, SwitchDevice):
|
2016-09-11 18:18:53 +00:00
|
|
|
"""Representation of an ISY994 switch device."""
|
2015-04-12 21:18:14 +00:00
|
|
|
|
2016-09-11 18:18:53 +00:00
|
|
|
@property
|
|
|
|
def is_on(self) -> bool:
|
|
|
|
"""Get whether the ISY994 device is in the on state."""
|
2017-12-26 08:26:37 +00:00
|
|
|
return bool(self.value)
|
2015-04-13 02:30:14 +00:00
|
|
|
|
2016-09-11 18:18:53 +00:00
|
|
|
def turn_off(self, **kwargs) -> None:
|
|
|
|
"""Send the turn on command to the ISY994 switch."""
|
|
|
|
if not self._node.off():
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.debug("Unable to turn on switch.")
|
2016-09-11 18:18:53 +00:00
|
|
|
|
|
|
|
def turn_on(self, **kwargs) -> None:
|
|
|
|
"""Send the turn off command to the ISY994 switch."""
|
|
|
|
if not self._node.on():
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.debug("Unable to turn on switch.")
|
2015-04-13 02:30:14 +00:00
|
|
|
|
|
|
|
|
2016-09-11 18:18:53 +00:00
|
|
|
class ISYSwitchProgram(ISYSwitchDevice):
|
|
|
|
"""A representation of an ISY994 program switch."""
|
2015-04-13 02:30:14 +00:00
|
|
|
|
2016-09-11 18:18:53 +00:00
|
|
|
def __init__(self, name: str, node, actions) -> None:
|
|
|
|
"""Initialize the ISY994 switch program."""
|
2017-12-26 08:26:37 +00:00
|
|
|
super().__init__(node)
|
2016-09-11 18:18:53 +00:00
|
|
|
self._name = name
|
|
|
|
self._actions = actions
|
|
|
|
|
|
|
|
@property
|
|
|
|
def is_on(self) -> bool:
|
|
|
|
"""Get whether the ISY994 switch program is on."""
|
|
|
|
return bool(self.value)
|
|
|
|
|
|
|
|
def turn_on(self, **kwargs) -> None:
|
|
|
|
"""Send the turn on command to the ISY994 switch program."""
|
|
|
|
if not self._actions.runThen():
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.error("Unable to turn on switch")
|
2016-09-11 18:18:53 +00:00
|
|
|
|
|
|
|
def turn_off(self, **kwargs) -> None:
|
|
|
|
"""Send the turn off command to the ISY994 switch program."""
|
|
|
|
if not self._actions.runElse():
|
2019-07-31 19:25:30 +00:00
|
|
|
_LOGGER.error("Unable to turn off switch")
|