mirror of
https://github.com/esphome/esphome.git
synced 2025-01-07 13:21:44 +01:00
Fix usage of CONF_TYPE
This commit is contained in:
parent
64ff886806
commit
64d34b2879
5 changed files with 17 additions and 21 deletions
|
@ -28,26 +28,26 @@ def item_type_schema(value):
|
||||||
|
|
||||||
ITEM_TYPE_SCHEMA = cv.typed_schema(
|
ITEM_TYPE_SCHEMA = cv.typed_schema(
|
||||||
{
|
{
|
||||||
text_panel.CONF_TYPE: text_panel.get_config_schema(
|
text_panel.CONF_TEXT_PANEL: text_panel.get_config_schema(
|
||||||
BASE_ITEM_SCHEMA, item_type_schema
|
BASE_ITEM_SCHEMA, item_type_schema
|
||||||
),
|
),
|
||||||
horizontal_stack.CONF_TYPE: horizontal_stack.get_config_schema(
|
horizontal_stack.CONF_HORIZONTAL_STACK: horizontal_stack.get_config_schema(
|
||||||
BASE_ITEM_SCHEMA, item_type_schema
|
BASE_ITEM_SCHEMA, item_type_schema
|
||||||
),
|
),
|
||||||
vertical_stack.CONF_TYPE: vertical_stack.get_config_schema(
|
vertical_stack.CONF_VERTICAL_STACK: vertical_stack.get_config_schema(
|
||||||
BASE_ITEM_SCHEMA, item_type_schema
|
BASE_ITEM_SCHEMA, item_type_schema
|
||||||
),
|
),
|
||||||
display_rendering_panel.CONF_TYPE: display_rendering_panel.get_config_schema(
|
display_rendering_panel.CONF_DISPLAY_RENDERING_PANEL: display_rendering_panel.get_config_schema(
|
||||||
BASE_ITEM_SCHEMA, item_type_schema
|
BASE_ITEM_SCHEMA, item_type_schema
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
CODE_GENERATORS = {
|
CODE_GENERATORS = {
|
||||||
text_panel.CONF_TYPE: text_panel.config_to_layout_item,
|
text_panel.CONF_TEXT_PANEL: text_panel.config_to_layout_item,
|
||||||
horizontal_stack.CONF_TYPE: horizontal_stack.config_to_layout_item,
|
horizontal_stack.CONF_HORIZONTAL_STACK: horizontal_stack.config_to_layout_item,
|
||||||
vertical_stack.CONF_TYPE: vertical_stack.config_to_layout_item,
|
vertical_stack.CONF_VERTICAL_STACK: vertical_stack.config_to_layout_item,
|
||||||
display_rendering_panel.CONF_TYPE: display_rendering_panel.config_to_layout_item,
|
display_rendering_panel.CONF_DISPLAY_RENDERING_PANEL: display_rendering_panel.config_to_layout_item,
|
||||||
}
|
}
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.Schema(
|
CONFIG_SCHEMA = cv.Schema(
|
||||||
|
|
|
@ -6,7 +6,7 @@ from esphome.components.display import DisplayRef
|
||||||
graphical_layout_ns = cg.esphome_ns.namespace("graphical_layout")
|
graphical_layout_ns = cg.esphome_ns.namespace("graphical_layout")
|
||||||
DisplayRenderingPanel = graphical_layout_ns.class_("DisplayRenderingPanel")
|
DisplayRenderingPanel = graphical_layout_ns.class_("DisplayRenderingPanel")
|
||||||
|
|
||||||
CONF_TYPE = "display_rendering_panel"
|
CONF_DISPLAY_RENDERING_PANEL = "display_rendering_panel"
|
||||||
|
|
||||||
|
|
||||||
def get_config_schema(base_item_schema, item_type_schema):
|
def get_config_schema(base_item_schema, item_type_schema):
|
||||||
|
|
|
@ -1,14 +1,13 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.const import CONF_ID
|
from esphome.const import CONF_ID, CONF_TYPE
|
||||||
|
|
||||||
graphical_layout_ns = cg.esphome_ns.namespace("graphical_layout")
|
graphical_layout_ns = cg.esphome_ns.namespace("graphical_layout")
|
||||||
HorizontalStack = graphical_layout_ns.class_("HorizontalStack")
|
HorizontalStack = graphical_layout_ns.class_("HorizontalStack")
|
||||||
|
|
||||||
CONF_ITEM_PADDING = "item_padding"
|
CONF_ITEM_PADDING = "item_padding"
|
||||||
CONF_TYPE = "horizontal_stack"
|
CONF_HORIZONTAL_STACK = "horizontal_stack"
|
||||||
CONF_ITEMS = "items"
|
CONF_ITEMS = "items"
|
||||||
CONF_TYPE_KEY = "type"
|
|
||||||
|
|
||||||
|
|
||||||
def get_config_schema(base_item_schema, item_type_schema):
|
def get_config_schema(base_item_schema, item_type_schema):
|
||||||
|
@ -30,7 +29,7 @@ async def config_to_layout_item(item_config, child_item_builder):
|
||||||
cg.add(var.set_item_padding(item_padding_config))
|
cg.add(var.set_item_padding(item_padding_config))
|
||||||
|
|
||||||
for child_item_config in item_config[CONF_ITEMS]:
|
for child_item_config in item_config[CONF_ITEMS]:
|
||||||
child_item_type = child_item_config[CONF_TYPE_KEY]
|
child_item_type = child_item_config[CONF_TYPE]
|
||||||
if child_item_type in child_item_builder:
|
if child_item_type in child_item_builder:
|
||||||
child_item_var = await child_item_builder[child_item_type](
|
child_item_var = await child_item_builder[child_item_type](
|
||||||
child_item_config, child_item_builder
|
child_item_config, child_item_builder
|
||||||
|
|
|
@ -7,7 +7,7 @@ graphical_layout_ns = cg.esphome_ns.namespace("graphical_layout")
|
||||||
TextPanel = graphical_layout_ns.class_("TextPanel")
|
TextPanel = graphical_layout_ns.class_("TextPanel")
|
||||||
|
|
||||||
CONF_ITEM_PADDING = "item_padding"
|
CONF_ITEM_PADDING = "item_padding"
|
||||||
CONF_TYPE = "text_panel"
|
CONF_TEXT_PANEL = "text_panel"
|
||||||
CONF_FONT = "font"
|
CONF_FONT = "font"
|
||||||
CONF_FOREGROUND_COLOR = "foreground_color"
|
CONF_FOREGROUND_COLOR = "foreground_color"
|
||||||
CONF_BACKGROUND_COLOR = "background_color"
|
CONF_BACKGROUND_COLOR = "background_color"
|
||||||
|
@ -18,9 +18,7 @@ def get_config_schema(base_item_schema, item_type_schema):
|
||||||
return base_item_schema.extend(
|
return base_item_schema.extend(
|
||||||
{
|
{
|
||||||
cv.GenerateID(): cv.declare_id(TextPanel),
|
cv.GenerateID(): cv.declare_id(TextPanel),
|
||||||
cv.Optional(CONF_ITEM_PADDING, default=0): cv.templatable(
|
cv.Optional(CONF_ITEM_PADDING, default=0): cv.templatable(cv.int_),
|
||||||
cv.int_
|
|
||||||
),
|
|
||||||
cv.Required(CONF_FONT): cv.use_id(font.Font),
|
cv.Required(CONF_FONT): cv.use_id(font.Font),
|
||||||
cv.Optional(CONF_FOREGROUND_COLOR): cv.use_id(color.ColorStruct),
|
cv.Optional(CONF_FOREGROUND_COLOR): cv.use_id(color.ColorStruct),
|
||||||
cv.Optional(CONF_BACKGROUND_COLOR): cv.use_id(color.ColorStruct),
|
cv.Optional(CONF_BACKGROUND_COLOR): cv.use_id(color.ColorStruct),
|
||||||
|
|
|
@ -1,14 +1,13 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
import esphome.config_validation as cv
|
||||||
from esphome.const import CONF_ID
|
from esphome.const import CONF_ID, CONF_TYPE
|
||||||
|
|
||||||
graphical_layout_ns = cg.esphome_ns.namespace("graphical_layout")
|
graphical_layout_ns = cg.esphome_ns.namespace("graphical_layout")
|
||||||
VerticalStack = graphical_layout_ns.class_("VerticalStack")
|
VerticalStack = graphical_layout_ns.class_("VerticalStack")
|
||||||
|
|
||||||
CONF_ITEM_PADDING = "item_padding"
|
CONF_ITEM_PADDING = "item_padding"
|
||||||
CONF_TYPE = "vertical_stack"
|
CONF_VERTICAL_STACK = "vertical_stack"
|
||||||
CONF_ITEMS = "items"
|
CONF_ITEMS = "items"
|
||||||
CONF_TYPE_KEY = "type"
|
|
||||||
|
|
||||||
|
|
||||||
def get_config_schema(base_item_schema, item_type_schema):
|
def get_config_schema(base_item_schema, item_type_schema):
|
||||||
|
@ -30,7 +29,7 @@ async def config_to_layout_item(item_config, child_item_builder):
|
||||||
cg.add(var.set_item_padding(item_padding_config))
|
cg.add(var.set_item_padding(item_padding_config))
|
||||||
|
|
||||||
for child_item_config in item_config[CONF_ITEMS]:
|
for child_item_config in item_config[CONF_ITEMS]:
|
||||||
child_item_type = child_item_config[CONF_TYPE_KEY]
|
child_item_type = child_item_config[CONF_TYPE]
|
||||||
if child_item_type in child_item_builder:
|
if child_item_type in child_item_builder:
|
||||||
child_item_var = await child_item_builder[child_item_type](
|
child_item_var = await child_item_builder[child_item_type](
|
||||||
child_item_config, child_item_builder
|
child_item_config, child_item_builder
|
||||||
|
|
Loading…
Reference in a new issue