import "@material/mwc-button/mwc-button";
import { mdiHelpCircle } from "@mdi/js";
import { CSSResultGroup, LitElement, css, html, nothing } from "lit";
import { customElement, property, query } from "lit/decorators";
import { fireEvent } from "../../../common/dom/fire_event";
import { nestedArrayMove } from "../../../common/util/array-move";
import "../../../components/ha-card";
import "../../../components/ha-icon-button";
import { Action, Fields, ScriptConfig } from "../../../data/script";
import { haStyle } from "../../../resources/styles";
import type { HomeAssistant } from "../../../types";
import { documentationUrl } from "../../../util/documentation-url";
import "../automation/action/ha-automation-action";
import "./ha-script-fields";
import type HaScriptFields from "./ha-script-fields";
@customElement("manual-script-editor")
export class HaManualScriptEditor extends LitElement {
@property({ attribute: false }) public hass!: HomeAssistant;
@property({ type: Boolean }) public isWide = false;
@property({ type: Boolean }) public narrow = false;
@property({ type: Boolean }) public disabled = false;
@property({ attribute: false }) public config!: ScriptConfig;
@query("ha-script-fields")
private _scriptFields?: HaScriptFields;
private _openFields = false;
public addFields() {
this._openFields = true;
fireEvent(this, "value-changed", {
value: {
...this.config,
fields: {
[this.hass.localize("ui.panel.config.script.editor.field.field") ||
"field"]: {
selector: {
text: null,
},
},
},
},
});
}
protected updated(changedProps) {
if (this._openFields && changedProps.has("config")) {
this._openFields = false;
this._scriptFields?.updateComplete.then(() =>
this._scriptFields?.focusLastField()
);
}
}
protected render() {
return html`
${this.disabled
? html`