ma ham: consolidate button management

This commit is contained in:
makefu 2021-08-31 15:14:37 +02:00
parent 2c9923264e
commit 6fa5b38bed
No known key found for this signature in database
GPG key ID: 36F7711F3FC0F225
5 changed files with 104 additions and 9 deletions

View file

@ -1,7 +0,0 @@
let
inherit (../lib) btn_cycle_light;
in {
services.home-assistant.config.automation = [
(btn_cycle_light "light.keller_osram" "keller_btn1" 128)
];
}

View file

@ -0,0 +1,24 @@
let
relay = "switch.terrasse_plug_relay";
timeout = "300";
in {
services.home-assistant.config.automation = [
{ alias = "Always turn off Charging station after ${toString (timeout)}m";
trigger = [
{
platform = "state";
entity_id = relay;
to = "on";
for.minutes = timeout;
}
];
action =
[
{
service = "homeassistant.turn_off";
entity_id = [ relay ];
}
];
}
];
}

View file

@ -1,6 +1,6 @@
let
inherit (../lib) btn_cycle_light;
inherit (import ../lib) btn_cycle_light;
turn_off_all = btn: #lights:
{
alias = "Turn of all lights via ${btn} double click";
@ -19,6 +19,8 @@ in {
services.home-assistant.config.automation = [
# (btn_cycle_light "light.arbeitszimmerbeleuchtung" "arbeitszimmer_btn1")
(btn_cycle_light "light.schlafzimmer_komode_osram" "schlafzimmer_btn2" 128)
(btn_cycle_light "light.keller_osram" "keller_btn1" 128)
# (btn_cycle_light "light.wohnzimmerbeleuchtung" "wohnzimmer_btn3")
(turn_off_all "schlafzimmer_btn2" )
];

View file

@ -1,5 +1,4 @@
{ pkgs, lib, config, ... }:
# Ideas:
## wake-on-lan server
##
@ -33,6 +32,7 @@ in {
./automation/firetv_restart.nix
./automation/light_buttons.nix
./automation/wohnzimmer_rf_fernbedienung.nix
./automation/ladestecker_timer.nix
#./automation/giesskanne.nix
./automation/pflanzen_giessen_erinnerung.nix
#./automation/urlaub.nix

View file

@ -40,5 +40,81 @@ in
entity = "firetv";
};
};
zigbee.prefix = "/ham/zigbee";
btn_cycle_light = light: btn: halfbright:
let
maxbright = 255;
transition = 0.2; # seconds
in
# this function implements a simple state machine based on the state and brightness of the light (light must support brightness
{
alias = "Cycle through states of ${light} via button ${btn}";
trigger = {
platform = "state";
entity_id = "sensor.${btn}_click";
to = "single";
};
action = {
choose = [
{
# state 0: off to half
conditions = {
condition = "template";
value_template = ''{{ states("${light}") == "off" }}'';
};
sequence = [
{
service = "light.turn_on";
data = {
entity_id = light;
brightness = halfbright;
};
}
];
}
{
# state 1: half to full
conditions = {
condition = "template";
value_template = ''{{ states('${light}') == 'on' and ( ${toString (halfbright - 1)} <= state_attr("${light}","brightness") <= ${toString (halfbright + 1)})}}'';
};
sequence = [
{
service = "light.turn_on";
data = {
entity_id = light;
brightness = maxbright;
};
}
];
}
{
# state 2: full to off
conditions = {
condition = "template";
# TODO: it seems like the devices respond with brightness-1 , maybe off-by-one somewhere?
value_template = ''{{ states("${light}") == "on" and state_attr("${light}","brightness") >= ${toString (maxbright - 1)}}}'';
};
sequence = [
{
service = "light.turn_off";
data = {
entity_id = light;
};
}
];
}
];
# default: on to off
# this works because state 0 checks for "state == off"
default = [{
service = "light.turn_off";
data = {
entity_id = light;
};
}];
};
};
}