############################################# ############################################# # LAUNDRY BENCH PLUGS POWER AND SWITCH # V1.0 2025-03-28 Initial Version ############################################# # Sonoff POW R1 # https://devices.esphome.io/devices/Sonoff-POW-R1 # # NOTES # - # ############################################# ############################################# ############################################# # SPECIFIC DEVICE VARIABLE SUBSTITUTIONS # If NOT using a secrets file, just replace these with the passwords etc (in quotes) ############################################# substitutions: device_name: "esp-laundryplugpow" # Reference name for the device in the system. project_name: "Sonoff Technologies.POW R1" # Project Details project_version: "v1" # Project V denotes release of yaml file, allowing checking of deployed vs latest version entity_prefix: "Load" # Simple device name where we want to prefix a sensor or switch, eg "Load" Current. friendly_name: "Laundry Bench Plug Power" description_comment: "Laundry Bench Plug Power and switch override using a Sonoff Pow R1." device_area: "Laundry" # Allows ESP device to be automatically linked to an 'Area' in Home Assistant. api_key: !secret esp-laundryplugpow_api_key # unfortunately you can't use substitutions inside secrets names ota_pass: !secret esp-laundryplugpow_ota_pass # unfortunately you can't use substitutions inside secrets names static_ip_address: !secret esp-laundryplugpow_ip log_level: "INFO" # Define logging level: NONE, ERROR, WARN, INFO, DEBUG (Default), VERBOSE, VERY_VERBOSE update_interval: "60s" # update time for for general sensors etc ########################################################################################## # PACKAGES: Included Common Packages # https://esphome.io/components/packages.html ########################################################################################## packages: common_wifi: !include file: common/network_common.yaml vars: local_device_name: "${device_name}" local_static_ip_address: "${static_ip_address}" local_ota_pass: "${ota_pass}" common_api: !include file: common/api_common.yaml vars: local_api_key: "${api_key}" #common_webportal: !include # file: common/webportal_common.yaml common_mqtt: !include file: common/mqtt_common.yaml vars: local_device_name: "${device_name}" common_sntp: !include file: common/sntp_common.yaml common_general_sensors: !include file: common/sensors_common.yaml vars: local_friendly_name: "${friendly_name}" local_update_interval: "${update_interval}" ############################################# # ESPHome # https://esphome.io/components/esphome.html ############################################# esphome: name: "${device_name}" friendly_name: "${friendly_name}" comment: "${description_comment}" # Appears on the esphome page in HA area: "${device_area}" project: name: "${project_name}" version: "${project_version}" on_boot: priority: 200 then: - switch.turn_on: "virtual_button" ############################################# # ESP Platform and Framework # https://esphome.io/components/esp32.html ############################################# esp8266: board: esp01_1m early_pin_init: False # Initialise pins early to known values. Recommended false where switches are involved. Defaults to True. board_flash_mode: dout # Default is dout ############################################# # ESPHome Logging Enable # https://esphome.io/components/logger.html ############################################# logger: level: ${log_level} #INFO Level suggested, or DEBUG for testing #baud_rate: 0 #set to 0 for no logging via UART, needed if you are using it for other serial things (eg PZEM) #esp8266_store_log_strings_in_flash: false #tx_buffer_size: 64 ############################################# # STATUS LED # https://esphome.io/components/status_led.html ############################################# #status_led: # pin: # number: GPIO2 # inverted: yes ############################################# # SENSORS # https://esphome.io/components/binary_sensor/ ############################################# binary_sensor: - platform: gpio pin: number: GPIO0 mode: INPUT_PULLUP inverted: True name: Button on_press: - switch.toggle: virtual_button - platform: template name: ${entity_prefix} Running filters: - delayed_off: 15s lambda: |- if (isnan(id(power).state)) { return {}; } else if (id(power).state > 4) { // Running return true; } else { // Not running return false; } sensor: - platform: hlw8012 sel_pin: 5 cf_pin: 14 cf1_pin: 13 update_interval: 2s current: name: ${entity_prefix} Current voltage: name: ${entity_prefix} Voltage power: name: ${entity_prefix} Power id: power #on_value_range: # - above: 4.0 # then: # - light.turn_on: led # - below: 3.0 # then: # - light.turn_off: led switch: - platform: template name: "Relay" optimistic: true id: virtual_button turn_on_action: - switch.turn_on: relay - light.turn_on: led turn_off_action: - switch.turn_off: relay - light.turn_off: led - platform: gpio id: relay pin: GPIO12 #restore_mode: ALWAYS_ON # Or RESTORE_DEFAULT_ON/RESTORE_DEFAULT_OFF output: - platform: esp8266_pwm id: pow_blue_led pin: number: GPIO15 inverted: True light: - platform: monochromatic name: Status LED output: pow_blue_led id: led