From a605b172ed7d301c5ab68f412918db4f1e350b2a Mon Sep 17 00:00:00 2001 From: Ben Vezzani Date: Thu, 26 Oct 2023 22:53:34 -0400 Subject: [PATCH] Adds support for Big+Quiet Carbon Dioxide sensors (#78) --- custom_components/dyson_local/manifest.json | 2 +- custom_components/dyson_local/sensor.py | 30 ++++++++++++++++++- .../libdyson/dyson_purifier_big_quiet.py | 5 ++++ 3 files changed, 35 insertions(+), 2 deletions(-) diff --git a/custom_components/dyson_local/manifest.json b/custom_components/dyson_local/manifest.json index 035aa05..970bd0e 100644 --- a/custom_components/dyson_local/manifest.json +++ b/custom_components/dyson_local/manifest.json @@ -7,5 +7,5 @@ "documentation": "https://github.com/libdyson-wg/ha-dyson", "iot_class": "local_push", "issue_tracker": "https://github.com/libdyson-wg/ha-dyson/issues", - "version": "1.2.0" + "version": "1.3.0" } diff --git a/custom_components/dyson_local/sensor.py b/custom_components/dyson_local/sensor.py index 8e16e76..84ee04e 100644 --- a/custom_components/dyson_local/sensor.py +++ b/custom_components/dyson_local/sensor.py @@ -8,6 +8,7 @@ DysonDevice, DysonPureCoolLink, DysonPurifierHumidifyCool, + DysonBigQuiet, ) from .vendor.libdyson.const import MessageType @@ -18,6 +19,7 @@ from homeassistant.const import ( CONCENTRATION_MICROGRAMS_PER_CUBIC_METER, CONCENTRATION_MILLIGRAMS_PER_CUBIC_METER, + CONCENTRATION_PARTS_PER_MILLION, CONF_NAME, PERCENTAGE, TEMP_CELSIUS, @@ -58,7 +60,10 @@ async def async_setup_entry( DysonParticulatesSensor(coordinator, device, name), ] ) - else: # DysonPureCool or DysonPurifierHumidifyCool + elif isinstance(device, DysonBigQuiet): + if hasattr(device, "carbon_dioxide") and device.carbon_dioxide is not None: + entities.append(DysonCarbonDioxideSensor(coordinator, device, name)) + else: entities.extend( [ DysonPM25Sensor(coordinator, device, name), @@ -386,3 +391,26 @@ def native_value(self) -> Optional[float]: def available(self) -> bool: """Return available only if device not in off, init or failed states.""" return isinstance(self._device.formaldehyde, (int, float)) + + +class DysonCarbonDioxideSensor(DysonSensorEnvironmental): + """Dyson sensor for Carbon Dioxide.""" + + _SENSOR_TYPE = "c02" + _SENSOR_NAME = "Carbon Dioxide" + + _attr_device_class = SensorDeviceClass.CO2 + _attr_native_unit_of_measurement = CONCENTRATION_PARTS_PER_MILLION + _attr_state_class = SensorStateClass.MEASUREMENT + + @property + def native_value(self) -> Optional[float]: + """Return the state of the sensor.""" + if (value := self._device.carbon_dioxide) >= 0: + return value + return None + + @property + def available(self) -> bool: + """Return available only if device not in off, init or failed states.""" + return isinstance(self._device.carbon_dioxide, (int, float)) diff --git a/custom_components/dyson_local/vendor/libdyson/dyson_purifier_big_quiet.py b/custom_components/dyson_local/vendor/libdyson/dyson_purifier_big_quiet.py index df86af8..4d9c889 100644 --- a/custom_components/dyson_local/vendor/libdyson/dyson_purifier_big_quiet.py +++ b/custom_components/dyson_local/vendor/libdyson/dyson_purifier_big_quiet.py @@ -62,6 +62,11 @@ def nitrogen_dioxide(self) -> float: """Return the index value for nitrogen.""" return self._get_environmental_field_value("noxl", divisor=10) + @property + def carbon_dioxide(self) -> Optional[int]: + """Return the PPM of carbon dioxide""" + return self._get_environmental_field_value("co2r") + def turn_on(self) -> None: """Turn on the device.""" self._set_configuration(fpwr="ON")