mirror of
https://github.com/esphome/esphome.git
synced 2025-01-18 18:35:59 +01:00
Binary Sensor codegen tidyup (#3217)
This commit is contained in:
parent
3b8bb09ae3
commit
7a242bb4ed
38 changed files with 196 additions and 222 deletions
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_DIRECTION, CONF_DEVICE_CLASS, DEVICE_CLASS_MOVING
|
from esphome.const import CONF_DIRECTION, DEVICE_CLASS_MOVING
|
||||||
from . import APDS9960, CONF_APDS9960_ID
|
from . import APDS9960, CONF_APDS9960_ID
|
||||||
|
|
||||||
DEPENDENCIES = ["apds9960"]
|
DEPENDENCIES = ["apds9960"]
|
||||||
|
@ -13,13 +13,12 @@ DIRECTIONS = {
|
||||||
"RIGHT": "set_right_direction",
|
"RIGHT": "set_right_direction",
|
||||||
}
|
}
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(
|
||||||
|
device_class=DEVICE_CLASS_MOVING
|
||||||
|
).extend(
|
||||||
{
|
{
|
||||||
cv.Required(CONF_DIRECTION): cv.one_of(*DIRECTIONS, upper=True),
|
|
||||||
cv.GenerateID(CONF_APDS9960_ID): cv.use_id(APDS9960),
|
cv.GenerateID(CONF_APDS9960_ID): cv.use_id(APDS9960),
|
||||||
cv.Optional(
|
cv.Required(CONF_DIRECTION): cv.one_of(*DIRECTIONS, upper=True),
|
||||||
CONF_DEVICE_CLASS, default=DEVICE_CLASS_MOVING
|
|
||||||
): binary_sensor.device_class,
|
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ from . import AS3935, CONF_AS3935_ID
|
||||||
|
|
||||||
DEPENDENCIES = ["as3935"]
|
DEPENDENCIES = ["as3935"]
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema().extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(CONF_AS3935_ID): cv.use_id(AS3935),
|
cv.GenerateID(CONF_AS3935_ID): cv.use_id(AS3935),
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
|
from esphome.cpp_generator import MockObjClass
|
||||||
from esphome.cpp_helpers import setup_entity
|
from esphome.cpp_helpers import setup_entity
|
||||||
from esphome import automation, core
|
from esphome import automation, core
|
||||||
from esphome.automation import Condition, maybe_simple_id
|
from esphome.automation import Condition, maybe_simple_id
|
||||||
|
@ -7,7 +8,9 @@ from esphome.components import mqtt
|
||||||
from esphome.const import (
|
from esphome.const import (
|
||||||
CONF_DELAY,
|
CONF_DELAY,
|
||||||
CONF_DEVICE_CLASS,
|
CONF_DEVICE_CLASS,
|
||||||
|
CONF_ENTITY_CATEGORY,
|
||||||
CONF_FILTERS,
|
CONF_FILTERS,
|
||||||
|
CONF_ICON,
|
||||||
CONF_ID,
|
CONF_ID,
|
||||||
CONF_INVALID_COOLDOWN,
|
CONF_INVALID_COOLDOWN,
|
||||||
CONF_INVERTED,
|
CONF_INVERTED,
|
||||||
|
@ -314,7 +317,7 @@ def validate_multi_click_timing(value):
|
||||||
return timings
|
return timings
|
||||||
|
|
||||||
|
|
||||||
device_class = cv.one_of(*DEVICE_CLASSES, lower=True, space="_")
|
validate_device_class = cv.one_of(*DEVICE_CLASSES, lower=True, space="_")
|
||||||
|
|
||||||
|
|
||||||
BINARY_SENSOR_SCHEMA = cv.ENTITY_BASE_SCHEMA.extend(cv.MQTT_COMPONENT_SCHEMA).extend(
|
BINARY_SENSOR_SCHEMA = cv.ENTITY_BASE_SCHEMA.extend(cv.MQTT_COMPONENT_SCHEMA).extend(
|
||||||
|
@ -323,7 +326,7 @@ BINARY_SENSOR_SCHEMA = cv.ENTITY_BASE_SCHEMA.extend(cv.MQTT_COMPONENT_SCHEMA).ex
|
||||||
cv.OnlyWith(CONF_MQTT_ID, "mqtt"): cv.declare_id(
|
cv.OnlyWith(CONF_MQTT_ID, "mqtt"): cv.declare_id(
|
||||||
mqtt.MQTTBinarySensorComponent
|
mqtt.MQTTBinarySensorComponent
|
||||||
),
|
),
|
||||||
cv.Optional(CONF_DEVICE_CLASS): device_class,
|
cv.Optional(CONF_DEVICE_CLASS): validate_device_class,
|
||||||
cv.Optional(CONF_FILTERS): validate_filters,
|
cv.Optional(CONF_FILTERS): validate_filters,
|
||||||
cv.Optional(CONF_ON_PRESS): automation.validate_automation(
|
cv.Optional(CONF_ON_PRESS): automation.validate_automation(
|
||||||
{
|
{
|
||||||
|
@ -376,6 +379,39 @@ BINARY_SENSOR_SCHEMA = cv.ENTITY_BASE_SCHEMA.extend(cv.MQTT_COMPONENT_SCHEMA).ex
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
_UNDEF = object()
|
||||||
|
|
||||||
|
|
||||||
|
def binary_sensor_schema(
|
||||||
|
class_: MockObjClass = _UNDEF,
|
||||||
|
*,
|
||||||
|
icon: str = _UNDEF,
|
||||||
|
entity_category: str = _UNDEF,
|
||||||
|
device_class: str = _UNDEF,
|
||||||
|
) -> cv.Schema:
|
||||||
|
schema = BINARY_SENSOR_SCHEMA
|
||||||
|
if class_ is not _UNDEF:
|
||||||
|
schema = schema.extend({cv.GenerateID(): cv.declare_id(class_)})
|
||||||
|
if icon is not _UNDEF:
|
||||||
|
schema = schema.extend({cv.Optional(CONF_ICON, default=icon): cv.icon})
|
||||||
|
if entity_category is not _UNDEF:
|
||||||
|
schema = schema.extend(
|
||||||
|
{
|
||||||
|
cv.Optional(
|
||||||
|
CONF_ENTITY_CATEGORY, default=entity_category
|
||||||
|
): cv.entity_category
|
||||||
|
}
|
||||||
|
)
|
||||||
|
if device_class is not _UNDEF:
|
||||||
|
schema = schema.extend(
|
||||||
|
{
|
||||||
|
cv.Optional(
|
||||||
|
CONF_DEVICE_CLASS, default=device_class
|
||||||
|
): validate_device_class
|
||||||
|
}
|
||||||
|
)
|
||||||
|
return schema
|
||||||
|
|
||||||
|
|
||||||
async def setup_binary_sensor_core_(var, config):
|
async def setup_binary_sensor_core_(var, config):
|
||||||
await setup_entity(var, config)
|
await setup_entity(var, config)
|
||||||
|
|
|
@ -7,7 +7,6 @@ from esphome.const import (
|
||||||
CONF_IBEACON_MAJOR,
|
CONF_IBEACON_MAJOR,
|
||||||
CONF_IBEACON_MINOR,
|
CONF_IBEACON_MINOR,
|
||||||
CONF_IBEACON_UUID,
|
CONF_IBEACON_UUID,
|
||||||
CONF_ID,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
DEPENDENCIES = ["esp32_ble_tracker"]
|
DEPENDENCIES = ["esp32_ble_tracker"]
|
||||||
|
@ -30,9 +29,9 @@ def _validate(config):
|
||||||
|
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(BLEPresenceDevice)
|
||||||
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(BLEPresenceDevice),
|
|
||||||
cv.Optional(CONF_MAC_ADDRESS): cv.mac_address,
|
cv.Optional(CONF_MAC_ADDRESS): cv.mac_address,
|
||||||
cv.Optional(CONF_SERVICE_UUID): esp32_ble_tracker.bt_uuid,
|
cv.Optional(CONF_SERVICE_UUID): esp32_ble_tracker.bt_uuid,
|
||||||
cv.Optional(CONF_IBEACON_MAJOR): cv.uint16_t,
|
cv.Optional(CONF_IBEACON_MAJOR): cv.uint16_t,
|
||||||
|
@ -48,10 +47,9 @@ CONFIG_SCHEMA = cv.All(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await esp32_ble_tracker.register_ble_device(var, config)
|
await esp32_ble_tracker.register_ble_device(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
if CONF_MAC_ADDRESS in config:
|
if CONF_MAC_ADDRESS in config:
|
||||||
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
||||||
|
|
|
@ -13,7 +13,7 @@ BLEScanner = ble_scanner_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
text_sensor.text_sensor_schema(klass=BLEScanner)
|
text_sensor.text_sensor_schema(BLEScanner)
|
||||||
.extend(esp32_ble_tracker.ESP_BLE_DEVICE_SCHEMA)
|
.extend(esp32_ble_tracker.ESP_BLE_DEVICE_SCHEMA)
|
||||||
.extend(cv.COMPONENT_SCHEMA)
|
.extend(cv.COMPONENT_SCHEMA)
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,15 +1,14 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_CHANNEL, CONF_ID
|
from esphome.const import CONF_CHANNEL
|
||||||
from . import cap1188_ns, CAP1188Component, CONF_CAP1188_ID
|
from . import cap1188_ns, CAP1188Component, CONF_CAP1188_ID
|
||||||
|
|
||||||
DEPENDENCIES = ["cap1188"]
|
DEPENDENCIES = ["cap1188"]
|
||||||
CAP1188Channel = cap1188_ns.class_("CAP1188Channel", binary_sensor.BinarySensor)
|
CAP1188Channel = cap1188_ns.class_("CAP1188Channel", binary_sensor.BinarySensor)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(CAP1188Channel).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(CAP1188Channel),
|
|
||||||
cv.GenerateID(CONF_CAP1188_ID): cv.use_id(CAP1188Component),
|
cv.GenerateID(CONF_CAP1188_ID): cv.use_id(CAP1188Component),
|
||||||
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=7),
|
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=7),
|
||||||
}
|
}
|
||||||
|
@ -17,8 +16,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
hub = await cg.get_variable(config[CONF_CAP1188_ID])
|
hub = await cg.get_variable(config[CONF_CAP1188_ID])
|
||||||
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,7 @@ CONFIG_SCHEMA = cv.Schema(
|
||||||
cv.GenerateID(): cv.declare_id(CustomBinarySensorConstructor),
|
cv.GenerateID(): cv.declare_id(CustomBinarySensorConstructor),
|
||||||
cv.Required(CONF_LAMBDA): cv.returning_lambda,
|
cv.Required(CONF_LAMBDA): cv.returning_lambda,
|
||||||
cv.Required(CONF_BINARY_SENSORS): cv.ensure_list(
|
cv.Required(CONF_BINARY_SENSORS): cv.ensure_list(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA
|
binary_sensor.binary_sensor_schema()
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_ID
|
|
||||||
from . import DalyBmsComponent, CONF_BMS_DALY_ID
|
from . import DalyBmsComponent, CONF_BMS_DALY_ID
|
||||||
|
|
||||||
CONF_CHARGING_MOS_ENABLED = "charging_mos_enabled"
|
CONF_CHARGING_MOS_ENABLED = "charging_mos_enabled"
|
||||||
|
@ -18,18 +17,10 @@ CONFIG_SCHEMA = cv.All(
|
||||||
cv.GenerateID(CONF_BMS_DALY_ID): cv.use_id(DalyBmsComponent),
|
cv.GenerateID(CONF_BMS_DALY_ID): cv.use_id(DalyBmsComponent),
|
||||||
cv.Optional(
|
cv.Optional(
|
||||||
CONF_CHARGING_MOS_ENABLED
|
CONF_CHARGING_MOS_ENABLED
|
||||||
): binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
): binary_sensor.binary_sensor_schema(),
|
||||||
{
|
|
||||||
cv.GenerateID(): cv.declare_id(binary_sensor.BinarySensor),
|
|
||||||
}
|
|
||||||
),
|
|
||||||
cv.Optional(
|
cv.Optional(
|
||||||
CONF_DISCHARGING_MOS_ENABLED
|
CONF_DISCHARGING_MOS_ENABLED
|
||||||
): binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
): binary_sensor.binary_sensor_schema(),
|
||||||
{
|
|
||||||
cv.GenerateID(): cv.declare_id(binary_sensor.BinarySensor),
|
|
||||||
}
|
|
||||||
),
|
|
||||||
}
|
}
|
||||||
).extend(cv.COMPONENT_SCHEMA)
|
).extend(cv.COMPONENT_SCHEMA)
|
||||||
)
|
)
|
||||||
|
@ -38,9 +29,8 @@ CONFIG_SCHEMA = cv.All(
|
||||||
async def setup_conf(config, key, hub):
|
async def setup_conf(config, key, hub):
|
||||||
if key in config:
|
if key in config:
|
||||||
conf = config[key]
|
conf = config[key]
|
||||||
sens = cg.new_Pvariable(conf[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(conf)
|
||||||
await binary_sensor.register_binary_sensor(sens, conf)
|
cg.add(getattr(hub, f"set_{key}_binary_sensor")(var))
|
||||||
cg.add(getattr(hub, f"set_{key}_binary_sensor")(sens))
|
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
|
|
|
@ -132,12 +132,8 @@ CONFIG_SCHEMA = cv.Schema(
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
): [
|
): [
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(DemoBinarySensor).extend(
|
||||||
cv.polling_component_schema("60s")
|
cv.polling_component_schema("60s")
|
||||||
).extend(
|
|
||||||
{
|
|
||||||
cv.GenerateID(): cv.declare_id(DemoBinarySensor),
|
|
||||||
}
|
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
cv.Optional(
|
cv.Optional(
|
||||||
|
@ -372,7 +368,7 @@ CONFIG_SCHEMA = cv.Schema(
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
): [
|
): [
|
||||||
text_sensor.text_sensor_schema(klass=DemoTextSensor).extend(
|
text_sensor.text_sensor_schema(DemoTextSensor).extend(
|
||||||
cv.polling_component_schema("60s")
|
cv.polling_component_schema("60s")
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
|
@ -382,9 +378,8 @@ CONFIG_SCHEMA = cv.Schema(
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
for conf in config[CONF_BINARY_SENSORS]:
|
for conf in config[CONF_BINARY_SENSORS]:
|
||||||
var = cg.new_Pvariable(conf[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(conf)
|
||||||
await cg.register_component(var, conf)
|
await cg.register_component(var, conf)
|
||||||
await binary_sensor.register_binary_sensor(var, conf)
|
|
||||||
|
|
||||||
for conf in config[CONF_CLIMATES]:
|
for conf in config[CONF_CLIMATES]:
|
||||||
var = cg.new_Pvariable(conf[CONF_ID])
|
var = cg.new_Pvariable(conf[CONF_ID])
|
||||||
|
|
|
@ -39,9 +39,8 @@ ESP32TouchBinarySensor = esp32_touch_ns.class_(
|
||||||
"ESP32TouchBinarySensor", binary_sensor.BinarySensor
|
"ESP32TouchBinarySensor", binary_sensor.BinarySensor
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(ESP32TouchBinarySensor).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(ESP32TouchBinarySensor),
|
|
||||||
cv.GenerateID(CONF_ESP32_TOUCH_ID): cv.use_id(ESP32TouchComponent),
|
cv.GenerateID(CONF_ESP32_TOUCH_ID): cv.use_id(ESP32TouchComponent),
|
||||||
cv.Required(CONF_PIN): validate_touch_pad,
|
cv.Required(CONF_PIN): validate_touch_pad,
|
||||||
cv.Required(CONF_THRESHOLD): cv.uint16_t,
|
cv.Required(CONF_THRESHOLD): cv.uint16_t,
|
||||||
|
|
|
@ -6,7 +6,7 @@ from . import CONF_FINGERPRINT_GROW_ID, FingerprintGrowComponent
|
||||||
|
|
||||||
DEPENDENCIES = ["fingerprint_grow"]
|
DEPENDENCIES = ["fingerprint_grow"]
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema().extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(CONF_FINGERPRINT_GROW_ID): cv.use_id(FingerprintGrowComponent),
|
cv.GenerateID(CONF_FINGERPRINT_GROW_ID): cv.use_id(FingerprintGrowComponent),
|
||||||
cv.Optional(CONF_ICON, default=ICON_KEY_PLUS): cv.icon,
|
cv.Optional(CONF_ICON, default=ICON_KEY_PLUS): cv.icon,
|
||||||
|
|
|
@ -2,25 +2,27 @@ import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome import pins
|
from esphome import pins
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_ID, CONF_PIN
|
from esphome.const import CONF_PIN
|
||||||
from .. import gpio_ns
|
from .. import gpio_ns
|
||||||
|
|
||||||
GPIOBinarySensor = gpio_ns.class_(
|
GPIOBinarySensor = gpio_ns.class_(
|
||||||
"GPIOBinarySensor", binary_sensor.BinarySensor, cg.Component
|
"GPIOBinarySensor", binary_sensor.BinarySensor, cg.Component
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = (
|
||||||
{
|
binary_sensor.binary_sensor_schema(GPIOBinarySensor)
|
||||||
cv.GenerateID(): cv.declare_id(GPIOBinarySensor),
|
.extend(
|
||||||
cv.Required(CONF_PIN): pins.gpio_input_pin_schema,
|
{
|
||||||
}
|
cv.Required(CONF_PIN): pins.gpio_input_pin_schema,
|
||||||
).extend(cv.COMPONENT_SCHEMA)
|
}
|
||||||
|
)
|
||||||
|
.extend(cv.COMPONENT_SCHEMA)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
pin = await cg.gpio_pin_expression(config[CONF_PIN])
|
pin = await cg.gpio_pin_expression(config[CONF_PIN])
|
||||||
cg.add(var.set_pin(pin))
|
cg.add(var.set_pin(pin))
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_ATTRIBUTE, CONF_ENTITY_ID, CONF_ID
|
from esphome.const import CONF_ATTRIBUTE, CONF_ENTITY_ID
|
||||||
from .. import homeassistant_ns
|
from .. import homeassistant_ns
|
||||||
|
|
||||||
DEPENDENCIES = ["api"]
|
DEPENDENCIES = ["api"]
|
||||||
|
@ -9,19 +9,21 @@ HomeassistantBinarySensor = homeassistant_ns.class_(
|
||||||
"HomeassistantBinarySensor", binary_sensor.BinarySensor, cg.Component
|
"HomeassistantBinarySensor", binary_sensor.BinarySensor, cg.Component
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = (
|
||||||
{
|
binary_sensor.binary_sensor_schema(HomeassistantBinarySensor)
|
||||||
cv.GenerateID(): cv.declare_id(HomeassistantBinarySensor),
|
.extend(
|
||||||
cv.Required(CONF_ENTITY_ID): cv.entity_id,
|
{
|
||||||
cv.Optional(CONF_ATTRIBUTE): cv.string,
|
cv.Required(CONF_ENTITY_ID): cv.entity_id,
|
||||||
}
|
cv.Optional(CONF_ATTRIBUTE): cv.string,
|
||||||
).extend(cv.COMPONENT_SCHEMA)
|
}
|
||||||
|
)
|
||||||
|
.extend(cv.COMPONENT_SCHEMA)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
cg.add(var.set_entity_id(config[CONF_ENTITY_ID]))
|
cg.add(var.set_entity_id(config[CONF_ENTITY_ID]))
|
||||||
if CONF_ATTRIBUTE in config:
|
if CONF_ATTRIBUTE in config:
|
||||||
|
|
|
@ -29,11 +29,11 @@ ModbusBinarySensor = modbus_controller_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(cv.COMPONENT_SCHEMA)
|
binary_sensor.binary_sensor_schema(ModbusBinarySensor)
|
||||||
|
.extend(cv.COMPONENT_SCHEMA)
|
||||||
.extend(ModbusItemBaseSchema)
|
.extend(ModbusItemBaseSchema)
|
||||||
.extend(
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(ModbusBinarySensor),
|
|
||||||
cv.Optional(CONF_REGISTER_TYPE): cv.enum(MODBUS_REGISTER_TYPE),
|
cv.Optional(CONF_REGISTER_TYPE): cv.enum(MODBUS_REGISTER_TYPE),
|
||||||
}
|
}
|
||||||
),
|
),
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_CHANNEL, CONF_ID
|
from esphome.const import CONF_CHANNEL
|
||||||
from . import (
|
from . import (
|
||||||
mpr121_ns,
|
mpr121_ns,
|
||||||
MPR121Component,
|
MPR121Component,
|
||||||
|
@ -13,9 +13,8 @@ from . import (
|
||||||
DEPENDENCIES = ["mpr121"]
|
DEPENDENCIES = ["mpr121"]
|
||||||
MPR121Channel = mpr121_ns.class_("MPR121Channel", binary_sensor.BinarySensor)
|
MPR121Channel = mpr121_ns.class_("MPR121Channel", binary_sensor.BinarySensor)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(MPR121Channel).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(MPR121Channel),
|
|
||||||
cv.GenerateID(CONF_MPR121_ID): cv.use_id(MPR121Component),
|
cv.GenerateID(CONF_MPR121_ID): cv.use_id(MPR121Component),
|
||||||
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=11),
|
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=11),
|
||||||
cv.Optional(CONF_TOUCH_THRESHOLD): cv.int_range(min=0x05, max=0x30),
|
cv.Optional(CONF_TOUCH_THRESHOLD): cv.int_range(min=0x05, max=0x30),
|
||||||
|
@ -25,8 +24,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
hub = await cg.get_variable(config[CONF_MPR121_ID])
|
hub = await cg.get_variable(config[CONF_MPR121_ID])
|
||||||
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
||||||
|
|
||||||
|
|
|
@ -20,9 +20,9 @@ NextionBinarySensor = nextion_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(NextionBinarySensor)
|
||||||
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(NextionBinarySensor),
|
|
||||||
cv.Optional(CONF_PAGE_ID): cv.uint8_t,
|
cv.Optional(CONF_PAGE_ID): cv.uint8_t,
|
||||||
cv.Optional(CONF_COMPONENT_ID): cv.uint8_t,
|
cv.Optional(CONF_COMPONENT_ID): cv.uint8_t,
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,7 @@ NextionTextSensor = nextion_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = (
|
CONFIG_SCHEMA = (
|
||||||
text_sensor.text_sensor_schema(klass=NextionTextSensor)
|
text_sensor.text_sensor_schema(NextionTextSensor)
|
||||||
.extend(CONFIG_TEXT_COMPONENT_SCHEMA)
|
.extend(CONFIG_TEXT_COMPONENT_SCHEMA)
|
||||||
.extend(cv.polling_component_schema("never"))
|
.extend(cv.polling_component_schema("never"))
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import (
|
|
||||||
CONF_ID,
|
|
||||||
)
|
|
||||||
from .. import PIPSOLAR_COMPONENT_SCHEMA, CONF_PIPSOLAR_ID
|
from .. import PIPSOLAR_COMPONENT_SCHEMA, CONF_PIPSOLAR_ID
|
||||||
|
|
||||||
DEPENDENCIES = ["uart"]
|
DEPENDENCIES = ["uart"]
|
||||||
|
@ -130,7 +128,7 @@ TYPES = [
|
||||||
]
|
]
|
||||||
|
|
||||||
CONFIG_SCHEMA = PIPSOLAR_COMPONENT_SCHEMA.extend(
|
CONFIG_SCHEMA = PIPSOLAR_COMPONENT_SCHEMA.extend(
|
||||||
{cv.Optional(type): binary_sensor.BINARY_SENSOR_SCHEMA for type in TYPES}
|
{cv.Optional(type): binary_sensor.binary_sensor_schema() for type in TYPES}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -139,6 +137,5 @@ async def to_code(config):
|
||||||
for type in TYPES:
|
for type in TYPES:
|
||||||
if type in config:
|
if type in config:
|
||||||
conf = config[type]
|
conf = config[type]
|
||||||
sens = cg.new_Pvariable(conf[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(conf)
|
||||||
await binary_sensor.register_binary_sensor(sens, conf)
|
cg.add(getattr(paren, f"set_{type}")(var))
|
||||||
cg.add(getattr(paren, f"set_{type}")(sens))
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_UID, CONF_ID
|
from esphome.const import CONF_UID
|
||||||
from esphome.core import HexInt
|
from esphome.core import HexInt
|
||||||
from . import pn532_ns, PN532, CONF_PN532_ID
|
from . import pn532_ns, PN532, CONF_PN532_ID
|
||||||
|
|
||||||
|
@ -31,9 +31,8 @@ def validate_uid(value):
|
||||||
|
|
||||||
PN532BinarySensor = pn532_ns.class_("PN532BinarySensor", binary_sensor.BinarySensor)
|
PN532BinarySensor = pn532_ns.class_("PN532BinarySensor", binary_sensor.BinarySensor)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(PN532BinarySensor).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(PN532BinarySensor),
|
|
||||||
cv.GenerateID(CONF_PN532_ID): cv.use_id(PN532),
|
cv.GenerateID(CONF_PN532_ID): cv.use_id(PN532),
|
||||||
cv.Required(CONF_UID): validate_uid,
|
cv.Required(CONF_UID): validate_uid,
|
||||||
}
|
}
|
||||||
|
@ -41,8 +40,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
hub = await cg.get_variable(config[CONF_PN532_ID])
|
hub = await cg.get_variable(config[CONF_PN532_ID])
|
||||||
cg.add(hub.register_tag(var))
|
cg.add(hub.register_tag(var))
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_UID, CONF_ID
|
from esphome.const import CONF_UID
|
||||||
from esphome.core import HexInt
|
from esphome.core import HexInt
|
||||||
from . import rc522_ns, RC522, CONF_RC522_ID
|
from . import rc522_ns, RC522, CONF_RC522_ID
|
||||||
|
|
||||||
|
@ -31,9 +31,8 @@ def validate_uid(value):
|
||||||
|
|
||||||
RC522BinarySensor = rc522_ns.class_("RC522BinarySensor", binary_sensor.BinarySensor)
|
RC522BinarySensor = rc522_ns.class_("RC522BinarySensor", binary_sensor.BinarySensor)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(RC522BinarySensor).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(RC522BinarySensor),
|
|
||||||
cv.GenerateID(CONF_RC522_ID): cv.use_id(RC522),
|
cv.GenerateID(CONF_RC522_ID): cv.use_id(RC522),
|
||||||
cv.Required(CONF_UID): validate_uid,
|
cv.Required(CONF_UID): validate_uid,
|
||||||
}
|
}
|
||||||
|
@ -41,8 +40,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
hub = await cg.get_variable(config[CONF_RC522_ID])
|
hub = await cg.get_variable(config[CONF_RC522_ID])
|
||||||
cg.add(hub.register_tag(var))
|
cg.add(hub.register_tag(var))
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor, rdm6300
|
from esphome.components import binary_sensor, rdm6300
|
||||||
from esphome.const import CONF_UID, CONF_ID
|
from esphome.const import CONF_UID
|
||||||
from . import rdm6300_ns
|
from . import rdm6300_ns
|
||||||
|
|
||||||
DEPENDENCIES = ["rdm6300"]
|
DEPENDENCIES = ["rdm6300"]
|
||||||
|
@ -11,9 +11,8 @@ RDM6300BinarySensor = rdm6300_ns.class_(
|
||||||
"RDM6300BinarySensor", binary_sensor.BinarySensor
|
"RDM6300BinarySensor", binary_sensor.BinarySensor
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(RDM6300BinarySensor).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(RDM6300BinarySensor),
|
|
||||||
cv.GenerateID(CONF_RDM6300_ID): cv.use_id(rdm6300.RDM6300Component),
|
cv.GenerateID(CONF_RDM6300_ID): cv.use_id(rdm6300.RDM6300Component),
|
||||||
cv.Required(CONF_UID): cv.uint32_t,
|
cv.Required(CONF_UID): cv.uint32_t,
|
||||||
}
|
}
|
||||||
|
@ -21,8 +20,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
hub = await cg.get_variable(config[CONF_RDM6300_ID])
|
hub = await cg.get_variable(config[CONF_RDM6300_ID])
|
||||||
cg.add(hub.register_card(var))
|
cg.add(hub.register_card(var))
|
||||||
|
|
|
@ -165,7 +165,7 @@ def declare_protocol(name):
|
||||||
|
|
||||||
|
|
||||||
BINARY_SENSOR_REGISTRY = Registry(
|
BINARY_SENSOR_REGISTRY = Registry(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema().extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(CONF_RECEIVER_ID): cv.use_id(RemoteReceiverBase),
|
cv.GenerateID(CONF_RECEIVER_ID): cv.use_id(RemoteReceiverBase),
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,8 +2,6 @@ import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import (
|
from esphome.const import (
|
||||||
CONF_DEVICE_CLASS,
|
|
||||||
CONF_ENTITY_CATEGORY,
|
|
||||||
DEVICE_CLASS_CONNECTIVITY,
|
DEVICE_CLASS_CONNECTIVITY,
|
||||||
ENTITY_CATEGORY_DIAGNOSTIC,
|
ENTITY_CATEGORY_DIAGNOSTIC,
|
||||||
)
|
)
|
||||||
|
@ -15,15 +13,9 @@ CONF_REGISTERED = "registered"
|
||||||
|
|
||||||
CONFIG_SCHEMA = {
|
CONFIG_SCHEMA = {
|
||||||
cv.GenerateID(CONF_SIM800L_ID): cv.use_id(Sim800LComponent),
|
cv.GenerateID(CONF_SIM800L_ID): cv.use_id(Sim800LComponent),
|
||||||
cv.Optional(CONF_REGISTERED): binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
cv.Optional(CONF_REGISTERED): binary_sensor.binary_sensor_schema(
|
||||||
{
|
device_class=DEVICE_CLASS_CONNECTIVITY,
|
||||||
cv.Optional(
|
entity_category=ENTITY_CATEGORY_DIAGNOSTIC,
|
||||||
CONF_DEVICE_CLASS, default=DEVICE_CLASS_CONNECTIVITY
|
|
||||||
): binary_sensor.device_class,
|
|
||||||
cv.Optional(
|
|
||||||
CONF_ENTITY_CATEGORY, default=ENTITY_CATEGORY_DIAGNOSTIC
|
|
||||||
): cv.entity_category,
|
|
||||||
}
|
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,9 +2,6 @@ import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import (
|
from esphome.const import (
|
||||||
CONF_ENTITY_CATEGORY,
|
|
||||||
CONF_ID,
|
|
||||||
CONF_DEVICE_CLASS,
|
|
||||||
DEVICE_CLASS_CONNECTIVITY,
|
DEVICE_CLASS_CONNECTIVITY,
|
||||||
ENTITY_CATEGORY_DIAGNOSTIC,
|
ENTITY_CATEGORY_DIAGNOSTIC,
|
||||||
)
|
)
|
||||||
|
@ -14,20 +11,13 @@ StatusBinarySensor = status_ns.class_(
|
||||||
"StatusBinarySensor", binary_sensor.BinarySensor, cg.Component
|
"StatusBinarySensor", binary_sensor.BinarySensor, cg.Component
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(
|
||||||
{
|
StatusBinarySensor,
|
||||||
cv.GenerateID(): cv.declare_id(StatusBinarySensor),
|
device_class=DEVICE_CLASS_CONNECTIVITY,
|
||||||
cv.Optional(
|
entity_category=ENTITY_CATEGORY_DIAGNOSTIC,
|
||||||
CONF_DEVICE_CLASS, default=DEVICE_CLASS_CONNECTIVITY
|
|
||||||
): binary_sensor.device_class,
|
|
||||||
cv.Optional(
|
|
||||||
CONF_ENTITY_CATEGORY, default=ENTITY_CATEGORY_DIAGNOSTIC
|
|
||||||
): cv.entity_category,
|
|
||||||
}
|
|
||||||
).extend(cv.COMPONENT_SCHEMA)
|
).extend(cv.COMPONENT_SCHEMA)
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_ID
|
|
||||||
from .. import SX1509Component, sx1509_ns, CONF_SX1509_ID
|
from .. import SX1509Component, sx1509_ns, CONF_SX1509_ID
|
||||||
|
|
||||||
CONF_ROW = "row"
|
CONF_ROW = "row"
|
||||||
|
@ -11,9 +11,8 @@ DEPENDENCIES = ["sx1509"]
|
||||||
|
|
||||||
SX1509BinarySensor = sx1509_ns.class_("SX1509BinarySensor", binary_sensor.BinarySensor)
|
SX1509BinarySensor = sx1509_ns.class_("SX1509BinarySensor", binary_sensor.BinarySensor)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(SX1509BinarySensor).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(SX1509BinarySensor),
|
|
||||||
cv.GenerateID(CONF_SX1509_ID): cv.use_id(SX1509Component),
|
cv.GenerateID(CONF_SX1509_ID): cv.use_id(SX1509Component),
|
||||||
cv.Required(CONF_ROW): cv.int_range(min=0, max=4),
|
cv.Required(CONF_ROW): cv.int_range(min=0, max=4),
|
||||||
cv.Required(CONF_COL): cv.int_range(min=0, max=4),
|
cv.Required(CONF_COL): cv.int_range(min=0, max=4),
|
||||||
|
@ -22,8 +21,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
hub = await cg.get_variable(config[CONF_SX1509_ID])
|
hub = await cg.get_variable(config[CONF_SX1509_ID])
|
||||||
cg.add(var.set_row_col(config[CONF_ROW], config[CONF_COL]))
|
cg.add(var.set_row_col(config[CONF_ROW], config[CONF_COL]))
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@ TeleInfoTextSensor = teleinfo_ns.class_(
|
||||||
"TeleInfoTextSensor", text_sensor.TextSensor, cg.Component
|
"TeleInfoTextSensor", text_sensor.TextSensor, cg.Component
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = text_sensor.text_sensor_schema(klass=TeleInfoTextSensor).extend(
|
CONFIG_SCHEMA = text_sensor.text_sensor_schema(TeleInfoTextSensor).extend(
|
||||||
TELEINFO_LISTENER_SCHEMA
|
TELEINFO_LISTENER_SCHEMA
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -9,18 +9,20 @@ TemplateBinarySensor = template_ns.class_(
|
||||||
"TemplateBinarySensor", binary_sensor.BinarySensor, cg.Component
|
"TemplateBinarySensor", binary_sensor.BinarySensor, cg.Component
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = (
|
||||||
{
|
binary_sensor.binary_sensor_schema(TemplateBinarySensor)
|
||||||
cv.GenerateID(): cv.declare_id(TemplateBinarySensor),
|
.extend(
|
||||||
cv.Optional(CONF_LAMBDA): cv.returning_lambda,
|
{
|
||||||
}
|
cv.Optional(CONF_LAMBDA): cv.returning_lambda,
|
||||||
).extend(cv.COMPONENT_SCHEMA)
|
}
|
||||||
|
)
|
||||||
|
.extend(cv.COMPONENT_SCHEMA)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
if CONF_LAMBDA in config:
|
if CONF_LAMBDA in config:
|
||||||
template_ = await cg.process_lambda(
|
template_ = await cg.process_lambda(
|
||||||
|
|
|
@ -137,13 +137,14 @@ _UNDEF = object()
|
||||||
|
|
||||||
|
|
||||||
def text_sensor_schema(
|
def text_sensor_schema(
|
||||||
klass: MockObjClass = _UNDEF,
|
class_: MockObjClass = _UNDEF,
|
||||||
|
*,
|
||||||
icon: str = _UNDEF,
|
icon: str = _UNDEF,
|
||||||
entity_category: str = _UNDEF,
|
entity_category: str = _UNDEF,
|
||||||
) -> cv.Schema:
|
) -> cv.Schema:
|
||||||
schema = TEXT_SENSOR_SCHEMA
|
schema = TEXT_SENSOR_SCHEMA
|
||||||
if klass is not _UNDEF:
|
if class_ is not _UNDEF:
|
||||||
schema = schema.extend({cv.GenerateID(): cv.declare_id(klass)})
|
schema = schema.extend({cv.GenerateID(): cv.declare_id(class_)})
|
||||||
if icon is not _UNDEF:
|
if icon is not _UNDEF:
|
||||||
schema = schema.extend({cv.Optional(CONF_ICON, default=icon): cv.icon})
|
schema = schema.extend({cv.Optional(CONF_ICON, default=icon): cv.icon})
|
||||||
if entity_category is not _UNDEF:
|
if entity_category is not _UNDEF:
|
||||||
|
|
|
@ -2,7 +2,6 @@ import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
|
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_ID
|
|
||||||
|
|
||||||
from .. import touchscreen_ns, CONF_TOUCHSCREEN_ID, Touchscreen, TouchListener
|
from .. import touchscreen_ns, CONF_TOUCHSCREEN_ID, Touchscreen, TouchListener
|
||||||
|
|
||||||
|
@ -34,23 +33,23 @@ def validate_coords(config):
|
||||||
|
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(TouchscreenBinarySensor)
|
||||||
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(TouchscreenBinarySensor),
|
|
||||||
cv.GenerateID(CONF_TOUCHSCREEN_ID): cv.use_id(Touchscreen),
|
cv.GenerateID(CONF_TOUCHSCREEN_ID): cv.use_id(Touchscreen),
|
||||||
cv.Required(CONF_X_MIN): cv.int_range(min=0, max=2000),
|
cv.Required(CONF_X_MIN): cv.int_range(min=0, max=2000),
|
||||||
cv.Required(CONF_X_MAX): cv.int_range(min=0, max=2000),
|
cv.Required(CONF_X_MAX): cv.int_range(min=0, max=2000),
|
||||||
cv.Required(CONF_Y_MIN): cv.int_range(min=0, max=2000),
|
cv.Required(CONF_Y_MIN): cv.int_range(min=0, max=2000),
|
||||||
cv.Required(CONF_Y_MAX): cv.int_range(min=0, max=2000),
|
cv.Required(CONF_Y_MAX): cv.int_range(min=0, max=2000),
|
||||||
}
|
}
|
||||||
).extend(cv.COMPONENT_SCHEMA),
|
)
|
||||||
|
.extend(cv.COMPONENT_SCHEMA),
|
||||||
validate_coords,
|
validate_coords,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await cg.register_parented(var, config[CONF_TOUCHSCREEN_ID])
|
await cg.register_parented(var, config[CONF_TOUCHSCREEN_ID])
|
||||||
|
|
||||||
|
|
|
@ -1,15 +1,14 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_CHANNEL, CONF_ID
|
from esphome.const import CONF_CHANNEL
|
||||||
from . import ttp229_bsf_ns, TTP229BSFComponent, CONF_TTP229_ID
|
from . import ttp229_bsf_ns, TTP229BSFComponent, CONF_TTP229_ID
|
||||||
|
|
||||||
DEPENDENCIES = ["ttp229_bsf"]
|
DEPENDENCIES = ["ttp229_bsf"]
|
||||||
TTP229BSFChannel = ttp229_bsf_ns.class_("TTP229BSFChannel", binary_sensor.BinarySensor)
|
TTP229BSFChannel = ttp229_bsf_ns.class_("TTP229BSFChannel", binary_sensor.BinarySensor)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(TTP229BSFChannel).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(TTP229BSFChannel),
|
|
||||||
cv.GenerateID(CONF_TTP229_ID): cv.use_id(TTP229BSFComponent),
|
cv.GenerateID(CONF_TTP229_ID): cv.use_id(TTP229BSFComponent),
|
||||||
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=15),
|
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=15),
|
||||||
}
|
}
|
||||||
|
@ -17,8 +16,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
||||||
hub = await cg.get_variable(config[CONF_TTP229_ID])
|
hub = await cg.get_variable(config[CONF_TTP229_ID])
|
||||||
|
|
|
@ -1,15 +1,14 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_CHANNEL, CONF_ID
|
from esphome.const import CONF_CHANNEL
|
||||||
from . import ttp229_lsf_ns, TTP229LSFComponent, CONF_TTP229_ID
|
from . import ttp229_lsf_ns, TTP229LSFComponent, CONF_TTP229_ID
|
||||||
|
|
||||||
DEPENDENCIES = ["ttp229_lsf"]
|
DEPENDENCIES = ["ttp229_lsf"]
|
||||||
TTP229Channel = ttp229_lsf_ns.class_("TTP229Channel", binary_sensor.BinarySensor)
|
TTP229Channel = ttp229_lsf_ns.class_("TTP229Channel", binary_sensor.BinarySensor)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = binary_sensor.binary_sensor_schema(TTP229Channel).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(TTP229Channel),
|
|
||||||
cv.GenerateID(CONF_TTP229_ID): cv.use_id(TTP229LSFComponent),
|
cv.GenerateID(CONF_TTP229_ID): cv.use_id(TTP229LSFComponent),
|
||||||
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=15),
|
cv.Required(CONF_CHANNEL): cv.int_range(min=0, max=15),
|
||||||
}
|
}
|
||||||
|
@ -17,8 +16,7 @@ CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
cg.add(var.set_channel(config[CONF_CHANNEL]))
|
||||||
hub = await cg.get_variable(config[CONF_TTP229_ID])
|
hub = await cg.get_variable(config[CONF_TTP229_ID])
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
from esphome.const import CONF_ID, CONF_SENSOR_DATAPOINT
|
from esphome.const import CONF_SENSOR_DATAPOINT
|
||||||
|
|
||||||
from .. import tuya_ns, CONF_TUYA_ID, Tuya
|
from .. import tuya_ns, CONF_TUYA_ID, Tuya
|
||||||
|
|
||||||
DEPENDENCIES = ["tuya"]
|
DEPENDENCIES = ["tuya"]
|
||||||
|
@ -11,19 +12,21 @@ TuyaBinarySensor = tuya_ns.class_(
|
||||||
"TuyaBinarySensor", binary_sensor.BinarySensor, cg.Component
|
"TuyaBinarySensor", binary_sensor.BinarySensor, cg.Component
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
CONFIG_SCHEMA = (
|
||||||
{
|
binary_sensor.binary_sensor_schema(TuyaBinarySensor)
|
||||||
cv.GenerateID(): cv.declare_id(TuyaBinarySensor),
|
.extend(
|
||||||
cv.GenerateID(CONF_TUYA_ID): cv.use_id(Tuya),
|
{
|
||||||
cv.Required(CONF_SENSOR_DATAPOINT): cv.uint8_t,
|
cv.GenerateID(CONF_TUYA_ID): cv.use_id(Tuya),
|
||||||
}
|
cv.Required(CONF_SENSOR_DATAPOINT): cv.uint8_t,
|
||||||
).extend(cv.COMPONENT_SCHEMA)
|
}
|
||||||
|
)
|
||||||
|
.extend(cv.COMPONENT_SCHEMA)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
paren = await cg.get_variable(config[CONF_TUYA_ID])
|
paren = await cg.get_variable(config[CONF_TUYA_ID])
|
||||||
cg.add(var.set_tuya_parent(paren))
|
cg.add(var.set_tuya_parent(paren))
|
||||||
|
|
|
@ -32,19 +32,19 @@ MacAddressWifiInfo = wifi_info_ns.class_(
|
||||||
CONFIG_SCHEMA = cv.Schema(
|
CONFIG_SCHEMA = cv.Schema(
|
||||||
{
|
{
|
||||||
cv.Optional(CONF_IP_ADDRESS): text_sensor.text_sensor_schema(
|
cv.Optional(CONF_IP_ADDRESS): text_sensor.text_sensor_schema(
|
||||||
klass=IPAddressWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
IPAddressWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
||||||
).extend(cv.polling_component_schema("1s")),
|
).extend(cv.polling_component_schema("1s")),
|
||||||
cv.Optional(CONF_SCAN_RESULTS): text_sensor.text_sensor_schema(
|
cv.Optional(CONF_SCAN_RESULTS): text_sensor.text_sensor_schema(
|
||||||
klass=ScanResultsWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
ScanResultsWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
||||||
).extend(cv.polling_component_schema("60s")),
|
).extend(cv.polling_component_schema("60s")),
|
||||||
cv.Optional(CONF_SSID): text_sensor.text_sensor_schema(
|
cv.Optional(CONF_SSID): text_sensor.text_sensor_schema(
|
||||||
klass=SSIDWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
SSIDWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
||||||
).extend(cv.polling_component_schema("1s")),
|
).extend(cv.polling_component_schema("1s")),
|
||||||
cv.Optional(CONF_BSSID): text_sensor.text_sensor_schema(
|
cv.Optional(CONF_BSSID): text_sensor.text_sensor_schema(
|
||||||
klass=BSSIDWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
BSSIDWiFiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
||||||
).extend(cv.polling_component_schema("1s")),
|
).extend(cv.polling_component_schema("1s")),
|
||||||
cv.Optional(CONF_MAC_ADDRESS): text_sensor.text_sensor_schema(
|
cv.Optional(CONF_MAC_ADDRESS): text_sensor.text_sensor_schema(
|
||||||
klass=MacAddressWifiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
MacAddressWifiInfo, entity_category=ENTITY_CATEGORY_DIAGNOSTIC
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
|
@ -4,9 +4,7 @@ from esphome.components import sensor, binary_sensor, esp32_ble_tracker
|
||||||
from esphome.const import (
|
from esphome.const import (
|
||||||
CONF_BATTERY_LEVEL,
|
CONF_BATTERY_LEVEL,
|
||||||
CONF_BINDKEY,
|
CONF_BINDKEY,
|
||||||
CONF_DEVICE_CLASS,
|
|
||||||
CONF_MAC_ADDRESS,
|
CONF_MAC_ADDRESS,
|
||||||
CONF_ID,
|
|
||||||
DEVICE_CLASS_BATTERY,
|
DEVICE_CLASS_BATTERY,
|
||||||
DEVICE_CLASS_ILLUMINANCE,
|
DEVICE_CLASS_ILLUMINANCE,
|
||||||
DEVICE_CLASS_MOTION,
|
DEVICE_CLASS_MOTION,
|
||||||
|
@ -31,15 +29,11 @@ XiaomiCGPR1 = xiaomi_cgpr1_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(XiaomiCGPR1, device_class=DEVICE_CLASS_MOTION)
|
||||||
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(XiaomiCGPR1),
|
|
||||||
cv.Required(CONF_BINDKEY): cv.bind_key,
|
cv.Required(CONF_BINDKEY): cv.bind_key,
|
||||||
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
||||||
cv.Optional(
|
|
||||||
CONF_DEVICE_CLASS,
|
|
||||||
default=DEVICE_CLASS_MOTION,
|
|
||||||
): binary_sensor.device_class,
|
|
||||||
cv.Optional(CONF_BATTERY_LEVEL): sensor.sensor_schema(
|
cv.Optional(CONF_BATTERY_LEVEL): sensor.sensor_schema(
|
||||||
unit_of_measurement=UNIT_PERCENT,
|
unit_of_measurement=UNIT_PERCENT,
|
||||||
accuracy_decimals=0,
|
accuracy_decimals=0,
|
||||||
|
@ -64,21 +58,20 @@ CONFIG_SCHEMA = cv.All(
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
yield cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
yield esp32_ble_tracker.register_ble_device(var, config)
|
await esp32_ble_tracker.register_ble_device(var, config)
|
||||||
yield binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
||||||
cg.add(var.set_bindkey(config[CONF_BINDKEY]))
|
cg.add(var.set_bindkey(config[CONF_BINDKEY]))
|
||||||
|
|
||||||
if CONF_IDLE_TIME in config:
|
if CONF_IDLE_TIME in config:
|
||||||
sens = yield sensor.new_sensor(config[CONF_IDLE_TIME])
|
sens = await sensor.new_sensor(config[CONF_IDLE_TIME])
|
||||||
cg.add(var.set_idle_time(sens))
|
cg.add(var.set_idle_time(sens))
|
||||||
if CONF_BATTERY_LEVEL in config:
|
if CONF_BATTERY_LEVEL in config:
|
||||||
sens = yield sensor.new_sensor(config[CONF_BATTERY_LEVEL])
|
sens = await sensor.new_sensor(config[CONF_BATTERY_LEVEL])
|
||||||
cg.add(var.set_battery_level(sens))
|
cg.add(var.set_battery_level(sens))
|
||||||
if CONF_ILLUMINANCE in config:
|
if CONF_ILLUMINANCE in config:
|
||||||
sens = yield sensor.new_sensor(config[CONF_ILLUMINANCE])
|
sens = await sensor.new_sensor(config[CONF_ILLUMINANCE])
|
||||||
cg.add(var.set_illuminance(sens))
|
cg.add(var.set_illuminance(sens))
|
||||||
|
|
|
@ -3,13 +3,13 @@ import esphome.config_validation as cv
|
||||||
from esphome.components import sensor, binary_sensor, esp32_ble_tracker
|
from esphome.components import sensor, binary_sensor, esp32_ble_tracker
|
||||||
from esphome.const import (
|
from esphome.const import (
|
||||||
CONF_MAC_ADDRESS,
|
CONF_MAC_ADDRESS,
|
||||||
CONF_ID,
|
|
||||||
CONF_BINDKEY,
|
CONF_BINDKEY,
|
||||||
CONF_DEVICE_CLASS,
|
|
||||||
CONF_LIGHT,
|
CONF_LIGHT,
|
||||||
CONF_BATTERY_LEVEL,
|
CONF_BATTERY_LEVEL,
|
||||||
DEVICE_CLASS_BATTERY,
|
DEVICE_CLASS_BATTERY,
|
||||||
DEVICE_CLASS_ILLUMINANCE,
|
DEVICE_CLASS_ILLUMINANCE,
|
||||||
|
DEVICE_CLASS_LIGHT,
|
||||||
|
DEVICE_CLASS_MOTION,
|
||||||
ENTITY_CATEGORY_DIAGNOSTIC,
|
ENTITY_CATEGORY_DIAGNOSTIC,
|
||||||
STATE_CLASS_MEASUREMENT,
|
STATE_CLASS_MEASUREMENT,
|
||||||
UNIT_PERCENT,
|
UNIT_PERCENT,
|
||||||
|
@ -32,14 +32,13 @@ XiaomiMJYD02YLA = xiaomi_mjyd02yla_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(
|
||||||
|
XiaomiMJYD02YLA, device_class=DEVICE_CLASS_MOTION
|
||||||
|
)
|
||||||
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(XiaomiMJYD02YLA),
|
|
||||||
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
||||||
cv.Required(CONF_BINDKEY): cv.bind_key,
|
cv.Required(CONF_BINDKEY): cv.bind_key,
|
||||||
cv.Optional(
|
|
||||||
CONF_DEVICE_CLASS, default="motion"
|
|
||||||
): binary_sensor.device_class,
|
|
||||||
cv.Optional(CONF_IDLE_TIME): sensor.sensor_schema(
|
cv.Optional(CONF_IDLE_TIME): sensor.sensor_schema(
|
||||||
unit_of_measurement=UNIT_MINUTE,
|
unit_of_measurement=UNIT_MINUTE,
|
||||||
icon=ICON_TIMELAPSE,
|
icon=ICON_TIMELAPSE,
|
||||||
|
@ -58,12 +57,8 @@ CONFIG_SCHEMA = cv.All(
|
||||||
device_class=DEVICE_CLASS_ILLUMINANCE,
|
device_class=DEVICE_CLASS_ILLUMINANCE,
|
||||||
state_class=STATE_CLASS_MEASUREMENT,
|
state_class=STATE_CLASS_MEASUREMENT,
|
||||||
),
|
),
|
||||||
cv.Optional(CONF_LIGHT): binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
cv.Optional(CONF_LIGHT): binary_sensor.binary_sensor_schema(
|
||||||
{
|
device_class=DEVICE_CLASS_LIGHT
|
||||||
cv.Optional(
|
|
||||||
CONF_DEVICE_CLASS, default="light"
|
|
||||||
): binary_sensor.device_class,
|
|
||||||
}
|
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
@ -73,10 +68,9 @@ CONFIG_SCHEMA = cv.All(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await esp32_ble_tracker.register_ble_device(var, config)
|
await esp32_ble_tracker.register_ble_device(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
||||||
cg.add(var.set_bindkey(config[CONF_BINDKEY]))
|
cg.add(var.set_bindkey(config[CONF_BINDKEY]))
|
||||||
|
|
|
@ -1,7 +1,11 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor, esp32_ble_tracker
|
from esphome.components import binary_sensor, esp32_ble_tracker
|
||||||
from esphome.const import CONF_MAC_ADDRESS, CONF_DEVICE_CLASS, CONF_TIMEOUT, CONF_ID
|
from esphome.const import (
|
||||||
|
CONF_MAC_ADDRESS,
|
||||||
|
CONF_TIMEOUT,
|
||||||
|
DEVICE_CLASS_MOTION,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
DEPENDENCIES = ["esp32_ble_tracker"]
|
DEPENDENCIES = ["esp32_ble_tracker"]
|
||||||
|
@ -16,13 +20,12 @@ XiaomiMUE4094RT = xiaomi_mue4094rt_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(
|
||||||
|
XiaomiMUE4094RT, device_class=DEVICE_CLASS_MOTION
|
||||||
|
)
|
||||||
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(XiaomiMUE4094RT),
|
|
||||||
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
||||||
cv.Optional(
|
|
||||||
CONF_DEVICE_CLASS, default="motion"
|
|
||||||
): binary_sensor.device_class,
|
|
||||||
cv.Optional(
|
cv.Optional(
|
||||||
CONF_TIMEOUT, default="5s"
|
CONF_TIMEOUT, default="5s"
|
||||||
): cv.positive_time_period_milliseconds,
|
): cv.positive_time_period_milliseconds,
|
||||||
|
@ -34,10 +37,9 @@ CONFIG_SCHEMA = cv.All(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await esp32_ble_tracker.register_ble_device(var, config)
|
await esp32_ble_tracker.register_ble_device(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
||||||
cg.add(var.set_time(config[CONF_TIMEOUT]))
|
cg.add(var.set_time(config[CONF_TIMEOUT]))
|
||||||
|
|
|
@ -10,12 +10,11 @@ from esphome.const import (
|
||||||
STATE_CLASS_MEASUREMENT,
|
STATE_CLASS_MEASUREMENT,
|
||||||
UNIT_PERCENT,
|
UNIT_PERCENT,
|
||||||
ICON_BUG,
|
ICON_BUG,
|
||||||
CONF_ID,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
DEPENDENCIES = ["esp32_ble_tracker"]
|
DEPENDENCIES = ["esp32_ble_tracker"]
|
||||||
AUTO_LOAD = ["xiaomi_ble"]
|
AUTO_LOAD = ["xiaomi_ble", "sensor"]
|
||||||
|
|
||||||
xiaomi_wx08zm_ns = cg.esphome_ns.namespace("xiaomi_wx08zm")
|
xiaomi_wx08zm_ns = cg.esphome_ns.namespace("xiaomi_wx08zm")
|
||||||
XiaomiWX08ZM = xiaomi_wx08zm_ns.class_(
|
XiaomiWX08ZM = xiaomi_wx08zm_ns.class_(
|
||||||
|
@ -26,9 +25,9 @@ XiaomiWX08ZM = xiaomi_wx08zm_ns.class_(
|
||||||
)
|
)
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(XiaomiWX08ZM)
|
||||||
|
.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(XiaomiWX08ZM),
|
|
||||||
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
cv.Required(CONF_MAC_ADDRESS): cv.mac_address,
|
||||||
cv.Optional(CONF_TABLET): sensor.sensor_schema(
|
cv.Optional(CONF_TABLET): sensor.sensor_schema(
|
||||||
unit_of_measurement=UNIT_PERCENT,
|
unit_of_measurement=UNIT_PERCENT,
|
||||||
|
@ -51,10 +50,9 @@ CONFIG_SCHEMA = cv.All(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await cg.register_component(var, config)
|
await cg.register_component(var, config)
|
||||||
await esp32_ble_tracker.register_ble_device(var, config)
|
await esp32_ble_tracker.register_ble_device(var, config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
|
|
||||||
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
cg.add(var.set_address(config[CONF_MAC_ADDRESS].as_hex))
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.components import binary_sensor
|
from esphome.components import binary_sensor
|
||||||
from esphome.const import CONF_ID
|
|
||||||
from . import (
|
from . import (
|
||||||
xpt2046_ns,
|
xpt2046_ns,
|
||||||
XPT2046Component,
|
XPT2046Component,
|
||||||
|
@ -27,9 +27,8 @@ def validate_xpt2046_button(config):
|
||||||
|
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
binary_sensor.BINARY_SENSOR_SCHEMA.extend(
|
binary_sensor.binary_sensor_schema(XPT2046Button).extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(XPT2046Button),
|
|
||||||
cv.GenerateID(CONF_XPT2046_ID): cv.use_id(XPT2046Component),
|
cv.GenerateID(CONF_XPT2046_ID): cv.use_id(XPT2046Component),
|
||||||
cv.Required(CONF_X_MIN): cv.int_range(min=0, max=4095),
|
cv.Required(CONF_X_MIN): cv.int_range(min=0, max=4095),
|
||||||
cv.Required(CONF_X_MAX): cv.int_range(min=0, max=4095),
|
cv.Required(CONF_X_MAX): cv.int_range(min=0, max=4095),
|
||||||
|
@ -42,8 +41,7 @@ CONFIG_SCHEMA = cv.All(
|
||||||
|
|
||||||
|
|
||||||
async def to_code(config):
|
async def to_code(config):
|
||||||
var = cg.new_Pvariable(config[CONF_ID])
|
var = await binary_sensor.new_binary_sensor(config)
|
||||||
await binary_sensor.register_binary_sensor(var, config)
|
|
||||||
hub = await cg.get_variable(config[CONF_XPT2046_ID])
|
hub = await cg.get_variable(config[CONF_XPT2046_ID])
|
||||||
cg.add(
|
cg.add(
|
||||||
var.set_area(
|
var.set_area(
|
||||||
|
|
Loading…
Reference in a new issue