core/homeassistant/components/sensibo/select.py

142 lines
4.6 KiB
Python
Raw Normal View History

2022-09-04 19:42:08 +00:00
"""Select platform for Sensibo integration."""
2022-03-12 02:23:24 +00:00
from __future__ import annotations
2022-09-04 19:42:08 +00:00
from collections.abc import Callable
2022-03-12 02:23:24 +00:00
from dataclasses import dataclass
2022-09-04 19:42:08 +00:00
from typing import TYPE_CHECKING, Any
from pysensibo.model import SensiboDevice
2022-03-12 02:23:24 +00:00
from homeassistant.components.select import SelectEntity, SelectEntityDescription
from homeassistant.config_entries import ConfigEntry
from homeassistant.core import HomeAssistant
from homeassistant.exceptions import HomeAssistantError
from homeassistant.helpers.entity_platform import AddEntitiesCallback
from .const import DOMAIN
from .coordinator import SensiboDataUpdateCoordinator
2022-09-04 19:42:08 +00:00
from .entity import SensiboDeviceBaseEntity, async_handle_api_call
2022-03-12 02:23:24 +00:00
2022-05-28 23:26:50 +00:00
PARALLEL_UPDATES = 0
2022-03-12 02:23:24 +00:00
@dataclass
class SensiboSelectDescriptionMixin:
"""Mixin values for Sensibo entities."""
2022-09-04 19:42:08 +00:00
data_key: str
value_fn: Callable[[SensiboDevice], str | None]
options_fn: Callable[[SensiboDevice], list[str] | None]
transformation: Callable[[SensiboDevice], dict | None]
2022-03-12 02:23:24 +00:00
@dataclass
class SensiboSelectEntityDescription(
SelectEntityDescription, SensiboSelectDescriptionMixin
):
2022-09-04 19:42:08 +00:00
"""Class describing Sensibo Select entities."""
2022-03-12 02:23:24 +00:00
2022-05-25 00:40:26 +00:00
DEVICE_SELECT_TYPES = (
2022-03-12 02:23:24 +00:00
SensiboSelectEntityDescription(
key="horizontalSwing",
2022-09-04 19:42:08 +00:00
data_key="horizontal_swing_mode",
name="Horizontal swing",
2022-03-12 02:23:24 +00:00
icon="mdi:air-conditioner",
2022-09-04 19:42:08 +00:00
value_fn=lambda data: data.horizontal_swing_mode,
options_fn=lambda data: data.horizontal_swing_modes,
translation_key="horizontalswing",
transformation=lambda data: data.horizontal_swing_modes_translated,
2022-03-12 02:23:24 +00:00
),
SensiboSelectEntityDescription(
key="light",
2022-09-04 19:42:08 +00:00
data_key="light_mode",
2022-03-12 02:23:24 +00:00
name="Light",
icon="mdi:flashlight",
2022-09-04 19:42:08 +00:00
value_fn=lambda data: data.light_mode,
options_fn=lambda data: data.light_modes,
translation_key="light",
transformation=lambda data: data.light_modes_translated,
2022-03-12 02:23:24 +00:00
),
)
async def async_setup_entry(
hass: HomeAssistant, entry: ConfigEntry, async_add_entities: AddEntitiesCallback
) -> None:
"""Set up Sensibo number platform."""
coordinator: SensiboDataUpdateCoordinator = hass.data[DOMAIN][entry.entry_id]
async_add_entities(
SensiboSelect(coordinator, device_id, description)
for device_id, device_data in coordinator.data.parsed.items()
2022-05-25 00:40:26 +00:00
for description in DEVICE_SELECT_TYPES
if description.key in device_data.full_features
2022-03-12 02:23:24 +00:00
)
class SensiboSelect(SensiboDeviceBaseEntity, SelectEntity):
2022-03-12 02:23:24 +00:00
"""Representation of a Sensibo Select."""
entity_description: SensiboSelectEntityDescription
def __init__(
self,
coordinator: SensiboDataUpdateCoordinator,
device_id: str,
entity_description: SensiboSelectEntityDescription,
) -> None:
"""Initiate Sensibo Select."""
super().__init__(coordinator, device_id)
self.entity_description = entity_description
self._attr_unique_id = f"{device_id}-{entity_description.key}"
@property
def current_option(self) -> str | None:
"""Return the current selected option."""
2022-09-04 19:42:08 +00:00
return self.entity_description.value_fn(self.device_data)
2022-03-12 02:23:24 +00:00
@property
def options(self) -> list[str]:
"""Return possible options."""
2022-09-04 19:42:08 +00:00
options = self.entity_description.options_fn(self.device_data)
if TYPE_CHECKING:
assert options is not None
return options
2022-03-12 02:23:24 +00:00
async def async_select_option(self, option: str) -> None:
"""Set state to the selected option."""
if self.entity_description.key not in self.device_data.active_features:
2022-03-12 02:23:24 +00:00
raise HomeAssistantError(
f"Current mode {self.device_data.hvac_mode} doesn't support setting"
f" {self.entity_description.name}"
2022-03-12 02:23:24 +00:00
)
2022-09-04 19:42:08 +00:00
await self.async_send_api_call(
key=self.entity_description.data_key,
value=option,
)
@async_handle_api_call
async def async_send_api_call(self, key: str, value: Any) -> bool:
2022-09-04 19:42:08 +00:00
"""Make service call to api."""
transformation = self.entity_description.transformation(self.device_data)
if TYPE_CHECKING:
assert transformation is not None
2022-09-04 19:42:08 +00:00
data = {
2022-03-12 02:23:24 +00:00
"name": self.entity_description.key,
2022-09-04 19:42:08 +00:00
"value": value,
"ac_states": self.device_data.ac_states,
2022-03-12 02:23:24 +00:00
"assumed_state": False,
}
2022-09-04 19:42:08 +00:00
result = await self._client.async_set_ac_state_property(
self._device_id,
data["name"],
transformation[data["value"]],
2022-09-04 19:42:08 +00:00
data["ac_states"],
data["assumed_state"],
2022-03-12 02:23:24 +00:00
)
2022-09-04 19:42:08 +00:00
return bool(result.get("result", {}).get("status") == "Success")