Home Assistant Unofficial Reference 2024.12.1
number.py
Go to the documentation of this file.
1 """Support for esphome numbers."""
2 
3 from __future__ import annotations
4 
5 from functools import partial
6 
7 from aioesphomeapi import (
8  EntityInfo,
9  NumberInfo,
10  NumberMode as EsphomeNumberMode,
11  NumberState,
12 )
13 
14 from homeassistant.components.number import NumberDeviceClass, NumberEntity, NumberMode
15 from homeassistant.core import callback
16 from homeassistant.util.enum import try_parse_enum
17 
18 from .entity import (
19  EsphomeEntity,
20  convert_api_error_ha_error,
21  esphome_float_state_property,
22  platform_async_setup_entry,
23 )
24 from .enum_mapper import EsphomeEnumMapper
25 
26 NUMBER_MODES: EsphomeEnumMapper[EsphomeNumberMode, NumberMode] = EsphomeEnumMapper(
27  {
28  EsphomeNumberMode.AUTO: NumberMode.AUTO,
29  EsphomeNumberMode.BOX: NumberMode.BOX,
30  EsphomeNumberMode.SLIDER: NumberMode.SLIDER,
31  }
32 )
33 
34 
35 class EsphomeNumber(EsphomeEntity[NumberInfo, NumberState], NumberEntity):
36  """A number implementation for esphome."""
37 
38  @callback
39  def _on_static_info_update(self, static_info: EntityInfo) -> None:
40  """Set attrs from static info."""
41  super()._on_static_info_update(static_info)
42  static_info = self._static_info_static_info
43  self._attr_device_class_attr_device_class = try_parse_enum(
44  NumberDeviceClass, static_info.device_class
45  )
46  self._attr_native_min_value_attr_native_min_value = static_info.min_value
47  self._attr_native_max_value_attr_native_max_value = static_info.max_value
48  self._attr_native_step_attr_native_step = static_info.step
49  # protobuf doesn't support nullable strings so we need to check
50  # if the string is empty
51  if unit_of_measurement := static_info.unit_of_measurement:
52  self._attr_native_unit_of_measurement_attr_native_unit_of_measurement = unit_of_measurement
53  if mode := static_info.mode:
54  self._attr_mode_attr_mode = NUMBER_MODES.from_esphome(mode)
55  else:
56  self._attr_mode_attr_mode = NumberMode.AUTO
57 
58  @property
59  @esphome_float_state_property
60  def native_value(self) -> float | None:
61  """Return the state of the entity."""
62  state = self._state_state
63  return None if state.missing_state else state.state
64 
65  @convert_api_error_ha_error
66  async def async_set_native_value(self, value: float) -> None:
67  """Update the current value."""
68  self._client_client.number_command(self._key_key, value)
69 
70 
71 async_setup_entry = partial(
72  platform_async_setup_entry,
73  info_type=NumberInfo,
74  entity_type=EsphomeNumber,
75  state_type=NumberState,
76 )
None _on_static_info_update(self, EntityInfo static_info)
Definition: number.py:39