Compare commits
1 Commits
2025.12.3
...
custom_med
| Author | SHA1 | Date | |
|---|---|---|---|
|
a33f9f66ae
|
118
automations.yaml
118
automations.yaml
@@ -2967,49 +2967,99 @@
|
||||
- id: '1696539209438'
|
||||
alias: Tony Custom Meds Handler
|
||||
description: ''
|
||||
trigger:
|
||||
- platform: time
|
||||
at: input_datetime.tony_custom_meds_notify_p1
|
||||
triggers:
|
||||
- minutes: /30
|
||||
id: trigger30
|
||||
alias: Every 30 minutes
|
||||
trigger: time_pattern
|
||||
- at: input_datetime.tony_custom_meds_notify_p1
|
||||
alias: Notify 1
|
||||
id: p1-notify
|
||||
- platform: state
|
||||
entity_id:
|
||||
trigger: time
|
||||
- alias: Notify 2
|
||||
at: input_datetime.tony_custom_meds_notify_p2
|
||||
id: p2-notify
|
||||
trigger: time
|
||||
- entity_id:
|
||||
- input_boolean.tony_custom_meds_taken_p1
|
||||
from: 'off'
|
||||
to: 'on'
|
||||
id: p1-taken
|
||||
alias: Taken 1
|
||||
condition: []
|
||||
action:
|
||||
- variables:
|
||||
trigger: '{{ trigger.id }}'
|
||||
num: '{{ trigger[:2] }}'
|
||||
reason: '{{ trigger.split(''-'')[1] }}'
|
||||
- if:
|
||||
- condition: template
|
||||
value_template: '{% set active = ''input_boolean.tony_custom_meds_tracker_''
|
||||
+ num %}
|
||||
|
||||
{{ is_state(active,''on'') }}'
|
||||
alias: Check tracker
|
||||
trigger: state
|
||||
- alias: Taken 2
|
||||
entity_id:
|
||||
- input_datetime.tony_custom_meds_taken_p2
|
||||
from: 'off'
|
||||
to: 'on'
|
||||
id: p2-taken
|
||||
trigger: state
|
||||
conditions:
|
||||
- condition: or
|
||||
conditions:
|
||||
- condition: state
|
||||
entity_id: input_boolean.tony_custom_meds_tracker_p1
|
||||
state: 'on'
|
||||
- condition: state
|
||||
entity_id: input_boolean.tony_custom_meds_tracker_p2
|
||||
state: 'on'
|
||||
alias: Any custom med trackers are on
|
||||
actions:
|
||||
- alias: Routing
|
||||
if:
|
||||
- condition: trigger
|
||||
id:
|
||||
- trigger30
|
||||
then:
|
||||
- if:
|
||||
- condition: template
|
||||
value_template: '{{ reason == ''notify'' }}'
|
||||
alias: Is this a notification
|
||||
- variables:
|
||||
trigger: '{{ trigger.id }}'
|
||||
num: all
|
||||
reason: notify
|
||||
alias: Override variables to indicate this is an interval notify request
|
||||
- alias: For each reminder entity
|
||||
repeat:
|
||||
for_each: '{{ states.input_boolean | selectattr(''entity_id'',''in'',label_entities(''Tony
|
||||
Custom Meds'')) | selectattr(''entity_id'',''search'',''reminder'') | map(attribute=''entity_id'')
|
||||
| list }}'
|
||||
sequence:
|
||||
- alias: Run custom meds script if tracker is active
|
||||
if:
|
||||
- alias: Check tracker
|
||||
condition: template
|
||||
value_template: '{{ is_state(repeat.item,''on'') }}'
|
||||
then:
|
||||
- data:
|
||||
num: '{{ num }}'
|
||||
reason: '{{ reason }}'
|
||||
alias: Run custom meds script
|
||||
action: script.tony_custom_meds
|
||||
else:
|
||||
- variables:
|
||||
trigger: '{{ trigger.id }}'
|
||||
num: '{{ trigger[:2] }}'
|
||||
reason: '{{ trigger.split(''-'')[1] }}'
|
||||
- alias: Run custom meds script if tracker is active
|
||||
if:
|
||||
- alias: Check tracker
|
||||
condition: template
|
||||
value_template: '{{ is_state(repeat.item,''on'') }}'
|
||||
then:
|
||||
- service: input_boolean.turn_off
|
||||
data: {}
|
||||
target:
|
||||
entity_id: '{{ ''input_boolean.tony_custom_meds_taken_'' + num }}'
|
||||
alias: Turn off "taken" boolean
|
||||
alias: Turn off "taken" boolean if this is a notification
|
||||
- service: script.tony_custom_meds
|
||||
data:
|
||||
num: '{{ num }}'
|
||||
reason: '{{ reason }}'
|
||||
alias: Run custom meds script
|
||||
alias: Run custom meds script if tracker is active
|
||||
- if:
|
||||
- condition: template
|
||||
value_template: '{{ reason == ''notify'' }}'
|
||||
alias: Is this a notification
|
||||
then:
|
||||
- data: {}
|
||||
target:
|
||||
entity_id: '{{ ''input_boolean.tony_custom_meds_taken_'' + num }}'
|
||||
alias: Turn off "taken" boolean
|
||||
action: input_boolean.turn_off
|
||||
alias: Turn off "taken" boolean if this is a notification
|
||||
- data:
|
||||
num: '{{ num }}'
|
||||
reason: '{{ reason }}'
|
||||
alias: Run custom meds script
|
||||
action: script.tony_custom_meds
|
||||
mode: parallel
|
||||
max: 10
|
||||
- id: '1696556688808'
|
||||
|
||||
@@ -119,10 +119,6 @@ recorder:
|
||||
- sensor.*_rssi
|
||||
- sensor.weatherflow_hub*
|
||||
- sensor.internet_round_trip*
|
||||
- sensor.*_monitor_type
|
||||
- sensor.*_certificate_expiry
|
||||
- sensor.*_monitored_url
|
||||
- sensor.*_response_time
|
||||
entities:
|
||||
- sensor.avg_ping
|
||||
- sensor.max_ping
|
||||
@@ -284,11 +280,6 @@ influxdb:
|
||||
- binary_sensor.asus_laptop*
|
||||
- sensor.*ashland*
|
||||
- sensor.*kasx*
|
||||
- sensor.*_monitor_type
|
||||
- sensor.*_certificate_expiry
|
||||
- sensor.*_monitored_url
|
||||
- sensor.*_response_time
|
||||
- sensor.*_status
|
||||
entities:
|
||||
- media_player.living_room_tv
|
||||
- media_player.basement_tv
|
||||
@@ -461,11 +452,6 @@ prometheus:
|
||||
- binary_sensor.asus_laptop*
|
||||
- sensor.*ashland*
|
||||
- sensor.*kasx*
|
||||
- sensor.*_monitor_type
|
||||
- sensor.*_certificate_expiry
|
||||
- sensor.*_monitored_url
|
||||
- sensor.*_response_time
|
||||
- sensor.*_status
|
||||
include_entities:
|
||||
- media_player.living_room_tv
|
||||
- media_player.basement_tv
|
||||
|
||||
@@ -47,6 +47,7 @@ ## HACS Components
|
||||
- [PyScript](https://github.com/custom-components/pyscript)
|
||||
- [Hass Animated Scenes](https://github.com/chazzu/hass-animated-scenes)
|
||||
- [Jokes](https://github.com/LaggAt/ha-jokes)
|
||||
- [Uptime Kuma](https://github.com/meichthys/uptime_kuma)
|
||||
- [Jellyfin](https://github.com/koying/jellyfin_ha)
|
||||
- [Sonoff LAN](https://github.com/AlexxIT/SonoffLAN)
|
||||
- [Powercalc](https://github.com/bramstroker/homeassistant-powercalc)
|
||||
|
||||
@@ -450,19 +450,18 @@
|
||||
unit_of_measurement: ''
|
||||
icon: mdi:close-network-outline
|
||||
state: >
|
||||
{% set uptimekuma = states.sensor |
|
||||
selectattr('entity_id','in',integration_entities('192.168.1.111')) |
|
||||
selectattr('state','eq','down') |
|
||||
{% set uptimekuma = states.binary_sensor |
|
||||
selectattr('entity_id','in',integration_entities('uptime_kuma')) |
|
||||
selectattr('state','eq','off') |
|
||||
map(attribute='attributes.friendly_name') |
|
||||
list %}
|
||||
{{ uptimekuma | count | int }}
|
||||
attributes:
|
||||
services: >
|
||||
{% set uptimekuma = states.sensor |
|
||||
selectattr('entity_id','in',integration_entities('192.168.1.111')) |
|
||||
selectattr('state','eq','down') |
|
||||
{% set uptimekuma = states.binary_sensor |
|
||||
selectattr('entity_id','in',integration_entities('uptime_kuma')) |
|
||||
selectattr('state','eq','off') |
|
||||
map(attribute='attributes.friendly_name') |
|
||||
map('regex_replace', ' Status$', '') |
|
||||
list %}
|
||||
{{ uptimekuma | join(', ') }}
|
||||
- name: Media Server Viewer Health
|
||||
|
||||
Reference in New Issue
Block a user