Skip to content

Latest commit

 

History

History
163 lines (130 loc) · 6.38 KB

README.md

File metadata and controls

163 lines (130 loc) · 6.38 KB

Carbon Intensity UK sensor

GitHub Release

GitHub Activity License

hacs Project Maintenance BuyMeCoffee

Discord Community Forum

Component to integrate with Carbon Intensity UK.

This component will set up the following platforms.

Platform Description
sensor Show info from Carbon Intensity UK API.

The sensor retrieves information using Carbon Intensity UK API library

alt Sensor attributes

Installation

  1. Using the tool of choice open the directory (folder) for your HA configuration (where you find configuration.yaml).
  2. If you do not have a custom_components directory (folder) there, you need to create it.
  3. In the custom_components directory (folder) create a new folder called carbon_intensity_uk.
  4. Download all the files from the custom_components/carbon_intensity_uk/ directory (folder) in this repository.
  5. Place the files you downloaded in the new directory (folder) you created.
  6. Restart Home Assistant
  7. In the HA UI go to "Configuration" -> "Integrations" click "+" and search for "Carbon Intensity UK"

Using your HA configuration directory (folder) as a starting point you should now also have this:

custom_components/carbon_intensity_uk/.translations/en.json
custom_components/carbon_intensity_uk/.translations/nb.json
custom_components/carbon_intensity_uk/.translations/sensor.nb.json
custom_components/carbon_intensity_uk/__init__.py
custom_components/carbon_intensity_uk/binary_sensor.py
custom_components/carbon_intensity_uk/config_flow.py
custom_components/carbon_intensity_uk/const.py
custom_components/carbon_intensity_uk/manifest.json
custom_components/carbon_intensity_uk/sensor.py
custom_components/carbon_intensity_uk/switch.py

Example Markdown card

alt Example card

{% set t_start = (  state_attr('sensor.carbon_intensity_uk','optimal_window_from') - now()).total_seconds() %}
{% set t_end = (  state_attr('sensor.carbon_intensity_uk','optimal_window_to') - now()).total_seconds() %}


The best time to run energy hungry devices is between {{ as_timestamp(state_attr('sensor.carbon_intensity_uk','optimal_window_from')) | timestamp_custom('%I:%M %p')  }} and {{ as_timestamp(state_attr('sensor.carbon_intensity_uk','optimal_window_to')) | timestamp_custom('%I:%M %p')  }}.
Starting in {{ t_start | timestamp_custom('%-H hr %-M min' if t_start > 3600 else '%-M min', false) }} and finishing {{ t_end | timestamp_custom('%-H hr %-M min' if t_end > 3600 else '%-M min', false) }} from now.

Display forecast in html card

alt Example card with a forecast

type: custom:html-template-card
title: Energy Intensity Forecast
ignore_line_breaks: true
content: >
  <style> table {    width: 100%;   } tr:nth-child(even) {     background-color:
  #222222;   } td, th {     text-align: left;   } </style>  <table> <thead> <tr>
  <th>Period</th> <th>Index</th>  <th>Intensity</th> </tr></thead> <tbody>  {%
  for state in   states.sensor.carbon_intensity_uk.attributes.forecast -%}  <tr
  {% if state.optimal %}  style="background-color:#336600;"{%endif%}>
    <td> {{ as_timestamp(state.from) | timestamp_custom('%I:%M %p') }} - {{ as_timestamp(state.to) | timestamp_custom('%I:%M %p')}}</td>
    <td {% if state.index=='high' or state.index=='very high' %} style="color:#cc3300"{%endif%}
    {% if state.index=='moderate' %} style="color:#ff9900"{%endif%} >  {{state.index}}</td>
    <td {% if state.index=='high' or state.index=='very high' %} style="color:#cc3300"{%endif%}
    {% if state.index=='moderate' %} style="color:#ff9900"{%endif%} >  {{state.intensity}}</td>
  </tr>  {%- endfor %}   </tbody> </table> 

Display forecast in html card

alt Example card forecast graph

type: custom:apexcharts-card
experimental:
  color_threshold: true
graph_span: 2d
span:
  start: minute
update_interval: 1min
series:
  - entity: sensor.carbon_intensity_uk
    unit: g/kWh
    name: Carbon Intensity g/kWh
    show:
      legend_value: false
    data_generator: |
      return entity.attributes.forecast.map(obj => {
        return [new Date(obj.from).getTime(), obj.intensity];
      });
    color_threshold:
      - value: 25
        color: darkgreen
        opacity: 1
      - value: 95
        color: green
      - value: 180
        color: gold
      - value: 279
        color: red
      - value: 330
        color: darkred
  - entity: sensor.carbon_intensity_uk
    type: area
    unit: g/kWh
    color: green
    name: Optimal Window
    stroke_width: 0
    show:
      legend_value: false
    data_generator: |
      return entity.attributes.forecast.map(obj => {
        return [new Date(obj.from).getTime(), (obj.optimal ? obj.intensity : 0 )];
      });

Configuration is done in the UI

Contributions are welcome!

If you want to contribute to this please read the Contribution guidelines