mirror of
https://github.com/esphome/esphome.git
synced 2024-12-31 18:01:45 +01:00
Device description in dashboard (#707)
* Description * Review fixes * Test * Label * Description renamed to comment
This commit is contained in:
parent
0eadda77b0
commit
be91cfb261
8 changed files with 40 additions and 5 deletions
|
@ -86,6 +86,7 @@ CONF_COLOR_CORRECT = 'color_correct'
|
||||||
CONF_COLOR_TEMPERATURE = 'color_temperature'
|
CONF_COLOR_TEMPERATURE = 'color_temperature'
|
||||||
CONF_COMMAND = 'command'
|
CONF_COMMAND = 'command'
|
||||||
CONF_COMMAND_TOPIC = 'command_topic'
|
CONF_COMMAND_TOPIC = 'command_topic'
|
||||||
|
CONF_COMMENT = 'comment'
|
||||||
CONF_COMMIT = 'commit'
|
CONF_COMMIT = 'commit'
|
||||||
CONF_COMPONENTS = 'components'
|
CONF_COMPONENTS = 'components'
|
||||||
CONF_COMPONENT_ID = 'component_id'
|
CONF_COMPONENT_ID = 'component_id'
|
||||||
|
|
|
@ -10,8 +10,8 @@ import re
|
||||||
# pylint: disable=unused-import, wrong-import-order
|
# pylint: disable=unused-import, wrong-import-order
|
||||||
from typing import Any, Dict, List # noqa
|
from typing import Any, Dict, List # noqa
|
||||||
|
|
||||||
from esphome.const import CONF_ARDUINO_VERSION, CONF_ESPHOME, CONF_USE_ADDRESS, CONF_WIFI, \
|
from esphome.const import CONF_ARDUINO_VERSION, SOURCE_FILE_EXTENSIONS, \
|
||||||
SOURCE_FILE_EXTENSIONS
|
CONF_COMMENT, CONF_ESPHOME, CONF_USE_ADDRESS, CONF_WIFI
|
||||||
from esphome.helpers import ensure_unique_string, is_hassio
|
from esphome.helpers import ensure_unique_string, is_hassio
|
||||||
from esphome.py_compat import IS_PY2, integer_types, text_type, string_types
|
from esphome.py_compat import IS_PY2, integer_types, text_type, string_types
|
||||||
from esphome.util import OrderedDict
|
from esphome.util import OrderedDict
|
||||||
|
@ -539,6 +539,13 @@ class EsphomeCore(object):
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def comment(self): # type: () -> str
|
||||||
|
if CONF_COMMENT in self.config[CONF_ESPHOME]:
|
||||||
|
return self.config[CONF_ESPHOME][CONF_COMMENT]
|
||||||
|
|
||||||
|
return None
|
||||||
|
|
||||||
def _add_active_coroutine(self, instance_id, obj):
|
def _add_active_coroutine(self, instance_id, obj):
|
||||||
self.active_coroutines[instance_id] = obj
|
self.active_coroutines[instance_id] = obj
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,7 @@ import esphome.config_validation as cv
|
||||||
from esphome import automation, pins
|
from esphome import automation, pins
|
||||||
from esphome.const import ARDUINO_VERSION_ESP32_DEV, ARDUINO_VERSION_ESP8266_DEV, \
|
from esphome.const import ARDUINO_VERSION_ESP32_DEV, ARDUINO_VERSION_ESP8266_DEV, \
|
||||||
CONF_ARDUINO_VERSION, CONF_BOARD, CONF_BOARD_FLASH_MODE, CONF_BUILD_PATH, \
|
CONF_ARDUINO_VERSION, CONF_BOARD, CONF_BOARD_FLASH_MODE, CONF_BUILD_PATH, \
|
||||||
CONF_ESPHOME, CONF_INCLUDES, CONF_LIBRARIES, \
|
CONF_COMMENT, CONF_ESPHOME, CONF_INCLUDES, CONF_LIBRARIES, \
|
||||||
CONF_NAME, CONF_ON_BOOT, CONF_ON_LOOP, CONF_ON_SHUTDOWN, CONF_PLATFORM, \
|
CONF_NAME, CONF_ON_BOOT, CONF_ON_LOOP, CONF_ON_SHUTDOWN, CONF_PLATFORM, \
|
||||||
CONF_PLATFORMIO_OPTIONS, CONF_PRIORITY, CONF_TRIGGER_ID, \
|
CONF_PLATFORMIO_OPTIONS, CONF_PRIORITY, CONF_TRIGGER_ID, \
|
||||||
CONF_ESP8266_RESTORE_FROM_FLASH, ARDUINO_VERSION_ESP8266_2_3_0, \
|
CONF_ESP8266_RESTORE_FROM_FLASH, ARDUINO_VERSION_ESP8266_2_3_0, \
|
||||||
|
@ -113,6 +113,7 @@ CONFIG_SCHEMA = cv.Schema({
|
||||||
cv.Required(CONF_NAME): cv.valid_name,
|
cv.Required(CONF_NAME): cv.valid_name,
|
||||||
cv.Required(CONF_PLATFORM): cv.one_of('ESP8266', 'ESP32', upper=True),
|
cv.Required(CONF_PLATFORM): cv.one_of('ESP8266', 'ESP32', upper=True),
|
||||||
cv.Required(CONF_BOARD): validate_board,
|
cv.Required(CONF_BOARD): validate_board,
|
||||||
|
cv.Optional(CONF_COMMENT): cv.string,
|
||||||
cv.Optional(CONF_ARDUINO_VERSION, default='recommended'): validate_arduino_version,
|
cv.Optional(CONF_ARDUINO_VERSION, default='recommended'): validate_arduino_version,
|
||||||
cv.Optional(CONF_BUILD_PATH, default=default_build_path): cv.string,
|
cv.Optional(CONF_BUILD_PATH, default=default_build_path): cv.string,
|
||||||
cv.Optional(CONF_PLATFORMIO_OPTIONS, default={}): cv.Schema({
|
cv.Optional(CONF_PLATFORMIO_OPTIONS, default={}): cv.Schema({
|
||||||
|
|
|
@ -401,6 +401,12 @@ class DashboardEntry(object):
|
||||||
return self.filename[:-len('.yaml')]
|
return self.filename[:-len('.yaml')]
|
||||||
return self.storage.name
|
return self.storage.name
|
||||||
|
|
||||||
|
@property
|
||||||
|
def comment(self):
|
||||||
|
if self.storage is None:
|
||||||
|
return None
|
||||||
|
return self.storage.comment
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def esp_platform(self):
|
def esp_platform(self):
|
||||||
if self.storage is None:
|
if self.storage is None:
|
||||||
|
|
|
@ -247,3 +247,10 @@ ul.stepper:not(.horizontal) .step.active::before, ul.stepper:not(.horizontal) .s
|
||||||
padding: 10px 15px;
|
padding: 10px 15px;
|
||||||
margin-top: 15px;
|
margin-top: 15px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.card-comment {
|
||||||
|
margin-bottom: 8px;
|
||||||
|
font-size: 14px;
|
||||||
|
color: #444;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
|
|
@ -79,6 +79,11 @@
|
||||||
{% end %}
|
{% end %}
|
||||||
<i class="material-icons right dropdown-trigger" data-target="dropdown-{{ i }}">more_vert</i>
|
<i class="material-icons right dropdown-trigger" data-target="dropdown-{{ i }}">more_vert</i>
|
||||||
</span>
|
</span>
|
||||||
|
{% if entry.comment %}
|
||||||
|
<div class="card-comment">
|
||||||
|
{{ escape(entry.comment) }}
|
||||||
|
</div>
|
||||||
|
{% end %}
|
||||||
<p>
|
<p>
|
||||||
<span class="status-indicator unknown" data-node="{{ entry.filename }}">
|
<span class="status-indicator unknown" data-node="{{ entry.filename }}">
|
||||||
<span class="status-indicator-icon"></span>
|
<span class="status-indicator-icon"></span>
|
||||||
|
|
|
@ -35,7 +35,7 @@ def trash_storage_path(base_path): # type: (str) -> str
|
||||||
|
|
||||||
# pylint: disable=too-many-instance-attributes
|
# pylint: disable=too-many-instance-attributes
|
||||||
class StorageJSON(object):
|
class StorageJSON(object):
|
||||||
def __init__(self, storage_version, name, esphome_version,
|
def __init__(self, storage_version, name, comment, esphome_version,
|
||||||
src_version, arduino_version, address, esp_platform, board, build_path,
|
src_version, arduino_version, address, esp_platform, board, build_path,
|
||||||
firmware_bin_path, loaded_integrations):
|
firmware_bin_path, loaded_integrations):
|
||||||
# Version of the storage JSON schema
|
# Version of the storage JSON schema
|
||||||
|
@ -43,6 +43,8 @@ class StorageJSON(object):
|
||||||
self.storage_version = storage_version # type: int
|
self.storage_version = storage_version # type: int
|
||||||
# The name of the node
|
# The name of the node
|
||||||
self.name = name # type: str
|
self.name = name # type: str
|
||||||
|
# The comment of the node
|
||||||
|
self.comment = comment # type: str
|
||||||
# The esphome version this was compiled with
|
# The esphome version this was compiled with
|
||||||
self.esphome_version = esphome_version # type: str
|
self.esphome_version = esphome_version # type: str
|
||||||
# The version of the file in src/main.cpp - Used to migrate the file
|
# The version of the file in src/main.cpp - Used to migrate the file
|
||||||
|
@ -69,6 +71,7 @@ class StorageJSON(object):
|
||||||
return {
|
return {
|
||||||
'storage_version': self.storage_version,
|
'storage_version': self.storage_version,
|
||||||
'name': self.name,
|
'name': self.name,
|
||||||
|
'comment': self.comment,
|
||||||
'esphome_version': self.esphome_version,
|
'esphome_version': self.esphome_version,
|
||||||
'src_version': self.src_version,
|
'src_version': self.src_version,
|
||||||
'arduino_version': self.arduino_version,
|
'arduino_version': self.arduino_version,
|
||||||
|
@ -93,6 +96,7 @@ class StorageJSON(object):
|
||||||
return StorageJSON(
|
return StorageJSON(
|
||||||
storage_version=1,
|
storage_version=1,
|
||||||
name=esph.name,
|
name=esph.name,
|
||||||
|
comment=esph.comment,
|
||||||
esphome_version=const.__version__,
|
esphome_version=const.__version__,
|
||||||
src_version=1,
|
src_version=1,
|
||||||
arduino_version=esph.arduino_version,
|
arduino_version=esph.arduino_version,
|
||||||
|
@ -110,6 +114,7 @@ class StorageJSON(object):
|
||||||
return StorageJSON(
|
return StorageJSON(
|
||||||
storage_version=1,
|
storage_version=1,
|
||||||
name=name,
|
name=name,
|
||||||
|
comment=None,
|
||||||
esphome_version=const.__version__,
|
esphome_version=const.__version__,
|
||||||
src_version=1,
|
src_version=1,
|
||||||
arduino_version=None,
|
arduino_version=None,
|
||||||
|
@ -128,6 +133,7 @@ class StorageJSON(object):
|
||||||
storage = json.loads(text, encoding='utf-8')
|
storage = json.loads(text, encoding='utf-8')
|
||||||
storage_version = storage['storage_version']
|
storage_version = storage['storage_version']
|
||||||
name = storage.get('name')
|
name = storage.get('name')
|
||||||
|
comment = storage.get('comment')
|
||||||
esphome_version = storage.get('esphome_version', storage.get('esphomeyaml_version'))
|
esphome_version = storage.get('esphome_version', storage.get('esphomeyaml_version'))
|
||||||
src_version = storage.get('src_version')
|
src_version = storage.get('src_version')
|
||||||
arduino_version = storage.get('arduino_version')
|
arduino_version = storage.get('arduino_version')
|
||||||
|
@ -137,7 +143,7 @@ class StorageJSON(object):
|
||||||
build_path = storage.get('build_path')
|
build_path = storage.get('build_path')
|
||||||
firmware_bin_path = storage.get('firmware_bin_path')
|
firmware_bin_path = storage.get('firmware_bin_path')
|
||||||
loaded_integrations = storage.get('loaded_integrations', [])
|
loaded_integrations = storage.get('loaded_integrations', [])
|
||||||
return StorageJSON(storage_version, name, esphome_version,
|
return StorageJSON(storage_version, name, comment, esphome_version,
|
||||||
src_version, arduino_version, address, esp_platform, board, build_path,
|
src_version, arduino_version, address, esp_platform, board, build_path,
|
||||||
firmware_bin_path, loaded_integrations)
|
firmware_bin_path, loaded_integrations)
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
esphome:
|
esphome:
|
||||||
name: $devicename
|
name: $devicename
|
||||||
|
comment: $devicecomment
|
||||||
platform: ESP8266
|
platform: ESP8266
|
||||||
board: d1_mini
|
board: d1_mini
|
||||||
build_path: build/test3
|
build_path: build/test3
|
||||||
|
@ -12,6 +13,7 @@ esphome:
|
||||||
|
|
||||||
substitutions:
|
substitutions:
|
||||||
devicename: test3
|
devicename: test3
|
||||||
|
devicecomment: test3 device
|
||||||
|
|
||||||
api:
|
api:
|
||||||
port: 8000
|
port: 8000
|
||||||
|
|
Loading…
Reference in a new issue