HA Personal Trainer

Convierte a Home Assistant en tu ‘personal trainer’

Tiene acceso a la información sobre tu actividad física, tu salud y tu dieta… no necesitas nada más. Convierte a Home Assistant en tu ‘personal trainer’ para que te ayude a conseguir tus objetivos.

Existe una versión 2.0 de esta guía, consúltala en este enlace!

Home Assistant, el mejor ‘personal trainer’

Puede que a priori no te cuadre el concepto, y nunca hayas visto a HA como un personal trainer, pero piénsalo bien mientras lees los siguientes motivos:

  • Tiene la información necesaria de forma precisa, constante e instantánea. No tienes que pedirle cita, ni le ves una vez a la semana. Va a estar pendiente de ti las 24 horas, los 7 días de la semana. Además, para bien o para mal, no le vas a poder engañar con los números.
  • Los objetivos los marcas tú, y por tanto el nivel de exigencia. No te va a juzgar, ni a echar la bronca, ni a disfrazar los datos (ni a cobrar la sesión). Se va a adecuar a lo que tú le indiques y te va a informar de forma objetiva.
  • Te va a ayudar a conseguir tus objetivos mediante el control de tu actividad física, el seguimiento de tu salud y notificaciones de refuerzo.
  • Esta función puede ser usada por varios usuarios, siempre que crees los sensores, ayudantes y automatizaciones correspondientes (por eso conviene indicar el nombre del usuario al que hace referencia en la denominación). Ademas puedes hacer que los datos sólo sean visibles para el usuario correspondiente.
  • ¿Necesitas ayuda? Si te surgen dudas en la construcción de tu personal trainer te ayudamos en nuestro grupo de Telegram.

Requisitos previos

Antes de empezar con el esquema definido, voy a indicarte los ajustes y complementos que vamos a utilizar:

  • Si aun no lo has hecho, incluye en tu fichero ‘configuration.yaml’ el siguiente código para que puedas utilizar el día de la semana en el que te encuentras (muy útil para nuestro propósito y muchas otras automatizaciones). Esto creará la entidad ‘sensor.diadelasemana’.
- platform: template
  sensors:
    diadelasemana:
      friendly_name: "Día de la Semana"
      icon_template: mdi:calendar
      value_template: >
        {{ ['lunes','martes','miercoles','jueves','viernes','sabado','domingo'][now().weekday()] }}
  • Para programar las notificaciones de las sesiones de entrenamiento y para reiniciar los valores cada semana vamos a utilizar el componente Scheduler Component, que puedes instalar directamente a través de HACS > Integraciones buscando «Scheduler component». Descárgalo y reinicia HA. Ahora ve a Ajustes > Dispositivos y servicios > Añadir integración, busca «Scheduler» y finaliza la integración.

Ten en cuenta que los códigos facilitados siguen la nomenclatura de los ejemplos, por lo que si cambias el nombre de las entidades creadas, también tendrás que adaptarlo en los códigos de creación de scripts y automatizaciones.

Primer paso: crear y recopilar sensores

Lo primero que vamos a hacer es crear o recopilar los sensores que van a proporcionar a HA la información necesaria para evaluar si estamos cumpliendo con los objetivos. Esto lo vamos a conseguir mediante la integración de otros elementos que ya utilizamos, si es posible, o proporcionándole directamente nosotros la información.

Elige aquellos que te aporten información que te interese en función de tus objetivos, y de las opciones que tengas a tu alcance.

Sensores de actividad de relojes / pulseras

Los relojes y pulseras de actividad proporcionan mucha información sobre nuestra actividad física, por lo que van a ser uno de los principales elementos a integrar en HA si quieres tener información de forma automática. A partir de ahí la información que puedas extraer va a depender del modelo que uses y de tu actividad física.

En mi caso una de las principales actividades físicas que realizo es correr, y siempre registro mis entrenos con mi reloj Garmin Forerunner 45 integrado en Home Assistant. Pero además de Garmin, son varias las marcas que tienen integración oficial (o no oficial) con HA (como Fitbit o Withings), por lo que si tienes un reloj o pulsera de actividad es fácil que vayas a poder proporcionarle este tipo de métricas.

Si no tienes ningún reloj/pulsera o no localizas ninguna forma de integración en Home Assistant, avanza hasta los apartados de «Sensores de deportes en Strava» y «Sensores de aplicaciones».

Yo voy a utilizar los siguientes datos de actividad de mi reloj:

  • Distancia recorrida. Este sensor (‘sensor.total_distance_mtr’) me va a indicar cada día la distancia que he recorrido en mis entrenos, y va a ser una de las metas que establezca. Para ello voy a seguir los siguientes pasos:
    1. Como es un sensor que se reinicia cada día, lo primero que tengo que hacer es crear un ayudante que registre la distancia recorrida para cada día de la semana. Desde Ajustes > Dispositivos y servicios > Ayudantes, clic en «Crear ayudante» del tipo número. El nombre tendrá la siguiente estructura «distancia_DIA-DE-LA-SEMANA_NOMBRE» (por ejemplo, distancia_lunes_tito). Ajusta el valor máximo a tu actividad. Esto creará la entidad ‘input_number.distancia_lunes_NOMBRE’.
    2. Crear una automatización que cada noche guarde la distancia recorrida en el día de la semana correspondiente. No olvides sustituir los datos de tu sensor que indica la distancia recorrida.
alias: Personal Trainer - Registro de distancia recorrida
description: >-
  Al llegar las 23.00h se guarda la distancia recorrida, en el día de la semana
  correspondiente.
trigger:
  - platform: time
    at: "23:00:00"
condition: []
action:
  - service: input_number.set_value
    data:
      value: "{{ states('sensor.SENSOR-DE-DISTANCIA-RECORRIDA') | int }}"
    target:
      entity_id: input_number.distancia_{{ states('sensor.diadelasemana') }}_NOMBRE
mode: single
  1. Ahora ya tenemos toda la información para crear el sensor con la distancia acumulada en la semana. Este va a ser el dato que comparemos con el objetivo semanal que estableceremos más adelante. Esto creará la entidad ‘sensor.distancia_acumulada_NOMBRE’. Para ello incluye el siguiente código en tu fichero ‘sensors.yaml’, y no olvides sustituir tu nombre.
- platform: template
  sensors:
    distancia_acumulada_TU-NOMBRE:
      friendly_name: "KM semanales NOMBRE"
      value_template: >
        {{
        (states('input_number.distancia_lunes_NOMBRE') | int +
        states('input_number.distancia_martes_NOMBRE') | int +
        states('input_number.distancia_miercoles_NOMBRE') | int +
        states('input_number.distancia_jueves_NOMBRE') | int +
        states('input_number.distancia_viernes_NOMBRE') | int +
        states('input_number.distancia_sabado_NOMBRE') | int +
        states('input_number.distancia_domingo_NOMBRE') | int) /1000
        }}
      icon_template: mdi:run-fast
      unit_of_measurement: "km"
  1. Para no hacer trampa, al empezar la semana tenemos que reiniciar los valores registrados en cada día, empezando un nuevo ciclo. Para ello avanza hasta el apartado «Reinicio de valores semanales» y recuerda que las entidades a reiniciar son las del tipo «distancia_DIA-DE-LA-SEMANA_NOMBRE» (por ejemplo, distancia_lunes_tito).

Por otro lado, para ver como establecer el objetivo y crear la tarjeta en el panel de control avanza hasta el apartado «Tarjeta de metas personales».

  • Calorías quemadas. Este sensor (‘sensor.active_kilocalories’) me va a indicar las calorías quemadas cada día. Este dato lo voy a comparar más adelante con las calorías consumidas, para determinar si estoy en déficit o superávit calórico. No obstante, podrías utilizarlo como un mero valor informativo, o como una meta diaria o semanal, por ejemplo, si tu plan estuviera orientado a la pérdida de peso. Si es el caso, sigue los pasos establecidos en el apartado anterior, pero utilizando este sensor como base.

Para ver como crear la tarjeta en el panel de control avanza hasta el apartado «Tarjeta de balance calórico».

Sensores de pasos del teléfono

Caminar es una actividad que está al alcance de todos y ni si quiera necesitas una pulsera para registrarlo de una forma aproximada, por que ya lo hace tu teléfono. Para proporcionar este dato sólo tienes que tener instalada la aplicación de Home Assistant en tu teléfono y activar el sensor correspondiente desde tú teléfono entrando en la aplicación en Ajustes > Aplicación complementaria > Administrar sensores > Sensor de pasos. Ahora podemos crear los siguientes sensores:

  • Sensor de pasos diario (contador). Puesto que el sensor proporciona el número total de pasos acumulados, vamos a crear un nuevo sensor que vaya contando los pasos durante el día, y cuando acabe la jornada se reinicie. Para ello pega el siguiente código en tu archivo ‘configuration.yaml’ (reemplazando en el código tu nombre y el sensor correspondiente de tu teléfono). Esto creará la entidad ‘sensor.pasos_diarios_contador_NOMBRE’.
utility_meter:
  pasos_diario_contador_NOMBRE:
    source: sensor.SENSOR_DE_PASOS_DE_TU_TELEFONO
    cycle: daily

Para ver como establecer el objetivo y crear la tarjeta en el panel de control avanza hasta el apartado «Tarjeta de contador de pasos».

  • Sensor de pasos diario (media). En mi caso caminar no es mi principal actividad física, y puede variar mucho de un día a otro, por lo que no lo voy a mostrar en mi tarjeta personal. No obstante, te explico como puedes usarlo como un indicador de movimiento calculando la media con base semanal (es decir, en los últimos 7 días). Para ello haz lo siguiente:
    1. Crea un ayudante que registre los pasos dados para cada día de la semana. Desde Ajustes > Dispositivos y servicios > Ayudantes, clic en «Crear ayudante» del tipo número. El nombre tendrá la siguiente estructura «pasos_DIA-DE-LA-SEMANA_NOMBRE» (por ejemplo, pasos_lunes_tito). Ajusta el valor máximo a tu actividad (el mínimo diario recomendado son 10.000 pasos). Esto creará la entidad ‘input_number.pasos_lunes_NOMBRE’.
    2. Crea un ayudante que registre el número de pasos acumulados que muestra el sensor de tu teléfono en el día de hoy. El nombre tendrá la estructura «pasos_acumulados_NOMBRE» (por ejemplo, pasos_acumulados_tito). Esto creará la entidad ‘input_number.pasos_acumulados_NOMBRE’.
    3. Por último crea una automatización que cada noche calcule los pasos que se han dado en el día (restando al valor del sensor de tu teléfono, el valor registrado el día anterior) y lo guarde en el día de la semana correspondiente. Luego va a sobreescribir el valor el registro de pasos acumulados para volver a realizar la misma operación al día siguiente. Para ello copia el siguiente código en una automatización. No olvides sustituir los datos correspondientes a tus sensores y las entidades que has creado.
alias: Personal Trainer - Registro de pasos diarios
description: >-
  Al llegar las 23.00h se calculan y guardan los pasos dados, en el día de la
  semana correspondiente.
trigger:
  - platform: time
    at: "23:00:00"
condition: []
action:
  - variables:
      pasoshoy: "{{ states('sensor.SENSOR-DE-PASOS-DE-TU-TELEFONO') | int }}"
      pasosayer: "{{ states('input_number.pasos_acumulados_NOMBRE') | int }}"
      pasos: "{{ pasoshoy - pasosayer }}"
  - service: input_number.set_value
    data:
      value: "{{ pasos }}"
    target:
      entity_id: input_number.pasos_{{ states('sensor.diadelasemana') }}_TU-NOMBRE
  - service: input_number.set_value
    data:
      value: "{{ states('sensor.SENSOR-DE-PASOS-DE-TU-TELEFONO') | int }}"
    target:
      entity_id: input_number.pasos_acumulados_NOMBRE
mode: single
  1. Ahora ya tenemos toda la información para crear el sensor con la media (con base semanal) de los pasos diarios. Esto creará la entidad ‘sensor.pasos_diario_media_NOMBRE‘. Para ello incluye el siguiente código en tu fichero ‘sensors.yaml’ y no olvides sustituir tu nombre.
- platform: template
  sensors:
    pasos_diario_media_NOMBRE:
      friendly_name: "Pasos diarios (media)"
      value_template: >
        {{
        (states('input_number.pasos_lunes_NOMBRE') | int +
        states('input_number.pasos_martes_NOMBRE') | int +
        states('input_number.pasos_miercoles_NOMBRE') | int +
        states('input_number.pasos_jueves_NOMBRE') | int +
        states('input_number.pasos_viernes_NOMBRE') | int +
        states('input_number.pasos_sabado_NOMBRE') | int +
        states('input_number.pasos_domingo_NOMBRE') | int) /7
        }}
      icon_template: mdi:shoe-print
      unit_of_measurement: "pasos"

Ten en cuenta que hasta que no recoja los datos de una semana no te va a mostrar un valor coherente.

Sensores de sesiones geolocalizadas

En este caso vamos a utilizar la localización GPS de nuestro teléfono para que reconozca que hemos ido al gimnasio, a la piscina, al rocódromo… y en general cualquier actividad física que desarrollemos en una zona determinada. En mi caso lo voy a utilizar para registrar cuando voy a nadar a la piscina. Para ello he seguido estos pasos:

  1. Crear un ayudante que va a ir anotando las sesiones que realizo. Desde Ajustes > Dispositivos y servicios > Ayudantes, clic en «Crear ayudante» del tipo contador. El nombre tendrá la siguiente estructura «sesiones_ACTIVIDAD_NOMBRE» (por ejemplo, sesiones_natacion_tito). Ajusta el valor máximo a tu actividad. Esto creará la entidad ‘counter.sesiones_ACTIVIDAD_NOMBRE’.
  2. Registrar la zona (o zonas) en la que se realiza la actividad. Desde Ajustes > Áreas y Zonas > Zonas > Añadir Zona. Abre una ventana en tu navegador y ve a Google Maps y busca tu ubicación (en mi caso, la piscina). Haz clic con el botón derecho y anota las coordenadas. Vuelve a HA e indícalas en la zona creada. Ajusta el radio y mueve el centro si lo deseas.
  3. Ahora vamos a crear una automatización que incremente el contador del ayudante creado cuando tu dispositivo entre en dicha zona/s. Para ello crea una nueva automatización e indica lo siguiente:
    • Desencadenantes. Selecciona «Dispositivo» y escoge tu teléfono. En desencadenante indica «…entra en una zona» y a continuación marca la zona predefinida donde realizas tu actividad. Repite este paso para cada una de las zonas donde desarrolles tu actividad.
    • Acciones. Selecciona «Llamar servicio», busca el servicio ‘counter.increment’ y selecciona como entidad el ayudante creado en el paso 1 (por ejemplo, ‘counter.sesiones_natacion_tito’).

Por otro lado, para ver como establecer el objetivo y crear la tarjeta en el panel de control avanza hasta el apartado «Tarjeta de metas personales».

Sensores de deportes en Strava

La integración de Strava con Home Assistant merece una mención especial en este proyecto, puesto que crea sensores específicos para cada tipo de deporte. Cabe destacar que la variedad de actividades deportivas que permite registrar Strava es muy variada y elevada (carrera, senderismo, bicicleta, natación, surf, kayak, esqui, snowboard, patinaje, escalada, crossfit, yoga… y muchos otros).

Asimismo, su aplicación permite la integración de múltiples marcas de relojes y pulseras de actividad, como Samsung, Fitbit, Zepp, Polar, Suunto, Amazfit… por mencionar algunos. Por tanto, esta aplicación puede ser el puente ideal para llevar a HA la información de los deportes o dispositivos que no hemos podido conectar de otra forma.

Por ejemplo, en mi caso es importante que realice sesiones de estiramientos los días que entreno, aunque se me olvida casi siempre a pesar de la importancia que tienen. A priori, no tengo ninguna forma de monitorizar esta actividad. Sin embargo, mi reloj Garmin ofrece el yoga entre las actividades que puedo registrar. Esta actividad está, a su vez, entre los deportes que monitoriza Strava.

Por tanto, lo que voy a hacer es utilizar este modo para realizar mis estiramientos, ya que el funcionamiento consiste en unas alarmas de ‘X’ minutos para cada postura de yoga (lo cuál encaja perfectamente con mi rutina de estiramientos). Cuando el reloj registre la actividad, la compartirá con Strava y esta la enviará a HA, indicando ‘yoga’ como tipo de deporte. Esto desencadenará una automatización que incrementará el contador de mis sesiones de estiramientos.

Para ello, he seguido estos pasos:

  1. Crear un ayudante que va a ir anotando las sesiones que realizo. Desde Ajustes > Dispositivos y servicios > Ayudantes, clic en “Crear ayudante” del tipo contador. El nombre tendrá la siguiente estructura “sesiones_ACTIVIDAD_NOMBRE” (por ejemplo, sesiones_estiramientos_tito). Ajusta el valor máximo a tu actividad (en mi caso sería 7, una por cada día de la semana). Esto creará la entidad ‘counter.sesiones_ACTIVIDAD_NOMBRE’.
  2. Crear una automatización con los siguientes elementos:
    • Desencadenante. Cuando se produce un cambio en el estado de la entidad ‘sensor.strava_0_0’, que corresponde a la actividad más reciente reportada por Strava. Es decir, en la práctica se va a desencadenar cuando Strava reporte una nueva actividad.
    • Condición. Que el atributo ‘sport_type’ sea iguala «Yoga». Importante, para que únicamente incremente el contador con el tipo de actividad correspondiente.
    • Acción. Llamar al servicio ‘counter.increment’ para sumar una sesión al contador creado en el paso anterior.

El código siguiente corresponde a la automatización que acabo de detallar:

alias: Personal Trainer - Registro de estiramientos
description: >-
  Cuando Strava reporta una actividad con tipo de deporte Yoga, incrementa el
  contador de sesiones de estiramiento
trigger:
  - platform: state
    entity_id:
      - sensor.strava_0_0
condition:
  - condition: state
    entity_id: sensor.strava_0_0
    attribute: sport_type
    state: Yoga
action:
  - service: counter.increment
    data: {}
    target:
      entity_id: counter.sesiones_estiramientos_NOMBRE
mode: single

Sensores de sesiones registradas

En el improbable caso de que no hayas conseguido registrar tu actividad mediante alguno de los métodos anteriores, ya sea porque no tienes reloj ni pulsera de actividad, o porque el que tienes no monitoriza la actividad que quieres registrar (gimnasio, clases de yoga, natación, spinning, sesiones de baile…), vamos a registrar algunas sesiones físicas de una forma alternativa. Aunque no es automático, será nuestro comodín.

Para ilustrar este ejemplo voy a obviar que ya estoy registrando mis sesiones de estiramiento con Strava, como te acabo de comentar y voy a considerar que no tengo ninguna forma de medir esta actividad de forma automática.

Siendo este el caso, voy a crear una automatización para que el día y a la hora idónea, HA me pregunte por Telegram si he cumplido con la sesión. De esta forma me sirve a la vez como recordatorio y como control. En función de mi respuesta, irá alimentando el sensor correspondiente. Para conseguirlo he hecho lo siguiente:

  1. Crear un ayudante que va a ir anotando las sesiones que realizo. Desde Ajustes > Dispositivos y servicios > Ayudantes, clic en «Crear ayudante» del tipo contador. El nombre tendrá la siguiente estructura «sesiones_ACTIVIDAD_NOMBRE» (por ejemplo, sesiones_estiramientos_tito). Ajusta el valor máximo a tu actividad (en mi caso sería 7, una por cada día de la semana). Esto creará la entidad ‘counter.sesiones_ACTIVIDAD_NOMBRE’.
  2. Ahora vamos a crear un ‘script’ para cada actividad con una única acción que va a consistir en una notificación por Telegram, preguntándome si he realizado la sesión. En el mismo mensaje me dará dos opciones de respuesta, «si» o «no». Para ello crea un nuevo ‘script’ y pega el siguiente código adaptando tu usuario y el mensaje.
alias: Personal Trainer - Seguimiento de estiramientos
sequence:
  - service: notify.USUARIO
    data:
      message: ¿Has hecho los estiramientos? 🧘‍♂️
      data:
        inline_keyboard:
          - ✅ Si:/estiramientos_si, ❌ No:/estiramientos_no
mode: single
icon: mdi:meditation
  1. A continuación vamos a crear dos automatizaciones por cada actividad. La primera se va a disparar si contestamos que «si» al mensaje anterior, incrementando el contador de sesiones y dándonos un mensaje de confirmación. La segunda se disparará si contestamos que «no», y únicamente generará un mensaje de refuerzo. Crea una automatización para cada una de ellas y pega el código correspondiente, adaptando tu usuario y el mensaje.
alias: Personal Trainer - Seguimiento de estiramientos (OK)
description: >-
  Cada día me pregunta si he estirado, y si la respuesta es afirmativa
  incrementa el contador de sesiones
trigger:
  - platform: event
    event_type: telegram_callback
    event_data:
      command: /estiramientos_si
action:
  - service: notify.USUARIO
    data:
      message: La constancia es el secreto del éxito! 👌
  - service: counter.increment
    data: {}
    target:
      entity_id: counter.sesiones_estiramientos_NOMBRE
mode: single
alias: Personal Trainer - Seguimiento de estiramientos (KO)
description: >-
  Cada día me pregunta si he estirado, y si la respuesta es afirmativa
  incrementa el contador de sesiones
trigger:
  - platform: event
    event_type: telegram_callback
    event_data:
      command: /estiramientos_no
action:
  - service: notify.USUARIO
    data:
      message: No permitas que la pereza venza a tus ganas 🙏
mode: single
  1. Necesitamos que estos mensajes se ejecuten de forma automática en función de los días que tenemos una sesión (por ejemplo, si vas al gimnasio los martes y jueves por la tarde). Para ello vamos a utilizar el Scheduler component, como te indicaba en los requisitos previos.
  2. Abre una nueva pestaña en el panel de control y agrega una nueva tarjeta «Scheduler card». En el listado de entidades que te aparecen, marca la opción «script» y agrega la tarjeta.
  3. Si haces clic en añadir, primero tendrás que seleccionar el ‘script’ a ejecutar (por ejemplo, «Personal Trainer – Seguimiento de estiramientos») y luego la opción «Ejecutar». En el siguiente paso vas a elegir los días que toca sesión (por ejemplo, lunes y miércoles) y la hora a la que quieres que te llegue el mensaje.
  4. Repite este último paso tantas veces como sesiones de actividades quieras registrar.

Para no hacer trampa, al empezar la semana tenemos que reiniciar las sesiones registradas para cada actividad, empezando un nuevo ciclo. Para ello avanza hasta el apartado «Reinicio de valores semanales» y recuerda que las entidades a reiniciar son las del tipo «sesiones_ACTIVIDAD_NOMBRE» (por ejemplo, sesiones_estiramientos_tito).

Por otro lado, para ver como establecer el objetivo y crear la tarjeta en el panel de control avanza hasta el apartado «Tarjeta de metas personales».

Sensores de salud de básculas

Puesto que el peso va a ser un indicativo claro de nuestro estado de salud, las básculas inteligentes son un dispositivo ideal para nuestro propósito, especialmente si proporcionan más datos además del propio peso. En mi caso tengo integrada la báscula de Xiaomi Mi Body Composition Scale 2.

De la información que me da, voy a utilizar los siguientes datos:

  • Peso (‘weight’). Este sensor va a ser un indicador sobre mi peso objetivo, y además lo voy a utilizar como principal referencia de mi estado de forma.
  • Grasa corporal (‘body_fat’), músculo (‘muscle_mass’) y masa ósea (‘bone_mass’). Estos sensores me van a permitir representar mi composición corporal.
  • Porcentaje de agua (‘water’). Este sensor aparecerá como un valor informativo.
  • Metabolismo basal (‘basal_metabolism’). Se refiere a la energía mínima requerida para mantener las funciones vitales. Lo voy a utilizar en el cálculo del balance calórico.

Para ver cómo crear las tarjetas en el panel de control avanza hasta el apartado «Tarjeta de peso y composición corporal» y «Tarjeta de balance calórico».

Sensores de aplicaciones

Es posible que tengas alguna pulsera de actividad, una báscula o registres tus hábitos con otras aplicaciones que no tienen integración directa con Home Assistant, ni oficial ni ‘custom’. No tires la toalla aun. A través de la integración de Google Fit o de otros dispositivos puedes recopilar información de un montón de aplicaciones de salud y dispositivos de otras marcas que no tienen integración directa.

En mi caso voy a utilizarla para incorporar información de la siguiente aplicación:

  • Sleep as Android. Esta aplicación sirve para registrar las distintas fases del sueño y mediante su integración en Google Fit voy a poder conocer cuánto tiempo he dormido, y cuánto tiempo he pasado en cada fase para evaluar la calidad de mi descanso puesto que es un factor crucial para nuestra salud, así como para poder entrenar de forma efectiva y que nuestro metabolismo funcione bien.

Para ver como crear la tarjeta en el panel de control y recopilar las horas de sueño semanales avanza hasta el apartado «Tarjeta de monitorización de sueño».

Por otro lado voy a incorporar en Garmin Connect la información de la siguiente aplicación:

  • MyFitnessPal. Esta aplicación sirve para calcular las calorías consumidas en función de los alimentos ingeridos. La voy a utilizar como calculadora de las calorías de mi dieta semanal, y además registraré en ella manualmente aquellas comidas «extra» que haga durante la semana. Mediante su integración con Garmin Connect tendré el dato diario del total de calorías consumidas. En el siguiente apartado te explico cómo hacerlo.

Sensores de calorías consumidas

Después de haber registrado la energía que gastamos, vamos a introducir la información sobre la energía que consumimos, en función de las calorías que nos aporta nuestra dieta. Esto nos servirá para saber si estamos en déficit o superávit calórico.

El sensor va a estar compuesto de dos partes, en función de los dos extremos que pueden darse en la planificación de tu dieta:

  • Parte estática. Son aquellos alimentos que consumes de forma regular, y por tanto se puede predecir las calorías que te van a aportar y cuándo. Un claro ejemplo es si sigues una dieta planificada por un nutricionista, pero también puedes incluir si siempre te tomas un cafe después de comer, o si siempre desayunas lo mismo.
  • Parte dinámica. Son todos aquellos alimentos que consumes de forma no planificada y que por tanto tendrás que registrar manualmente. Como te indicaba un poco más arriba, para ello voy a utilizar la aplicación MyFitnessPal con la integración de Garmin Connect.

Para construir el sensor sigue estos pasos:

  1. Vamos a empezar por la parte estática, creando un ayudante de tipo ‘número’ para cada día de la semana, denominándolo con la siguiente estructura ‘calorias_consumidas_DIA-DE-LA-SEMANA_NOMBRE’ (por ejemplo, calorias_consumidas_lunes_tito). En modo de visualización indica «campo de entrada». Esto creará la entidad ‘input_number.calorias_consumidas_lunes_NOMBRE’.
  2. Ve a la pestaña del panel de control creada para configurar los objetivos y añade una tarjeta del tipo “Entidades”. Agrega aquí todos los ayudantes creados en el paso anterior.
  3. Ahora desde esta tarjeta ya puedes añadir esa parte conocida de calorías que consumes cada día. Puedes calcularlas con aplicaciones como MyFitnessPal, pero también puedes utilizar cualquier calculadora de internet.
  4. Ahora voy a localizar la parte dinámica entre los sensores creados con la integración de Garmin Connect, cuya información procede de la aplicación MyFitnessPal. En mi caso el sensor correspondiente es ‘sensor.consumed_kilocalories’.
  5. Por último, vamos a crear un sensor que unifique cada día ambas partes. Para ello copia el siguiente código en tu fichero ‘sensors.yaml’, sustituyendo tu nombre y el sensor correspondiente. Esto creará la entidad ‘sensor.NOMBRE_calorias_consumidas_hoy’.
- platform: template
  sensors:
    NOMBRE_calorias_consumidas_hoy:
      friendly_name: "Calorias consumidas hoy (NOMBRE)"
      value_template: >
        {% set dia = states('sensor.diadelasemana') %}
        {% set estatica = states.input_number
          | selectattr('object_id', 'contains', 'calorias_consumidas')
          | selectattr('object_id', 'contains', dia)
          | map(attribute='state')
          | list
          | replace("[","")
          | replace("]","")
          | replace("'","")
          | int %}
        {% set dinamica = states('sensor.consumed_kilocalories') | int if states('sensor.consumed_kilocalories')|is_number else 0 %}
        {{ estatica + dinamica}}

Para ver cómo crear la tarjeta en el panel de control avanza hasta el apartado “Tarjeta de balance calórico”.

Sensores de malos hábitos

Cuando se trata de salud, puede ser tan importante (o más) lo que no hacemos que lo que hacemos. Por eso vamos a incluir un sensor para dejar los malos hábitos (fumar, comer fritos, ultraprocesados…). En concreto vamos a registrar la fecha de la última vez que «caimos», y vamos a crear un contador de días desde la última vez. Para ello sigue estos pasos:

  1. Crea una ayudante del tipo «Fecha y hora».
  2. Ponle un nombre con la siguiente estructura «ultimo_HABITO_NOMBRE» (por ejemplo, ultimo_fumar_tito). Esto creará entidad ‘input_datetime.ultimo_fumar_NOMBRE’.
  3. Indica que quieres introducir una fecha.
  4. Como en este caso el objetivo es simplemente no repetir el hábito, vamos a construir directamente el contador e incluirlo como una tarjeta (Mushroom Card) en la pestaña que hayas creado para el seguimiento de objetivos. Para ello crea una nueva tarjeta y pega el siguiente código, sustituyendo el sensor correspondiente. Si haces clic en la tarjeta podrás introducir la fecha de inicio.
type: custom:mushroom-template-card
primary: >-
  {{
  (((states.input_datetime.ultimo_HABITO_NOMBRE.attributes.timestamp)-as_timestamp(now()))
  | int /60/1440) | round(0) * -1 }} días
secondary: Sin fumar 💪
icon: mdi:smoking-off
entity: input_datetime.ultimo_HABITO_NOMBRE
icon_color: green
tap_action:
  action: more-info

Si específicamente quieres dejar de fumar, también puedes utilizar la tarjeta ampliada para dejar de fumar.

Segundo paso: fijación de objetivos y panel de control

Tarjeta de peso y composición corporal

Vamos a empezar el panel de control con una tarjeta en la que vamos a mostrar nuestro peso y una imagen que variará en función de si nos encontramos dentro o no de nuestro peso objetivo, así como unos valores sobre nuestra composición corporal. Para esta tarjeta vamos a utilizar Mushroom CardsApexchart CardStack In Card y Card Mod, y al final tendrá este aspecto.

Composición corporal

En primer lugar vamos a usar el sensor de peso para evaluar cómo estamos respecto a nuestro peso ideal.

  1. Crea un Ayudante de tipo número y ponle un nombre con la siguiente estructura ‘objetivo_peso_NOMBRE’ (por ejemplo, objetivo_peso_tito). En modo de visualización indica «Campo de entrada». Esto creará la entidad ‘input_number.objetivo_peso_NOMBRE’.
  2. Ve a la pestaña del panel de control creada para configurar los objetivos y añade una tarjeta del tipo «Entidades». Agrega aquí el ayudante creado en el paso anterior, y ya podrás establecer el objetivo.
  3. Ahora vamos a crear un sensor que va a comparar el peso real con el peso objetivo, y en función de ello va a definir nuestro estado en «delgado», «fit» o «sobrepeso». Puedes ajustar el margen de tolerancia como quieras (en mi caso lo he establecido en +/- 0.5 kg). Para ello copia el siguiente código en tu fichero ‘sensors.yaml’, sustituyendo tu nombre. Esto creará la entidad ‘sensor.NOMBRE_forma’.
- platform: template
  sensors:
    NOMBRE_forma:
      friendly_name: "Estado de forma NOMBRE"
      value_template: >
        {% set peso = states('sensor.TU-SENSOR-DE-PESO') | float(2) %}
        {% set objetivo = states('input_number.objetivo_peso_NOMBRE') | float(2) %}
        {% if (objetivo + 0.5) < peso %} sobrepeso
        {% elif (objetivo + 0.5) >= peso >= (objetivo - 0.5) %} fit
        {% elif peso < (objetivo - 0.5) %} delgado
        {% endif %}
  1. Escoge tres imágenes que reflejen esos tres estados de forma. Pueden ser fotos tuyas o cualquier imagen que creas que te puede motivar. En mi caso he generado estas tres utilizando inteligencia artificial.
  1. Después de crearlas nómbralas con la siguiente estructura ‘peso_NOMBRE_ESTADO.jpg’ (por ejemplo, peso_tito_fit.jpg) y guárdalas en la ruta ‘config/www’. Si no existe esta última carpeta, créala. Para este paso te recomiendo que utilices el complemento Samba Share, ya que vas a poder acceder fácilmente con tu explorador de archivos.
  2. Ya solo te queda crear una nueva tarjeta y pegar el siguiente código, sustituyendo los sensores correspondientes:
type: custom:stack-in-card
cards:
  - square: false
    type: grid
    columns: 2
    cards:
      - type: vertical-stack
        cards:
          - type: custom:apexcharts-card
            card_mod:
              style: |
                ha-card {
                  margin-left: -10px;
                  border: 0px !important;
                }
            header:
              show: false
            chart_type: donut
            apex_config:
              plotOptions:
                pie:
                  customScale: 1
                  donut:
                    size: 80%
              legend:
                show: false
              chart:
                height: 170px
              dataLabels:
                enabled: false
              tooltip:
                enabled: false
            series:
              - entity: sensor.NOMBRE_grasa
                color: b83050
              - entity: sensor.NOMBRE_masa_muscular
                color: 83b926
              - entity: sensor.NOMBRE_masa_osea
                color: 26b0b9
          - type: custom:mushroom-template-card
            tap_action:
              action: none
            primary: ''
            secondary: ''
            icon: 'mdi:'
            picture: local/peso_NOMBRE_{{ states('sensor.NOMBRE_forma') }}.jpg
            layout: vertical
            card_mod:
              style: |
                ha-card {
                  margin-top: -133px;
                  margin-left: -7px;
                  --icon-size: 95px;
                  --card-primary-font-size: 20px;
                  border: 0px !important;
                }
          - type: custom:mushroom-chips-card
            alignment: center
            card_mod:
              style: |
                ha-card {
                  --primary-text-color: white;
                }
            chips:
              - type: template
                tap_action:
                  action: none
                content: '{{ states(''sensor.NOMBRE_weight'') | round (1) }} kg'
                card_mod:
                  style: |
                    ha-card {
                      margin-top: -40px;
                      margin-left: -10px;
                      background-color: #000000 !important;
                      height: 30px !important;
                    }
      - type: vertical-stack
        cards:
          - type: custom:mushroom-template-card
            primary: |
              {{user}}
            secondary: ''
            icon: ''
            tap_action:
              action: none
            card_mod:
              style: |
                ha-card {
                  border: 0px !important;
                  --card-primary-font-size: 25px;
                  margin-left: -10px;
                  margin-bottom: -5px;
                }
          - type: custom:mushroom-chips-card
            card_mod:
              style: |
                ha-card {
                  height: 10px !important;
                  border: 0px !important;
                  --chip-box-shadow: 0px;
                  --chip-spacing: 0px;
                  margin-bottom: 10px;
                  margin-left: -8px;
                }
            chips:
              - type: template
                tap_action:
                  action: none
                content: >-
                  🟢 {{ states('sensor.NOMBRE_masa_muscular') | round (1) }}% Masa
                  muscular
                card_mod:
                  style: |
                    ha-card {
                      border: 0px !important;
                      background-color: transparent !important;
                    }
          - type: custom:mushroom-chips-card
            card_mod:
              style: |
                ha-card {
                  height: 10px !important;
                  border: 0px !important;
                  --chip-box-shadow: 0px;
                  --chip-spacing: 0px;
                  margin-bottom: 10px;
                  margin-left: -8px;
                }
            chips:
              - type: template
                tap_action:
                  action: none
                content: >-
                  🔴 {{ states('sensor.NOMBRE_grasa') | round (1) }}% Grasa
                  corporal
                card_mod:
                  style: |
                    ha-card {
                      border: 0px !important;
                      background-color: transparent !important;
                    }
          - type: custom:mushroom-chips-card
            card_mod:
              style: |
                ha-card {
                  height: 10px !important;
                  border: 0px !important;
                  --chip-box-shadow: 0px;
                  --chip-spacing: 0px;
                  margin-bottom: 10px;
                  margin-left: -8px;
                }
            chips:
              - type: template
                tap_action:
                  action: none
                content: >-
                  🔵 {{ states('sensor.NOMBRE_masa_osea') | round (1) }}% Masa
                  ósea
                card_mod:
                  style: |
                    ha-card {
                      border: 0px !important;
                      background-color: transparent !important;
                    }

Tarjeta de metas personales

Esta tarjeta va reflejar el grado de avance en nuestras metas establecidas, tanto numéricamente como de forma gráfica. Para esta tarjeta vamos a utilizar Mushroom CardsBar CardStack In Card y Card Mod, y al final tendrá este aspecto.

Metas personalez

Sigue estos pasos para la creación de la tarjeta:

  1. Como en los apartados anteriores hemos recopilado y creado los sensores que nos indican la actividad realizada, ahora tenemos que crear la meta.
  2. Crea un Ayudante de tipo número y ponle un nombre con la siguiente estructura ‘objetivo_SENSOR-A-EVALUAR_NOMBRE’ (por ejemplo, objetivo_distancia_semanal_tito). En modo de visualización indica «Campo de entrada». Esto creará la entidad ‘input_number.objetivo_distancia_semanal_NOMBRE’.
  3. Ve a la pestaña del panel de control creada para configurar los objetivos y añade una tarjeta del tipo «Entidades». Agrega aquí los ayudantes creados en el paso anterior, y ya podrás establecer cada uno de los objetivos.
  4. Para que el gráfico se actualice siempre automáticamente, aunque cambiemos los objetivos, vamos a crear un sensor (para cada meta) en tu fichero ‘sensors.yaml’ para calcular el porcentaje de cumplimiento. El código que adjunto corresponde a la imagen anterior, siguiendo los ejemplos establecidos en la guía. Esto creará entidades del tipo ‘sensor.cumplimiento_sesiones_natacion_NOMBRE’.
- platform: template
  sensors:
    cumplimiento_sesiones_natacion_NOMBRE:
      friendly_name: "Grado de cumplimiento (natación)"
      value_template: >
        {{
        ((states('counter.sesiones_natacion_NOMBRE') | round(2)) /
        (states('input_number.objetivo_sesiones_natacion') | int) * 100) | int
        }}
      icon_template: mdi:swim
      unit_of_measurement: "%"

- platform: template
  sensors:
    cumplimiento_sesiones_estiramientos_NOMBRE:
      friendly_name: "Grado de cumplimiento (estiramientos)"
      value_template: >
        {{
        ((states('counter.sesiones_estiramientos_NOMBRE') | round(2)) /
        (states('input_number.objetivo_sesiones_estiramientos') | int) * 100) | int
        }}
      icon_template: mdi:meditation
      unit_of_measurement: "%"

- platform: template
  sensors:
    cumplimiento_carrera_tito:
      friendly_name: "Grado de cumplimiento (carrera)"
      value_template: >
        {{
        ((states('sensor.distancia_acumulada_NOMBRE') | round(2)) /
        (states('input_number.objetivo_distancia_semanal_NOMBRE') | int) * 100) | int
        }}
      icon_template: mdi:run-fast
      unit_of_measurement: "%"
  1. Ya solo tienes que crear una tarjeta nueva y pegar el siguiente código, sustituyendo tu nombre y tus metas:
type: custom:stack-in-card
cards:
  - type: vertical-stack
    cards:
      - type: custom:bar-card
        card_mod:
          style: |-
            bar-card-currentbar {
              border-radius: 50px !important;
            }
            bar-card-backgroundbar {
              border-radius: 50px !important;
              opacity: 0.7
            }
            bar-card-value {
              margin-right: 12px;
              font-size: 12px;
              text-shadow: 1px 1px #0005;
              opacity: .5
            }
        entities:
          - entity: sensor.cumplimiento_carrera_NOMBRE
            color: mediumvioletred
            height: 25px
            positions:
              icon: 'off'
              name: 'off'
              value: inside
          - entity: sensor.cumplimiento_sesiones_natacion_NOMBRE
            color: dodgerblue
            height: 25px
            positions:
              icon: 'off'
              name: 'off'
              value: inside
          - entity: sensor.cumplimiento_sesiones_estiramientos_NOMBRE
            color: forestgreen
            height: 25px
            positions:
              icon: 'off'
              name: 'off'
              value: inside
      - type: custom:mushroom-chips-card
        card_mod:
          style: |
            ha-card {
              margin-top: -112px;
              margin-left: 12px;
              padding-bottom: 10px;
              height: 30px !important;
              border: 0px !important;
              --chip-box-shadow: 0px;
              --chip-spacing: 0px;
              text-shadow: 1px 1px #0005;
              --primary-text-color: white;
            }
        chips:
          - type: template
            entity: sensor.distancia_acumulada_NOMBRE
            content: >-
              {{ states('sensor.distancia_acumulada_NOMBRE') | round(2)
              }}/{{(states('input_number.objetivo_distancia_semanal_NOMBRE') |
              int)}} km en carrera 
            icon: mdi:run-fast
            tap_action:
              action: none
            card_mod:
              style: |
                ha-card {
                  border: 0px;
                  background-color: transparent !important;
                }
      - type: custom:mushroom-chips-card
        card_mod:
          style: |
            ha-card {
              margin-top: -79px;
              margin-left: 12px;
              padding-bottom: 10px;
              height: 30px !important;
              border: 0px !important;
              --chip-box-shadow: 0px;
              --chip-spacing: 0px;
              text-shadow: 1px 1px #0005;
              --primary-text-color: white;
            }
        chips:
          - type: template
            entity: counter.sesiones_natacion_NOMBRE
            content: >-
              {{ states('counter.sesiones_natacion_NOMBRE') | int
              }}/{{(states('input_number.objetivo_sesiones_natacion') | int)}}
              sesiones de natación
            icon: mdi:swim
            tap_action:
              action: none
            card_mod:
              style: |
                ha-card {
                  border: 0px;
                  background-color: transparent !important;
                }
      - type: custom:mushroom-chips-card
        card_mod:
          style: |
            ha-card {
              margin-top: -46px;
              margin-left: 12px;
              padding-bottom: 10px;
              height: 30px !important;
              border: 0px !important;
              --chip-box-shadow: 0px;
              --chip-spacing: 0px;
              text-shadow: 1px 1px #0005;
              --primary-text-color: white;
            }
        chips:
          - type: template
            entity: counter.sesiones_estiramientos_NOMBRE
            content: >-
              {{ states('counter.sesiones_estiramientos_NOMBRE') | int
              }}/{{(states('input_number.objetivo_sesiones_estiramientos') |
              int)}} sesiones de estiramientos
            icon: mdi:meditation
            tap_action:
              action: none
            card_mod:
              style: |
                ha-card {
                  border: 0px;
                  background-color: transparent !important;
                }

Por otro lado, vamos a crear una entidad que registre si hemos cumplido o no nuestras metas de actividad física, para que el ‘personal trainer’ lo compruebe más adelante. Esta entidad se actualizará semanalmente. Sigue estos pasos para construirla:

  1. Crea un Ayudante de tipo alternar y ponle un nombre con la siguiente estructura ‘metas_fisicas_NOMBRE’ (por ejemplo, metas_fisicas__tito). Esto creará la entidad ‘input_boolean.metas_fisicas_tito’.
  2. Ahora vamos a crear un script que va a comprobar los sensores que hemos creado en el paso 4 del apartado anterior (porcentaje de cumplimiento). Si todos están al 100% (valor numérico por encima de 99), encenderá el ayudante creado en el paso anterior (estado on). De lo contrario lo apagará (estado off). El código que adjunto corresponde a los ejemplos establecidos en la guía. Aseguráte de sustituir en el código tus sensores con tus objetivos.
alias: Personal Trainer - Comprobacion de metas fisicas
sequence:
  - if:
      - condition: numeric_state
        entity_id: sensor.cumplimiento_carrera_NOMBRE
        above: 99
      - condition: numeric_state
        entity_id: sensor.cumplimiento_sesiones_estiramientos_NOMBRE
        above: 99
      - condition: numeric_state
        entity_id: sensor.cumplimiento_sesiones_natacion_NOMBRE
        above: 99
    then:
      - service: input_boolean.turn_on
        data: {}
        target:
          entity_id: input_boolean.metas_fisicas_NOMBRE
    else:
      - service: input_boolean.turn_off
        data: {}
        target:
          entity_id: input_boolean.metas_fisicas_NOMBRE
mode: single
icon: mdi:trophy
  1. Ahora vamos a utilizar el Scheduler Component para disparar este ‘script’ cada domingo a las 22:00h. Para ello ve a la pestaña en la que has incluido la tarjeta y haz clic en “Añadir”. Selecciona el ‘script’ que acabamos de crear y “Ejecutar”. Ahora elige el domingo a las 22.00h para que se ejecute.

Tarjeta de monitorización de sueño

Con los sensores proporcionados por Sleep as Android vamos a construir la siguiente tarjeta (utilizando Bar Card, Mushroom Cards, Stack in Card y Card Mod), en la que vamos a visualizar el tiempo total de sueño y el tiempo por cada fase, tanto de forma numérica como de forma gráfica. Con esta información podremos tomar acciones para mejorar la calidad del sueño. Al final te quedará una tarjeta con el siguiente aspecto.

Tarjeta monitorización sueño

Como ves, además incluirá (o no) una serie de estrellas en función de la calidad del sueño. Por defecto aplica las siguientes reglas, aunque lo puedes personalizar como quieras:

  • 1 estrella si el tiempo total de sueño es > 7 horas
  • 1 estrella si el tiempo total de sueño es > 8 horas
  • 1 estrella si el tiempo de sueño profundo es > 1 hora
  • 1 estrella si el tiempo de sueño profundo es > 2 horas

Primero vamos a crear un par de sensores que vamos a utilizar para que el gráfico de colores se ajuste a los valores de cada día automáticamente. Para ello copia el siguiente código en tu fichero ‘sensors.yaml’, sustituyendo tu nombre de usuario. Esto creará las entidades ‘sensor.sueno_profundo_NOMBRE’ y ‘sensor.sueno_rem_NOMBRE’

- platform: template
  sensors:
    sueno_profundo_USUARIO:
      friendly_name: 'Tiempo de sueño profundo (USUARIO)'
      icon_template: mdi:power-sleep
      unit_of_measurement: '%'
      value_template: >
        {{ ((states('sensor.deep_sleep') | int) / (states('sensor.sleep') | int)) | round (2) * 100 }}

- platform: template
  sensors:
    sueno_rem_USUARIO:
      friendly_name: 'Tiempo de sueño REM (USUARIO)'
      icon_template: mdi:power-sleep
      unit_of_measurement: '%'
      value_template: >
        {{ (((((states('sensor.deep_sleep')) | int) + ((states('sensor.rem_sleep')) | int))| int) / (states('sensor.sleep') | int)) | round (2) * 100 }}

Ahora crea una nueva tarjeta y pega el siguiente código, sustituyendo tu usuario en los sensores que acabas de crear. Al final del código podrás modificar las reglas de las estrellas si lo deseas.

type: custom:stack-in-card
cards:
  - type: vertical-stack
    cards:
      - type: custom:bar-card
        card_mod:
          style: |-
            ha-card {
              border: 0px !important;
            }
            bar-card-currentbar {
              border-radius: 20px !important;
            }
            bar-card-backgroundbar {
              opacity: .0
            }
        entities:
          - entity: sensor.light_sleep
            color: seagreen
            height: 55px
            positions:
              icon: 'off'
              name: 'off'
              value: 'off'
      - type: custom:bar-card
        card_mod:
          style: |-
            ha-card {
              margin-top: -87px;
              background-color: transparent;
              border: 0px;
            }
            bar-card-currentbar {
              border-radius: 20px !important;
            }
            bar-card-backgroundbar {
              opacity: .0
            }
        entities:
          - entity: sensor.sueno_rem_NOMBRE
            color: deepskyblue
            height: 55px
            positions:
              icon: 'off'
              name: 'off'
              value: 'off'
      - type: custom:bar-card
        card_mod:
          style: |-
            ha-card {
              margin-top: -87px;
              background-color: transparent;
              --card-mod-icon-color: white;
              border: 0px;
            }
            bar-card-currentbar {
              border-radius: 20px !important;
            }
            bar-card-backgroundbar {
              opacity: .0
            }
        entities:
          - entity: sensor.sueno_profundo_NOMBRE
            height: 55px
            color: slateblue
            positions:
              icon: inside
              name: 'off'
              value: 'off'
      - type: custom:mushroom-chips-card
        alignment: end
        card_mod:
          style: |
            ha-card {
              margin-top: -75px;
              margin-right: 25px;
              padding-bottom: 10px;
              height: 30px !important;
              border: 0px !important;
              --chip-box-shadow: 0px;
              --chip-spacing: 0px;
              --primary-text-color: white;
            }
        chips:
          - type: template
            entity: sensor.deep_sleep
            content: >-
              {% set sueno = states('sensor.deep_sleep') | int / 60%} {% if
              (sueno | int // 60) > 0 %}{{ sueno | int // 60}}h{% endif %} {{
              sueno | int % 60}}' sueño profundo 🟣
            tap_action:
              action: none
            card_mod:
              style: |
                ha-card {
                  border: 0px;
                  background-color: transparent !important;
                }
      - type: custom:mushroom-chips-card
        alignment: end
        card_mod:
          style: |
            ha-card {
              margin-top: -60px;
              margin-right: 25px;
              padding-bottom: 10px;
              height: 30px !important;
              border: 0px !important;
              --chip-box-shadow: 0px;
              --chip-spacing: 0px;
              --primary-text-color: white;
            }
        chips:
          - type: template
            entity: sensor.light_sleep
            content: >-
              {% set sueno = states('sensor.light_sleep') | int / 60%} {% if
              (sueno | int // 60) > 0 %}{{ sueno | int // 60}}h{% endif %} {{
              sueno | int % 60}}' sueño ligero 🟢
            tap_action:
              action: none
            card_mod:
              style: |
                ha-card {
                  border: 0px;
                  background-color: transparent !important;
                }
      - type: custom:mushroom-chips-card
        alignment: end
        card_mod:
          style: |
            ha-card {
              margin-top: -45px;
              margin-right: 25px;
              padding-bottom: 10px;
              height: 30px !important;
              border: 0px !important;
              --chip-box-shadow: 0px;
              --chip-spacing: 0px;
              --primary-text-color: white;
            }
        chips:
          - type: template
            entity: sensor.rem_sleep
            content: >-
              {% set sueno = states('sensor.rem_sleep') | int / 60%} {% if
              (sueno | int // 60) > 0 %}{{ sueno | int // 60}}h{% endif %} {{
              sueno | int % 60}}' fase REM 🔵
            tap_action:
              action: none
            card_mod:
              style: |
                ha-card {
                  border: 0px;
                  background-color: transparent !important;
                }
      - type: custom:mushroom-template-card
        card_mod:
          style: |
            ha-card {
              margin-top: -80px;
              margin-left: 50px;
              border: 0px !important;
              --card-primary-font-size: 20px;
              --card-secondary-font-size: 11px;
              --primary-text-color: white;
              --secondary-text-color: #ffffff !important;
              text-shadow: 1px 1px #0005;
            }
        primary: |-
          {% set sueno = states('sensor.sleep') | int / 60%} {% if
          (sueno | int // 60) > 0 %}{{ sueno | int // 60}}h{% endif %} {{
          sueno | int % 60}}' 
        secondary: ''
        entity: sensor.sleep
        tap_action:
          action: none
  - type: custom:mushroom-chips-card
    card_mod:
      style: |
        ha-card {
          margin-top: -50px;
          margin-left: 50px;
          --chip-box-shadow: 0px;
          --chip-spacing: 0px !important;
        }
    chips:
      - type: template
        icon: mdi:star
        icon_color: yellow
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              {% set sueno = states('sensor.sleep') | int / 60%}
              {% if (sueno | int // 60) < 7 %}
              display: none !important;
              {% endif %}
              margin-right: -20px;
              background-color: transparent !important;
            }
      - type: template
        icon: mdi:star
        icon_color: yellow
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              {% set sueno = states('sensor.sleep') | int / 60%}
              {% if (sueno | int // 60) < 8 %}
              display: none !important;
              {% endif %}
              margin-right: -20px;
              background-color: transparent !important;
            }
      - type: template
        icon: mdi:star
        icon_color: yellow
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              {% set sueno = states('sensor.deep_sleep') | int / 60%}
              {% if (sueno | int // 60) < 1 %}
              display: none !important;
              {% endif %}
              margin-right: -20px;
              background-color: transparent !important;
            }
      - type: template
        icon: mdi:star
        icon_color: yellow
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              {% set sueno = states('sensor.deep_sleep') | int / 60%}
              {% if (sueno | int // 60) < 2 %}
              display: none !important;
              {% endif %}
              margin-right: -20px;
              background-color: transparent !important;
            }

Por otro lado, vamos a crear un sensor que registre cada día las horas de sueño. Esto va a servir para establecer una media en los últimos 7 días, como medida cuantitativa de nuestro descanso. Para ello voy a seguir los siguientes pasos:

  1. Como es un sensor que se reinicia cada día, lo primero que tengo que hacer es crear un ayudante que registre las horas de sueño para cada día de la semana. Desde Ajustes > Dispositivos y servicios > Ayudantes, clic en “Crear ayudante” del tipo número. El nombre tendrá la siguiente estructura “descanso_DIA-DE-LA-SEMANA_NOMBRE” (por ejemplo, descanso_lunes_tito). Ten en cuenta que el tiempo de sueño se proporciona en segundos, por lo que el valor máximo tiene que ser elevado (por ejemplo, 8h al día corresponden a 28800 segundos). Esto creará entidas como ‘input_number.descanso_lunes_NOMBRE’.
  2. Crear una automatización que cada dia guarde la distancia recorrida en el día de la semana correspondiente. No olvides sustituir los datos correspondientes a tus entidades.
alias: Personal Trainer - Registro de tiempo de sueño
description: >-
  Al llegar las 12.00h se guarda el tiempo de sueño, en el día de la semana
  correspondiente.
trigger:
  - platform: time
    at: "12:00:00"
condition: []
action:
  - service: input_number.set_value
    data:
      value: "{{ states('sensor.TU-SENSOR-DE-SUEÑO') | int }}"
    target:
      entity_id: input_number.descanso_{{ states('sensor.diadelasemana') }}_NOMBRE
mode: single
  1. Ahora ya tenemos toda la información para crear el sensor con la media de horas de sueño en los últimos 7 días. Este va a ser el dato que utilizaremos más adelante para evaluar nuestro grado de descanso. Para ello incluye el siguiente código en tu fichero ‘sensors.yaml’. Esto creará la entidad ‘sensor.descanso_acumulado_NOMBRE’.
- platform: template
  sensors:
    descanso_acumulado_NOMBRE:
      friendly_name: "Media descanso NOMBRE"
      value_template: >
        {{
        (states('input_number.descanso_lunes_NOMBRE') | int +
        states('input_number.descanso_martes_NOMBRE') | int +
        states('input_number.descanso_miercoles_NOMBRE') | int +
        states('input_number.descanso_jueves_NOMBRE') | int +
        states('input_number.descanso_viernes_NOMBRE') | int +
        states('input_number.descanso_sabado_NOMBRE') | int +
        states('input_number.descanso_domingo_NOMBRE') | int) /25200
        }}
      icon_template: mdi:sleep
      unit_of_measurement: "horas"

Tarjeta de contador de pasos

Tanto si vas a utilizar el contador de pasos diarios como una media semanal, vas a poder utilizar la siguiente tarjeta. Para construirla vamos a usar Mushroom CardsApexchart CardStack In Card y Card Mod.

Tarjeta de pasos

Simplemente crea una nueva tarjeta y pega el siguiente código, sustituyendo el sensor correspondiente y el objetivo de pasos (en el ejemplo es 10000 pasos).

square: false
type: grid
columns: 2
cards:
  - type: custom:stack-in-card
    cards:
      - type: custom:apexcharts-card
        header:
          show: false
        chart_type: radialBar
        apex_config:
          legend:
            show: false
          chart:
            height: 160px
          plotOptions:
            radialBar:
              hollow:
                size: 60%
              dataLabels:
                name:
                  show: false
                value:
                  show: false
        series:
          - entity: sensor.TU-SENSOR-DE-PASOS
            name: Pasos
            color: 83b926
            min: 0
            max: 10000
      - type: custom:mushroom-template-card
        primary: ''
        secondary: ''
        icon: mdi:shoe-print
        icon_color: '#83b926'
        layout: vertical
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              margin-top: -143px;
              opacity: 0.5 !important;
              --icon-size: 130px;
              margin-bottom: -20px;
            }
            mushroom-shape-icon {
              --shape-color: none !important;
            }
      - type: custom:mushroom-template-card
        primary: '{{ states(''sensor.TU-SENSOR-DE-PASOS'') | int }}'
        secondary: pasos
        layout: vertical
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              --card-primary-font-size: 18px;
              --card-secondary-font-size: 10px;
              margin-top: -100px;
            }

Tarjeta de balance calórico

Vamos a crear una tarjeta que de un lado tenga en cuenta las calorías que quemamos con nuestras funciones vitales básicas (a través del sensor de la báscula de metabolismo basal, o calculándolo en cualquier página de internet e incluyendo un importe fijo), más las calorías que quemamos con nuestra actividad física (con los sensores proporcionados por el reloj de actividad), y de otro lado las calorías que consumimos/ingerimos (según el sensor que hemos construido en el apartado correspondiente).

Metabolismo basal + Actividad física VS Calorías consumidas

Nos va a quedar la siguiente tarjeta (utilizando Bar Card, Mushroom Cards, Stack in Card y Card Mod) con la que vamos a ver si nos encontramos en déficit o superávit calórico.

Tarjeta balance calórico

Primero vamos a crear un sensor que vamos a utilizar para que el gráfico de colores se ajuste a los valores de cada día automáticamente. Para ello copia el siguiente código en tu fichero ‘sensors.yaml’, sustituyendo tus sensores correspondientes. Esto creará la entidad ‘sensor.NOMBRE_calorias_quemadas_hoy_grafico’

- platform: template
  sensors:
    USUARIO_calorias_quemadas_hoy_grafico:
      friendly_name: "Gráfico calorias quemadas hoy (USUARIO)"
      icon_template: mdi:fire
      unit_of_measurement: '%'
      value_template: >
        {% set mbasal = states('sensor.USUARIO_metabolismo_basal') | int if states('sensor.USUARIO_metabolismo_basal')|is_number else 0 %}
        {% set actividad = states('sensor.active_kilocalories') | int if states('sensor.active_kilocalories')|is_number else 0 %}
        {% set quemadas = mbasal + actividad %}
        {% set consumidas = states('sensor.USUARIO_calorias_consumidas_hoy') | int %}
        {{ ((quemadas) / (quemadas + consumidas) * 100) | int }}

Hecho esto ya podemos crear la tarjeta correspondiente, pegando el siguiente código:

square: false
type: grid
columns: 2
cards:
  - type: custom:stack-in-card
    cards:
      - type: custom:apexcharts-card
        header:
          show: false
        chart_type: radialBar
        apex_config:
          legend:
            show: false
          chart:
            height: 160px
          plotOptions:
            radialBar:
              hollow:
                size: 60%
              dataLabels:
                name:
                  show: false
                value:
                  show: false
        series:
          - entity: sensor.USUARIO_calorias_quemadas_hoy_grafico
            name: Balance calórico
            color: d62b4b
            min: 0
            max: 100
      - type: custom:mushroom-template-card
        primary: ''
        secondary: ''
        icon: mdi:fire
        icon_color: '#d62b4b'
        layout: vertical
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              margin-top: -143px;
              opacity: 0.5 !important;
              --icon-size: 130px;
              margin-bottom: -20px;
            }
            mushroom-shape-icon {
              --shape-color: none !important;
            }
      - type: custom:mushroom-template-card
        primary: >
          {% set mbasal = states('sensor.USUARIO_metabolismo_basal') | int if states('sensor.USUARIO_metabolismo_basal')|is_number else 0 %}
          {% set actividad = states('sensor.active_kilocalories') | int if states('sensor.active_kilocalories')|is_number else 0 %}
          {% set quemadas = mbasal + actividad %}
          {% set consumidas = states('sensor.USUARIO_calorias_consumidas_hoy') | int %}
          {% if (consumidas - quemadas) > 0 %}+{% endif %} {{ consumidas - quemadas }}
        secondary: kcal
        layout: vertical
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              --card-primary-font-size: 18px;
              --card-secondary-font-size: 10px;
              margin-top: -100px;
            }

Tarjeta de objetivos sobre un valor de referencia

Son los objetivos que nos vamos a marcar para conseguir acercarnos a un valor predefinido. Puede corresponderse con alguno de los casos anteriores (por ejemplo, la media de pasos diarios que das o las calorías que quemas) o cualquier otro objetivo que se te ocurra. Sea como sea, puedes construirlos de la siguiente forma (para el ejemplo voy a utilizar como objetivo la media de pasos diarios, aprovechando que hemos creado los sensores correspondiente en el apartado de «Sensores de pasos del teléfono«).

  1. Crea un Ayudante de tipo número y ponle un nombre con la siguiente estructura ‘objetivo_SENSOR-A-EVALUAR_NOMBRE’ (por ejemplo, objetivo_pasos_diario_media_tito). En modo de visualización indica «Campo de entrada».
  2. Ve a la pestaña del panel de control creada para configurar los objetivos y añade una tarjeta del tipo «Entidades». Agrega aquí los ayudantes creados en el paso anterior, y ya podrás establecer cada uno de los objetivos.
  3. Ahora vamos a crear una Mushroom Card. Crea una tarjeta nueva, haz clic en mostrar el editor de código y pega el siguiente código.
type: custom:mushroom-template-card
primary: '{{ states(''sensor.pasos_diario_media_NOMBRE'') | int }} p / d'
secondary: '{{ states(''sensor.pasos_diarios_NOMBRE'') | int }} pasos hoy'
icon: mdi:shoe-print
entity: input_number.objetivo_pasos_diario_media_NOMBRE
icon_color: >-
  {% set media = states('sensor.pasos_diario_media_NOMBRE') | int %}
  {% set objetivo = states('input_number.objetivo_pasos_diario_media_NOMBRE') | int %}
  {% set objetivo_tolerancia = states('input_number.objetivo_pasos_diario_media_NOMBRE') | int * 0.9 %}
  {% if media > objetivo %} green
  {% elif objetivo > media > objetivo_tolerancia %} yellow
  {% else %} red
  {% endif %}
tap_action:
  action: none

Este código te va a generar una tarjeta en la que te aparece un icono, cuyo color dependerá si estamos por encima del objetivo marcado (verde), estamos por encima del 90% del objetivo marcado (amarillo) o estamos por debajo (rojo). Puedes ajustar el margen de tolerancia en la línea correspondiente a la variable ‘objetivo_tolerancia’, en el número 0.9.

En la línea principal te va a mostrar la media de pasos diarios en la última semana (objetivo a evaluar), y en la línea secundaria el número de pasos que llevas a día de hoy (informativo).

Las tarjetas resultantes tendrán un aspecto como este:

Objetivos sobre un valor

Tercer paso: reinicio de valores semanales

Como hemos comentado varias veces a lo largo de la entrada, una vez a la semana (o cuando tú decidas) tenemos que reiniciar los valores registrados sobre la actividad realizada. Esto es aplicable a los sensores que se establecen sobre una meta establecida (no a los objetivos relacionados, ni a los sensores que se evalúan sobre un valor de referencia).

Para ello vamos a crear un ‘script’ cuya única acción es establecer el valor ‘0’ en todas las entidades que indiquemos. Como hemos creado dos tipos de ayudantes (de número y contadores), tendremos que llamar a un servicio distinto para cada tipo, y a partir de ahí simplemente tendremos que añadir todas las entidades que vayamos creando.

La base del ‘script’ sería la siguiente, sobre la que tendrías que añadir tus entidades.

alias: Personal Trainer - Reinicio semanal de valores
sequence:
  - service: input_number.set_value
    data:
      value: 0
    target:
      entity_id:
        - input_number.distancia_lunes_NOMBRE
        - input_number.distancia_martes_NOMBRE
        - input_number.distancia_miercoles_NOMBRE
        - input_number.distancia_jueves_NOMBRE
        - input_number.distancia_viernes_NOMBRE
        - input_number.distancia_sabado_NOMBRE
        - input_number.distancia_domingo_NOMBRE
  - service: counter.reset
    data: {}
    target:
      entity_id:
        - counter.sesiones_estiramientos_NOMBRE
        - counter.sesiones_natacion_NOMBRE
mode: single
icon: mdi:restart

Ahora vamos a utilizar el Scheduler Component para disparar este ‘script’ cada lunes a las 00:01h. Para ello ve a la pestaña en la que has incluido la tarjeta y haz clic en «Añadir». Selecciona el ‘script’ que acabamos de crear y «Ejecutar». Ahora elige el lunes a las 00.10h para que se ejecute.

Último paso: dale vida al ‘personal trainer’

Evaluación del ‘personal trainer’

La evaluación va a ser una notificación que nos va a enviar HA a través de Telegram con un análisis detallado de nuestros estado de salud, proponiendo acciones para mejorarla.

Para ello vamos a crear un script que va a adaptar el mensaje de la notificación en función de nuestros valores. Primero voy a incluir un «árbol de respuesta» simple, de ejemplo, para que entiendas cómo se construyen las distintas variantes en el script (una vez entendido el proceso, podrás personalizar y completar la notificación como quieras).

En este mensaje HA nos va a dar información de interés sobre nuestro estado de salud (último peso registrado, último porcentaje de agua corporal registrado y horas de sueño en los últimos 7 días). Estos datos van a ir comparados con los objetivos, por lo que nos dirá si nos encontramos dentro de los valores deseados.

Finalmente nos va a indicar si en la última semana hemos cumplido nuestras metas y, en función de ello y de nuestro peso, nos va a proponer ajustar nuestras metas y objetivos de actividad física.

Evaluacion Personal Trainer

El código que adjunto corresponde a la notificación de la imagen de ejemplo, pero recuerda que es 100% personalizable y puedes adaptar los mensajes, incluir consejos o sugerencias, frases motivacionales, e incluso comandos para incluir productos en la lista de la compra o modificar desde aquí tus metas físicas.

alias: Personal Trainer - Evaluacion
sequence:
  - service: notify.tito
    data:
      message: >-
        Hola TiTo! 


        Pesas {{ states('sensor.tito_weight') | round (1) }} kg, lo que
        significa que {% if states('sensor.tito_forma') == "fit" %}estás
        fenomenal! 🥰 Sigue trabajando en esta línea y mantén los hábitos
        saludables 💪{% elif states('sensor.tito_forma') == "delgado" %}estás
        por debajo de tu peso objetivo 😓 Es el momento de permitirte algún
        antojo 🍕 o de tomarte un descanso 🛌{% elif states('sensor.tito_forma')
        == "sobrepeso" %}tienes sobrepeso 😓 Es el momento de hacer un pequeño
        esfuerzo para volver a tu peso objetivo 🍏🏃‍♂️{% endif %}


        Tu porcentaje de agua corporal es del {{ states('sensor.tito_agua') |
        int }}%, {% if 60>= (states('sensor.tito_agua') | int) >= 50 %}por lo
        que estás bien hidratado 👍{% elif states('sensor.tito_agua') | int < 50
        %}por lo que deberías beber más agua 🥵, ya que el porcentaje
        recomendado está entre el 50 y el 60%. El agua es un vehículo necesario
        para que se realicen la mayoría de las funciones vitales 💙{% elif
        states('sensor.tito_agua') | int > 60 %}por lo que no deberías beber
        tanto agua ✋, ya que el porcentaje recomendado está entre el 50 y el 60%
        y beber agua en exceso también puede producir trastornos 🥶{% endif %}


        En los últimos 7 días has dormido, de media, unas {{
        states('sensor.descanso_acumulado_tito') | round(1) }} horas 😴 {% if
        (states('sensor.descanso_acumulado_tito') | int) >= 7 %}Esto está por
        encima del mínimo recomendado de 7h diarias, así que debes sentirte
        descansado y con fuerza 😀{% elif
        (states('sensor.descanso_acumulado_tito') | int) < 7 %}Esto está por
        debajo del mínimo recomendado de 7h diarias, por lo que es posible que
        te encuentres cansado o de mal humor 🥴 Recuerda que el sueño le permite
        al cuerpo revitalizarse, renovarse y reponerse.{% endif %}


        Parece que en la última semana {% if
        states('input_boolean.metas_fisicas_tito') == "on" %}has cumplido tus
        metas de actividad física!! enhorabuena!! 🤩{% if
        states('sensor.tito_forma') == "fit" %} Normal que estés así de bien 😘
        {% elif states('sensor.tito_forma') == "delgado" %} No obstante, en este
        momento estás por debajo de tu peso ideal, por lo que deberías aumentar
        la ingesta calórica (si quieres mantener el ritmo) o reducir tu
        actividad física. {% elif states('sensor.tito_forma') == "sobrepeso" %}
        No obstante, en este momento estás por encima de tu peso ideal, por lo
        que deberías reducir la ingesta calórica o aumentar tu actividad
        física.{% endif %}{% elif states('input_boolean.metas_fisicas_tito') ==
        "off" %}no has cumplido tus metas de actividad física...😓{% if
        states('sensor.tito_forma') == "fit" %} En este momento estás en forma,
        disfruta de ello pero no te relajes! 😉 {% elif
        states('sensor.tito_forma') == "delgado" %} Por otro lado, en este
        momento estás por debajo de tu peso ideal. Quizás necesites un aporte
        extra de energía o tus metas de actividad física son demasiado
        exigentes! {% elif states('sensor.tito_forma') == "sobrepeso" %} Además,
        en este momento estás por encima de tu peso ideal. Ajusta tu dieta o tus
        metas de actividad física para acercarte a tus objetivos.{% endif %}{%
        endif %}
mode: single
icon: mdi:heart-circle

Este script puede ejecutarse cuando tú decidas, por ejemplo:

  • Manualmente, por ejemplo al pulsar un botón del panel del control.
  • Periódicamente, en el momento de la semana que tu quieras (por ejemplo, justo antes de empezar el fin de semana). Utiliza el Scheduler Component para disparar este ‘script’ el día de la semana y a la hora que decidas, como hemos visto anteriormente.
  • Al producirse un evento, por ejempo cada vez que te peses. Esta es la opción que más me gusta, ya que recibo un mensaje informativo una vez a la semana cuando me peso. Para ello he creado una automatización que ejecuta el script cuando cambia el valor del sensor que contiene los valores de la báscula.

Notificaciones de refuerzo

Nuestro ‘personal trainter’ también se puede comunicar con nosotros a través de notificaciones de Telegram, cuando se de algún evento que requiera nuestra atención para mejorar nuestra salud. Obviamente van a depender de tus preferencias y tu actividad, así como de los elementos que hayas integrado y los sensores que hayas recopilado. No obstante, a continuación te detallo una serie de ideas.

  • Meta conseguida! Haz que te envíe un mensaje de refuerzo positivo cuando alcances tus metas.
  • Días sin malos hábitos. Recibe una felicitación cuando lleves sin caer en los malos hábitos 1 día, 1 semana, 1 mes, 1 año…
  • Nivel de actividad bajo. Por ejemplo, puedes utilizar la media de pasos diarios como un valor de referencia de movimiento. Por tanto, cuando la media caiga por debajo del objetivo, HA te mandará una notificación animándote a caminar más.
  • Kcal consumidas por debajo del objetivo. Si tu plan está orientado a la pérdida de peso, te va a interesar recibir una notificación de HA los días que no hayas cumplido tu objetivo, para «ponerte las pilas».
  • Falta de sueño. Si el tiempo de sueño de la última noche está por debajo del objetivo marcado, a medio día te manda una notificación recomendándote una siesta recuperadora. Si al final del día sigues por debajo del objetivo, a una hora determinada te recomienda que te vayas a la cama.

Desactivación de las notificaciones

Ya sea porque te vas de vacaciones, das por concluida la ‘operación bikini’ o simplementeno no quieres continuar con el ‘personal trainer’, vas a poder desactivar rápida y fácilmente las notificaciones. De esta forma HA va a dejar de mandarte cualquier tipo de mensaje relacionado, guardando toda la configuración por si quieres retomarlo en un futuro.

Para ello sigue estos pasos:

  1. Crea un Ayudante de tipo alternar y ponle un nombre con la siguiente estructura ‘personal_trainer_NOMBRE’ (por ejemplo, personal_trainer_tito). Esto creará la entidad ‘input_boolean.personal_trainer_tito’.
  2. Agrega en el apartado de seguimiento del panel de control una tarjeta del tipo «Entidades» y añade el ayudante creado en el paso anterior.
  3. Ahora vamos a crear una automatización que se activará cuando cambie el estado del ayudante creado en el primer paso. Si cambia a ‘off’ deshabilitará todas automatizaciones que nos envían notificaciones del ‘personal trainer’. Si cambia a ‘on’ las habilitará. Para ello crea una nueva automatización y pega el siguiente código, y no olvides sustituir tu nombre según el ayudante creado en el primer paso, así como seleccionar las automatizaciones que has creado para que HA te genere notificaciones del ‘personal trainer’.
alias: Personal Trainer - Notificaciones
description: Habilita o deshabilita las notificaciones del Personal Trainer
trigger:
  - platform: state
    entity_id:
      - input_boolean.personal_trainer_NOMBRE
condition: []
action:
  - if:
      - condition: state
        entity_id: input_boolean.personal_trainer_NOMBRE
        state: "off"
    then:
      - service: homeassistant.turn_off
        data: {}
        target:
          entity_id:
            - automation.personal_trainer_evaluacion
    else:
      - service: homeassistant.turn_on
        data: {}
        target:
          entity_id:
            - automation.personal_trainer_evaluacion
mode: single
🛟 ¿Dudas? Si necesitas ayuda entra aquí 👈 🎁 Y si te ha gustado y quieres más... 🥑
Contenido exclusivo de Aguacatec