Home Assistant Unofficial Reference 2024.12.1
cover.py
Go to the documentation of this file.
1 """Support for ESPHome covers."""
2 
3 from __future__ import annotations
4 
5 from functools import partial
6 from typing import Any
7 
8 from aioesphomeapi import APIVersion, CoverInfo, CoverOperation, CoverState, EntityInfo
9 
11  ATTR_POSITION,
12  ATTR_TILT_POSITION,
13  CoverDeviceClass,
14  CoverEntity,
15  CoverEntityFeature,
16 )
17 from homeassistant.core import callback
18 from homeassistant.util.enum import try_parse_enum
19 
20 from .entity import (
21  EsphomeEntity,
22  convert_api_error_ha_error,
23  esphome_state_property,
24  platform_async_setup_entry,
25 )
26 
27 
28 class EsphomeCover(EsphomeEntity[CoverInfo, CoverState], CoverEntity):
29  """A cover implementation for ESPHome."""
30 
31  @callback
32  def _on_static_info_update(self, static_info: EntityInfo) -> None:
33  """Set attrs from static info."""
34  super()._on_static_info_update(static_info)
35  static_info = self._static_info_static_info
36  flags = CoverEntityFeature.OPEN | CoverEntityFeature.CLOSE
37  if self._api_version_api_version < APIVersion(1, 8) or static_info.supports_stop:
38  flags |= CoverEntityFeature.STOP
39  if static_info.supports_position:
40  flags |= CoverEntityFeature.SET_POSITION
41  if static_info.supports_tilt:
42  flags |= (
43  CoverEntityFeature.OPEN_TILT
44  | CoverEntityFeature.CLOSE_TILT
45  | CoverEntityFeature.SET_TILT_POSITION
46  )
47  self._attr_supported_features_attr_supported_features = flags
48  self._attr_device_class_attr_device_class = try_parse_enum(
49  CoverDeviceClass, static_info.device_class
50  )
51  self._attr_assumed_state_attr_assumed_state = static_info.assumed_state
52 
53  @property
54  @esphome_state_property
55  def is_closed(self) -> bool | None:
56  """Return if the cover is closed or not."""
57  # Check closed state with api version due to a protocol change
58  return self._state_state.is_closed(self._api_version_api_version)
59 
60  @property
61  @esphome_state_property
62  def is_opening(self) -> bool:
63  """Return if the cover is opening or not."""
64  return self._state_state.current_operation is CoverOperation.IS_OPENING
65 
66  @property
67  @esphome_state_property
68  def is_closing(self) -> bool:
69  """Return if the cover is closing or not."""
70  return self._state_state.current_operation is CoverOperation.IS_CLOSING
71 
72  @property
73  @esphome_state_property
74  def current_cover_position(self) -> int | None:
75  """Return current position of cover. 0 is closed, 100 is open."""
76  if not self._static_info_static_info.supports_position:
77  return None
78  return round(self._state_state.position * 100.0)
79 
80  @property
81  @esphome_state_property
82  def current_cover_tilt_position(self) -> int | None:
83  """Return current position of cover tilt. 0 is closed, 100 is open."""
84  if not self._static_info_static_info.supports_tilt:
85  return None
86  return round(self._state_state.tilt * 100.0)
87 
88  @convert_api_error_ha_error
89  async def async_open_cover(self, **kwargs: Any) -> None:
90  """Open the cover."""
91  self._client_client.cover_command(key=self._key_key, position=1.0)
92 
93  @convert_api_error_ha_error
94  async def async_close_cover(self, **kwargs: Any) -> None:
95  """Close cover."""
96  self._client_client.cover_command(key=self._key_key, position=0.0)
97 
98  @convert_api_error_ha_error
99  async def async_stop_cover(self, **kwargs: Any) -> None:
100  """Stop the cover."""
101  self._client_client.cover_command(key=self._key_key, stop=True)
102 
103  @convert_api_error_ha_error
104  async def async_set_cover_position(self, **kwargs: Any) -> None:
105  """Move the cover to a specific position."""
106  self._client_client.cover_command(key=self._key_key, position=kwargs[ATTR_POSITION] / 100)
107 
108  @convert_api_error_ha_error
109  async def async_open_cover_tilt(self, **kwargs: Any) -> None:
110  """Open the cover tilt."""
111  self._client_client.cover_command(key=self._key_key, tilt=1.0)
112 
113  @convert_api_error_ha_error
114  async def async_close_cover_tilt(self, **kwargs: Any) -> None:
115  """Close the cover tilt."""
116  self._client_client.cover_command(key=self._key_key, tilt=0.0)
117 
118  @convert_api_error_ha_error
119  async def async_set_cover_tilt_position(self, **kwargs: Any) -> None:
120  """Move the cover tilt to a specific position."""
121  tilt_position: int = kwargs[ATTR_TILT_POSITION]
122  self._client_client.cover_command(key=self._key_key, tilt=tilt_position / 100)
123 
124 
125 async_setup_entry = partial(
126  platform_async_setup_entry,
127  info_type=CoverInfo,
128  entity_type=EsphomeCover,
129  state_type=CoverState,
130 )
None async_close_cover_tilt(self, **Any kwargs)
Definition: cover.py:114
None async_open_cover(self, **Any kwargs)
Definition: cover.py:89
None async_set_cover_position(self, **Any kwargs)
Definition: cover.py:104
None async_open_cover_tilt(self, **Any kwargs)
Definition: cover.py:109
None _on_static_info_update(self, EntityInfo static_info)
Definition: cover.py:32
None async_close_cover(self, **Any kwargs)
Definition: cover.py:94
None async_stop_cover(self, **Any kwargs)
Definition: cover.py:99
None async_set_cover_tilt_position(self, **Any kwargs)
Definition: cover.py:119