From 3308c07b22addec2b0be9ee8814479da5460091c Mon Sep 17 00:00:00 2001 From: Till Date: Fri, 26 Jan 2024 22:18:18 +0100 Subject: [PATCH] Component file structure refactor (#3) * Refactor separate switch component into nested switch component * Refactor separate button component into nested button component * Refactor separate binary_sensor component into nested binary_sensor component * Refactor separate sensor component into nested sensor component * Refactor switch and button component to be in-line with ESPHomes standard --- .clang-format | 1 + README.md | 105 ++++++++++-------- components/desk_height_sensor/__init__.py | 0 components/desk_height_sensor/sensor.py | 35 ------ components/desk_is_moving_sensor/__init__.py | 0 components/desk_memory_button/__init__.py | 0 components/desk_memory_button/button.py | 31 ------ components/desk_switch/__init__.py | 0 components/desk_switch/switch.py | 29 ----- components/generic_desk/__init__.py | 11 +- .../binary_sensor/__init__.py} | 2 +- components/generic_desk/button/__init__.py | 50 +++++++++ .../button}/desk_memory_button.cpp | 0 .../button}/desk_memory_button.h | 10 +- components/generic_desk/generic_desk.cpp | 13 +++ components/generic_desk/generic_desk.h | 55 +++++++-- components/generic_desk/sensor/__init__.py | 19 ++++ components/generic_desk/switch/__init__.py | 45 ++++++++ .../switch}/desk_switch.cpp | 0 .../switch}/desk_switch.h | 10 +- desk.yaml | 44 +++----- tests/full.yaml | 46 +++----- 22 files changed, 285 insertions(+), 221 deletions(-) delete mode 100644 components/desk_height_sensor/__init__.py delete mode 100644 components/desk_height_sensor/sensor.py delete mode 100644 components/desk_is_moving_sensor/__init__.py delete mode 100644 components/desk_memory_button/__init__.py delete mode 100644 components/desk_memory_button/button.py delete mode 100644 components/desk_switch/__init__.py delete mode 100644 components/desk_switch/switch.py rename components/{desk_is_moving_sensor/binary_sensor.py => generic_desk/binary_sensor/__init__.py} (89%) create mode 100644 components/generic_desk/button/__init__.py rename components/{desk_memory_button => generic_desk/button}/desk_memory_button.cpp (100%) rename components/{desk_memory_button => generic_desk/button}/desk_memory_button.h (69%) create mode 100644 components/generic_desk/sensor/__init__.py create mode 100644 components/generic_desk/switch/__init__.py rename components/{desk_switch => generic_desk/switch}/desk_switch.cpp (100%) rename components/{desk_switch => generic_desk/switch}/desk_switch.h (71%) diff --git a/.clang-format b/.clang-format index a565c3b..d3c185d 100644 --- a/.clang-format +++ b/.clang-format @@ -4,6 +4,7 @@ NamespaceIndentation: All AccessModifierOffset: -4 BreakBeforeBraces: Allman AllowShortIfStatementsOnASingleLine: false +AllowShortFunctionsOnASingleLine: false IndentCaseLabels: false SortIncludes: false ColumnLimit: 0 diff --git a/README.md b/README.md index a133db5..14bc3d2 100644 --- a/README.md +++ b/README.md @@ -15,6 +15,7 @@ This is a custom Component for [ESPHome](https://esphome.io/) based on the [ESPH - Home Assistant Core 2021.12 or higher ## Usage + ```yaml external_components: - source: github://TillFleisch/ESPHomeGenericSitStandDesk@main @@ -35,70 +36,84 @@ generic_desk: correction_term: 1.24836 sensor: - - platform: desk_height_sensor + - platform: generic_desk desk_id: desk1 id: desk_height name: "Desk Height" binary_sensor: - - platform: desk_is_moving_sensor - desk_id: desk1 - id: desk_is_moving - name: "Desk is Moving" - -switch: - - platform: desk_switch + - platform: generic_desk desk_id: desk1 - name: "Up" - direction: true + id: desk_is_moving + name: "Desk is Moving" - - platform: desk_switch +switch: + - platform: generic_desk desk_id: desk1 - name: "Down" - direction: false + up: + name: "Up" + down: + name: "Down" button: - - platform: desk_memory_button + - platform: generic_desk desk_id: desk1 - name: "M1" - memory_id: 1 + M1: + name: "M1" + M2: + name: "M2" + M3: + name: "M3" + M4: + name: "M4" +``` - - platform: desk_memory_button - desk_id: desk1 - name: "M2" - memory_id: 2 +An example configuration can be found [here](desk.yaml). - - platform: desk_memory_button - desk_id: desk1 - name: "M3" - memory_id: 3 +## Generic Desk - - platform: desk_memory_button - desk_id: desk1 - name: "M4" - memory_id: 4 -``` -An example configuration can be found [here](desk.yaml). +The desks hub component to which other components refer. -## Entities -This Component can provide the following entities: +- **id**(**Required**, string): Controller ID which will be used by other components to refer to this desk. +- **display_uart**(**Required**, string): ID of the UART-Component connected desk-controller. +- **base_height**(**Required**, float): The Desks height measured in the lowest position in cm. +- **correction_term**(**Optional**, float): Optional correction factor, in case the height does not scale properly -**Controls:** -- M1 -- M2 -- M3 -- M4 -- Up -- Down +## Sensor -**Sensors:** -- height -- is moving +A sensor which reports the current height of the desk in cm. +- **desk_id**(**Required**, string): The desk controllers id to which this sensor belongs. +- All other options from [Sensor](https://esphome.io/components/sensor/index.html#base-sensor-configuration) + +## Binary Sensor + +A binary sensor which reports if the desk is currently moving. + +- **desk_id**(**Required**, string): The desk controllers id to which this binary sensor belongs. +- All other options from [Binary Sensor](https://esphome.io/components/binary_sensor/index.html#base-binary-sensor-configuration) + +## Switch + +Switches which control the desks movement. + +- **desk_id**(**Required**, string): The desk controllers id to which switches belongs. +- **up**(**Optional**): Moves the desk upwards. May contain all other options from [Switch](https://esphome.io/components/switch/index.html#base-switch-configuration). +- **down**(**Optional**): Moves the desk downwards. May contain all other options from [Switch](https://esphome.io/components/switch/index.html#base-switch-configuration). + +## Button + +Buttons which select a preset on the desks controller. + +- **desk_id**(**Required**, string): The desk controllers id to which buttons belongs. +- **M1**(**Optional**): Activates the `M1` preset. May contain all other options from [Button](https://esphome.io/components/button/index.html#base-button-configuration). +- **M2**(**Optional**): Activates the `M2` preset. May contain all other options from [Button](https://esphome.io/components/button/index.html#base-button-configuration). +- **M3**(**Optional**): Activates the `M3` preset. May contain all other options from [Button](https://esphome.io/components/button/index.html#base-button-configuration). +- **M4**(**Optional**): Activates the `M4` preset. May contain all other options from [Button](https://esphome.io/components/button/index.html#base-button-configuration). ## Wiring -On my particular model the Handset is connected via a RJ-45 connector. +On my particular model the Handset is connected via a RJ-45 connector. Control Box|Handset :-:|:-: @@ -117,9 +132,9 @@ GND ------- 6 (Green) - GND TX ------- 7 (Brown/White) - RX RX ------- 8 (Brown) - TX ``` -Be aware that most ESPs run on 3.3v! +Be aware that most ESPs run on 3.3v! ## Communication -For information regarding the communication between the Controller and Handset look [here](communication.md). +For information regarding the communication between the Controller and Handset look [here](communication.md). diff --git a/components/desk_height_sensor/__init__.py b/components/desk_height_sensor/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/components/desk_height_sensor/sensor.py b/components/desk_height_sensor/sensor.py deleted file mode 100644 index 8d5d4aa..0000000 --- a/components/desk_height_sensor/sensor.py +++ /dev/null @@ -1,35 +0,0 @@ -import esphome.codegen as cg -import esphome.config_validation as cv -from esphome.components import sensor -from esphome.const import CONF_ID, ICON_ARROW_EXPAND_VERTICAL - -from ..generic_desk import CONF_DESK_ID, GenericDesk - -DEPENDENCIES = ["generic_desk"] - -generic_desk_sensor_ns = cg.esphome_ns.namespace("generic_desk") -GenericDeskSensor = generic_desk_sensor_ns.class_( - "GenericDesk", sensor.Sensor, cg.PollingComponent -) - -CONFIG_SCHEMA = ( - sensor.sensor_schema( - unit_of_measurement="cm", icon=ICON_ARROW_EXPAND_VERTICAL, accuracy_decimals=1 - ) - .extend( - { - cv.GenerateID(): cv.declare_id(GenericDeskSensor), - cv.GenerateID(CONF_DESK_ID): cv.use_id(GenericDesk), - } - ) - .extend(cv.COMPONENT_SCHEMA) -) - - -def to_code(config): - parent = yield cg.get_variable(config[CONF_DESK_ID]) - var = cg.new_Pvariable(config[CONF_ID]) - - yield sensor.register_sensor(var, config) - - cg.add(parent.register_sensor(var)) diff --git a/components/desk_is_moving_sensor/__init__.py b/components/desk_is_moving_sensor/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/components/desk_memory_button/__init__.py b/components/desk_memory_button/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/components/desk_memory_button/button.py b/components/desk_memory_button/button.py deleted file mode 100644 index 4d5af44..0000000 --- a/components/desk_memory_button/button.py +++ /dev/null @@ -1,31 +0,0 @@ -import esphome.codegen as cg -import esphome.config_validation as cv -from esphome.components import button -from esphome.const import CONF_ID - -from ..generic_desk import CONF_DESK_ID, GenericDesk - -DEPENDENCIES = ["generic_desk"] - -CONF_MEMORY_BUTTON_ID = "memory_id" - -memory_button_ns = cg.esphome_ns.namespace("memory_button") -MemoryButton = memory_button_ns.class_("MemoryButton", button.Button, cg.Component) - -CONFIG_SCHEMA = button.BUTTON_SCHEMA.extend( - { - cv.GenerateID(): cv.declare_id(MemoryButton), - cv.GenerateID(CONF_DESK_ID): cv.use_id(GenericDesk), - cv.Required(CONF_MEMORY_BUTTON_ID): cv.int_, - } -).extend(cv.COMPONENT_SCHEMA) - - -async def to_code(config): - parent = await cg.get_variable(config[CONF_DESK_ID]) - var = cg.new_Pvariable(config[CONF_ID]) - await cg.register_component(var, config) - await button.register_button(var, config) - - cg.add(var.set_memory_id(config[CONF_MEMORY_BUTTON_ID])) - cg.add(parent.add_button(var)) diff --git a/components/desk_switch/__init__.py b/components/desk_switch/__init__.py deleted file mode 100644 index e69de29..0000000 diff --git a/components/desk_switch/switch.py b/components/desk_switch/switch.py deleted file mode 100644 index bf66c6f..0000000 --- a/components/desk_switch/switch.py +++ /dev/null @@ -1,29 +0,0 @@ -import esphome.codegen as cg -import esphome.config_validation as cv -from esphome.components import switch -from esphome.const import CONF_ID - -from ..generic_desk import CONF_DESK_ID, GenericDesk - -CONF_DIRECTION = "direction" - -desk_switch_ns = cg.esphome_ns.namespace("desk_switch") -DeskSwitch = desk_switch_ns.class_("DeskSwitch", switch.Switch, cg.Component) - -CONFIG_SCHEMA = switch.SWITCH_SCHEMA.extend( - { - cv.GenerateID(): cv.declare_id(DeskSwitch), - cv.GenerateID(CONF_DESK_ID): cv.use_id(GenericDesk), - cv.Required(CONF_DIRECTION): cv.boolean, - } -).extend(cv.COMPONENT_SCHEMA) - - -async def to_code(config): - parent = await cg.get_variable(config[CONF_DESK_ID]) - var = cg.new_Pvariable(config[CONF_ID]) - await cg.register_component(var, config) - await switch.register_switch(var, config) - - cg.add(var.set_direction(config[CONF_DIRECTION])) - cg.add(parent.add_switch(var)) diff --git a/components/generic_desk/__init__.py b/components/generic_desk/__init__.py index cbc8069..8b09980 100644 --- a/components/generic_desk/__init__.py +++ b/components/generic_desk/__init__.py @@ -5,16 +5,7 @@ from esphome.const import CONF_ID DEPENDENCIES = ["uart"] -AUTO_LOAD = [ - "desk_memory_button", - "desk_switch", - "desk_height_sensor", - "desk_is_moving_sensor", - "sensor", - "binary_sensor", - "button", - "switch", -] + MULTI_CONF = True CONF_DESK_ID = "desk_id" diff --git a/components/desk_is_moving_sensor/binary_sensor.py b/components/generic_desk/binary_sensor/__init__.py similarity index 89% rename from components/desk_is_moving_sensor/binary_sensor.py rename to components/generic_desk/binary_sensor/__init__.py index 2bc9195..57144ec 100644 --- a/components/desk_is_moving_sensor/binary_sensor.py +++ b/components/generic_desk/binary_sensor/__init__.py @@ -2,7 +2,7 @@ import esphome.config_validation as cv from esphome.components import binary_sensor -from ..generic_desk import CONF_DESK_ID, GenericDesk +from .. import CONF_DESK_ID, GenericDesk DEPENDENCIES = ["generic_desk"] diff --git a/components/generic_desk/button/__init__.py b/components/generic_desk/button/__init__.py new file mode 100644 index 0000000..34ff4aa --- /dev/null +++ b/components/generic_desk/button/__init__.py @@ -0,0 +1,50 @@ +import esphome.codegen as cg +import esphome.config_validation as cv +from esphome.components import button +from esphome.const import CONF_ID + +from .. import CONF_DESK_ID, GenericDesk + +DEPENDENCIES = ["generic_desk"] + +CONF_MEMORY_ID_1 = "M1" +CONF_MEMORY_ID_2 = "M2" +CONF_MEMORY_ID_3 = "M3" +CONF_MEMORY_ID_4 = "M4" + +ID_CONFIGS = [ + CONF_MEMORY_ID_1, + CONF_MEMORY_ID_2, + CONF_MEMORY_ID_3, + CONF_MEMORY_ID_4, +] + +memory_button_ns = cg.esphome_ns.namespace("memory_button") +MemoryButton = memory_button_ns.class_("MemoryButton", button.Button, cg.Component) + +BUTTON_CONFIG = button.BUTTON_SCHEMA.extend( + {cv.GenerateID(): cv.declare_id(MemoryButton)} +).extend(cv.COMPONENT_SCHEMA) + +CONFIG_SCHEMA = cv.All( + cv.Schema( + { + cv.GenerateID(CONF_DESK_ID): cv.use_id(GenericDesk), + cv.Optional(CONF_MEMORY_ID_1): BUTTON_CONFIG, + cv.Optional(CONF_MEMORY_ID_2): BUTTON_CONFIG, + cv.Optional(CONF_MEMORY_ID_3): BUTTON_CONFIG, + cv.Optional(CONF_MEMORY_ID_4): BUTTON_CONFIG, + } + ), + cv.has_at_least_one_key(*ID_CONFIGS), +) + + +async def to_code(config): + parent = await cg.get_variable(config[CONF_DESK_ID]) + + for id, config_id in enumerate(ID_CONFIGS): + if button_config := config.get(config_id): + var = await button.new_button(button_config) + cg.add(var.set_memory_id(id)) + cg.add(parent.add_button(var)) diff --git a/components/desk_memory_button/desk_memory_button.cpp b/components/generic_desk/button/desk_memory_button.cpp similarity index 100% rename from components/desk_memory_button/desk_memory_button.cpp rename to components/generic_desk/button/desk_memory_button.cpp diff --git a/components/desk_memory_button/desk_memory_button.h b/components/generic_desk/button/desk_memory_button.h similarity index 69% rename from components/desk_memory_button/desk_memory_button.h rename to components/generic_desk/button/desk_memory_button.h index 8b1ef59..8392565 100644 --- a/components/desk_memory_button/desk_memory_button.h +++ b/components/generic_desk/button/desk_memory_button.h @@ -15,8 +15,14 @@ namespace esphome { public: void dump_config() override; - void set_memory_id(int id) { this->memory_id = id - 1; }; - void set_uart_device(uart::UARTDevice *uart_device) { this->uart_device = uart_device; }; + void set_memory_id(int id) + { + this->memory_id = id; + }; + void set_uart_device(uart::UARTDevice *uart_device) + { + this->uart_device = uart_device; + }; protected: void press_action() override; diff --git a/components/generic_desk/generic_desk.cpp b/components/generic_desk/generic_desk.cpp index 9fc76fd..7376ce8 100644 --- a/components/generic_desk/generic_desk.cpp +++ b/components/generic_desk/generic_desk.cpp @@ -39,23 +39,32 @@ namespace esphome if (height != last_height) { last_height = height; +#ifdef USE_SENSOR for (auto *height_sensor : this->height_sensors) height_sensor->publish_state(height); +#endif +#ifdef USE_BINARY_SENSOR for (auto *moving_sensor : this->moving_sensors) moving_sensor->publish_state(true); +#endif + desk_moving_debounce_counter = 0; } // Debounce desk is moving to prevent state flickering if (desk_moving_debounce_counter == DESK_MOVING_DEBOUNCE_THRESHOLD) { +#ifdef USE_BINARY_SENSOR // Set all sensors to false for (auto *moving_sensor : this->moving_sensors) moving_sensor->publish_state(false); +#endif +#ifdef USE_SWITCH // Reset switches for (auto *desk_switch : this->desk_switches) desk_switch->publish_state(false); +#endif desk_moving_debounce_counter++; } @@ -75,10 +84,14 @@ namespace esphome void GenericDesk::dump_config() { ESP_LOGCONFIG(TAG, "Generic SitStand Desk"); +#ifdef USE_SENSOR for (auto *height_sensor : this->height_sensors) LOG_SENSOR("", "Height sensor: ", height_sensor); +#endif +#ifdef USE_BINARY_SENSOR for (auto *moving_sensor : this->moving_sensors) LOG_BINARY_SENSOR("", "Is Moving binary sensor: ", moving_sensor); +#endif } /** diff --git a/components/generic_desk/generic_desk.h b/components/generic_desk/generic_desk.h index 72316ab..b69fe64 100644 --- a/components/generic_desk/generic_desk.h +++ b/components/generic_desk/generic_desk.h @@ -2,10 +2,18 @@ #include "esphome/core/component.h" #include "esphome/components/uart/uart.h" +#ifdef USE_SENSOR #include "esphome/components/sensor/sensor.h" +#endif +#ifdef USE_BINARY_SENSOR #include "esphome/components/binary_sensor/binary_sensor.h" -#include "../desk_memory_button/desk_memory_button.h" -#include "../desk_switch/desk_switch.h" +#endif +#ifdef USE_BUTTON +#include "./button/desk_memory_button.h" +#endif +#ifdef USE_SWITCH +#include "./switch/desk_switch.h" +#endif #define DESK_MOVING_DEBOUNCE_THRESHOLD 3 @@ -14,29 +22,58 @@ namespace esphome namespace generic_desk { - class GenericDesk : public uart::UARTDevice, public sensor::Sensor, public PollingComponent + class GenericDesk : public uart::UARTDevice, public PollingComponent { public: void setup() override; void loop() override; void update() override; void dump_config() override; - void register_sensor(sensor::Sensor *obj) { this->height_sensors.push_back(obj); } - void register_binary_sensor(binary_sensor::BinarySensor *obj) { this->moving_sensors.push_back(obj); } - void set_base_height(float base_height) { this->base_height = base_height; } - void set_correction_term(float correction_term) { this->correction_term = correction_term; } - void add_button(memory_button::MemoryButton *button) { button->set_uart_device(static_cast(this)); } +#ifdef USE_SENSOR + void register_sensor(sensor::Sensor *obj) + { + this->height_sensors.push_back(obj); + } +#endif +#ifdef USE_BINARY_SENSOR + void register_binary_sensor(binary_sensor::BinarySensor *obj) + { + this->moving_sensors.push_back(obj); + } +#endif + void set_base_height(float base_height) + { + this->base_height = base_height; + } + void set_correction_term(float correction_term) + { + this->correction_term = correction_term; + } +#ifdef USE_BUTTON + void add_button(memory_button::MemoryButton *button) + { + button->set_uart_device(static_cast(this)); + } +#endif +#ifdef USE_SWITCH void add_switch(desk_switch::DeskSwitch *switch_) { this->desk_switches.push_back(switch_); switch_->set_uart_device(static_cast(this)); } +#endif private: uint16_t crc16(const uint8_t *data, uint8_t len); +#ifdef USE_SENSOR std::vector height_sensors; +#endif +#ifdef USE_BINARY_SENSOR std::vector moving_sensors; +#endif +#ifdef USE_SWITCH std::vector desk_switches; +#endif /** * @brief The desks base height in CM. Measured in the lowest position. @@ -59,7 +96,7 @@ namespace esphome int desk_moving_debounce_counter = 0; /** - * @breif The Desks current height + * @brief The Desks current height * * */ float height = 0.0; diff --git a/components/generic_desk/sensor/__init__.py b/components/generic_desk/sensor/__init__.py new file mode 100644 index 0000000..d6e1654 --- /dev/null +++ b/components/generic_desk/sensor/__init__.py @@ -0,0 +1,19 @@ +import esphome.codegen as cg +import esphome.config_validation as cv +from esphome.components import sensor +from esphome.const import CONF_ID, ICON_ARROW_EXPAND_VERTICAL + +from .. import CONF_DESK_ID, GenericDesk + +DEPENDENCIES = ["generic_desk"] + +CONFIG_SCHEMA = sensor.sensor_schema( + unit_of_measurement="cm", icon=ICON_ARROW_EXPAND_VERTICAL, accuracy_decimals=1 +).extend({cv.GenerateID(CONF_DESK_ID): cv.use_id(GenericDesk)}) + + +async def to_code(config): + parent = await cg.get_variable(config[CONF_DESK_ID]) + var = await sensor.new_sensor(config) + + cg.add(parent.register_sensor(var)) diff --git a/components/generic_desk/switch/__init__.py b/components/generic_desk/switch/__init__.py new file mode 100644 index 0000000..2acfc3f --- /dev/null +++ b/components/generic_desk/switch/__init__.py @@ -0,0 +1,45 @@ +import esphome.codegen as cg +import esphome.config_validation as cv +from esphome.components import switch +from esphome.const import CONF_ID + +from .. import CONF_DESK_ID, GenericDesk + +CONF_UP = "up" +CONF_DOWN = "down" + +desk_switch_ns = cg.esphome_ns.namespace("desk_switch") +DeskSwitch = desk_switch_ns.class_("DeskSwitch", switch.Switch, cg.Component) + +SWITCH_CONFIG = switch.SWITCH_SCHEMA.extend( + {cv.GenerateID(): cv.declare_id(DeskSwitch)} +).extend(cv.COMPONENT_SCHEMA) + +CONFIG_SCHEMA = cv.All( + cv.Schema( + { + cv.GenerateID(CONF_DESK_ID): cv.use_id(GenericDesk), + cv.Optional(CONF_UP): SWITCH_CONFIG, + cv.Optional(CONF_DOWN): SWITCH_CONFIG, + } + ), + cv.has_at_least_one_key(CONF_DOWN, CONF_UP), +) + + +async def to_code(config): + parent = await cg.get_variable(config[CONF_DESK_ID]) + + if up_config := config.get(CONF_UP): + var = await switch.new_switch(up_config) + await cg.register_component(var, up_config) + + cg.add(var.set_direction(True)) + cg.add(parent.add_switch(var)) + + if down_config := config.get(CONF_DOWN): + var = await switch.new_switch(down_config) + await cg.register_component(var, down_config) + + cg.add(var.set_direction(False)) + cg.add(parent.add_switch(var)) diff --git a/components/desk_switch/desk_switch.cpp b/components/generic_desk/switch/desk_switch.cpp similarity index 100% rename from components/desk_switch/desk_switch.cpp rename to components/generic_desk/switch/desk_switch.cpp diff --git a/components/desk_switch/desk_switch.h b/components/generic_desk/switch/desk_switch.h similarity index 71% rename from components/desk_switch/desk_switch.h rename to components/generic_desk/switch/desk_switch.h index f74698e..e47886b 100644 --- a/components/desk_switch/desk_switch.h +++ b/components/generic_desk/switch/desk_switch.h @@ -16,8 +16,14 @@ namespace esphome void setup() override; void write_state(bool state) override; void dump_config() override; - void set_direction(bool direction) { this->direction = direction; }; - void set_uart_device(uart::UARTDevice *uart_device) { this->uart_device = uart_device; }; + void set_direction(bool direction) + { + this->direction = direction; + }; + void set_uart_device(uart::UARTDevice *uart_device) + { + this->uart_device = uart_device; + }; protected: uint32_t last_send = 0; diff --git a/desk.yaml b/desk.yaml index d46cb5d..79c0db9 100644 --- a/desk.yaml +++ b/desk.yaml @@ -42,45 +42,33 @@ generic_desk: correction_term: 1.24836 sensor: - - platform: desk_height_sensor + - platform: generic_desk desk_id: desk1 id: desk_height name: "Desk Height" binary_sensor: - - platform: desk_is_moving_sensor + - platform: generic_desk desk_id: desk1 id: desk_is_moving name: "Desk is Moving" switch: - - platform: desk_switch + - platform: generic_desk desk_id: desk1 - name: "Up" - direction: true - - - platform: desk_switch - desk_id: desk1 - name: "Down" - direction: false + up: + name: "Up" + down: + name: "Down" button: - - platform: desk_memory_button - desk_id: desk1 - name: "M1" - memory_id: 1 - - - platform: desk_memory_button - desk_id: desk1 - name: "M2" - memory_id: 2 - - - platform: desk_memory_button - desk_id: desk1 - name: "M3" - memory_id: 3 - - - platform: desk_memory_button + - platform: generic_desk desk_id: desk1 - name: "M4" - memory_id: 4 + M1: + name: "M1" + M2: + name: "M2" + M3: + name: "M3" + M4: + name: "M4" diff --git a/tests/full.yaml b/tests/full.yaml index a0cfdda..2ef3299 100644 --- a/tests/full.yaml +++ b/tests/full.yaml @@ -25,45 +25,33 @@ generic_desk: correction_term: 1.24836 sensor: - - platform: desk_height_sensor + - platform: generic_desk desk_id: desk1 id: desk_height name: "Desk Height" binary_sensor: - - platform: desk_is_moving_sensor + - platform: generic_desk desk_id: desk1 id: desk_is_moving name: "Desk is Moving" switch: - - platform: desk_switch + - platform: generic_desk desk_id: desk1 - name: "Up" - direction: true - - - platform: desk_switch - desk_id: desk1 - name: "Down" - direction: false + up: + name: "Up" + down: + name: "Down" button: - - platform: desk_memory_button - desk_id: desk1 - name: "M1" - memory_id: 1 - - - platform: desk_memory_button - desk_id: desk1 - name: "M2" - memory_id: 2 - - - platform: desk_memory_button - desk_id: desk1 - name: "M3" - memory_id: 3 - - - platform: desk_memory_button - desk_id: desk1 - name: "M4" - memory_id: 4 + - platform: generic_desk + desk_id: desk1 + M1: + name: "M1" + M2: + name: "M2" + M3: + name: "M3" + M4: + name: "M4"