mirror of
https://github.com/home-assistant/frontend.git
synced 2025-07-25 18:26:35 +00:00
Add options flow button to conversation agent in assist pipeline dialog (#16595)
This commit is contained in:
parent
5a36f100a9
commit
4ccfd6a3fc
@ -1,3 +1,4 @@
|
|||||||
|
import { mdiCog } from "@mdi/js";
|
||||||
import {
|
import {
|
||||||
css,
|
css,
|
||||||
CSSResultGroup,
|
CSSResultGroup,
|
||||||
@ -10,7 +11,10 @@ import { customElement, property, state } from "lit/decorators";
|
|||||||
import { fireEvent } from "../common/dom/fire_event";
|
import { fireEvent } from "../common/dom/fire_event";
|
||||||
import { stopPropagation } from "../common/dom/stop_propagation";
|
import { stopPropagation } from "../common/dom/stop_propagation";
|
||||||
import { debounce } from "../common/util/debounce";
|
import { debounce } from "../common/util/debounce";
|
||||||
|
import { ConfigEntry, getConfigEntry } from "../data/config_entries";
|
||||||
import { Agent, listAgents } from "../data/conversation";
|
import { Agent, listAgents } from "../data/conversation";
|
||||||
|
import { fetchIntegrationManifest } from "../data/integration";
|
||||||
|
import { showOptionsFlowDialog } from "../dialogs/config-flow/show-dialog-options-flow";
|
||||||
import { HomeAssistant } from "../types";
|
import { HomeAssistant } from "../types";
|
||||||
import "./ha-list-item";
|
import "./ha-list-item";
|
||||||
import "./ha-select";
|
import "./ha-select";
|
||||||
@ -34,6 +38,8 @@ export class HaConversationAgentPicker extends LitElement {
|
|||||||
|
|
||||||
@state() _agents?: Agent[];
|
@state() _agents?: Agent[];
|
||||||
|
|
||||||
|
@state() private _configEntry?: ConfigEntry;
|
||||||
|
|
||||||
protected render() {
|
protected render() {
|
||||||
if (!this._agents) {
|
if (!this._agents) {
|
||||||
return nothing;
|
return nothing;
|
||||||
@ -77,8 +83,13 @@ export class HaConversationAgentPicker extends LitElement {
|
|||||||
>
|
>
|
||||||
${agent.name}
|
${agent.name}
|
||||||
</ha-list-item>`
|
</ha-list-item>`
|
||||||
)}
|
)}</ha-select
|
||||||
</ha-select>
|
>${this._configEntry?.supports_options
|
||||||
|
? html`<ha-icon-button
|
||||||
|
.path=${mdiCog}
|
||||||
|
@click=${this._openOptionsFlow}
|
||||||
|
></ha-icon-button>`
|
||||||
|
: ""}
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -89,6 +100,24 @@ export class HaConversationAgentPicker extends LitElement {
|
|||||||
} else if (changedProperties.has("language")) {
|
} else if (changedProperties.has("language")) {
|
||||||
this._debouncedUpdateAgents();
|
this._debouncedUpdateAgents();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (changedProperties.has("value")) {
|
||||||
|
this._maybeFetchConfigEntry();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private async _maybeFetchConfigEntry() {
|
||||||
|
if (!this.value || this.value === "homeassistant") {
|
||||||
|
this._configEntry = undefined;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
this._configEntry = (
|
||||||
|
await getConfigEntry(this.hass, this.value)
|
||||||
|
).config_entry;
|
||||||
|
} catch (err) {
|
||||||
|
this._configEntry = undefined;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private _debouncedUpdateAgents = debounce(() => this._updateAgents(), 500);
|
private _debouncedUpdateAgents = debounce(() => this._updateAgents(), 500);
|
||||||
@ -122,11 +151,29 @@ export class HaConversationAgentPicker extends LitElement {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private async _openOptionsFlow() {
|
||||||
|
if (!this._configEntry) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
showOptionsFlowDialog(
|
||||||
|
this,
|
||||||
|
this._configEntry,
|
||||||
|
await fetchIntegrationManifest(this.hass, this._configEntry.domain)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
static get styles(): CSSResultGroup {
|
static get styles(): CSSResultGroup {
|
||||||
return css`
|
return css`
|
||||||
|
:host {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
ha-select {
|
ha-select {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
ha-icon-button {
|
||||||
|
color: var(--secondary-text-color);
|
||||||
|
}
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user