mirror of
https://github.com/home-assistant/frontend.git
synced 2025-07-27 11:16:35 +00:00
Deduplicate blueprint editor code (#19791)
* Deduplicate blueprint editor code * prune unneeded imports
This commit is contained in:
parent
763c672e36
commit
291638a9dd
@ -1,56 +1,23 @@
|
|||||||
import "@material/mwc-button/mwc-button";
|
import "@material/mwc-button/mwc-button";
|
||||||
import { HassEntity } from "home-assistant-js-websocket";
|
import { HassEntity } from "home-assistant-js-websocket";
|
||||||
import { css, CSSResultGroup, html, LitElement } from "lit";
|
import { html } from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { customElement, property } from "lit/decorators";
|
||||||
import { fireEvent } from "../../../common/dom/fire_event";
|
|
||||||
import { nestedArrayMove } from "../../../common/util/array-move";
|
|
||||||
import "../../../components/ha-alert";
|
import "../../../components/ha-alert";
|
||||||
import "../../../components/ha-blueprint-picker";
|
|
||||||
import "../../../components/ha-card";
|
|
||||||
import "../../../components/ha-circular-progress";
|
|
||||||
import "../../../components/ha-markdown";
|
|
||||||
import "../../../components/ha-selector/ha-selector";
|
|
||||||
import "../../../components/ha-settings-row";
|
|
||||||
import { BlueprintAutomationConfig } from "../../../data/automation";
|
import { BlueprintAutomationConfig } from "../../../data/automation";
|
||||||
import {
|
import { fetchBlueprints } from "../../../data/blueprint";
|
||||||
BlueprintOrError,
|
import { HaBlueprintGenericEditor } from "../blueprint/blueprint-generic-editor";
|
||||||
Blueprints,
|
|
||||||
fetchBlueprints,
|
|
||||||
} from "../../../data/blueprint";
|
|
||||||
import { haStyle } from "../../../resources/styles";
|
|
||||||
import { HomeAssistant } from "../../../types";
|
|
||||||
import "../ha-config-section";
|
|
||||||
|
|
||||||
@customElement("blueprint-automation-editor")
|
@customElement("blueprint-automation-editor")
|
||||||
export class HaBlueprintAutomationEditor extends LitElement {
|
export class HaBlueprintAutomationEditor extends HaBlueprintGenericEditor {
|
||||||
@property({ attribute: false }) public hass!: HomeAssistant;
|
|
||||||
|
|
||||||
@property({ type: Boolean }) public isWide = false;
|
|
||||||
|
|
||||||
@property({ type: Boolean }) public disabled = false;
|
|
||||||
|
|
||||||
@property({ type: Boolean, reflect: true }) public narrow = false;
|
|
||||||
|
|
||||||
@property({ attribute: false }) public config!: BlueprintAutomationConfig;
|
@property({ attribute: false }) public config!: BlueprintAutomationConfig;
|
||||||
|
|
||||||
@property({ attribute: false }) public stateObj?: HassEntity;
|
@property({ attribute: false }) public stateObj?: HassEntity;
|
||||||
|
|
||||||
@state() private _blueprints?: Blueprints;
|
protected get _config(): BlueprintAutomationConfig {
|
||||||
|
return this.config;
|
||||||
protected firstUpdated(changedProps) {
|
|
||||||
super.firstUpdated(changedProps);
|
|
||||||
this._getBlueprints();
|
|
||||||
}
|
|
||||||
|
|
||||||
private get _blueprint(): BlueprintOrError | undefined {
|
|
||||||
if (!this._blueprints) {
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
return this._blueprints[this.config.use_blueprint.path];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected render() {
|
protected render() {
|
||||||
const blueprint = this._blueprint;
|
|
||||||
return html`
|
return html`
|
||||||
${this.disabled
|
${this.disabled
|
||||||
? html`<ha-alert alert-type="warning">
|
? html`<ha-alert alert-type="warning">
|
||||||
@ -77,167 +44,14 @@ export class HaBlueprintAutomationEditor extends LitElement {
|
|||||||
${this.config.description
|
${this.config.description
|
||||||
? html`<p class="description">${this.config.description}</p>`
|
? html`<p class="description">${this.config.description}</p>`
|
||||||
: ""}
|
: ""}
|
||||||
<ha-card
|
${this.renderCard()}
|
||||||
outlined
|
|
||||||
class="blueprint"
|
|
||||||
.header=${this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.header"
|
|
||||||
)}
|
|
||||||
>
|
|
||||||
<div class="blueprint-picker-container">
|
|
||||||
${this._blueprints
|
|
||||||
? Object.keys(this._blueprints).length
|
|
||||||
? html`
|
|
||||||
<ha-blueprint-picker
|
|
||||||
.hass=${this.hass}
|
|
||||||
.label=${this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.blueprint_to_use"
|
|
||||||
)}
|
|
||||||
.blueprints=${this._blueprints}
|
|
||||||
.value=${this.config.use_blueprint.path}
|
|
||||||
.disabled=${this.disabled}
|
|
||||||
@value-changed=${this._blueprintChanged}
|
|
||||||
></ha-blueprint-picker>
|
|
||||||
`
|
|
||||||
: this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.no_blueprints"
|
|
||||||
)
|
|
||||||
: html`<ha-circular-progress indeterminate></ha-circular-progress>`}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
${this.config.use_blueprint.path
|
|
||||||
? blueprint && "error" in blueprint
|
|
||||||
? html`<p class="warning padding">
|
|
||||||
There is an error in this Blueprint: ${blueprint.error}
|
|
||||||
</p>`
|
|
||||||
: html`${blueprint?.metadata.description
|
|
||||||
? html`<ha-markdown
|
|
||||||
class="card-content"
|
|
||||||
breaks
|
|
||||||
.content=${blueprint.metadata.description}
|
|
||||||
></ha-markdown>`
|
|
||||||
: ""}
|
|
||||||
${blueprint?.metadata?.input &&
|
|
||||||
Object.keys(blueprint.metadata.input).length
|
|
||||||
? Object.entries(blueprint.metadata.input).map(
|
|
||||||
([key, value]) => {
|
|
||||||
const selector = value?.selector ?? { text: undefined };
|
|
||||||
const type = Object.keys(selector)[0];
|
|
||||||
const enhancedSelector = [
|
|
||||||
"action",
|
|
||||||
"condition",
|
|
||||||
"trigger",
|
|
||||||
].includes(type)
|
|
||||||
? {
|
|
||||||
[type]: {
|
|
||||||
...selector[type],
|
|
||||||
path: [key],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
: selector;
|
|
||||||
|
|
||||||
return html`<ha-settings-row .narrow=${this.narrow}>
|
|
||||||
<span slot="heading">${value?.name || key}</span>
|
|
||||||
<ha-markdown
|
|
||||||
slot="description"
|
|
||||||
class="card-content"
|
|
||||||
breaks
|
|
||||||
.content=${value?.description}
|
|
||||||
></ha-markdown>
|
|
||||||
${html`<ha-selector
|
|
||||||
.hass=${this.hass}
|
|
||||||
.selector=${enhancedSelector}
|
|
||||||
.key=${key}
|
|
||||||
.disabled=${this.disabled}
|
|
||||||
.required=${value?.default === undefined}
|
|
||||||
.placeholder=${value?.default}
|
|
||||||
.value=${this.config.use_blueprint.input &&
|
|
||||||
key in this.config.use_blueprint.input
|
|
||||||
? this.config.use_blueprint.input[key]
|
|
||||||
: value?.default}
|
|
||||||
@value-changed=${this._inputChanged}
|
|
||||||
@item-moved=${this._itemMoved}
|
|
||||||
></ha-selector>`}
|
|
||||||
</ha-settings-row>`;
|
|
||||||
}
|
|
||||||
)
|
|
||||||
: html`<p class="padding">
|
|
||||||
${this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.no_inputs"
|
|
||||||
)}
|
|
||||||
</p>`}`
|
|
||||||
: ""}
|
|
||||||
</ha-card>
|
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async _getBlueprints() {
|
protected async _getBlueprints() {
|
||||||
this._blueprints = await fetchBlueprints(this.hass, "automation");
|
this._blueprints = await fetchBlueprints(this.hass, "automation");
|
||||||
}
|
}
|
||||||
|
|
||||||
private _blueprintChanged(ev) {
|
|
||||||
ev.stopPropagation();
|
|
||||||
if (this.config.use_blueprint.path === ev.detail.value) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
fireEvent(this, "value-changed", {
|
|
||||||
value: {
|
|
||||||
...this.config,
|
|
||||||
use_blueprint: {
|
|
||||||
path: ev.detail.value,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private _inputChanged(ev) {
|
|
||||||
ev.stopPropagation();
|
|
||||||
const target = ev.target as any;
|
|
||||||
const key = target.key;
|
|
||||||
const value = ev.detail ? ev.detail.value : target.value;
|
|
||||||
if (
|
|
||||||
(this.config.use_blueprint.input &&
|
|
||||||
this.config.use_blueprint.input[key] === value) ||
|
|
||||||
(!this.config.use_blueprint.input && value === "")
|
|
||||||
) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const input = { ...this.config.use_blueprint.input, [key]: value };
|
|
||||||
|
|
||||||
fireEvent(this, "value-changed", {
|
|
||||||
value: {
|
|
||||||
...this.config,
|
|
||||||
use_blueprint: {
|
|
||||||
...this.config.use_blueprint,
|
|
||||||
input,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private _itemMoved(ev) {
|
|
||||||
ev.stopPropagation();
|
|
||||||
const { oldIndex, newIndex, oldPath, newPath } = ev.detail;
|
|
||||||
|
|
||||||
const input = nestedArrayMove(
|
|
||||||
this.config.use_blueprint.input,
|
|
||||||
oldIndex,
|
|
||||||
newIndex,
|
|
||||||
oldPath,
|
|
||||||
newPath
|
|
||||||
);
|
|
||||||
|
|
||||||
fireEvent(this, "value-changed", {
|
|
||||||
value: {
|
|
||||||
...this.config,
|
|
||||||
use_blueprint: {
|
|
||||||
...this.config.use_blueprint,
|
|
||||||
input,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private async _enable(): Promise<void> {
|
private async _enable(): Promise<void> {
|
||||||
if (!this.hass || !this.stateObj) {
|
if (!this.hass || !this.stateObj) {
|
||||||
return;
|
return;
|
||||||
@ -246,69 +60,7 @@ export class HaBlueprintAutomationEditor extends LitElement {
|
|||||||
entity_id: this.stateObj.entity_id,
|
entity_id: this.stateObj.entity_id,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private _duplicate() {
|
|
||||||
fireEvent(this, "duplicate");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static get styles(): CSSResultGroup {
|
|
||||||
return [
|
|
||||||
haStyle,
|
|
||||||
css`
|
|
||||||
:host {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
ha-card.blueprint {
|
|
||||||
margin: 0 auto;
|
|
||||||
}
|
|
||||||
.padding {
|
|
||||||
padding: 16px;
|
|
||||||
}
|
|
||||||
.link-button-row {
|
|
||||||
padding: 14px;
|
|
||||||
}
|
|
||||||
.blueprint-picker-container {
|
|
||||||
padding: 0 16px 16px;
|
|
||||||
}
|
|
||||||
ha-textfield,
|
|
||||||
ha-blueprint-picker {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
h3 {
|
|
||||||
margin: 16px;
|
|
||||||
}
|
|
||||||
.introduction {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
}
|
|
||||||
.introduction a {
|
|
||||||
color: var(--primary-color);
|
|
||||||
}
|
|
||||||
p {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
.description {
|
|
||||||
margin-bottom: 16px;
|
|
||||||
}
|
|
||||||
ha-settings-row {
|
|
||||||
--paper-time-input-justify-content: flex-end;
|
|
||||||
--settings-row-content-width: 100%;
|
|
||||||
--settings-row-prefix-display: contents;
|
|
||||||
border-top: 1px solid var(--divider-color);
|
|
||||||
}
|
|
||||||
ha-alert {
|
|
||||||
margin-bottom: 16px;
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
ha-alert.re-order {
|
|
||||||
border-radius: var(--ha-card-border-radius, 12px);
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
`,
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
interface HTMLElementTagNameMap {
|
interface HTMLElementTagNameMap {
|
||||||
"blueprint-automation-editor": HaBlueprintAutomationEditor;
|
"blueprint-automation-editor": HaBlueprintAutomationEditor;
|
||||||
|
275
src/panels/config/blueprint/blueprint-generic-editor.ts
Normal file
275
src/panels/config/blueprint/blueprint-generic-editor.ts
Normal file
@ -0,0 +1,275 @@
|
|||||||
|
import "@material/mwc-button/mwc-button";
|
||||||
|
import { css, CSSResultGroup, html, LitElement } from "lit";
|
||||||
|
import { customElement, property, state } from "lit/decorators";
|
||||||
|
import { fireEvent } from "../../../common/dom/fire_event";
|
||||||
|
import { nestedArrayMove } from "../../../common/util/array-move";
|
||||||
|
import "../../../components/ha-alert";
|
||||||
|
import "../../../components/ha-blueprint-picker";
|
||||||
|
import "../../../components/ha-card";
|
||||||
|
import "../../../components/ha-circular-progress";
|
||||||
|
import "../../../components/ha-markdown";
|
||||||
|
import "../../../components/ha-selector/ha-selector";
|
||||||
|
import "../../../components/ha-settings-row";
|
||||||
|
import { BlueprintAutomationConfig } from "../../../data/automation";
|
||||||
|
import { BlueprintOrError, Blueprints } from "../../../data/blueprint";
|
||||||
|
import { BlueprintScriptConfig } from "../../../data/script";
|
||||||
|
import { haStyle } from "../../../resources/styles";
|
||||||
|
import { HomeAssistant } from "../../../types";
|
||||||
|
|
||||||
|
@customElement("blueprint-generic-editor")
|
||||||
|
export abstract class HaBlueprintGenericEditor extends LitElement {
|
||||||
|
@property({ attribute: false }) public hass!: HomeAssistant;
|
||||||
|
|
||||||
|
@property({ type: Boolean }) public isWide = false;
|
||||||
|
|
||||||
|
@property({ type: Boolean }) public disabled = false;
|
||||||
|
|
||||||
|
@property({ type: Boolean, reflect: true }) public narrow = false;
|
||||||
|
|
||||||
|
@state() protected _blueprints?: Blueprints;
|
||||||
|
|
||||||
|
protected firstUpdated(changedProps) {
|
||||||
|
super.firstUpdated(changedProps);
|
||||||
|
this._getBlueprints();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected get _blueprint(): BlueprintOrError | undefined {
|
||||||
|
if (!this._blueprints) {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
return this._blueprints[this._config.use_blueprint.path];
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract get _config():
|
||||||
|
| BlueprintAutomationConfig
|
||||||
|
| BlueprintScriptConfig;
|
||||||
|
|
||||||
|
protected renderCard() {
|
||||||
|
const blueprint = this._blueprint;
|
||||||
|
return html`
|
||||||
|
<ha-card
|
||||||
|
outlined
|
||||||
|
class="blueprint"
|
||||||
|
.header=${this.hass.localize(
|
||||||
|
"ui.panel.config.automation.editor.blueprint.header"
|
||||||
|
)}
|
||||||
|
>
|
||||||
|
<div class="blueprint-picker-container">
|
||||||
|
${this._blueprints
|
||||||
|
? Object.keys(this._blueprints).length
|
||||||
|
? html`
|
||||||
|
<ha-blueprint-picker
|
||||||
|
.hass=${this.hass}
|
||||||
|
.label=${this.hass.localize(
|
||||||
|
"ui.panel.config.automation.editor.blueprint.blueprint_to_use"
|
||||||
|
)}
|
||||||
|
.blueprints=${this._blueprints}
|
||||||
|
.value=${this._config.use_blueprint.path}
|
||||||
|
.disabled=${this.disabled}
|
||||||
|
@value-changed=${this._blueprintChanged}
|
||||||
|
></ha-blueprint-picker>
|
||||||
|
`
|
||||||
|
: this.hass.localize(
|
||||||
|
"ui.panel.config.automation.editor.blueprint.no_blueprints"
|
||||||
|
)
|
||||||
|
: html`<ha-circular-progress indeterminate></ha-circular-progress>`}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
${this._config.use_blueprint.path
|
||||||
|
? blueprint && "error" in blueprint
|
||||||
|
? html`<p class="warning padding">
|
||||||
|
There is an error in this Blueprint: ${blueprint.error}
|
||||||
|
</p>`
|
||||||
|
: html`${blueprint?.metadata.description
|
||||||
|
? html`<ha-markdown
|
||||||
|
class="card-content"
|
||||||
|
breaks
|
||||||
|
.content=${blueprint.metadata.description}
|
||||||
|
></ha-markdown>`
|
||||||
|
: ""}
|
||||||
|
${blueprint?.metadata?.input &&
|
||||||
|
Object.keys(blueprint.metadata.input).length
|
||||||
|
? Object.entries(blueprint.metadata.input).map(
|
||||||
|
([key, value]) => {
|
||||||
|
const selector = value?.selector ?? { text: undefined };
|
||||||
|
const type = Object.keys(selector)[0];
|
||||||
|
const enhancedSelector = [
|
||||||
|
"action",
|
||||||
|
"condition",
|
||||||
|
"trigger",
|
||||||
|
].includes(type)
|
||||||
|
? {
|
||||||
|
[type]: {
|
||||||
|
...selector[type],
|
||||||
|
path: [key],
|
||||||
|
},
|
||||||
|
}
|
||||||
|
: selector;
|
||||||
|
|
||||||
|
return html`<ha-settings-row .narrow=${this.narrow}>
|
||||||
|
<span slot="heading">${value?.name || key}</span>
|
||||||
|
<ha-markdown
|
||||||
|
slot="description"
|
||||||
|
class="card-content"
|
||||||
|
breaks
|
||||||
|
.content=${value?.description}
|
||||||
|
></ha-markdown>
|
||||||
|
${html`<ha-selector
|
||||||
|
.hass=${this.hass}
|
||||||
|
.selector=${enhancedSelector}
|
||||||
|
.key=${key}
|
||||||
|
.disabled=${this.disabled}
|
||||||
|
.required=${value?.default === undefined}
|
||||||
|
.placeholder=${value?.default}
|
||||||
|
.value=${this._config.use_blueprint.input &&
|
||||||
|
key in this._config.use_blueprint.input
|
||||||
|
? this._config.use_blueprint.input[key]
|
||||||
|
: value?.default}
|
||||||
|
@value-changed=${this._inputChanged}
|
||||||
|
@item-moved=${this._itemMoved}
|
||||||
|
></ha-selector>`}
|
||||||
|
</ha-settings-row>`;
|
||||||
|
}
|
||||||
|
)
|
||||||
|
: html`<p class="padding">
|
||||||
|
${this.hass.localize(
|
||||||
|
"ui.panel.config.automation.editor.blueprint.no_inputs"
|
||||||
|
)}
|
||||||
|
</p>`}`
|
||||||
|
: ""}
|
||||||
|
</ha-card>
|
||||||
|
`;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract _getBlueprints();
|
||||||
|
|
||||||
|
private _blueprintChanged(ev) {
|
||||||
|
ev.stopPropagation();
|
||||||
|
if (this._config.use_blueprint.path === ev.detail.value) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
fireEvent(this, "value-changed", {
|
||||||
|
value: {
|
||||||
|
...this._config,
|
||||||
|
use_blueprint: {
|
||||||
|
path: ev.detail.value,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private _inputChanged(ev) {
|
||||||
|
ev.stopPropagation();
|
||||||
|
const target = ev.target as any;
|
||||||
|
const key = target.key;
|
||||||
|
const value = ev.detail ? ev.detail.value : target.value;
|
||||||
|
if (
|
||||||
|
(this._config.use_blueprint.input &&
|
||||||
|
this._config.use_blueprint.input[key] === value) ||
|
||||||
|
(!this._config.use_blueprint.input && value === "")
|
||||||
|
) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const input = { ...this._config.use_blueprint.input, [key]: value };
|
||||||
|
|
||||||
|
fireEvent(this, "value-changed", {
|
||||||
|
value: {
|
||||||
|
...this._config,
|
||||||
|
use_blueprint: {
|
||||||
|
...this._config.use_blueprint,
|
||||||
|
input,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private _itemMoved(ev) {
|
||||||
|
ev.stopPropagation();
|
||||||
|
const { oldIndex, newIndex, oldPath, newPath } = ev.detail;
|
||||||
|
|
||||||
|
const input = nestedArrayMove(
|
||||||
|
this._config.use_blueprint.input,
|
||||||
|
oldIndex,
|
||||||
|
newIndex,
|
||||||
|
oldPath,
|
||||||
|
newPath
|
||||||
|
);
|
||||||
|
|
||||||
|
fireEvent(this, "value-changed", {
|
||||||
|
value: {
|
||||||
|
...this._config,
|
||||||
|
use_blueprint: {
|
||||||
|
...this._config.use_blueprint,
|
||||||
|
input,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
protected _duplicate() {
|
||||||
|
fireEvent(this, "duplicate");
|
||||||
|
}
|
||||||
|
|
||||||
|
static get styles(): CSSResultGroup {
|
||||||
|
return [
|
||||||
|
haStyle,
|
||||||
|
css`
|
||||||
|
:host {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
ha-card.blueprint {
|
||||||
|
margin: 0 auto;
|
||||||
|
}
|
||||||
|
.padding {
|
||||||
|
padding: 16px;
|
||||||
|
}
|
||||||
|
.link-button-row {
|
||||||
|
padding: 14px;
|
||||||
|
}
|
||||||
|
.blueprint-picker-container {
|
||||||
|
padding: 0 16px 16px;
|
||||||
|
}
|
||||||
|
ha-textfield,
|
||||||
|
ha-blueprint-picker {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
h3 {
|
||||||
|
margin: 16px;
|
||||||
|
}
|
||||||
|
.introduction {
|
||||||
|
margin-top: 0;
|
||||||
|
margin-bottom: 12px;
|
||||||
|
}
|
||||||
|
.introduction a {
|
||||||
|
color: var(--primary-color);
|
||||||
|
}
|
||||||
|
p {
|
||||||
|
margin-bottom: 0;
|
||||||
|
}
|
||||||
|
.description {
|
||||||
|
margin-bottom: 16px;
|
||||||
|
}
|
||||||
|
ha-settings-row {
|
||||||
|
--paper-time-input-justify-content: flex-end;
|
||||||
|
--settings-row-content-width: 100%;
|
||||||
|
--settings-row-prefix-display: contents;
|
||||||
|
border-top: 1px solid var(--divider-color);
|
||||||
|
}
|
||||||
|
ha-alert {
|
||||||
|
margin-bottom: 16px;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
ha-alert.re-order {
|
||||||
|
border-radius: var(--ha-card-border-radius, 12px);
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
`,
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
declare global {
|
||||||
|
interface HTMLElementTagNameMap {
|
||||||
|
"blueprint-generic-editor": HaBlueprintGenericEditor;
|
||||||
|
}
|
||||||
|
}
|
@ -1,52 +1,19 @@
|
|||||||
import { css, CSSResultGroup, html, LitElement } from "lit";
|
import { html } from "lit";
|
||||||
import { customElement, property, state } from "lit/decorators";
|
import { customElement, property } from "lit/decorators";
|
||||||
import { fireEvent } from "../../../common/dom/fire_event";
|
|
||||||
import { nestedArrayMove } from "../../../common/util/array-move";
|
|
||||||
import "../../../components/ha-alert";
|
import "../../../components/ha-alert";
|
||||||
import "../../../components/ha-blueprint-picker";
|
|
||||||
import "../../../components/ha-card";
|
|
||||||
import "../../../components/ha-circular-progress";
|
|
||||||
import "../../../components/ha-markdown";
|
|
||||||
import "../../../components/ha-selector/ha-selector";
|
|
||||||
import "../../../components/ha-settings-row";
|
|
||||||
import {
|
|
||||||
BlueprintOrError,
|
|
||||||
Blueprints,
|
|
||||||
fetchBlueprints,
|
|
||||||
} from "../../../data/blueprint";
|
|
||||||
import { BlueprintScriptConfig } from "../../../data/script";
|
import { BlueprintScriptConfig } from "../../../data/script";
|
||||||
import { haStyle } from "../../../resources/styles";
|
import { fetchBlueprints } from "../../../data/blueprint";
|
||||||
import { HomeAssistant } from "../../../types";
|
import { HaBlueprintGenericEditor } from "../blueprint/blueprint-generic-editor";
|
||||||
import "../ha-config-section";
|
|
||||||
|
|
||||||
@customElement("blueprint-script-editor")
|
@customElement("blueprint-script-editor")
|
||||||
export class HaBlueprintScriptEditor extends LitElement {
|
export class HaBlueprintScriptEditor extends HaBlueprintGenericEditor {
|
||||||
@property({ attribute: false }) public hass!: HomeAssistant;
|
|
||||||
|
|
||||||
@property({ type: Boolean }) public isWide = false;
|
|
||||||
|
|
||||||
@property({ reflect: true, type: Boolean }) public narrow = false;
|
|
||||||
|
|
||||||
@property({ type: Boolean }) public disabled = false;
|
|
||||||
|
|
||||||
@property({ attribute: false }) public config!: BlueprintScriptConfig;
|
@property({ attribute: false }) public config!: BlueprintScriptConfig;
|
||||||
|
|
||||||
@state() private _blueprints?: Blueprints;
|
protected get _config(): BlueprintScriptConfig {
|
||||||
|
return this.config;
|
||||||
protected firstUpdated(changedProps) {
|
|
||||||
super.firstUpdated(changedProps);
|
|
||||||
this._getBlueprints();
|
|
||||||
}
|
|
||||||
|
|
||||||
private get _blueprint(): BlueprintOrError | undefined {
|
|
||||||
if (!this._blueprints) {
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
return this._blueprints[this.config.use_blueprint.path];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected render() {
|
protected render() {
|
||||||
const blueprint = this._blueprint;
|
|
||||||
return html`
|
return html`
|
||||||
${this.disabled
|
${this.disabled
|
||||||
? html`<ha-alert alert-type="warning">
|
? html`<ha-alert alert-type="warning">
|
||||||
@ -56,228 +23,14 @@ export class HaBlueprintScriptEditor extends LitElement {
|
|||||||
</mwc-button>
|
</mwc-button>
|
||||||
</ha-alert>`
|
</ha-alert>`
|
||||||
: ""}
|
: ""}
|
||||||
<ha-card
|
${this.renderCard()}
|
||||||
outlined
|
|
||||||
class="blueprint"
|
|
||||||
.header=${this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.header"
|
|
||||||
)}
|
|
||||||
>
|
|
||||||
<div class="blueprint-picker-container">
|
|
||||||
${this._blueprints
|
|
||||||
? Object.keys(this._blueprints).length
|
|
||||||
? html`
|
|
||||||
<ha-blueprint-picker
|
|
||||||
.hass=${this.hass}
|
|
||||||
.label=${this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.blueprint_to_use"
|
|
||||||
)}
|
|
||||||
.blueprints=${this._blueprints}
|
|
||||||
.value=${this.config.use_blueprint.path}
|
|
||||||
.disabled=${this.disabled}
|
|
||||||
@value-changed=${this._blueprintChanged}
|
|
||||||
></ha-blueprint-picker>
|
|
||||||
`
|
|
||||||
: this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.no_blueprints"
|
|
||||||
)
|
|
||||||
: html`<ha-circular-progress indeterminate></ha-circular-progress>`}
|
|
||||||
</div>
|
|
||||||
${this.config.use_blueprint.path
|
|
||||||
? blueprint && "error" in blueprint
|
|
||||||
? html`<p class="warning padding">
|
|
||||||
There is an error in this Blueprint: ${blueprint.error}
|
|
||||||
</p>`
|
|
||||||
: html`${blueprint?.metadata.description
|
|
||||||
? html`<ha-markdown
|
|
||||||
class="card-content"
|
|
||||||
breaks
|
|
||||||
.content=${blueprint.metadata.description}
|
|
||||||
></ha-markdown>`
|
|
||||||
: ""}
|
|
||||||
${blueprint?.metadata?.input &&
|
|
||||||
Object.keys(blueprint.metadata.input).length
|
|
||||||
? Object.entries(blueprint.metadata.input).map(
|
|
||||||
([key, value]) => {
|
|
||||||
const selector = value?.selector ?? { text: undefined };
|
|
||||||
const type = Object.keys(selector)[0];
|
|
||||||
const enhancedSelector = [
|
|
||||||
"action",
|
|
||||||
"condition",
|
|
||||||
"trigger",
|
|
||||||
].includes(type)
|
|
||||||
? {
|
|
||||||
[type]: {
|
|
||||||
...selector[type],
|
|
||||||
path: [key],
|
|
||||||
},
|
|
||||||
}
|
|
||||||
: selector;
|
|
||||||
|
|
||||||
return html`<ha-settings-row .narrow=${this.narrow}>
|
|
||||||
<span slot="heading">${value?.name || key}</span>
|
|
||||||
<ha-markdown
|
|
||||||
slot="description"
|
|
||||||
class="card-content"
|
|
||||||
breaks
|
|
||||||
.content=${value?.description}
|
|
||||||
></ha-markdown>
|
|
||||||
${html`<ha-selector
|
|
||||||
.hass=${this.hass}
|
|
||||||
.selector=${enhancedSelector}
|
|
||||||
.key=${key}
|
|
||||||
.disabled=${this.disabled}
|
|
||||||
.required=${value?.default === undefined}
|
|
||||||
.placeholder=${value?.default}
|
|
||||||
.value=${this.config.use_blueprint.input &&
|
|
||||||
key in this.config.use_blueprint.input
|
|
||||||
? this.config.use_blueprint.input[key]
|
|
||||||
: value?.default}
|
|
||||||
@value-changed=${this._inputChanged}
|
|
||||||
@item-moved=${this._itemMoved}
|
|
||||||
></ha-selector>`}
|
|
||||||
</ha-settings-row>`;
|
|
||||||
}
|
|
||||||
)
|
|
||||||
: html`<p class="padding">
|
|
||||||
${this.hass.localize(
|
|
||||||
"ui.panel.config.automation.editor.blueprint.no_inputs"
|
|
||||||
)}
|
|
||||||
</p>`}`
|
|
||||||
: ""}
|
|
||||||
</ha-card>
|
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|
||||||
private async _getBlueprints() {
|
protected async _getBlueprints() {
|
||||||
this._blueprints = await fetchBlueprints(this.hass, "script");
|
this._blueprints = await fetchBlueprints(this.hass, "script");
|
||||||
}
|
}
|
||||||
|
|
||||||
private _blueprintChanged(ev) {
|
|
||||||
ev.stopPropagation();
|
|
||||||
if (this.config.use_blueprint.path === ev.detail.value) {
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
fireEvent(this, "value-changed", {
|
|
||||||
value: {
|
|
||||||
...this.config,
|
|
||||||
use_blueprint: {
|
|
||||||
path: ev.detail.value,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private _inputChanged(ev) {
|
|
||||||
ev.stopPropagation();
|
|
||||||
const target = ev.target as any;
|
|
||||||
const key = target.key;
|
|
||||||
const value = ev.detail ? ev.detail.value : target.value;
|
|
||||||
if (
|
|
||||||
(this.config.use_blueprint.input &&
|
|
||||||
this.config.use_blueprint.input[key] === value) ||
|
|
||||||
(!this.config.use_blueprint.input && value === "")
|
|
||||||
) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const input = { ...this.config.use_blueprint.input, [key]: value };
|
|
||||||
|
|
||||||
fireEvent(this, "value-changed", {
|
|
||||||
value: {
|
|
||||||
...this.config,
|
|
||||||
use_blueprint: {
|
|
||||||
...this.config.use_blueprint,
|
|
||||||
input,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private _itemMoved(ev) {
|
|
||||||
ev.stopPropagation();
|
|
||||||
const { oldIndex, newIndex, oldPath, newPath } = ev.detail;
|
|
||||||
|
|
||||||
const input = nestedArrayMove(
|
|
||||||
this.config.use_blueprint.input,
|
|
||||||
oldIndex,
|
|
||||||
newIndex,
|
|
||||||
oldPath,
|
|
||||||
newPath
|
|
||||||
);
|
|
||||||
|
|
||||||
fireEvent(this, "value-changed", {
|
|
||||||
value: {
|
|
||||||
...this.config,
|
|
||||||
use_blueprint: {
|
|
||||||
...this.config.use_blueprint,
|
|
||||||
input,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private _duplicate() {
|
|
||||||
fireEvent(this, "duplicate");
|
|
||||||
}
|
|
||||||
|
|
||||||
static get styles(): CSSResultGroup {
|
|
||||||
return [
|
|
||||||
haStyle,
|
|
||||||
css`
|
|
||||||
:host {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
ha-card.blueprint {
|
|
||||||
margin: 0 auto;
|
|
||||||
}
|
|
||||||
.padding {
|
|
||||||
padding: 16px;
|
|
||||||
}
|
|
||||||
.link-button-row {
|
|
||||||
padding: 14px;
|
|
||||||
}
|
|
||||||
.blueprint-picker-container {
|
|
||||||
padding: 0 16px 16px;
|
|
||||||
}
|
|
||||||
ha-textfield,
|
|
||||||
ha-blueprint-picker {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
h3 {
|
|
||||||
margin: 16px;
|
|
||||||
}
|
|
||||||
.introduction {
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 12px;
|
|
||||||
}
|
|
||||||
.introduction a {
|
|
||||||
color: var(--primary-color);
|
|
||||||
}
|
|
||||||
p {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
.description {
|
|
||||||
margin-bottom: 16px;
|
|
||||||
}
|
|
||||||
ha-settings-row {
|
|
||||||
--paper-time-input-justify-content: flex-end;
|
|
||||||
--settings-row-content-width: 100%;
|
|
||||||
--settings-row-prefix-display: contents;
|
|
||||||
border-top: 1px solid var(--divider-color);
|
|
||||||
}
|
|
||||||
ha-alert {
|
|
||||||
margin-bottom: 16px;
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
ha-alert.re-order {
|
|
||||||
border-radius: var(--ha-card-border-radius, 12px);
|
|
||||||
overflow: hidden;
|
|
||||||
}
|
|
||||||
`,
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare global {
|
declare global {
|
||||||
interface HTMLElementTagNameMap {
|
interface HTMLElementTagNameMap {
|
||||||
"blueprint-script-editor": HaBlueprintScriptEditor;
|
"blueprint-script-editor": HaBlueprintScriptEditor;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user