Move temperature conversions to sensor base class (1/8) (#48261)
* Move temperature conversions to entity base class (1/8) * Update integrations a-c * Leave old temperature conversion until all integrations are migrated * tweak * Use contextlib.suppress * Remove the MeasurableUnitEntity mixin * Address comments, add tests * Fix f-string * Drop deprecation warning from base entity class * Update with _attr-shorthand * Fix rebase mistakes * Fix additional rebase mistakes * Only report temperature conversion once * Fix additional rebase mistakes * Format homeassistant/components/bbox/sensor.py * Fix check for overidden _attr_state * Remove test workarounds from implementation * Remove useless None-check * Tweaks * Migrate new sensors a-c * Update climacell * Push deprecation of temperature conversion forward * Override __repr__ in SensorEntity * Include native_value in SensorEntity attributes * Pylint * Black * Black * Fix rebase mistakes * black * Fix rebase mistakes * Revert changes in august/sensor.py * Revert handling of unit converted restored state * Apply code review suggestion * Fix arlo test
This commit is contained in:
parent
930c1dbe9b
commit
4e07ab1b32
71 changed files with 516 additions and 360 deletions
|
@ -86,9 +86,13 @@ class BloomSkySensor(SensorEntity):
|
|||
self._sensor_name = sensor_name
|
||||
self._attr_name = f"{device['DeviceName']} {sensor_name}"
|
||||
self._attr_unique_id = f"{self._device_id}-{sensor_name}"
|
||||
self._attr_unit_of_measurement = SENSOR_UNITS_IMPERIAL.get(sensor_name, None)
|
||||
self._attr_native_unit_of_measurement = SENSOR_UNITS_IMPERIAL.get(
|
||||
sensor_name, None
|
||||
)
|
||||
if self._bloomsky.is_metric:
|
||||
self._attr_unit_of_measurement = SENSOR_UNITS_METRIC.get(sensor_name, None)
|
||||
self._attr_native_unit_of_measurement = SENSOR_UNITS_METRIC.get(
|
||||
sensor_name, None
|
||||
)
|
||||
|
||||
@property
|
||||
def device_class(self):
|
||||
|
@ -99,6 +103,6 @@ class BloomSkySensor(SensorEntity):
|
|||
"""Request an update from the BloomSky API."""
|
||||
self._bloomsky.refresh_devices()
|
||||
state = self._bloomsky.devices[self._device_id]["Data"][self._sensor_name]
|
||||
self._attr_state = (
|
||||
self._attr_native_value = (
|
||||
f"{state:.2f}" if self._sensor_name in FORMAT_NUMBERS else state
|
||||
)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue