mirror of
https://github.com/esphome/esphome.git
synced 2025-11-18 15:55:46 +00:00
Co-authored-by: Samuel Sieb <samuel@sieb.net> Co-authored-by: Jesse Hills <3060199+jesserockz@users.noreply.github.com>
44 lines
1.1 KiB
Python
44 lines
1.1 KiB
Python
import esphome.codegen as cg
|
|
import esphome.config_validation as cv
|
|
from esphome.components import one_wire, sensor
|
|
from esphome.const import (
|
|
CONF_RESOLUTION,
|
|
DEVICE_CLASS_TEMPERATURE,
|
|
STATE_CLASS_MEASUREMENT,
|
|
UNIT_CELSIUS,
|
|
)
|
|
|
|
dallas_temp_ns = cg.esphome_ns.namespace("dallas_temp")
|
|
|
|
DallasTemperatureSensor = dallas_temp_ns.class_(
|
|
"DallasTemperatureSensor",
|
|
cg.PollingComponent,
|
|
sensor.Sensor,
|
|
one_wire.OneWireDevice,
|
|
)
|
|
|
|
CONFIG_SCHEMA = (
|
|
sensor.sensor_schema(
|
|
DallasTemperatureSensor,
|
|
unit_of_measurement=UNIT_CELSIUS,
|
|
accuracy_decimals=1,
|
|
device_class=DEVICE_CLASS_TEMPERATURE,
|
|
state_class=STATE_CLASS_MEASUREMENT,
|
|
)
|
|
.extend(
|
|
{
|
|
cv.Optional(CONF_RESOLUTION, default=12): cv.int_range(min=9, max=12),
|
|
}
|
|
)
|
|
.extend(one_wire.one_wire_device_schema())
|
|
.extend(cv.polling_component_schema("60s"))
|
|
)
|
|
|
|
|
|
async def to_code(config):
|
|
var = await sensor.new_sensor(config)
|
|
await cg.register_component(var, config)
|
|
await one_wire.register_one_wire_device(var, config)
|
|
|
|
cg.add(var.set_resolution(config[CONF_RESOLUTION]))
|