mirror of
https://github.com/home-assistant/core.git
synced 2025-07-14 16:57:10 +00:00
Airvisual Pro Outside Station Support (#96618)
* Airvisual Pro Outside Station Support * pr feedback * formatting, language * Update homeassistant/components/airvisual_pro/strings.json Co-authored-by: Joost Lekkerkerker <joostlek@outlook.com> * fix assertion on airvisual test --------- Co-authored-by: Joost Lekkerkerker <joostlek@outlook.com>
This commit is contained in:
parent
194d4e4f66
commit
33d2dd3797
@ -60,6 +60,10 @@ async def async_setup_entry(hass: HomeAssistant, entry: ConfigEntry) -> bool:
|
|||||||
"""Get data from the device."""
|
"""Get data from the device."""
|
||||||
try:
|
try:
|
||||||
data = await node.async_get_latest_measurements()
|
data = await node.async_get_latest_measurements()
|
||||||
|
data["history"] = {}
|
||||||
|
if data["settings"].get("follow_mode") == "device":
|
||||||
|
history = await node.async_get_history(include_trends=False)
|
||||||
|
data["history"] = history.get("measurements", [])[-1]
|
||||||
except InvalidAuthenticationError as err:
|
except InvalidAuthenticationError as err:
|
||||||
raise ConfigEntryAuthFailed("Invalid Samba password") from err
|
raise ConfigEntryAuthFailed("Invalid Samba password") from err
|
||||||
except NodeConnectionError as err:
|
except NodeConnectionError as err:
|
||||||
|
@ -30,7 +30,9 @@ from .const import DOMAIN
|
|||||||
class AirVisualProMeasurementKeyMixin:
|
class AirVisualProMeasurementKeyMixin:
|
||||||
"""Define an entity description mixin to include a measurement key."""
|
"""Define an entity description mixin to include a measurement key."""
|
||||||
|
|
||||||
value_fn: Callable[[dict[str, Any], dict[str, Any], dict[str, Any]], float | int]
|
value_fn: Callable[
|
||||||
|
[dict[str, Any], dict[str, Any], dict[str, Any], dict[str, Any]], float | int
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
@ -45,29 +47,42 @@ SENSOR_DESCRIPTIONS = (
|
|||||||
key="air_quality_index",
|
key="air_quality_index",
|
||||||
device_class=SensorDeviceClass.AQI,
|
device_class=SensorDeviceClass.AQI,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
value_fn=lambda settings, status, measurements: measurements[
|
value_fn=lambda settings, status, measurements, history: measurements[
|
||||||
async_get_aqi_locale(settings)
|
async_get_aqi_locale(settings)
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
AirVisualProMeasurementDescription(
|
||||||
|
key="outdoor_air_quality_index",
|
||||||
|
device_class=SensorDeviceClass.AQI,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
value_fn=lambda settings, status, measurements, history: int(
|
||||||
|
history.get(
|
||||||
|
f'Outdoor {"AQI(US)" if settings["is_aqi_usa"] else "AQI(CN)"}', -1
|
||||||
|
)
|
||||||
|
),
|
||||||
|
translation_key="outdoor_air_quality_index",
|
||||||
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="battery_level",
|
key="battery_level",
|
||||||
device_class=SensorDeviceClass.BATTERY,
|
device_class=SensorDeviceClass.BATTERY,
|
||||||
entity_category=EntityCategory.DIAGNOSTIC,
|
entity_category=EntityCategory.DIAGNOSTIC,
|
||||||
native_unit_of_measurement=PERCENTAGE,
|
native_unit_of_measurement=PERCENTAGE,
|
||||||
value_fn=lambda settings, status, measurements: status["battery"],
|
value_fn=lambda settings, status, measurements, history: status["battery"],
|
||||||
),
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="carbon_dioxide",
|
key="carbon_dioxide",
|
||||||
device_class=SensorDeviceClass.CO2,
|
device_class=SensorDeviceClass.CO2,
|
||||||
native_unit_of_measurement=CONCENTRATION_PARTS_PER_MILLION,
|
native_unit_of_measurement=CONCENTRATION_PARTS_PER_MILLION,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
value_fn=lambda settings, status, measurements: measurements["co2"],
|
value_fn=lambda settings, status, measurements, history: measurements["co2"],
|
||||||
),
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="humidity",
|
key="humidity",
|
||||||
device_class=SensorDeviceClass.HUMIDITY,
|
device_class=SensorDeviceClass.HUMIDITY,
|
||||||
native_unit_of_measurement=PERCENTAGE,
|
native_unit_of_measurement=PERCENTAGE,
|
||||||
value_fn=lambda settings, status, measurements: measurements["humidity"],
|
value_fn=lambda settings, status, measurements, history: measurements[
|
||||||
|
"humidity"
|
||||||
|
],
|
||||||
),
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="particulate_matter_0_1",
|
key="particulate_matter_0_1",
|
||||||
@ -75,7 +90,7 @@ SENSOR_DESCRIPTIONS = (
|
|||||||
device_class=SensorDeviceClass.PM1,
|
device_class=SensorDeviceClass.PM1,
|
||||||
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
value_fn=lambda settings, status, measurements: measurements["pm0_1"],
|
value_fn=lambda settings, status, measurements, history: measurements["pm0_1"],
|
||||||
),
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="particulate_matter_1_0",
|
key="particulate_matter_1_0",
|
||||||
@ -83,28 +98,30 @@ SENSOR_DESCRIPTIONS = (
|
|||||||
device_class=SensorDeviceClass.PM10,
|
device_class=SensorDeviceClass.PM10,
|
||||||
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
value_fn=lambda settings, status, measurements: measurements["pm1_0"],
|
value_fn=lambda settings, status, measurements, history: measurements["pm1_0"],
|
||||||
),
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="particulate_matter_2_5",
|
key="particulate_matter_2_5",
|
||||||
device_class=SensorDeviceClass.PM25,
|
device_class=SensorDeviceClass.PM25,
|
||||||
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
value_fn=lambda settings, status, measurements: measurements["pm2_5"],
|
value_fn=lambda settings, status, measurements, history: measurements["pm2_5"],
|
||||||
),
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="temperature",
|
key="temperature",
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
value_fn=lambda settings, status, measurements: measurements["temperature_C"],
|
value_fn=lambda settings, status, measurements, history: measurements[
|
||||||
|
"temperature_C"
|
||||||
|
],
|
||||||
),
|
),
|
||||||
AirVisualProMeasurementDescription(
|
AirVisualProMeasurementDescription(
|
||||||
key="voc",
|
key="voc",
|
||||||
device_class=SensorDeviceClass.VOLATILE_ORGANIC_COMPOUNDS,
|
device_class=SensorDeviceClass.VOLATILE_ORGANIC_COMPOUNDS,
|
||||||
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
value_fn=lambda settings, status, measurements: measurements["voc"],
|
value_fn=lambda settings, status, measurements, history: measurements["voc"],
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -143,4 +160,5 @@ class AirVisualProSensor(AirVisualProEntity, SensorEntity):
|
|||||||
self.coordinator.data["settings"],
|
self.coordinator.data["settings"],
|
||||||
self.coordinator.data["status"],
|
self.coordinator.data["status"],
|
||||||
self.coordinator.data["measurements"],
|
self.coordinator.data["measurements"],
|
||||||
|
self.coordinator.data["history"],
|
||||||
)
|
)
|
||||||
|
@ -24,5 +24,12 @@
|
|||||||
"already_configured": "[%key:common::config_flow::abort::already_configured_device%]",
|
"already_configured": "[%key:common::config_flow::abort::already_configured_device%]",
|
||||||
"reauth_successful": "[%key:common::config_flow::abort::reauth_successful%]"
|
"reauth_successful": "[%key:common::config_flow::abort::reauth_successful%]"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"entity": {
|
||||||
|
"sensor": {
|
||||||
|
"outdoor_air_quality_index": {
|
||||||
|
"name": "Outdoor air quality index"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ async def test_entry_diagnostics(
|
|||||||
"time": "16:00:44",
|
"time": "16:00:44",
|
||||||
"timestamp": "1665072044",
|
"timestamp": "1665072044",
|
||||||
},
|
},
|
||||||
|
"history": {},
|
||||||
"measurements": {
|
"measurements": {
|
||||||
"co2": "472",
|
"co2": "472",
|
||||||
"humidity": "57",
|
"humidity": "57",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user