From b3e14d449e03dbf10cc53b31911c973b5c590e2f Mon Sep 17 00:00:00 2001
From: Simon Lamon <32477463+silamon@users.noreply.github.com>
Date: Wed, 29 May 2024 14:07:52 +0200
Subject: [PATCH] Show detailed config entry error inline (#20764)
* Put config entry error inline
* Fixes (show configure button and don't make them interactive)
---
.../ha-config-integration-page.ts | 103 +++++++++---------
1 file changed, 52 insertions(+), 51 deletions(-)
diff --git a/src/panels/config/integrations/ha-config-integration-page.ts b/src/panels/config/integrations/ha-config-integration-page.ts
index 7eabbeb93e7e..2afb107fd9fe 100644
--- a/src/panels/config/integrations/ha-config-integration-page.ts
+++ b/src/panels/config/integrations/ha-config-integration-page.ts
@@ -47,6 +47,9 @@ import { nextRender } from "../../../common/util/render-status";
import "../../../components/ha-button";
import "../../../components/ha-card";
import "../../../components/ha-list-item";
+import "../../../components/ha-list-new";
+import "../../../components/ha-list-item-new";
+import "../../../components/ha-button-menu-new";
import {
deleteApplicationCredential,
fetchApplicationCredentialsConfigEntry,
@@ -419,17 +422,13 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
"ui.panel.config.integrations.discovered"
)}
-
+
${discoveryFlows.map(
(flow) =>
- html`
+ html`
${flow.localized_title}
- `
+ `
)}
-
+
`
: ""}
${attentionFlows.length || attentionEntries.length
@@ -449,19 +448,16 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
`ui.panel.config.integrations.integration_page.attention_entries`
)}
-
+
${attentionFlows.map((flow) => {
const attention = ATTENTION_SOURCES.includes(
flow.context.source
);
- return html`
${flow.localized_title}
- ${this.hass.localize(
`ui.panel.config.integrations.${
attention ? "attention" : "discovered"
@@ -469,7 +465,7 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
)}
- `;
+ `;
})}
${attentionEntries.map((item) =>
this._renderConfigEntry(item)
)}
-
+
`
: ""}
@@ -505,9 +501,9 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
)}
`
: nothing}
-
+
${normalEntries.map((item) => this._renderConfigEntry(item))}
-
+
${this._manifest?.integration_type
@@ -671,41 +667,42 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
const configPanel = this._configPanel(item.domain, this.hass.panels);
- return html`
- ${stateText
- ? html`
-
-
-
${this.hass.localize(...stateText)}
- ${stateTextExtra
- ? html`
${stateTextExtra}`
- : ""}
-
- `
- : ""}
${item.title || domainToName(this.hass.localize, item.domain)}
- ${devicesLine}
+
+
${devicesLine}
+ ${stateText
+ ? html`
+
+
+
+ ${this.hass.localize(...stateText)}${stateTextExtra
+ ? html`: ${stateTextExtra}`
+ : ""}
+
+
+ `
+ : ""}
+
${item.disabled_by === "user"
- ? html`
+ ? html`
${this.hass.localize("ui.common.enable")}
`
: configPanel &&
(item.domain !== "matter" || isDevVersion(this.hass.config.version))
? html`
${this.hass.localize(
@@ -715,14 +712,14 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
>`
: item.supports_options && !stateText
? html`
-
+
${this.hass.localize(
"ui.panel.config.integrations.config_entry.configure"
)}
`
: ""}
-
+
`
: ""}
-
- `;
+
+ `;
}
private async _highlightEntry() {
@@ -1431,30 +1428,30 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
ha-alert:first-of-type {
margin-top: 16px;
}
- ha-list-item.discovered {
+ ha-list-item-new.discovered {
--mdc-list-item-meta-size: auto;
--mdc-list-item-meta-display: flex;
height: 72px;
}
- ha-list-item.config_entry {
+ ha-list-item-new.config_entry {
overflow: visible;
--mdc-list-item-meta-size: auto;
--mdc-list-item-meta-display: flex;
}
- ha-button-menu ha-list-item {
+ ha-button-menu-new ha-list-item {
--mdc-list-item-meta-size: 24px;
}
- ha-list-item.config_entry::after {
+ ha-list-item-new.config_entry::after {
position: absolute;
- top: 0;
+ top: 8px;
right: 0;
- bottom: 0;
+ bottom: 8px;
left: 0;
opacity: 0.12;
pointer-events: none;
content: "";
}
- ha-button-menu {
+ ha-button-menu-new {
flex: 0;
}
a {
@@ -1513,6 +1510,10 @@ class HaConfigIntegrationPage extends SubscribeMixin(LitElement) {
overflow: hidden;
text-overflow: ellipsis;
}
+ ha-list-new {
+ margin-top: 8px;
+ margin-bottom: 8px;
+ }
`,
];
}