mirror of
https://github.com/esphome/esphome.git
synced 2025-09-12 08:12:22 +01:00
225 lines
8.1 KiB
Python
225 lines
8.1 KiB
Python
from esphome import automation
|
|
import esphome.codegen as cg
|
|
from esphome.components import display, esp32, uart
|
|
import esphome.config_validation as cv
|
|
from esphome.const import (
|
|
CONF_BRIGHTNESS,
|
|
CONF_ID,
|
|
CONF_LAMBDA,
|
|
CONF_ON_TOUCH,
|
|
CONF_TRIGGER_ID,
|
|
)
|
|
from esphome.core import CORE, TimePeriod
|
|
|
|
from . import Nextion, nextion_ns, nextion_ref
|
|
from .base_component import (
|
|
CONF_AUTO_WAKE_ON_TOUCH,
|
|
CONF_COMMAND_SPACING,
|
|
CONF_DUMP_DEVICE_INFO,
|
|
CONF_EXIT_REPARSE_ON_START,
|
|
CONF_MAX_COMMANDS_PER_LOOP,
|
|
CONF_MAX_QUEUE_SIZE,
|
|
CONF_ON_BUFFER_OVERFLOW,
|
|
CONF_ON_PAGE,
|
|
CONF_ON_SETUP,
|
|
CONF_ON_SLEEP,
|
|
CONF_ON_WAKE,
|
|
CONF_SKIP_CONNECTION_HANDSHAKE,
|
|
CONF_START_UP_PAGE,
|
|
CONF_TFT_URL,
|
|
CONF_TOUCH_SLEEP_TIMEOUT,
|
|
CONF_WAKE_UP_PAGE,
|
|
)
|
|
|
|
CODEOWNERS = ["@senexcrenshaw", "@edwardtfn"]
|
|
|
|
DEPENDENCIES = ["uart"]
|
|
AUTO_LOAD = ["binary_sensor", "switch", "sensor", "text_sensor"]
|
|
|
|
NextionSetBrightnessAction = nextion_ns.class_(
|
|
"NextionSetBrightnessAction", automation.Action
|
|
)
|
|
SetupTrigger = nextion_ns.class_("SetupTrigger", automation.Trigger.template())
|
|
SleepTrigger = nextion_ns.class_("SleepTrigger", automation.Trigger.template())
|
|
WakeTrigger = nextion_ns.class_("WakeTrigger", automation.Trigger.template())
|
|
PageTrigger = nextion_ns.class_("PageTrigger", automation.Trigger.template())
|
|
TouchTrigger = nextion_ns.class_("TouchTrigger", automation.Trigger.template())
|
|
BufferOverflowTrigger = nextion_ns.class_(
|
|
"BufferOverflowTrigger", automation.Trigger.template()
|
|
)
|
|
|
|
CONFIG_SCHEMA = (
|
|
display.BASIC_DISPLAY_SCHEMA.extend(
|
|
{
|
|
cv.GenerateID(): cv.declare_id(Nextion),
|
|
cv.Optional(CONF_AUTO_WAKE_ON_TOUCH, default=True): cv.boolean,
|
|
cv.Optional(CONF_BRIGHTNESS): cv.percentage,
|
|
cv.Optional(CONF_COMMAND_SPACING): cv.All(
|
|
cv.positive_time_period_milliseconds,
|
|
cv.Range(max=TimePeriod(milliseconds=255)),
|
|
),
|
|
cv.Optional(CONF_DUMP_DEVICE_INFO, default=False): cv.boolean,
|
|
cv.Optional(CONF_EXIT_REPARSE_ON_START, default=False): cv.boolean,
|
|
cv.Optional(CONF_MAX_COMMANDS_PER_LOOP): cv.uint16_t,
|
|
cv.Optional(CONF_MAX_QUEUE_SIZE): cv.positive_int,
|
|
cv.Optional(CONF_ON_BUFFER_OVERFLOW): automation.validate_automation(
|
|
{
|
|
cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(
|
|
BufferOverflowTrigger
|
|
),
|
|
}
|
|
),
|
|
cv.Optional(CONF_ON_PAGE): automation.validate_automation(
|
|
{
|
|
cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(PageTrigger),
|
|
}
|
|
),
|
|
cv.Optional(CONF_ON_SETUP): automation.validate_automation(
|
|
{
|
|
cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(SetupTrigger),
|
|
}
|
|
),
|
|
cv.Optional(CONF_ON_SLEEP): automation.validate_automation(
|
|
{
|
|
cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(SleepTrigger),
|
|
}
|
|
),
|
|
cv.Optional(CONF_ON_TOUCH): automation.validate_automation(
|
|
{
|
|
cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(TouchTrigger),
|
|
}
|
|
),
|
|
cv.Optional(CONF_ON_WAKE): automation.validate_automation(
|
|
{
|
|
cv.GenerateID(CONF_TRIGGER_ID): cv.declare_id(WakeTrigger),
|
|
}
|
|
),
|
|
cv.Optional(CONF_SKIP_CONNECTION_HANDSHAKE, default=False): cv.boolean,
|
|
cv.Optional(CONF_START_UP_PAGE): cv.uint8_t,
|
|
cv.Optional(CONF_TFT_URL): cv.url,
|
|
cv.Optional(CONF_TOUCH_SLEEP_TIMEOUT): cv.Any(
|
|
0, cv.int_range(min=3, max=65535)
|
|
),
|
|
cv.Optional(CONF_WAKE_UP_PAGE): cv.uint8_t,
|
|
}
|
|
)
|
|
.extend(cv.polling_component_schema("5s"))
|
|
.extend(uart.UART_DEVICE_SCHEMA)
|
|
)
|
|
|
|
|
|
@automation.register_action(
|
|
"display.nextion.set_brightness",
|
|
NextionSetBrightnessAction,
|
|
cv.maybe_simple_value(
|
|
{
|
|
cv.GenerateID(): cv.use_id(Nextion),
|
|
cv.Required(CONF_BRIGHTNESS): cv.templatable(cv.percentage),
|
|
},
|
|
key=CONF_BRIGHTNESS,
|
|
),
|
|
)
|
|
async def nextion_set_brightness_to_code(config, action_id, template_arg, args):
|
|
paren = await cg.get_variable(config[CONF_ID])
|
|
var = cg.new_Pvariable(action_id, template_arg, paren)
|
|
|
|
template_ = await cg.templatable(config[CONF_BRIGHTNESS], args, float)
|
|
cg.add(var.set_brightness(template_))
|
|
|
|
return var
|
|
|
|
|
|
async def to_code(config):
|
|
var = cg.new_Pvariable(config[CONF_ID])
|
|
await uart.register_uart_device(var, config)
|
|
|
|
if max_queue_size := config.get(CONF_MAX_QUEUE_SIZE):
|
|
cg.add_define("USE_NEXTION_MAX_QUEUE_SIZE")
|
|
cg.add(var.set_max_queue_size(max_queue_size))
|
|
|
|
if command_spacing := config.get(CONF_COMMAND_SPACING):
|
|
cg.add_define("USE_NEXTION_COMMAND_SPACING")
|
|
cg.add(var.set_command_spacing(command_spacing.total_milliseconds))
|
|
|
|
if CONF_BRIGHTNESS in config:
|
|
cg.add(var.set_brightness(config[CONF_BRIGHTNESS]))
|
|
|
|
if CONF_LAMBDA in config:
|
|
lambda_ = await cg.process_lambda(
|
|
config[CONF_LAMBDA], [(nextion_ref, "it")], return_type=cg.void
|
|
)
|
|
cg.add(var.set_writer(lambda_))
|
|
|
|
if CONF_TFT_URL in config:
|
|
cg.add_define("USE_NEXTION_TFT_UPLOAD")
|
|
cg.add(var.set_tft_url(config[CONF_TFT_URL]))
|
|
if CORE.is_esp32 and CORE.using_arduino:
|
|
cg.add_library("NetworkClientSecure", None)
|
|
cg.add_library("HTTPClient", None)
|
|
elif CORE.is_esp32 and CORE.using_esp_idf:
|
|
esp32.add_idf_sdkconfig_option("CONFIG_ESP_TLS_INSECURE", True)
|
|
esp32.add_idf_sdkconfig_option(
|
|
"CONFIG_ESP_TLS_SKIP_SERVER_CERT_VERIFY", True
|
|
)
|
|
elif CORE.is_esp8266 and CORE.using_arduino:
|
|
cg.add_library("ESP8266HTTPClient", None)
|
|
|
|
if CONF_TOUCH_SLEEP_TIMEOUT in config:
|
|
cg.add(var.set_touch_sleep_timeout(config[CONF_TOUCH_SLEEP_TIMEOUT]))
|
|
|
|
if CONF_WAKE_UP_PAGE in config:
|
|
cg.add(var.set_wake_up_page(config[CONF_WAKE_UP_PAGE]))
|
|
|
|
if CONF_START_UP_PAGE in config:
|
|
cg.add_define("USE_NEXTION_CONF_START_UP_PAGE")
|
|
cg.add(var.set_start_up_page(config[CONF_START_UP_PAGE]))
|
|
|
|
cg.add(var.set_auto_wake_on_touch(config[CONF_AUTO_WAKE_ON_TOUCH]))
|
|
|
|
if config[CONF_DUMP_DEVICE_INFO]:
|
|
cg.add_define("USE_NEXTION_CONFIG_DUMP_DEVICE_INFO")
|
|
|
|
if config[CONF_EXIT_REPARSE_ON_START]:
|
|
cg.add_define("USE_NEXTION_CONFIG_EXIT_REPARSE_ON_START")
|
|
|
|
if config[CONF_SKIP_CONNECTION_HANDSHAKE]:
|
|
cg.add_define("USE_NEXTION_CONFIG_SKIP_CONNECTION_HANDSHAKE")
|
|
|
|
if max_commands_per_loop := config.get(CONF_MAX_COMMANDS_PER_LOOP):
|
|
cg.add_define("USE_NEXTION_MAX_COMMANDS_PER_LOOP")
|
|
cg.add(var.set_max_commands_per_loop(max_commands_per_loop))
|
|
|
|
await display.register_display(var, config)
|
|
|
|
for conf in config.get(CONF_ON_SETUP, []):
|
|
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
|
|
await automation.build_automation(trigger, [], conf)
|
|
|
|
for conf in config.get(CONF_ON_SLEEP, []):
|
|
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
|
|
await automation.build_automation(trigger, [], conf)
|
|
|
|
for conf in config.get(CONF_ON_WAKE, []):
|
|
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
|
|
await automation.build_automation(trigger, [], conf)
|
|
|
|
for conf in config.get(CONF_ON_PAGE, []):
|
|
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
|
|
await automation.build_automation(trigger, [(cg.uint8, "x")], conf)
|
|
|
|
for conf in config.get(CONF_ON_TOUCH, []):
|
|
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
|
|
await automation.build_automation(
|
|
trigger,
|
|
[
|
|
(cg.uint8, "page_id"),
|
|
(cg.uint8, "component_id"),
|
|
(cg.bool_, "touch_event"),
|
|
],
|
|
conf,
|
|
)
|
|
|
|
for conf in config.get(CONF_ON_BUFFER_OVERFLOW, []):
|
|
trigger = cg.new_Pvariable(conf[CONF_TRIGGER_ID], var)
|
|
await automation.build_automation(trigger, [], conf)
|