diff --git a/custom_components/dyson_local/sensor.py b/custom_components/dyson_local/sensor.py index 60b4119..cb96e99 100644 --- a/custom_components/dyson_local/sensor.py +++ b/custom_components/dyson_local/sensor.py @@ -12,7 +12,7 @@ ) from libdyson.const import MessageType -from homeassistant.components.sensor import SensorDeviceClass, SensorEntity +from homeassistant.components.sensor import SensorDeviceClass, SensorStateClass, SensorEntity from homeassistant.config_entries import ConfigEntry from homeassistant.const import ( CONCENTRATION_MICROGRAMS_PER_CUBIC_METER, @@ -119,7 +119,7 @@ class DysonBatterySensor(DysonSensor): _SENSOR_TYPE = "battery_level" _SENSOR_NAME = "Battery Level" _attr_device_class = SensorDeviceClass.BATTERY - _attr_unit_of_measurement = PERCENTAGE + _attr_native_unit_of_measurement = PERCENTAGE @property def state(self) -> int: @@ -134,7 +134,7 @@ class DysonFilterLifeSensor(DysonSensor): _SENSOR_NAME = "Filter Life" _attr_entity_category = EntityCategory.DIAGNOSTIC _attr_icon = "mdi:filter-outline" - _attr_unit_of_measurement = TIME_HOURS + _attr_native_unit_of_measurement = TIME_HOURS @property def state(self) -> int: @@ -149,7 +149,7 @@ class DysonCarbonFilterLifeSensor(DysonSensor): _SENSOR_NAME = "Carbon Filter Life" _attr_entity_category = EntityCategory.DIAGNOSTIC _attr_icon = "mdi:filter-outline" - _attr_unit_of_measurement = PERCENTAGE + _attr_native_unit_of_measurement = PERCENTAGE @property def state(self) -> int: @@ -164,7 +164,7 @@ class DysonHEPAFilterLifeSensor(DysonSensor): _SENSOR_NAME = "HEPA Filter Life" _attr_entity_category = EntityCategory.DIAGNOSTIC _attr_icon = "mdi:filter-outline" - _attr_unit_of_measurement = PERCENTAGE + _attr_native_unit_of_measurement = PERCENTAGE @property def state(self) -> int: @@ -179,7 +179,7 @@ class DysonCombinedFilterLifeSensor(DysonSensor): _SENSOR_NAME = "Filter Life" _attr_entity_category = EntityCategory.DIAGNOSTIC _attr_icon = "mdi:filter-outline" - _attr_unit_of_measurement = PERCENTAGE + _attr_native_unit_of_measurement = PERCENTAGE @property def state(self) -> int: @@ -194,7 +194,7 @@ class DysonNextDeepCleanSensor(DysonSensor): _SENSOR_NAME = "Next Deep Clean" _attr_entity_category = EntityCategory.DIAGNOSTIC _attr_icon = "mdi:filter-outline" - _attr_unit_of_measurement = TIME_HOURS + _attr_native_unit_of_measurement = TIME_HOURS @property def state(self) -> int: @@ -208,7 +208,8 @@ class DysonHumiditySensor(DysonSensorEnvironmental): _SENSOR_TYPE = "humidity" _SENSOR_NAME = "Humidity" _attr_device_class = SensorDeviceClass.HUMIDITY - _attr_unit_of_measurement = PERCENTAGE + _attr_native_unit_of_measurement = PERCENTAGE + _attr_state_class = SensorStateClass.MEASUREMENT @environmental_property def state(self) -> int: @@ -222,7 +223,8 @@ class DysonTemperatureSensor(DysonSensorEnvironmental): _SENSOR_TYPE = "temperature" _SENSOR_NAME = "Temperature" _attr_device_class = SensorDeviceClass.TEMPERATURE - native_unit_of_measurement = TEMP_CELSIUS + _attr_native_unit_of_measurement = TEMP_CELSIUS + _attr_state_class = SensorStateClass.MEASUREMENT @environmental_property def temperature_kelvin(self) -> int: @@ -250,7 +252,8 @@ class DysonPM25Sensor(DysonSensorEnvironmental): _SENSOR_TYPE = "pm25" _SENSOR_NAME = "PM 2.5" _attr_device_class = SensorDeviceClass.PM25 - _attr_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_native_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_state_class = SensorStateClass.MEASUREMENT @environmental_property def state(self) -> int: @@ -264,7 +267,8 @@ class DysonPM10Sensor(DysonSensorEnvironmental): _SENSOR_TYPE = "pm10" _SENSOR_NAME = "PM 10" _attr_device_class = SensorDeviceClass.PM10 - _attr_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_native_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_state_class = SensorStateClass.MEASUREMENT @environmental_property def state(self) -> int: @@ -278,7 +282,8 @@ class DysonParticulatesSensor(DysonSensorEnvironmental): _SENSOR_TYPE = "pm1" _SENSOR_NAME = "Particulates" _attr_device_class = SensorDeviceClass.PM1 - _attr_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_native_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_state_class = SensorStateClass.MEASUREMENT @environmental_property def state(self) -> int: @@ -292,7 +297,8 @@ class DysonVOCSensor(DysonSensorEnvironmental): _SENSOR_TYPE = "voc" _SENSOR_NAME = "Volatile Organic Compounds" _attr_device_class = SensorDeviceClass.VOLATILE_ORGANIC_COMPOUNDS - _attr_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_native_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_state_class = SensorStateClass.MEASUREMENT @environmental_property def state(self) -> int: @@ -306,7 +312,8 @@ class DysonNO2Sensor(DysonSensorEnvironmental): _SENSOR_TYPE = "no2" _SENSOR_NAME = "Nitrogen Dioxide" _attr_device_class = SensorDeviceClass.NITROGEN_DIOXIDE - _attr_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_native_unit_of_measurement = CONCENTRATION_MICROGRAMS_PER_CUBIC_METER + _attr_state_class = SensorStateClass.MEASUREMENT @environmental_property def state(self) -> int: