mirror of
https://github.com/esphome/esphome.git
synced 2025-02-21 04:18:16 +00:00
* Added initial bme68x component * Initialize all child sensors to nullptr This was added to all other sensors in #3808 * Update BSEC2 and BME68x Libraries Current versions from Bosch Sensortec * Add myself to codeowners for bme68x_bsec * Move constants to const.py, according to ci-custom checks Move constants to const.py, according to ci-custom checks * Update library dependencies We'll stick with 1.4.2200 for now. 1.4.2200 is not on platform.io registry, use tag instead. Update to 1.5.2400 needs some work due to multi instance support. * Update BSEC2 to 1.6.2400 * Add consts to bme680x_bsec Enable inclusion with external_components * Update device class for pressure * Update to use multisensor API * Tidy up some constants * Add tests * Remove scd30 changes * Import CONF_SAMPLE_RATE * Pull BSEC config blob from repo based on config * Rename component to `bme68x_bsec_i2c` * Fix tests + codeowners * Cleanup for review * Rename using `bsec2` * Apply suggestions from code review Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com> * Download file during validation stage, instead * Make `dump_config()` only dump stuff * Compile safely without sensor and text sensor headers * Use `intf_ptr` * Save state if measuring static IAQ, too * Update CODEOWNERS * Simplify esphome/components/bme68x_bsec2_i2c/__init__.py Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com> * Remove extraneous colon & imports * Track & save the maximum accuracy value * Polish up accuracy sensor handling * Log static sensor, update `defines.h` * Walruses make it better * Add some logging of setup failures * Update esphome/components/bme68x_bsec2_i2c/bme68x_bsec2_i2c.cpp Co-authored-by: Trevor North <trevor@freedisc.co.uk> * Break out some things * Update CODEOWNERS * Update CODEOWNERS take 2 * Use `add_extra` in base schema * Another walrus in the sensor Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com> --------- Co-authored-by: Keith Burzinski <kbx81x@gmail.com> Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com> Co-authored-by: Trevor North <trevor@freedisc.co.uk>
131 lines
4.2 KiB
Python
131 lines
4.2 KiB
Python
import esphome.codegen as cg
|
|
from esphome.components import sensor
|
|
import esphome.config_validation as cv
|
|
from esphome.const import (
|
|
CONF_GAS_RESISTANCE,
|
|
CONF_HUMIDITY,
|
|
CONF_IAQ_ACCURACY,
|
|
CONF_PRESSURE,
|
|
CONF_SAMPLE_RATE,
|
|
CONF_TEMPERATURE,
|
|
DEVICE_CLASS_ATMOSPHERIC_PRESSURE,
|
|
DEVICE_CLASS_HUMIDITY,
|
|
DEVICE_CLASS_TEMPERATURE,
|
|
ICON_GAS_CYLINDER,
|
|
ICON_GAUGE,
|
|
ICON_THERMOMETER,
|
|
ICON_WATER_PERCENT,
|
|
STATE_CLASS_MEASUREMENT,
|
|
UNIT_CELSIUS,
|
|
UNIT_HECTOPASCAL,
|
|
UNIT_OHM,
|
|
UNIT_PARTS_PER_MILLION,
|
|
UNIT_PERCENT,
|
|
)
|
|
|
|
from . import CONF_BME68X_BSEC2_ID, SAMPLE_RATE_OPTIONS, BME68xBSEC2Component
|
|
|
|
DEPENDENCIES = ["bme68x_bsec2"]
|
|
|
|
CONF_BREATH_VOC_EQUIVALENT = "breath_voc_equivalent"
|
|
CONF_CO2_EQUIVALENT = "co2_equivalent"
|
|
CONF_IAQ = "iaq"
|
|
CONF_IAQ_STATIC = "iaq_static"
|
|
ICON_ACCURACY = "mdi:checkbox-marked-circle-outline"
|
|
ICON_TEST_TUBE = "mdi:test-tube"
|
|
UNIT_IAQ = "IAQ"
|
|
|
|
TYPES = [
|
|
CONF_TEMPERATURE,
|
|
CONF_PRESSURE,
|
|
CONF_HUMIDITY,
|
|
CONF_GAS_RESISTANCE,
|
|
CONF_IAQ,
|
|
CONF_IAQ_STATIC,
|
|
CONF_IAQ_ACCURACY,
|
|
CONF_CO2_EQUIVALENT,
|
|
CONF_BREATH_VOC_EQUIVALENT,
|
|
]
|
|
|
|
CONFIG_SCHEMA = cv.Schema(
|
|
{
|
|
cv.GenerateID(CONF_BME68X_BSEC2_ID): cv.use_id(BME68xBSEC2Component),
|
|
cv.Optional(CONF_TEMPERATURE): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_CELSIUS,
|
|
icon=ICON_THERMOMETER,
|
|
accuracy_decimals=1,
|
|
device_class=DEVICE_CLASS_TEMPERATURE,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
).extend(
|
|
{cv.Optional(CONF_SAMPLE_RATE): cv.enum(SAMPLE_RATE_OPTIONS, upper=True)}
|
|
),
|
|
cv.Optional(CONF_PRESSURE): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_HECTOPASCAL,
|
|
icon=ICON_GAUGE,
|
|
accuracy_decimals=1,
|
|
device_class=DEVICE_CLASS_ATMOSPHERIC_PRESSURE,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
).extend(
|
|
{cv.Optional(CONF_SAMPLE_RATE): cv.enum(SAMPLE_RATE_OPTIONS, upper=True)}
|
|
),
|
|
cv.Optional(CONF_HUMIDITY): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_PERCENT,
|
|
icon=ICON_WATER_PERCENT,
|
|
accuracy_decimals=1,
|
|
device_class=DEVICE_CLASS_HUMIDITY,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
).extend(
|
|
{cv.Optional(CONF_SAMPLE_RATE): cv.enum(SAMPLE_RATE_OPTIONS, upper=True)}
|
|
),
|
|
cv.Optional(CONF_GAS_RESISTANCE): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_OHM,
|
|
icon=ICON_GAS_CYLINDER,
|
|
accuracy_decimals=0,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
),
|
|
cv.Optional(CONF_IAQ): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_IAQ,
|
|
icon=ICON_GAUGE,
|
|
accuracy_decimals=0,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
),
|
|
cv.Optional(CONF_IAQ_STATIC): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_IAQ,
|
|
icon=ICON_GAUGE,
|
|
accuracy_decimals=0,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
),
|
|
cv.Optional(CONF_IAQ_ACCURACY): sensor.sensor_schema(
|
|
icon=ICON_ACCURACY,
|
|
accuracy_decimals=0,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
),
|
|
cv.Optional(CONF_CO2_EQUIVALENT): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_PARTS_PER_MILLION,
|
|
icon=ICON_TEST_TUBE,
|
|
accuracy_decimals=1,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
),
|
|
cv.Optional(CONF_BREATH_VOC_EQUIVALENT): sensor.sensor_schema(
|
|
unit_of_measurement=UNIT_PARTS_PER_MILLION,
|
|
icon=ICON_TEST_TUBE,
|
|
accuracy_decimals=1,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
),
|
|
}
|
|
)
|
|
|
|
|
|
async def setup_conf(config, key, hub):
|
|
if conf := config.get(key):
|
|
sens = await sensor.new_sensor(conf)
|
|
cg.add(getattr(hub, f"set_{key}_sensor")(sens))
|
|
if sample_rate := conf.get(CONF_SAMPLE_RATE):
|
|
cg.add(getattr(hub, f"set_{key}_sample_rate")(sample_rate))
|
|
|
|
|
|
async def to_code(config):
|
|
hub = await cg.get_variable(config[CONF_BME68X_BSEC2_ID])
|
|
for key in TYPES:
|
|
await setup_conf(config, key, hub)
|