Update sensor.yaml

Updated the checks to check between sunrise and sunset for the forecast time - looks better!
pull/3/head
Stephen Ludgate 2 years ago committed by GitHub
parent 5c83360b83
commit dada2d74d5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -63,7 +63,10 @@ template:
{% endif %} {% endif %}
weather_condition_0: > weather_condition_0: >
{% set cond0 = state_attr('weather.hourly', 'forecast')[0].condition %} {% set cond0 = state_attr('weather.hourly', 'forecast')[0].condition %}
{% if states('sun.sun') == 'below_horizon' %} {% set next_setting = as_timestampstate_attr('sun.sun', 'next_setting')) %}
{% set next_rising = as_timestampstate_attr('sun.sun', 'next_rising')) %}
{% set cond0_time = as_timestampstate_attr('weather.hourly', 'forecast')[0].datetime) %}
{% if cond0_time > next_setting && cond0_time < next_rising %}
{% if cond0 == 'sunny' %} night {% elif cond0 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond0 }} {% endif %} {% if cond0 == 'sunny' %} night {% elif cond0 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond0 }} {% endif %}
{% else %} {% else %}
{{ cond0 }} {{ cond0 }}
@ -74,7 +77,10 @@ template:
{{ as_timestamp(state_attr('weather.hourly', 'forecast')[0].datetime) | timestamp_custom('%I') | int }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[0].datetime) | timestamp_custom('%p') }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[0].datetime) | timestamp_custom('%I') | int }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[0].datetime) | timestamp_custom('%p') }}
weather_condition_1: > weather_condition_1: >
{% set cond1 = state_attr('weather.hourly', 'forecast')[1].condition %} {% set cond1 = state_attr('weather.hourly', 'forecast')[1].condition %}
{% if states('sun.sun') == 'below_horizon' %} {% set next_setting = as_timestampstate_attr('sun.sun', 'next_setting')) %}
{% set next_rising = as_timestampstate_attr('sun.sun', 'next_rising')) %}
{% set cond1_time = as_timestampstate_attr('weather.hourly', 'forecast')[1].datetime) %}
{% if cond1_time > next_setting && cond1_time < next_rising %}
{% if cond1 == 'sunny' %} night {% elif cond1 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond1 }} {% endif %} {% if cond1 == 'sunny' %} night {% elif cond1 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond1 }} {% endif %}
{% else %} {% else %}
{{ cond1 }} {{ cond1 }}
@ -85,7 +91,10 @@ template:
{{ as_timestamp(state_attr('weather.hourly', 'forecast')[1].datetime) | timestamp_custom('%I') | int }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[1].datetime) | timestamp_custom('%p') }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[1].datetime) | timestamp_custom('%I') | int }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[1].datetime) | timestamp_custom('%p') }}
weather_condition_2: > weather_condition_2: >
{% set cond2 = state_attr('weather.hourly', 'forecast')[2].condition %} {% set cond2 = state_attr('weather.hourly', 'forecast')[2].condition %}
{% if states('sun.sun') == 'below_horizon' %} {% set next_setting = as_timestampstate_attr('sun.sun', 'next_setting')) %}
{% set next_rising = as_timestampstate_attr('sun.sun', 'next_rising')) %}
{% set cond2_time = as_timestampstate_attr('weather.hourly', 'forecast')[2].datetime) %}
{% if cond2_time > next_setting && cond2_time < next_rising %}
{% if cond2 == 'sunny' %} night {% elif cond2 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond2 }} {% endif %} {% if cond2 == 'sunny' %} night {% elif cond2 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond2 }} {% endif %}
{% else %} {% else %}
{{ cond2 }} {{ cond2 }}
@ -96,7 +105,10 @@ template:
{{ as_timestamp(state_attr('weather.hourly', 'forecast')[2].datetime) | timestamp_custom('%I') | int }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[2].datetime) | timestamp_custom('%p') }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[2].datetime) | timestamp_custom('%I') | int }} {{ as_timestamp(state_attr('weather.hourly', 'forecast')[2].datetime) | timestamp_custom('%p') }}
weather_condition_3: > weather_condition_3: >
{% set cond3 = state_attr('weather.hourly', 'forecast')[3].condition %} {% set cond3 = state_attr('weather.hourly', 'forecast')[3].condition %}
{% if states('sun.sun') == 'below_horizon' %} {% set next_setting = as_timestampstate_attr('sun.sun', 'next_setting')) %}
{% set next_rising = as_timestampstate_attr('sun.sun', 'next_rising')) %}
{% set cond3_time = as_timestampstate_attr('weather.hourly', 'forecast')[3]].datetime) %}
{% if cond3_time > next_setting && cond3_time < next_rising %}
{% if cond3 == 'sunny' %} night {% elif cond3 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond3 }} {% endif %} {% if cond3 == 'sunny' %} night {% elif cond3 == 'partlycloudy' %} night-partly-cloudy {% else %} {{ cond3 }} {% endif %}
{% else %} {% else %}
{{ cond3 }} {{ cond3 }}

Loading…
Cancel
Save