|
|
- # --------------------------------------------------------------------------
- # A few practical configuration substitutions.
- # --------------------------------------------------------------------------
-
- substitutions:
- name: bedside_lamp
- friendly_name: Bedside Lamp
- transition_length: 500ms
-
- # Derive component identifiers, based on the device name.
- id_light: ${name}
- id_front_panel_output: ${name}_front_panel_output
- id_power_button: ${name}_power_button
- id_color_button: ${name}_color_button
- id_slider_level: ${name}_slider_level
- id_light_mode: ${name}_light_mode
-
- # --------------------------------------------------------------------------
- # Use your own preferences for these components.
- # --------------------------------------------------------------------------
-
- wifi:
- ssid: "Your-SSID"
- password: "Your-WiFi-Network-Password"
-
- # Enable fallback hotspot (for captive portal) in case wifi connection fails
- ap:
- ssid: "ESPHome $friendly_name"
- password: "Password-For-Connecting-To-Captive-Portal"
-
- captive_portal:
-
- api:
- password: "Password-To-Link-HomeAssistant-To-This-Device"
-
- ota:
- password: "Password-For-Flashing-This-Device-Over-The-Air"
-
- # The log level can be raised when needed for debugging the device. For
- # production, a low log level is recommended. Mainly because high volume
- # log output might interfere with the API/WiFi connection stability.
- # So when raising the log level, beware that you might see dropped
- # connections from Home Assistant and the network log viewer.
- logger:
- level: WARN
-
- # --------------------------------------------------------------------------
- # Configuration specific for the Xiaomi Mijia Bedside Lamp 2.
- # This is just an example. You can of course modify it for your own needs.
- # --------------------------------------------------------------------------
-
- # Special platform + package are used for enabling unicore and disabling the
- # efuse mac crc check. These two changes are required for the ESP32-WROOM-32D
- # chip that is used in the device.
- esphome:
- name: ${name}
- platform: ESP32
- board: esp32doit-devkit-v1
- platformio_options:
- platform: espressif32@3.2.0
- platform_packages: |-4
- framework-arduinoespressif32 @ https://github.com/pauln/arduino-esp32.git#solo-no-mac-crc/1.0.6
-
- light:
- # This component controls the LED lights of the device.
- - platform: xiaomi_bslamp2
- id: ${id_light}
- name: ${friendly_name} RGBW Light
- default_transition_length: ${transition_length}
- # When the brightness is changed, then update the level indication
- # on the front panel accordingly. In night light mode, turn off
- # the front panel illumination.
- on_brightness:
- - if:
- condition:
- text_sensor.state:
- id: ${id_light_mode}
- state: night
- then:
- - output.set_level:
- id: ${id_front_panel_output}
- level: 0
- else:
- - output.set_level:
- id: ${id_front_panel_output}
- level: !lambda return x;
- # You can use any effects that you like. These are just examples.
- effects:
- - random:
- name: "Slow Random"
- transition_length: 30s
- update_interval: 30s
- - random:
- name: "Fast Random"
- transition_length: 3s
- update_interval: 3s
- presets:
- - rgb:
- - red_bright: { red: 1 }
- - green: { green: 1 }
- - blue_dimmed: { blue: 1 }
- - yellow: { red: 1, green: 1 }
- - something: { red: 0.2, green: 0.4, blue: 1 }
- - white:
- - warm: { color_temperature: 588 }
- - luke: { color_temperature: 400 }
- - chilly: { color_temperature: 275 }
- - cold: { color_temperature: 153 }
-
- # This text sensor propagates the currently active light mode.
- # The possible light modes are: "off", "rgb", "white" and "night".
- text_sensor:
- - platform: xiaomi_bslamp2
- name: ${name} Light Mode
- id: ${id_light_mode}
-
- # This output controls the front panel illumination + level indication.
- # Value 0.0 turns off the illumination.
- # Other values (up to 1.0) turn on the illumination and set the level
- # indication to the requested level.
- output:
- - platform: xiaomi_bslamp2
- id: ${id_front_panel_output}
-
- # Binary sensors can be created for handling front panel touch / release
- # events. To specify what part of the front panel to look at, the "part"
- # parameter can be set to: "any" (i.e. the default), "power button",
- # "color button" or "slider".
- binary_sensor:
- # When touching the power button, toggle the light.
- # When holding the power button, turn on night light mode.
- - platform: xiaomi_bslamp2
- id: ${id_power_button}
- part: power button
- on_multi_click:
- - timing:
- - ON for at most 0.8s
- then:
- - light.toggle: ${id_light}
- - timing:
- - ON for at least 0.8s
- then:
- - light.turn_on:
- id: ${id_light}
- red: 1
- green: 1
- blue: 1
- brightness: 0.01
-
- # When touching the color button, set a random color.
- - platform: xiaomi_bslamp2
- id: ${id_color_button}
- part: color button
- on_press:
- then:
- - light.turn_on:
- id: ${id_light}
- red: !lambda return random_float();
- green: !lambda return random_float();
- blue: !lambda return random_float();
-
- # This sensor component publishes touch events for the front panel slider.
- # The published value represents the level at which the slider was touched.
- # By default, values range from 0.01 to 1.00 (in 20 steps). This range can
- # be modified using the "range_from" and "range_to" parameters.
- sensor:
- # When the slider is touched, update the brightness.
- # Brightness 0.01 initiates the light night mode, which has already
- # been handled above. Therefore, brightness starts from 0.02 here,
- # so night mode is not triggered from the slider.
- - platform: xiaomi_bslamp2
- id: ${id_slider_level}
- range_from: 0.02
- on_value:
- then:
- - light.turn_on:
- id: ${id_light}
- brightness: !lambda return x;
-
|