hon/scripts/sensor_docs.py

82 lines
2.8 KiB
Python
Raw Normal View History

2023-04-23 03:06:31 +05:30
#!/usr/bin/env python
2023-04-18 02:48:27 +05:30
import re
2023-04-23 03:06:31 +05:30
import sys
2023-04-18 02:48:27 +05:30
from pathlib import Path
2023-05-10 21:43:05 +05:30
2023-04-23 03:06:31 +05:30
if __name__ == "__main__":
sys.path.insert(0, str(Path(__file__).parent.parent))
from custom_components.hon.const import APPLIANCES
2023-04-17 03:05:43 +05:30
from custom_components.hon.binary_sensor import BINARY_SENSORS
from custom_components.hon.button import BUTTONS
2023-06-30 23:10:30 +05:30
from custom_components.hon.light import LIGHTS
2023-05-10 21:43:05 +05:30
from custom_components.hon.climate import CLIMATES
2023-04-17 03:05:43 +05:30
from custom_components.hon.number import NUMBERS
from custom_components.hon.select import SELECTS
from custom_components.hon.sensor import SENSORS
2023-06-09 09:26:52 +05:30
from custom_components.hon.fan import FANS
2023-05-28 11:20:59 +05:30
from custom_components.hon.switch import (
SWITCHES,
HonControlSwitchEntityDescription,
HonSwitchEntityDescription,
)
2023-04-17 03:05:43 +05:30
ENTITY_CATEGORY_SORT = ["control", "config", "sensor"]
entities = {
"binary_sensor": BINARY_SENSORS,
"button": BUTTONS,
"light": LIGHTS,
"climate": CLIMATES,
2023-04-17 03:05:43 +05:30
"number": NUMBERS,
"select": SELECTS,
"sensor": SENSORS,
2023-06-09 09:26:52 +05:30
"fan": FANS,
"switch": SWITCHES,
2023-04-17 03:05:43 +05:30
}
result = {}
for entity_type, appliances in entities.items():
for appliance, data in appliances.items():
for entity in data:
2023-05-28 11:20:59 +05:30
if isinstance(entity, HonControlSwitchEntityDescription):
2023-04-18 02:48:27 +05:30
key = f"{entity.turn_on_key}` / `{entity.turn_off_key}"
else:
key = entity.key
2023-04-25 01:08:05 +05:30
attributes = (key, entity.name, entity.icon, entity_type)
2023-05-10 21:43:05 +05:30
category = (
"control"
2023-05-17 03:31:33 +05:30
if entity.key.startswith("settings")
2023-05-28 11:20:59 +05:30
or isinstance(entity, HonSwitchEntityDescription)
or isinstance(entity, HonControlSwitchEntityDescription)
2023-05-17 03:31:33 +05:30
or entity_type in ["button", "climate"]
2023-05-10 21:43:05 +05:30
else "sensor"
)
2023-04-17 03:05:43 +05:30
result.setdefault(appliance, {}).setdefault(
entity.entity_category or category, []
).append(attributes)
2023-04-18 02:48:27 +05:30
text = ""
2023-04-17 03:05:43 +05:30
for appliance, categories in sorted(result.items()):
2023-04-18 02:48:27 +05:30
text += f"\n### {APPLIANCES[appliance]}\n"
2023-04-17 03:05:43 +05:30
categories = {k: categories[k] for k in ENTITY_CATEGORY_SORT if k in categories}
for category, data in categories.items():
2023-04-18 02:48:27 +05:30
text += f"#### {str(category).capitalize()}s\n"
2023-04-25 01:08:05 +05:30
text += "| Name | Icon | Entity | Key |\n"
text += "| --- | --- | --- | --- |\n"
for key, name, icon, entity_type in sorted(data, key=lambda d: d[1]):
2023-04-23 05:31:14 +05:30
icon = f"`{icon.replace('mdi:', '')}`" if icon else ""
2023-04-25 01:08:05 +05:30
text += f"| {name} | {icon} | `{entity_type}` | `{key}` |\n"
2023-04-18 02:48:27 +05:30
with open(Path(__file__).parent.parent / "README.md", "r") as file:
readme = file.read()
readme = re.sub(
"(## Appliance Features\n)(?:.|\\s)+?([^#]## |\\Z)",
f"\\1{text}\\2",
readme,
re.DOTALL,
)
with open(Path(__file__).parent.parent / "README.md", "w") as file:
file.write(readme)