mirror of
https://github.com/GrKoR/esphome_aux_ac_component.git
synced 2025-12-06 11:36:55 +03:00
105 lines
3.6 KiB
Python
105 lines
3.6 KiB
Python
import logging
|
|
import esphome.config_validation as cv
|
|
import esphome.codegen as cg
|
|
from esphome.components import climate, uart
|
|
from esphome.const import (
|
|
CONF_ID,
|
|
CONF_NAME,
|
|
CONF_UART_ID,
|
|
CONF_PERIOD,
|
|
CONF_CUSTOM_FAN_MODES,
|
|
CONF_CUSTOM_PRESETS
|
|
)
|
|
from esphome.components.climate import (
|
|
ClimateMode,
|
|
ClimatePreset,
|
|
ClimateSwingMode,
|
|
)
|
|
_LOGGER = logging.getLogger(__name__)
|
|
|
|
CODEOWNERS = ["@GrKoR"]
|
|
DEPENDENCIES = ["climate", "uart"]
|
|
|
|
CONF_SUPPORTED_MODES = 'supported_modes'
|
|
CONF_SUPPORTED_SWING_MODES = 'supported_swing_modes'
|
|
CONF_SUPPORTED_PRESETS = 'supported_presets'
|
|
CONF_SHOW_ACTION = 'show_action'
|
|
|
|
aux_ac_ns = cg.esphome_ns.namespace("aux_ac")
|
|
AirCon = aux_ac_ns.class_("AirCon", climate.Climate, cg.Component)
|
|
Capabilities = aux_ac_ns.namespace("Constants")
|
|
|
|
ALLOWED_CLIMATE_MODES = {
|
|
"HEAT_COOL": ClimateMode.CLIMATE_MODE_HEAT_COOL,
|
|
"COOL": ClimateMode.CLIMATE_MODE_COOL,
|
|
"HEAT": ClimateMode.CLIMATE_MODE_HEAT,
|
|
"DRY": ClimateMode.CLIMATE_MODE_DRY,
|
|
"FAN_ONLY": ClimateMode.CLIMATE_MODE_FAN_ONLY,
|
|
}
|
|
validate_modes = cv.enum(ALLOWED_CLIMATE_MODES, upper=True)
|
|
|
|
ALLOWED_CLIMATE_PRESETS = {
|
|
"SLEEP": ClimatePreset.CLIMATE_PRESET_SLEEP,
|
|
}
|
|
validate_presets = cv.enum(ALLOWED_CLIMATE_PRESETS, upper=True)
|
|
|
|
ALLOWED_CLIMATE_SWING_MODES = {
|
|
"BOTH": ClimateSwingMode.CLIMATE_SWING_BOTH,
|
|
"VERTICAL": ClimateSwingMode.CLIMATE_SWING_VERTICAL,
|
|
"HORIZONTAL": ClimateSwingMode.CLIMATE_SWING_HORIZONTAL,
|
|
}
|
|
validate_swing_modes = cv.enum(ALLOWED_CLIMATE_SWING_MODES, upper=True)
|
|
|
|
CUSTOM_FAN_MODES = {
|
|
"MUTE": Capabilities.MUTE,
|
|
"TURBO": Capabilities.TURBO,
|
|
}
|
|
validate_custom_fan_modes = cv.enum(CUSTOM_FAN_MODES, upper=True)
|
|
|
|
CUSTOM_PRESETS = {
|
|
"CLEAN": Capabilities.CLEAN,
|
|
"FEEL": Capabilities.FEEL,
|
|
"HEALTH": Capabilities.HEALTH,
|
|
"ANTIFUNGUS": Capabilities.ANTIFUNGUS,
|
|
}
|
|
validate_custom_presets = cv.enum(CUSTOM_PRESETS, upper=True)
|
|
|
|
def output_info(config):
|
|
_LOGGER.info(config)
|
|
return config
|
|
|
|
CONFIG_SCHEMA = cv.All(
|
|
climate.CLIMATE_SCHEMA.extend(
|
|
{
|
|
cv.GenerateID(): cv.declare_id(AirCon),
|
|
cv.Optional(CONF_PERIOD, default="7s"): cv.time_period,
|
|
cv.Optional(CONF_SHOW_ACTION, default="true"): cv.boolean,
|
|
cv.Optional(CONF_SUPPORTED_MODES): cv.ensure_list(validate_modes),
|
|
cv.Optional(CONF_SUPPORTED_SWING_MODES): cv.ensure_list(validate_swing_modes),
|
|
cv.Optional(CONF_SUPPORTED_PRESETS): cv.ensure_list(validate_presets),
|
|
cv.Optional(CONF_CUSTOM_PRESETS): cv.ensure_list(validate_custom_presets),
|
|
cv.Optional(CONF_CUSTOM_FAN_MODES): cv.ensure_list(validate_custom_fan_modes),
|
|
}
|
|
)
|
|
.extend(uart.UART_DEVICE_SCHEMA)
|
|
.extend(cv.COMPONENT_SCHEMA),
|
|
output_info
|
|
)
|
|
|
|
async def to_code(config):
|
|
var = cg.new_Pvariable(config[CONF_ID])
|
|
await cg.register_component(var, config)
|
|
await climate.register_climate(var, config)
|
|
cg.add(var.set_period(config[CONF_PERIOD].total_milliseconds))
|
|
cg.add(var.set_show_action(config[CONF_SHOW_ACTION]))
|
|
if CONF_SUPPORTED_MODES in config:
|
|
cg.add(var.set_supported_modes(config[CONF_SUPPORTED_MODES]))
|
|
if CONF_SUPPORTED_SWING_MODES in config:
|
|
cg.add(var.set_supported_swing_modes(config[CONF_SUPPORTED_SWING_MODES]))
|
|
if CONF_SUPPORTED_PRESETS in config:
|
|
cg.add(var.set_supported_presets(config[CONF_SUPPORTED_PRESETS]))
|
|
if CONF_CUSTOM_PRESETS in config:
|
|
cg.add(var.set_custom_presets(config[CONF_CUSTOM_PRESETS]))
|
|
if CONF_CUSTOM_FAN_MODES in config:
|
|
cg.add(var.set_custom_fan_modes(config[CONF_CUSTOM_FAN_MODES]))
|
|
|