mirror of
https://github.com/Threnklyn/esphome-dev.git
synced 2026-05-20 04:53:28 +02:00
821c1a8bbd
* making SPI CS optional * CS pin should be declared as optional or required in CONFIG_SCHEMA * changed SPI_DEVICE_SCHEMA to a function, like i2c * added spi_device_schema() to pcd8544, lint fixes * updated max31856 with new spi_device_schema() * cleanup imports Co-authored-by: Ilya Goldberg <iggie@mac.com>
25 lines
1.1 KiB
Python
25 lines
1.1 KiB
Python
import esphome.codegen as cg
|
|
import esphome.config_validation as cv
|
|
from esphome.components import sensor, spi
|
|
from esphome.const import CONF_ID, CONF_REFERENCE_TEMPERATURE, ICON_THERMOMETER, UNIT_CELSIUS
|
|
|
|
max31855_ns = cg.esphome_ns.namespace('max31855')
|
|
MAX31855Sensor = max31855_ns.class_('MAX31855Sensor', sensor.Sensor, cg.PollingComponent,
|
|
spi.SPIDevice)
|
|
|
|
CONFIG_SCHEMA = sensor.sensor_schema(UNIT_CELSIUS, ICON_THERMOMETER, 1).extend({
|
|
cv.GenerateID(): cv.declare_id(MAX31855Sensor),
|
|
cv.Optional(CONF_REFERENCE_TEMPERATURE):
|
|
sensor.sensor_schema(UNIT_CELSIUS, ICON_THERMOMETER, 2),
|
|
}).extend(cv.polling_component_schema('60s')).extend(spi.spi_device_schema())
|
|
|
|
|
|
def to_code(config):
|
|
var = cg.new_Pvariable(config[CONF_ID])
|
|
yield cg.register_component(var, config)
|
|
yield spi.register_spi_device(var, config)
|
|
yield sensor.register_sensor(var, config)
|
|
if CONF_REFERENCE_TEMPERATURE in config:
|
|
tc_ref = yield sensor.new_sensor(config[CONF_REFERENCE_TEMPERATURE])
|
|
cg.add(var.set_reference_sensor(tc_ref))
|