mirror of
https://github.com/home-assistant/core.git
synced 2025-07-12 15:57:06 +00:00
Code cleanup of velux scene (#12390)
* Code cleanup of velux scene * fixed review comments * fixed review comments
This commit is contained in:
parent
6f043f3c5c
commit
f25d56d666
@ -4,6 +4,8 @@ Support for VELUX scenes.
|
|||||||
For more details about this platform, please refer to the documentation at
|
For more details about this platform, please refer to the documentation at
|
||||||
https://home-assistant.io/components/scene.velux/
|
https://home-assistant.io/components/scene.velux/
|
||||||
"""
|
"""
|
||||||
|
import asyncio
|
||||||
|
|
||||||
from homeassistant.components.scene import Scene
|
from homeassistant.components.scene import Scene
|
||||||
from homeassistant.components.velux import _LOGGER, DATA_VELUX
|
from homeassistant.components.velux import _LOGGER, DATA_VELUX
|
||||||
|
|
||||||
@ -11,26 +13,22 @@ from homeassistant.components.velux import _LOGGER, DATA_VELUX
|
|||||||
DEPENDENCIES = ['velux']
|
DEPENDENCIES = ['velux']
|
||||||
|
|
||||||
|
|
||||||
def setup_platform(hass, config, add_devices, discovery_info=None):
|
@asyncio.coroutine
|
||||||
|
def async_setup_platform(hass, config, async_add_devices,
|
||||||
|
discovery_info=None):
|
||||||
"""Set up the scenes for velux platform."""
|
"""Set up the scenes for velux platform."""
|
||||||
if DATA_VELUX not in hass.data \
|
|
||||||
or not hass.data[DATA_VELUX].initialized:
|
|
||||||
return False
|
|
||||||
|
|
||||||
entities = []
|
entities = []
|
||||||
for scene in hass.data[DATA_VELUX].pyvlx.scenes:
|
for scene in hass.data[DATA_VELUX].pyvlx.scenes:
|
||||||
entities.append(VeluxScene(hass, scene))
|
entities.append(VeluxScene(scene))
|
||||||
add_devices(entities)
|
async_add_devices(entities)
|
||||||
return True
|
|
||||||
|
|
||||||
|
|
||||||
class VeluxScene(Scene):
|
class VeluxScene(Scene):
|
||||||
"""Representation of a velux scene."""
|
"""Representation of a velux scene."""
|
||||||
|
|
||||||
def __init__(self, hass, scene):
|
def __init__(self, scene):
|
||||||
"""Init velux scene."""
|
"""Init velux scene."""
|
||||||
_LOGGER.info("Adding VELUX scene: %s", scene)
|
_LOGGER.info("Adding VELUX scene: %s", scene)
|
||||||
self.hass = hass
|
|
||||||
self.scene = scene
|
self.scene = scene
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@ -38,16 +36,7 @@ class VeluxScene(Scene):
|
|||||||
"""Return the name of the scene."""
|
"""Return the name of the scene."""
|
||||||
return self.scene.name
|
return self.scene.name
|
||||||
|
|
||||||
@property
|
@asyncio.coroutine
|
||||||
def should_poll(self):
|
def async_activate(self):
|
||||||
"""Return that polling is not necessary."""
|
|
||||||
return False
|
|
||||||
|
|
||||||
@property
|
|
||||||
def is_on(self):
|
|
||||||
"""There is no way of detecting if a scene is active (yet)."""
|
|
||||||
return False
|
|
||||||
|
|
||||||
def activate(self):
|
|
||||||
"""Activate the scene."""
|
"""Activate the scene."""
|
||||||
self.hass.async_add_job(self.scene.run())
|
yield from self.scene.run()
|
||||||
|
@ -52,16 +52,13 @@ class VeluxModule:
|
|||||||
def __init__(self, hass, config):
|
def __init__(self, hass, config):
|
||||||
"""Initialize for velux component."""
|
"""Initialize for velux component."""
|
||||||
from pyvlx import PyVLX
|
from pyvlx import PyVLX
|
||||||
self.initialized = False
|
|
||||||
host = config[DOMAIN].get(CONF_HOST)
|
host = config[DOMAIN].get(CONF_HOST)
|
||||||
password = config[DOMAIN].get(CONF_PASSWORD)
|
password = config[DOMAIN].get(CONF_PASSWORD)
|
||||||
self.pyvlx = PyVLX(
|
self.pyvlx = PyVLX(
|
||||||
host=host,
|
host=host,
|
||||||
password=password)
|
password=password)
|
||||||
self.hass = hass
|
|
||||||
|
|
||||||
@asyncio.coroutine
|
@asyncio.coroutine
|
||||||
def async_start(self):
|
def async_start(self):
|
||||||
"""Start velux component."""
|
"""Start velux component."""
|
||||||
yield from self.pyvlx.load_scenes()
|
yield from self.pyvlx.load_scenes()
|
||||||
self.initialized = True
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user