# ------------------------------------------------------------------------
|
|
# Behavior: default
|
|
#
|
|
# * Presets that resemble the original Xiaomi firmware
|
|
# (one group of RGB colors, one group of white light colors)
|
|
# * Tapping the power button, toggles the light
|
|
# * Holding the power button, turns on night light mode
|
|
# * Tapping the color button, activates the next preset
|
|
# * Holding the color button, activates the next preset group
|
|
# * Touching the slider sets the brightness level and turns on the lamp
|
|
# * When the light is on, the front panel illumination is on
|
|
# * When the night light is on, only the power button is illuminated
|
|
# ------------------------------------------------------------------------
|
|
|
|
# A global variable to keep track of the brightness level. This one is
|
|
# used by the update_front_panel script to represent the brightness level
|
|
# using the front panel illumination.
|
|
#
|
|
# This variable is used instead of querying the light component directly,
|
|
# because that brightness level may vary during a light transition. The
|
|
# behavior that I want: when you touch the front panel slider at 75%, then
|
|
# the illumination rises directly to that level, while the light might do
|
|
# a smooth transition.
|
|
globals:
|
|
- id: current_brightness
|
|
type: float
|
|
initial_value: "0.0"
|
|
|
|
# This script updates the front panel illumination.
|
|
script:
|
|
- id: update_front_panel
|
|
mode: restart
|
|
then:
|
|
- front_panel.turn_off_leds: ALL
|
|
# In rgb or white light mode, turn on the front panel illumination,
|
|
# and show the current brightness level.
|
|
- if:
|
|
condition:
|
|
or:
|
|
- text_sensor.state:
|
|
id: my_light_mode
|
|
state: rgb
|
|
- text_sensor.state:
|
|
id: my_light_mode
|
|
state: white
|
|
then:
|
|
- front_panel.turn_on_leds: [ POWER, COLOR ]
|
|
- front_panel.set_level: !lambda return id(current_brightness);
|
|
# In night light mode, turn off the front panel illumination, except
|
|
# for the power button.
|
|
- if:
|
|
condition:
|
|
- text_sensor.state:
|
|
id: my_light_mode
|
|
state: night
|
|
then:
|
|
- front_panel.turn_on_leds: [ POWER ]
|
|
- front_panel.update_leds:
|
|
|
|
# This component controls the LED lights of the lamp.
|
|
light:
|
|
- platform: xiaomi_bslamp2
|
|
id: my_light
|
|
name: ${light_name}
|
|
default_transition_length: ${default_transition_length}
|
|
|
|
# When the brightness changes, update the front panel illumination.
|
|
on_brightness:
|
|
then:
|
|
- globals.set:
|
|
id: current_brightness
|
|
value: !lambda return x;
|
|
- script.execute: update_front_panel
|
|
|
|
# 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
|
|
|
|
# You can define one or more groups of presets. These presets can
|
|
# be activated using various "preset.activate" action options.
|
|
# The presets can for example be used to mimic the behavior of the
|
|
# original firmware (tapping the color button = go to next preset,
|
|
# holding the color button = switch between RGB and white light mode).
|
|
# These bindings have been setup below, using the binary_sensor for
|
|
# the color button.
|
|
presets:
|
|
rgb:
|
|
pink: { red: 59%, green: 30%, blue: 77% }
|
|
lpink: { red: 96%, green: 49%, blue: 73% }
|
|
purple: { red: 37%, green: 30%, blue: 67% }
|
|
magenta: { red: 59%, green: 30%, blue: 77% }
|
|
purple2: { red: 41%, green: 32%, blue: 52% }
|
|
lpurple: { red: 58%, green: 40%, blue: 58% }
|
|
randomize: { effect: Fast Random }
|
|
white:
|
|
cold: { color_temperature: 153 mireds }
|
|
chilly: { color_temperature: 275 mireds }
|
|
luke: { color_temperature: 400 mireds }
|
|
warm: { color_temperature: 588 mireds }
|
|
|
|
# Binary sensors can be created for handling front panel touch / release
|
|
# events. To specify what part of the front panel to look at, the "for"
|
|
# parameter can be set to: "POWER_BUTTON", "COLOR_BUTTON" or "SLIDER".
|
|
binary_sensor:
|
|
# When tapping the power button, toggle the light.
|
|
# When holding the power button, turn on night light mode.
|
|
- platform: xiaomi_bslamp2
|
|
id: my_power_button
|
|
for: POWER_BUTTON
|
|
on_multi_click:
|
|
- timing:
|
|
- ON for at most 0.8s
|
|
then:
|
|
- light.toggle: my_light
|
|
- timing:
|
|
- ON for at least 0.8s
|
|
then:
|
|
- light.turn_on:
|
|
id: my_light
|
|
brightness: 1%
|
|
|
|
# When tapping the color button, activate the next preset.
|
|
# When holding the color button, activate the next preset group.
|
|
- platform: xiaomi_bslamp2
|
|
id: my_color_button
|
|
for: COLOR_BUTTON
|
|
on_multi_click:
|
|
- timing:
|
|
- ON for at most 0.6s
|
|
then:
|
|
- preset.activate:
|
|
next: preset
|
|
- timing:
|
|
- ON for at least 0.6s
|
|
then:
|
|
- preset.activate:
|
|
next: group
|
|
|
|
# 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 (by holding the power button). Therefore, brightness
|
|
# starts from 0.02 here, to not trigger night mode using the slider.
|
|
- platform: xiaomi_bslamp2
|
|
id: my_slider_level
|
|
range_from: 0.02
|
|
on_value:
|
|
then:
|
|
- light.turn_on:
|
|
id: my_light
|
|
brightness: !lambda return x;
|
|
|
|
# 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: ${light_mode_text_sensor_name}
|
|
id: my_light_mode
|