This repository has been archived by the owner on Nov 11, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathsensor.py
79 lines (62 loc) · 2.04 KB
/
sensor.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
"""The Recteq sensor component."""
from .const import (
DOMAIN,
DPS_ACTUAL,
DPS_PROBEA,
DPS_PROBEB,
DPS_TARGET,
)
from homeassistant.components.sensor import DEVICE_CLASS_TEMPERATURE
from homeassistant.const import TEMP_FAHRENHEIT, STATE_UNAVAILABLE
from homeassistant.core import callback
from homeassistant.helpers import entity
async def async_setup_entry(hass, entry, add):
device = hass.data[DOMAIN][entry.entry_id]
add(
[
RecteqSensor(device, DPS_TARGET, 'Target Temperature'),
RecteqSensor(device, DPS_ACTUAL, 'Actual Temperature'),
RecteqSensor(device, DPS_PROBEA, 'Probe A Temperature'),
RecteqSensor(device, DPS_PROBEB, 'Probe B Temperature')
]
)
class RecteqSensor(entity.Entity):
def __init__(self, device, dps, name):
self._device = device
self._dps = dps
self._name = f"{device.name} {name}"
@property
def name(self) -> str:
return self._name
@property
def unique_id(self):
return f"{self._device.device_id}.{self._dps}"
@property
def available(self):
return self._device.available and self._device.is_on
@property
def state(self):
if not self.available:
return STATE_UNAVAILABLE
value = self._device.dps(self._dps);
if value == None or value == 0:
return STATE_UNAVAILABLE
return round(float(self._device.temperature(value)), 1)
@property
def unit_of_measurement(self):
if self._device.force_fahrenheit:
return None
return self._device.temperature_unit
@property
def device_class(self):
return DEVICE_CLASS_TEMPERATURE
@property
def should_poll(self):
return False
async def async_update(self):
await self._device.async_request_refresh()
async def async_added_to_hass(self):
self.async_on_remove(self._device.async_add_listener(self._update_callback))
@callback
def _update_callback(self):
self.async_write_ha_state()