Black
This commit is contained in:
parent
da05dfe708
commit
4de97abc3a
2676 changed files with 163166 additions and 140084 deletions
|
@ -8,17 +8,27 @@ from homeassistant.const import ATTR_ATTRIBUTION, CONF_MONITORED_CONDITIONS
|
|||
import homeassistant.helpers.config_validation as cv
|
||||
|
||||
from . import (
|
||||
ALLOWED_WATERING_TIME, ATTRIBUTION, CONF_WATERING_TIME, DATA_RAINCLOUD,
|
||||
DEFAULT_WATERING_TIME, SWITCHES, RainCloudEntity)
|
||||
ALLOWED_WATERING_TIME,
|
||||
ATTRIBUTION,
|
||||
CONF_WATERING_TIME,
|
||||
DATA_RAINCLOUD,
|
||||
DEFAULT_WATERING_TIME,
|
||||
SWITCHES,
|
||||
RainCloudEntity,
|
||||
)
|
||||
|
||||
_LOGGER = logging.getLogger(__name__)
|
||||
|
||||
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
|
||||
vol.Optional(CONF_MONITORED_CONDITIONS, default=list(SWITCHES)):
|
||||
vol.All(cv.ensure_list, [vol.In(SWITCHES)]),
|
||||
vol.Optional(CONF_WATERING_TIME, default=DEFAULT_WATERING_TIME):
|
||||
vol.All(vol.In(ALLOWED_WATERING_TIME)),
|
||||
})
|
||||
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend(
|
||||
{
|
||||
vol.Optional(CONF_MONITORED_CONDITIONS, default=list(SWITCHES)): vol.All(
|
||||
cv.ensure_list, [vol.In(SWITCHES)]
|
||||
),
|
||||
vol.Optional(CONF_WATERING_TIME, default=DEFAULT_WATERING_TIME): vol.All(
|
||||
vol.In(ALLOWED_WATERING_TIME)
|
||||
),
|
||||
}
|
||||
)
|
||||
|
||||
|
||||
def setup_platform(hass, config, add_entities, discovery_info=None):
|
||||
|
@ -30,8 +40,7 @@ def setup_platform(hass, config, add_entities, discovery_info=None):
|
|||
for sensor_type in config.get(CONF_MONITORED_CONDITIONS):
|
||||
# create a sensor for each zone managed by faucet
|
||||
for zone in raincloud.controller.faucet.zones:
|
||||
sensors.append(
|
||||
RainCloudSwitch(default_watering_timer, zone, sensor_type))
|
||||
sensors.append(RainCloudSwitch(default_watering_timer, zone, sensor_type))
|
||||
|
||||
add_entities(sensors, True)
|
||||
|
||||
|
@ -51,26 +60,26 @@ class RainCloudSwitch(RainCloudEntity, SwitchDevice):
|
|||
|
||||
def turn_on(self, **kwargs):
|
||||
"""Turn the device on."""
|
||||
if self._sensor_type == 'manual_watering':
|
||||
if self._sensor_type == "manual_watering":
|
||||
self.data.watering_time = self._default_watering_timer
|
||||
elif self._sensor_type == 'auto_watering':
|
||||
elif self._sensor_type == "auto_watering":
|
||||
self.data.auto_watering = True
|
||||
self._state = True
|
||||
|
||||
def turn_off(self, **kwargs):
|
||||
"""Turn the device off."""
|
||||
if self._sensor_type == 'manual_watering':
|
||||
self.data.watering_time = 'off'
|
||||
elif self._sensor_type == 'auto_watering':
|
||||
if self._sensor_type == "manual_watering":
|
||||
self.data.watering_time = "off"
|
||||
elif self._sensor_type == "auto_watering":
|
||||
self.data.auto_watering = False
|
||||
self._state = False
|
||||
|
||||
def update(self):
|
||||
"""Update device state."""
|
||||
_LOGGER.debug("Updating RainCloud switch: %s", self._name)
|
||||
if self._sensor_type == 'manual_watering':
|
||||
if self._sensor_type == "manual_watering":
|
||||
self._state = bool(self.data.watering_time)
|
||||
elif self._sensor_type == 'auto_watering':
|
||||
elif self._sensor_type == "auto_watering":
|
||||
self._state = self.data.auto_watering
|
||||
|
||||
@property
|
||||
|
@ -78,6 +87,6 @@ class RainCloudSwitch(RainCloudEntity, SwitchDevice):
|
|||
"""Return the state attributes."""
|
||||
return {
|
||||
ATTR_ATTRIBUTION: ATTRIBUTION,
|
||||
'default_manual_timer': self._default_watering_timer,
|
||||
'identifier': self.data.serial
|
||||
"default_manual_timer": self._default_watering_timer,
|
||||
"identifier": self.data.serial,
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue