2020-05-05 09:29:58 +00:00
|
|
|
"""BleBox cover entity."""
|
2022-06-25 09:59:56 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
2022-06-24 04:40:26 +00:00
|
|
|
from typing import Any
|
|
|
|
|
2020-05-05 09:29:58 +00:00
|
|
|
from homeassistant.components.cover import (
|
|
|
|
ATTR_POSITION,
|
|
|
|
CoverEntity,
|
2022-04-05 21:53:45 +00:00
|
|
|
CoverEntityFeature,
|
2020-05-05 09:29:58 +00:00
|
|
|
)
|
2022-01-03 14:13:18 +00:00
|
|
|
from homeassistant.config_entries import ConfigEntry
|
2022-01-05 15:44:13 +00:00
|
|
|
from homeassistant.const import STATE_CLOSED, STATE_CLOSING, STATE_OPENING
|
2022-01-03 14:13:18 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
|
|
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
2020-05-05 09:29:58 +00:00
|
|
|
|
|
|
|
from . import BleBoxEntity, create_blebox_entities
|
2020-05-16 15:51:37 +00:00
|
|
|
from .const import BLEBOX_TO_HASS_COVER_STATES, BLEBOX_TO_HASS_DEVICE_CLASSES
|
2020-05-05 09:29:58 +00:00
|
|
|
|
|
|
|
|
2022-01-03 14:13:18 +00:00
|
|
|
async def async_setup_entry(
|
|
|
|
hass: HomeAssistant,
|
|
|
|
config_entry: ConfigEntry,
|
|
|
|
async_add_entities: AddEntitiesCallback,
|
|
|
|
) -> None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Set up a BleBox entry."""
|
|
|
|
|
2020-05-18 20:30:15 +00:00
|
|
|
create_blebox_entities(
|
|
|
|
hass, config_entry, async_add_entities, BleBoxCoverEntity, "covers"
|
|
|
|
)
|
2020-05-05 09:29:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
class BleBoxCoverEntity(BleBoxEntity, CoverEntity):
|
|
|
|
"""Representation of a BleBox cover feature."""
|
|
|
|
|
2021-07-12 20:52:38 +00:00
|
|
|
def __init__(self, feature):
|
|
|
|
"""Initialize a BleBox cover feature."""
|
|
|
|
super().__init__(feature)
|
|
|
|
self._attr_device_class = BLEBOX_TO_HASS_DEVICE_CLASSES[feature.device_class]
|
2022-04-05 21:53:45 +00:00
|
|
|
position = CoverEntityFeature.SET_POSITION if feature.is_slider else 0
|
|
|
|
stop = CoverEntityFeature.STOP if feature.has_stop else 0
|
|
|
|
self._attr_supported_features = (
|
|
|
|
position | stop | CoverEntityFeature.OPEN | CoverEntityFeature.CLOSE
|
|
|
|
)
|
2021-07-12 20:52:38 +00:00
|
|
|
|
2020-05-05 09:29:58 +00:00
|
|
|
@property
|
2022-06-25 09:59:56 +00:00
|
|
|
def current_cover_position(self) -> int | None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Return the current cover position."""
|
|
|
|
position = self._feature.current
|
|
|
|
if position == -1: # possible for shutterBox
|
|
|
|
return None
|
|
|
|
|
|
|
|
return None if position is None else 100 - position
|
|
|
|
|
|
|
|
@property
|
2022-06-25 09:59:56 +00:00
|
|
|
def is_opening(self) -> bool | None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Return whether cover is opening."""
|
|
|
|
return self._is_state(STATE_OPENING)
|
|
|
|
|
|
|
|
@property
|
2022-06-25 09:59:56 +00:00
|
|
|
def is_closing(self) -> bool | None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Return whether cover is closing."""
|
|
|
|
return self._is_state(STATE_CLOSING)
|
|
|
|
|
|
|
|
@property
|
2022-06-25 09:59:56 +00:00
|
|
|
def is_closed(self) -> bool | None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Return whether cover is closed."""
|
|
|
|
return self._is_state(STATE_CLOSED)
|
|
|
|
|
2022-06-24 04:40:26 +00:00
|
|
|
async def async_open_cover(self, **kwargs: Any) -> None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Open the cover position."""
|
|
|
|
await self._feature.async_open()
|
|
|
|
|
2022-06-24 04:40:26 +00:00
|
|
|
async def async_close_cover(self, **kwargs: Any) -> None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Close the cover position."""
|
|
|
|
await self._feature.async_close()
|
|
|
|
|
2022-06-24 04:40:26 +00:00
|
|
|
async def async_set_cover_position(self, **kwargs: Any) -> None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Set the cover position."""
|
|
|
|
|
|
|
|
position = kwargs[ATTR_POSITION]
|
|
|
|
await self._feature.async_set_position(100 - position)
|
|
|
|
|
2022-06-24 04:40:26 +00:00
|
|
|
async def async_stop_cover(self, **kwargs: Any) -> None:
|
2020-05-05 09:29:58 +00:00
|
|
|
"""Stop the cover."""
|
|
|
|
await self._feature.async_stop()
|
|
|
|
|
2022-06-25 09:59:56 +00:00
|
|
|
def _is_state(self, state_name) -> bool | None:
|
2021-10-11 13:24:06 +00:00
|
|
|
value = BLEBOX_TO_HASS_COVER_STATES[self._feature.state]
|
2020-05-05 09:29:58 +00:00
|
|
|
return None if value is None else value == state_name
|