# ------------------------------------------------------------------------ # 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: red: { red: 100%, green: 0%, blue: 0% } green: { red: 0%, green: 100%, blue: 0% } blue: { red: 0%, green: 0%, blue: 100% } yellow: { red: 100%, green: 100%, blue: 0% } purple: { red: 100%, green: 0%, blue: 100% } 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