@tylertech/forge-ai 0.8.2 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/custom-elements.json +1200 -935
- package/dist/ai-agent-selector/ai-agent-selector.d.ts +50 -0
- package/dist/ai-agent-selector/ai-agent-selector.mjs +439 -0
- package/dist/ai-agent-selector/ai-agent-selector.scss.mjs +4 -0
- package/dist/ai-agent-selector/index.d.ts +1 -0
- package/dist/ai-agent-selector/index.mjs +5 -0
- package/dist/ai-chat-header/ai-chat-header.d.ts +18 -1
- package/dist/ai-chat-header/ai-chat-header.mjs +41 -8
- package/dist/ai-chat-header/ai-chat-header.scss.mjs +1 -1
- package/dist/ai-chat-header/index.d.ts +1 -1
- package/dist/ai-chatbot/ag-ui-adapter.mjs +1 -1
- package/dist/ai-chatbot/agent-runner.mjs +1 -0
- package/dist/ai-chatbot/ai-chatbot-tool-call.mjs +5 -3
- package/dist/ai-chatbot/ai-chatbot-tool-call.scss.mjs +1 -1
- package/dist/ai-chatbot/ai-chatbot.d.ts +19 -1
- package/dist/ai-chatbot/ai-chatbot.mjs +69 -6
- package/dist/ai-chatbot/index.d.ts +2 -2
- package/dist/ai-chatbot/message-state-controller.d.ts +2 -1
- package/dist/ai-chatbot/message-state-controller.mjs +10 -1
- package/dist/ai-chatbot/types.d.ts +7 -0
- package/dist/ai-empty-state/ai-empty-state.scss.mjs +1 -1
- package/dist/ai-error-message/ai-error-message.scss.mjs +1 -1
- package/dist/ai-icon/ai-icon.scss.mjs +1 -1
- package/dist/ai-message-thread/ai-message-thread.mjs +1 -1
- package/dist/ai-message-thread/ai-message-thread.scss.mjs +1 -1
- package/dist/ai-modal/ai-modal.scss.mjs +1 -1
- package/dist/ai-suggestions/ai-suggestions.d.ts +1 -0
- package/dist/ai-suggestions/ai-suggestions.scss.mjs +1 -1
- package/dist/ai-user-message/ai-user-message.scss.mjs +1 -1
- package/dist/core/tooltip/tooltip.scss.mjs +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.mjs +3 -0
- package/package.json +1 -1
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { LitElement, TemplateResult, PropertyValues } from 'lit';
|
|
2
|
+
import { Agent } from '../ai-chatbot/types.js';
|
|
3
|
+
declare global {
|
|
4
|
+
interface HTMLElementTagNameMap {
|
|
5
|
+
'forge-ai-agent-selector': AiAgentSelectorComponent;
|
|
6
|
+
}
|
|
7
|
+
interface HTMLElementEventMap {
|
|
8
|
+
'forge-ai-agent-selector-change': CustomEvent<ForgeAiAgentSelectorChangeEventData>;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export interface ForgeAiAgentSelectorChangeEventData {
|
|
12
|
+
agent: Agent | undefined;
|
|
13
|
+
previousAgentId: string | undefined;
|
|
14
|
+
}
|
|
15
|
+
export declare const AiAgentSelectorComponentTagName: keyof HTMLElementTagNameMap;
|
|
16
|
+
/**
|
|
17
|
+
* @summary Agent selector component for switching between AI agents.
|
|
18
|
+
*
|
|
19
|
+
* @description
|
|
20
|
+
* Displays the current agent name with a dropdown to select from available agents.
|
|
21
|
+
* When no agents are provided, displays static title text.
|
|
22
|
+
*
|
|
23
|
+
* @tag forge-ai-agent-selector
|
|
24
|
+
*
|
|
25
|
+
* @property {Agent[]} agents - Array of available agents
|
|
26
|
+
* @property {string} selectedAgentId - ID of the currently selected agent
|
|
27
|
+
* @property {string} titleText - Fallback text when no agent is selected
|
|
28
|
+
* @property {boolean} disabled - Disables the selector (e.g., during streaming)
|
|
29
|
+
*
|
|
30
|
+
* @event forge-ai-agent-selector-change - Fired when an agent is selected
|
|
31
|
+
*/
|
|
32
|
+
export declare class AiAgentSelectorComponent extends LitElement {
|
|
33
|
+
#private;
|
|
34
|
+
static styles: import('lit').CSSResult;
|
|
35
|
+
constructor();
|
|
36
|
+
agents: Agent[];
|
|
37
|
+
selectedAgentId?: string;
|
|
38
|
+
titleText: string;
|
|
39
|
+
disabled: boolean;
|
|
40
|
+
private _open;
|
|
41
|
+
private _focusedIndex;
|
|
42
|
+
private _isTextOverflowing;
|
|
43
|
+
private _filterValue;
|
|
44
|
+
private _triggerButton?;
|
|
45
|
+
private _agentList?;
|
|
46
|
+
private _filterInput?;
|
|
47
|
+
willUpdate(changedProperties: PropertyValues): void;
|
|
48
|
+
updated(changedProperties: PropertyValues<this>): void;
|
|
49
|
+
render(): TemplateResult;
|
|
50
|
+
}
|
|
@@ -0,0 +1,439 @@
|
|
|
1
|
+
import { unsafeCSS, LitElement, html, nothing } from "lit";
|
|
2
|
+
import { property, state, query, customElement } from "lit/decorators.js";
|
|
3
|
+
import { classMap } from "lit/directives/class-map.js";
|
|
4
|
+
import { when } from "lit/directives/when.js";
|
|
5
|
+
import { toggleState } from "../utils.mjs";
|
|
6
|
+
import "../core/popover/popover.mjs";
|
|
7
|
+
import "../core/tooltip/tooltip.mjs";
|
|
8
|
+
import styles from "./ai-agent-selector.scss.mjs";
|
|
9
|
+
var __defProp = Object.defineProperty;
|
|
10
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
11
|
+
var __typeError = (msg) => {
|
|
12
|
+
throw TypeError(msg);
|
|
13
|
+
};
|
|
14
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
15
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
16
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
17
|
+
if (decorator = decorators[i])
|
|
18
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
19
|
+
if (kind && result) __defProp(target, key, result);
|
|
20
|
+
return result;
|
|
21
|
+
};
|
|
22
|
+
var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
|
|
23
|
+
var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
|
|
24
|
+
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
25
|
+
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), member.set(obj, value), value);
|
|
26
|
+
var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
|
|
27
|
+
var _internals, _AiAgentSelectorComponent_instances, selectedAgent_get, effectiveTitleText_get, displayText_get, hasAgents_get, shouldShowFilter_get, filteredAgents_get, tooltipContent_get, checkTextOverflow_fn, handleTriggerClick_fn, handlePopoverToggle_fn, handleFilterInput_fn, handleKeyDown_fn, moveSelection_fn, updateItemFocus_fn, focusFilterOrFirstItem_fn, scrollToSelectedOrTop_fn, selectAgent_fn, handleAgentClick_fn, handleDefaultClick_fn, triggerTemplate_get, tooltipTemplate_get, filterFieldTemplate_get, isDefaultSelected_get, defaultOptionTemplate_get, agentListTemplate_get, dropdownTemplate_get, staticTitleTemplate_get;
|
|
28
|
+
const AiAgentSelectorComponentTagName = "forge-ai-agent-selector";
|
|
29
|
+
const MIN_AGENTS_FOR_FILTER = 5;
|
|
30
|
+
let AiAgentSelectorComponent = class extends LitElement {
|
|
31
|
+
constructor() {
|
|
32
|
+
super();
|
|
33
|
+
__privateAdd(this, _AiAgentSelectorComponent_instances);
|
|
34
|
+
__privateAdd(this, _internals);
|
|
35
|
+
this.agents = [];
|
|
36
|
+
this.titleText = "AI Assistant";
|
|
37
|
+
this.disabled = false;
|
|
38
|
+
this._open = false;
|
|
39
|
+
this._focusedIndex = -1;
|
|
40
|
+
this._isTextOverflowing = false;
|
|
41
|
+
this._filterValue = "";
|
|
42
|
+
__privateSet(this, _internals, this.attachInternals());
|
|
43
|
+
}
|
|
44
|
+
willUpdate(changedProperties) {
|
|
45
|
+
if (changedProperties.has("_open")) {
|
|
46
|
+
toggleState(__privateGet(this, _internals), "open", this._open);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
updated(changedProperties) {
|
|
50
|
+
if (changedProperties.has("selectedAgentId") || changedProperties.has("titleText") || changedProperties.has("agents")) {
|
|
51
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, checkTextOverflow_fn).call(this);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
render() {
|
|
55
|
+
return html`
|
|
56
|
+
${when(
|
|
57
|
+
__privateGet(this, _AiAgentSelectorComponent_instances, hasAgents_get),
|
|
58
|
+
() => html` ${__privateGet(this, _AiAgentSelectorComponent_instances, triggerTemplate_get)} ${__privateGet(this, _AiAgentSelectorComponent_instances, tooltipTemplate_get)} ${__privateGet(this, _AiAgentSelectorComponent_instances, dropdownTemplate_get)} `,
|
|
59
|
+
() => __privateGet(this, _AiAgentSelectorComponent_instances, staticTitleTemplate_get)
|
|
60
|
+
)}
|
|
61
|
+
`;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
_internals = /* @__PURE__ */ new WeakMap();
|
|
65
|
+
_AiAgentSelectorComponent_instances = /* @__PURE__ */ new WeakSet();
|
|
66
|
+
selectedAgent_get = function() {
|
|
67
|
+
return this.agents.find((a) => a.id === this.selectedAgentId);
|
|
68
|
+
};
|
|
69
|
+
effectiveTitleText_get = function() {
|
|
70
|
+
return this.titleText || "AI Assistant";
|
|
71
|
+
};
|
|
72
|
+
displayText_get = function() {
|
|
73
|
+
return __privateGet(this, _AiAgentSelectorComponent_instances, selectedAgent_get)?.name ?? __privateGet(this, _AiAgentSelectorComponent_instances, effectiveTitleText_get);
|
|
74
|
+
};
|
|
75
|
+
hasAgents_get = function() {
|
|
76
|
+
return this.agents.length > 0;
|
|
77
|
+
};
|
|
78
|
+
shouldShowFilter_get = function() {
|
|
79
|
+
return this.agents.length > MIN_AGENTS_FOR_FILTER;
|
|
80
|
+
};
|
|
81
|
+
filteredAgents_get = function() {
|
|
82
|
+
if (!this._filterValue.trim()) {
|
|
83
|
+
return this.agents;
|
|
84
|
+
}
|
|
85
|
+
const searchQuery = this._filterValue.toLowerCase();
|
|
86
|
+
return this.agents.filter((agent) => agent.name.toLowerCase().includes(searchQuery));
|
|
87
|
+
};
|
|
88
|
+
tooltipContent_get = function() {
|
|
89
|
+
const agent = __privateGet(this, _AiAgentSelectorComponent_instances, selectedAgent_get);
|
|
90
|
+
if (!agent) {
|
|
91
|
+
return __privateGet(this, _AiAgentSelectorComponent_instances, effectiveTitleText_get);
|
|
92
|
+
}
|
|
93
|
+
return agent.description ? `${agent.name}
|
|
94
|
+
${agent.description}` : agent.name;
|
|
95
|
+
};
|
|
96
|
+
checkTextOverflow_fn = function() {
|
|
97
|
+
requestAnimationFrame(() => {
|
|
98
|
+
const textElement = this.shadowRoot?.querySelector(".trigger-text, .title-text");
|
|
99
|
+
if (textElement) {
|
|
100
|
+
const isOverflowing = textElement.scrollWidth > textElement.offsetWidth;
|
|
101
|
+
if (this._isTextOverflowing !== isOverflowing) {
|
|
102
|
+
this._isTextOverflowing = isOverflowing;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
};
|
|
107
|
+
handleTriggerClick_fn = function() {
|
|
108
|
+
if (this.disabled) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
this._open = !this._open;
|
|
112
|
+
if (this._open) {
|
|
113
|
+
this._focusedIndex = -1;
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
handlePopoverToggle_fn = function(event) {
|
|
117
|
+
this._open = event.detail.open;
|
|
118
|
+
if (!this._open) {
|
|
119
|
+
this._focusedIndex = -1;
|
|
120
|
+
this._filterValue = "";
|
|
121
|
+
this._triggerButton?.focus();
|
|
122
|
+
} else {
|
|
123
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, scrollToSelectedOrTop_fn).call(this);
|
|
124
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, focusFilterOrFirstItem_fn).call(this);
|
|
125
|
+
}
|
|
126
|
+
};
|
|
127
|
+
handleFilterInput_fn = function(event) {
|
|
128
|
+
this._filterValue = event.target.value;
|
|
129
|
+
this._focusedIndex = -1;
|
|
130
|
+
};
|
|
131
|
+
handleKeyDown_fn = function(event) {
|
|
132
|
+
if (this.disabled) {
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
switch (event.key) {
|
|
136
|
+
case "Enter":
|
|
137
|
+
case " ":
|
|
138
|
+
if (event.target === this._triggerButton) {
|
|
139
|
+
event.preventDefault();
|
|
140
|
+
this._open = true;
|
|
141
|
+
} else if (event.key === "Enter" && this._open) {
|
|
142
|
+
event.preventDefault();
|
|
143
|
+
if (this._focusedIndex === -1) {
|
|
144
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, handleDefaultClick_fn).call(this);
|
|
145
|
+
} else if (this._focusedIndex >= 0) {
|
|
146
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, selectAgent_fn).call(this, __privateGet(this, _AiAgentSelectorComponent_instances, filteredAgents_get)[this._focusedIndex]);
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
break;
|
|
150
|
+
case "Escape":
|
|
151
|
+
if (this._open) {
|
|
152
|
+
event.preventDefault();
|
|
153
|
+
event.stopPropagation();
|
|
154
|
+
this._open = false;
|
|
155
|
+
this._triggerButton?.focus();
|
|
156
|
+
}
|
|
157
|
+
break;
|
|
158
|
+
case "ArrowDown":
|
|
159
|
+
event.preventDefault();
|
|
160
|
+
if (this._open) {
|
|
161
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, moveSelection_fn).call(this, 1);
|
|
162
|
+
} else if (event.target === this._triggerButton) {
|
|
163
|
+
this._open = true;
|
|
164
|
+
}
|
|
165
|
+
break;
|
|
166
|
+
case "ArrowUp":
|
|
167
|
+
event.preventDefault();
|
|
168
|
+
if (this._open) {
|
|
169
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, moveSelection_fn).call(this, -1);
|
|
170
|
+
}
|
|
171
|
+
break;
|
|
172
|
+
case "Home":
|
|
173
|
+
if (this._open) {
|
|
174
|
+
event.preventDefault();
|
|
175
|
+
this._focusedIndex = -1;
|
|
176
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, updateItemFocus_fn).call(this);
|
|
177
|
+
}
|
|
178
|
+
break;
|
|
179
|
+
case "End":
|
|
180
|
+
if (this._open) {
|
|
181
|
+
event.preventDefault();
|
|
182
|
+
this._focusedIndex = __privateGet(this, _AiAgentSelectorComponent_instances, filteredAgents_get).length - 1;
|
|
183
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, updateItemFocus_fn).call(this);
|
|
184
|
+
}
|
|
185
|
+
break;
|
|
186
|
+
}
|
|
187
|
+
};
|
|
188
|
+
moveSelection_fn = function(direction) {
|
|
189
|
+
const agents = __privateGet(this, _AiAgentSelectorComponent_instances, filteredAgents_get);
|
|
190
|
+
let newIndex = this._focusedIndex + direction;
|
|
191
|
+
if (newIndex < -1) {
|
|
192
|
+
newIndex = agents.length - 1;
|
|
193
|
+
} else if (newIndex >= agents.length) {
|
|
194
|
+
newIndex = -1;
|
|
195
|
+
}
|
|
196
|
+
this._focusedIndex = newIndex;
|
|
197
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, updateItemFocus_fn).call(this);
|
|
198
|
+
};
|
|
199
|
+
updateItemFocus_fn = function() {
|
|
200
|
+
const items = this._agentList?.querySelectorAll(".agent-item");
|
|
201
|
+
const filterHasFocus = this.shadowRoot?.activeElement === this._filterInput;
|
|
202
|
+
const domIndex = this._focusedIndex + 1;
|
|
203
|
+
items?.forEach((item, index) => {
|
|
204
|
+
item.setAttribute("tabindex", index === domIndex ? "0" : "-1");
|
|
205
|
+
if (index === domIndex) {
|
|
206
|
+
item.scrollIntoView({ block: "nearest" });
|
|
207
|
+
if (!filterHasFocus) {
|
|
208
|
+
item.focus();
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
});
|
|
212
|
+
};
|
|
213
|
+
focusFilterOrFirstItem_fn = function() {
|
|
214
|
+
requestAnimationFrame(() => {
|
|
215
|
+
if (__privateGet(this, _AiAgentSelectorComponent_instances, shouldShowFilter_get) && this._filterInput) {
|
|
216
|
+
this._filterInput.focus();
|
|
217
|
+
} else {
|
|
218
|
+
this._focusedIndex = -1;
|
|
219
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, updateItemFocus_fn).call(this);
|
|
220
|
+
}
|
|
221
|
+
});
|
|
222
|
+
};
|
|
223
|
+
scrollToSelectedOrTop_fn = async function() {
|
|
224
|
+
await this.updateComplete;
|
|
225
|
+
if (!this._agentList) {
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
const selectedItem = this._agentList.querySelector(".agent-item--selected");
|
|
229
|
+
if (selectedItem) {
|
|
230
|
+
selectedItem.scrollIntoView({ block: "nearest" });
|
|
231
|
+
} else {
|
|
232
|
+
this._agentList.scrollTop = 0;
|
|
233
|
+
}
|
|
234
|
+
};
|
|
235
|
+
selectAgent_fn = function(agent) {
|
|
236
|
+
const previousAgentId = this.selectedAgentId;
|
|
237
|
+
if (agent.id === previousAgentId) {
|
|
238
|
+
this._open = false;
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
this.dispatchEvent(
|
|
242
|
+
new CustomEvent("forge-ai-agent-selector-change", {
|
|
243
|
+
detail: { agent, previousAgentId },
|
|
244
|
+
bubbles: true,
|
|
245
|
+
composed: true
|
|
246
|
+
})
|
|
247
|
+
);
|
|
248
|
+
this._open = false;
|
|
249
|
+
};
|
|
250
|
+
handleAgentClick_fn = function(agent) {
|
|
251
|
+
__privateMethod(this, _AiAgentSelectorComponent_instances, selectAgent_fn).call(this, agent);
|
|
252
|
+
};
|
|
253
|
+
handleDefaultClick_fn = function() {
|
|
254
|
+
if (__privateGet(this, _AiAgentSelectorComponent_instances, isDefaultSelected_get)) {
|
|
255
|
+
this._open = false;
|
|
256
|
+
return;
|
|
257
|
+
}
|
|
258
|
+
this.dispatchEvent(
|
|
259
|
+
new CustomEvent("forge-ai-agent-selector-change", {
|
|
260
|
+
detail: { agent: void 0, previousAgentId: this.selectedAgentId },
|
|
261
|
+
bubbles: true,
|
|
262
|
+
composed: true
|
|
263
|
+
})
|
|
264
|
+
);
|
|
265
|
+
this._open = false;
|
|
266
|
+
};
|
|
267
|
+
triggerTemplate_get = function() {
|
|
268
|
+
return html`
|
|
269
|
+
<button
|
|
270
|
+
class="forge-button trigger-button"
|
|
271
|
+
id="agent-selector-trigger"
|
|
272
|
+
?disabled=${this.disabled}
|
|
273
|
+
aria-haspopup="listbox"
|
|
274
|
+
aria-expanded=${this._open}
|
|
275
|
+
@click=${__privateMethod(this, _AiAgentSelectorComponent_instances, handleTriggerClick_fn)}
|
|
276
|
+
@keydown=${__privateMethod(this, _AiAgentSelectorComponent_instances, handleKeyDown_fn)}>
|
|
277
|
+
<slot name="icon"></slot>
|
|
278
|
+
<span class="trigger-text">${__privateGet(this, _AiAgentSelectorComponent_instances, displayText_get)}</span>
|
|
279
|
+
<svg class="dropdown-icon" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" aria-hidden="true">
|
|
280
|
+
<path d="M7 10l5 5 5-5z" />
|
|
281
|
+
</svg>
|
|
282
|
+
</button>
|
|
283
|
+
`;
|
|
284
|
+
};
|
|
285
|
+
tooltipTemplate_get = function() {
|
|
286
|
+
if (!this._isTextOverflowing) {
|
|
287
|
+
return nothing;
|
|
288
|
+
}
|
|
289
|
+
return html`
|
|
290
|
+
<forge-ai-tooltip for="agent-selector-trigger" placement="bottom"> ${__privateGet(this, _AiAgentSelectorComponent_instances, tooltipContent_get)} </forge-ai-tooltip>
|
|
291
|
+
`;
|
|
292
|
+
};
|
|
293
|
+
filterFieldTemplate_get = function() {
|
|
294
|
+
return html`
|
|
295
|
+
<div class="filter-field">
|
|
296
|
+
<div class="forge-field forge-field--small">
|
|
297
|
+
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" class="search-icon" aria-hidden="true">
|
|
298
|
+
<path
|
|
299
|
+
d="M15.5 14h-.79l-.28-.27A6.47 6.47 0 0 0 16 9.5 6.5 6.5 0 1 0 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14" />
|
|
300
|
+
</svg>
|
|
301
|
+
<input
|
|
302
|
+
type="text"
|
|
303
|
+
class="filter-input"
|
|
304
|
+
placeholder="Search agents..."
|
|
305
|
+
.value=${this._filterValue}
|
|
306
|
+
@input=${__privateMethod(this, _AiAgentSelectorComponent_instances, handleFilterInput_fn)}
|
|
307
|
+
@keydown=${__privateMethod(this, _AiAgentSelectorComponent_instances, handleKeyDown_fn)} />
|
|
308
|
+
</div>
|
|
309
|
+
</div>
|
|
310
|
+
`;
|
|
311
|
+
};
|
|
312
|
+
isDefaultSelected_get = function() {
|
|
313
|
+
return this.selectedAgentId === void 0;
|
|
314
|
+
};
|
|
315
|
+
defaultOptionTemplate_get = function() {
|
|
316
|
+
const isDefaultFocused = this._focusedIndex === -1 && this._open;
|
|
317
|
+
return html`
|
|
318
|
+
<div
|
|
319
|
+
class=${classMap({
|
|
320
|
+
"agent-item": true,
|
|
321
|
+
"agent-item--default": true,
|
|
322
|
+
"agent-item--focused": isDefaultFocused,
|
|
323
|
+
"agent-item--selected": __privateGet(this, _AiAgentSelectorComponent_instances, isDefaultSelected_get)
|
|
324
|
+
})}
|
|
325
|
+
role="option"
|
|
326
|
+
tabindex=${isDefaultFocused ? "0" : "-1"}
|
|
327
|
+
aria-selected=${__privateGet(this, _AiAgentSelectorComponent_instances, isDefaultSelected_get)}
|
|
328
|
+
@click=${__privateMethod(this, _AiAgentSelectorComponent_instances, handleDefaultClick_fn)}>
|
|
329
|
+
<span class="agent-item__selection-icon">
|
|
330
|
+
${when(
|
|
331
|
+
__privateGet(this, _AiAgentSelectorComponent_instances, isDefaultSelected_get),
|
|
332
|
+
() => html`
|
|
333
|
+
<svg class="selection-icon" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" aria-hidden="true">
|
|
334
|
+
<path d="M21 7 9 19l-5.5-5.5 1.41-1.41L9 16.17 19.59 5.59z" />
|
|
335
|
+
</svg>
|
|
336
|
+
`
|
|
337
|
+
)}
|
|
338
|
+
</span>
|
|
339
|
+
<span class="agent-name">${__privateGet(this, _AiAgentSelectorComponent_instances, effectiveTitleText_get)} (default)</span>
|
|
340
|
+
</div>
|
|
341
|
+
<div class="agent-list-separator" role="separator"></div>
|
|
342
|
+
`;
|
|
343
|
+
};
|
|
344
|
+
agentListTemplate_get = function() {
|
|
345
|
+
const agents = __privateGet(this, _AiAgentSelectorComponent_instances, filteredAgents_get);
|
|
346
|
+
if (agents.length === 0) {
|
|
347
|
+
return html`<div class="no-results">No agents found</div>`;
|
|
348
|
+
}
|
|
349
|
+
return html`
|
|
350
|
+
${agents.map(
|
|
351
|
+
(agent, index) => html`
|
|
352
|
+
<div
|
|
353
|
+
class=${classMap({
|
|
354
|
+
"agent-item": true,
|
|
355
|
+
"agent-item--focused": index === this._focusedIndex,
|
|
356
|
+
"agent-item--selected": agent.id === this.selectedAgentId
|
|
357
|
+
})}
|
|
358
|
+
role="option"
|
|
359
|
+
tabindex=${index === this._focusedIndex ? "0" : "-1"}
|
|
360
|
+
aria-selected=${agent.id === this.selectedAgentId}
|
|
361
|
+
@click=${() => __privateMethod(this, _AiAgentSelectorComponent_instances, handleAgentClick_fn).call(this, agent)}>
|
|
362
|
+
<span class="agent-item__selection-icon">
|
|
363
|
+
${when(
|
|
364
|
+
agent.id === this.selectedAgentId,
|
|
365
|
+
() => html`
|
|
366
|
+
<svg class="selection-icon" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" aria-hidden="true">
|
|
367
|
+
<path d="M21 7 9 19l-5.5-5.5 1.41-1.41L9 16.17 19.59 5.59z" />
|
|
368
|
+
</svg>
|
|
369
|
+
`
|
|
370
|
+
)}
|
|
371
|
+
</span>
|
|
372
|
+
<span class="agent-name">${agent.name}</span>
|
|
373
|
+
</div>
|
|
374
|
+
`
|
|
375
|
+
)}
|
|
376
|
+
`;
|
|
377
|
+
};
|
|
378
|
+
dropdownTemplate_get = function() {
|
|
379
|
+
return html`
|
|
380
|
+
<forge-ai-popover
|
|
381
|
+
.anchor=${this._triggerButton ?? null}
|
|
382
|
+
placement="bottom-start"
|
|
383
|
+
?open=${this._open}
|
|
384
|
+
.offset=${{ mainAxis: 4 }}
|
|
385
|
+
flip
|
|
386
|
+
shift
|
|
387
|
+
@forge-ai-popover-toggle=${__privateMethod(this, _AiAgentSelectorComponent_instances, handlePopoverToggle_fn)}>
|
|
388
|
+
<div class="dropdown-header">Switch to another agent</div>
|
|
389
|
+
${when(__privateGet(this, _AiAgentSelectorComponent_instances, shouldShowFilter_get), () => __privateGet(this, _AiAgentSelectorComponent_instances, filterFieldTemplate_get))}
|
|
390
|
+
<div class="agent-list" role="listbox" aria-label="Select an agent" @keydown=${__privateMethod(this, _AiAgentSelectorComponent_instances, handleKeyDown_fn)}>
|
|
391
|
+
${__privateGet(this, _AiAgentSelectorComponent_instances, defaultOptionTemplate_get)} ${__privateGet(this, _AiAgentSelectorComponent_instances, agentListTemplate_get)}
|
|
392
|
+
</div>
|
|
393
|
+
</forge-ai-popover>
|
|
394
|
+
`;
|
|
395
|
+
};
|
|
396
|
+
staticTitleTemplate_get = function() {
|
|
397
|
+
return html`<span class="title-text" id="agent-selector-trigger">${this.titleText}</span>`;
|
|
398
|
+
};
|
|
399
|
+
AiAgentSelectorComponent.styles = unsafeCSS(styles);
|
|
400
|
+
__decorateClass([
|
|
401
|
+
property({ attribute: false })
|
|
402
|
+
], AiAgentSelectorComponent.prototype, "agents", 2);
|
|
403
|
+
__decorateClass([
|
|
404
|
+
property({ attribute: "selected-agent-id" })
|
|
405
|
+
], AiAgentSelectorComponent.prototype, "selectedAgentId", 2);
|
|
406
|
+
__decorateClass([
|
|
407
|
+
property({ attribute: "title-text" })
|
|
408
|
+
], AiAgentSelectorComponent.prototype, "titleText", 2);
|
|
409
|
+
__decorateClass([
|
|
410
|
+
property({ type: Boolean, reflect: true })
|
|
411
|
+
], AiAgentSelectorComponent.prototype, "disabled", 2);
|
|
412
|
+
__decorateClass([
|
|
413
|
+
state()
|
|
414
|
+
], AiAgentSelectorComponent.prototype, "_open", 2);
|
|
415
|
+
__decorateClass([
|
|
416
|
+
state()
|
|
417
|
+
], AiAgentSelectorComponent.prototype, "_focusedIndex", 2);
|
|
418
|
+
__decorateClass([
|
|
419
|
+
state()
|
|
420
|
+
], AiAgentSelectorComponent.prototype, "_isTextOverflowing", 2);
|
|
421
|
+
__decorateClass([
|
|
422
|
+
state()
|
|
423
|
+
], AiAgentSelectorComponent.prototype, "_filterValue", 2);
|
|
424
|
+
__decorateClass([
|
|
425
|
+
query("#agent-selector-trigger")
|
|
426
|
+
], AiAgentSelectorComponent.prototype, "_triggerButton", 2);
|
|
427
|
+
__decorateClass([
|
|
428
|
+
query(".agent-list")
|
|
429
|
+
], AiAgentSelectorComponent.prototype, "_agentList", 2);
|
|
430
|
+
__decorateClass([
|
|
431
|
+
query(".filter-input")
|
|
432
|
+
], AiAgentSelectorComponent.prototype, "_filterInput", 2);
|
|
433
|
+
AiAgentSelectorComponent = __decorateClass([
|
|
434
|
+
customElement(AiAgentSelectorComponentTagName)
|
|
435
|
+
], AiAgentSelectorComponent);
|
|
436
|
+
export {
|
|
437
|
+
AiAgentSelectorComponent,
|
|
438
|
+
AiAgentSelectorComponentTagName
|
|
439
|
+
};
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
const styles = '/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/* prettier-ignore */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/* prettier-ignore */\n.forge-button {\n --_button-primary-color: var(--forge-button-primary-color, var(--forge-theme-primary, #3f51b5));\n --_button-text-color: var(--forge-button-text-color, var(--_button-primary-color));\n --_button-disabled-color: var(--forge-button-disabled-color, var(--forge-theme-surface-container, #e0e0e0));\n --_button-padding: var(--forge-button-padding, var(--forge-spacing-medium, 16px));\n --_button-display: var(--forge-button-display, inline-grid);\n --_button-justify: var(--forge-button-justify, center);\n --_button-shape: var(--forge-button-shape, calc(var(--forge-shape-medium, 4px) * var(--forge-shape-factor, 1)));\n --_button-height: var(--forge-button-height, 36px);\n --_button-min-width: var(--forge-button-min-width, 64px);\n --_button-spacing: var(--forge-button-spacing, var(--forge-spacing-xsmall, 8px));\n --_button-border-width: var(--forge-button-border-width, medium);\n --_button-border-style: var(--forge-button-border-style, none);\n --_button-border-color: var(--forge-button-border-color, currentColor);\n --_button-shape-start-start-radius: var(--forge-button-shape-start-start-radius, var(--_button-shape));\n --_button-shape-start-end-radius: var(--forge-button-shape-start-end-radius, var(--_button-shape));\n --_button-shape-end-start-radius: var(--forge-button-shape-end-start-radius, var(--_button-shape));\n --_button-shape-end-end-radius: var(--forge-button-shape-end-end-radius, var(--_button-shape));\n --_button-padding-block: var(--forge-button-padding-block, var(--_button-0));\n --_button-padding-inline: var(--forge-button-padding-inline, var(--_button-padding));\n --_button-background: var(--forge-button-background, transparent);\n --_button-hover-background: var(--forge-button-hover-background, var(--_button-background));\n --_button-active-background: var(--forge-button-active-background, var(--_button-background));\n --_button-color: var(--forge-button-color, var(--_button-text-color));\n --_button-icon-size: var(--forge-button-icon-size, calc(var(--forge-typography-font-size, 1rem) * 1.125));\n --_button-shadow: var(--forge-button-shadow, none);\n --_button-hover-shadow: var(--forge-button-hover-shadow, none);\n --_button-active-shadow: var(--forge-button-active-shadow, none);\n --_button-cursor: var(--forge-button-cursor, pointer);\n --_button-transition-duration: var(--forge-button-transition-duration, var(--forge-animation-duration-short3, 150ms));\n --_button-transition-timing: var(--forge-button-transition-timing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n --_button-text-padding-inline: var(--forge-button-text-padding-inline, var(--forge-spacing-xsmall, 8px));\n --_button-outlined-background: var(--forge-button-outlined-background, transparent);\n --_button-outlined-color: var(--forge-button-outlined-color, var(--_button-primary-color));\n --_button-outlined-border-width: var(--forge-button-outlined-border-width, var(--forge-border-thin, 1px));\n --_button-outlined-border-style: var(--forge-button-outlined-border-style, solid);\n --_button-outlined-border-color: var(--forge-button-outlined-border-color, var(--_button-primary-color));\n --_button-tonal-background: var(--forge-button-tonal-background, var(--forge-theme-primary-container, #d1d5ed));\n --_button-tonal-disabled-background: var(--forge-button-tonal-disabled-background, var(--_button-disabled-color));\n --_button-tonal-color: var(--forge-button-tonal-color, var(--forge-theme-on-primary-container, #222c62));\n --_button-tonal-disabled-color: var(--forge-button-tonal-disabled-color, var(--_button-disabled-text-color));\n --_button-filled-background: var(--forge-button-filled-background, var(--_button-primary-color));\n --_button-filled-disabled-background: var(--forge-button-filled-disabled-background, var(--_button-disabled-color));\n --_button-filled-color: var(--forge-button-filled-color, var(--forge-theme-on-primary, #ffffff));\n --_button-filled-disabled-color: var(--forge-button-filled-disabled-color, var(--_button-disabled-text-color));\n --_button-raised-background: var(--forge-button-raised-background, var(--_button-primary-color));\n --_button-raised-disabled-background: var(--forge-button-raised-disabled-background, var(--_button-disabled-color));\n --_button-raised-color: var(--forge-button-raised-color, var(--forge-theme-on-primary, #ffffff));\n --_button-raised-disabled-color: var(--forge-button-raised-disabled-color, var(--_button-disabled-text-color));\n --_button-raised-shadow: var(--forge-button-raised-shadow, 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12));\n --_button-raised-hover-shadow: var(--forge-button-raised-hover-shadow, 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12));\n --_button-raised-active-shadow: var(--forge-button-raised-active-shadow, 0px 5px 5px -3px rgba(0, 0, 0, 0.2), 0px 8px 10px 1px rgba(0, 0, 0, 0.14), 0px 3px 14px 2px rgba(0, 0, 0, 0.12));\n --_button-raised-disabled-shadow: var(--forge-button-raised-disabled-shadow, none);\n --_button-link-color: var(--forge-button-link-color, var(--_button-primary-color));\n --_button-link-text-decoration: var(--forge-button-link-text-decoration, underline);\n --_button-link-height: var(--forge-button-link-height, auto);\n --_button-link-padding: var(--forge-button-link-padding, 0);\n --_button-link-line-height: var(--forge-button-link-line-height, normal);\n --_button-link-width: var(--forge-button-link-width, auto);\n --_button-link-hover-text-decoration: var(--forge-button-link-hover-text-decoration, none);\n --_button-link-active-opacity: var(--forge-button-link-active-opacity, 0.65);\n --_button-link-transition-duration: var(--forge-button-link-transition-duration, var(--forge-animation-duration-short3, 150ms));\n --_button-link-transition-timing: var(--forge-button-link-transition-timing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n --_button-disabled-cursor: var(--forge-button-disabled-cursor, not-allowed);\n --_button-disabled-text-color: var(--forge-button-disabled-text-color, var(--forge-theme-text-low, rgba(0, 0, 0, 0.38)));\n --_button-disabled-background: var(--forge-button-disabled-background, transparent);\n --_button-disabled-border-color: var(--forge-button-disabled-border-color, var(--_button-disabled-color));\n --_button-disabled-shadow: var(--forge-button-disabled-shadow, none);\n --_button-dense-height: var(--forge-button-dense-height, 24px);\n --_button-pill-shape: var(--forge-button-pill-shape, calc(var(--forge-shape-full, 9999px) * var(--forge-shape-factor, 1)));\n --_button-pill-padding-inline: var(--forge-button-pill-padding-inline, var(--forge-spacing-small, 12px));\n --_button-focus-indicator-offset: var(--forge-button-focus-indicator-offset, 4px);\n --_button-text-focus-indicator-offset: var(--forge-button-text-focus-indicator-offset, 0px);\n --_button-link-focus-indicator-offset: var(--forge-button-link-focus-indicator-offset, 2px);\n --_button-popover-icon-transition-duration: var(--forge-button-popover-icon-transition-duration, var(--forge-animation-duration-short3, 150ms));\n --_button-popover-icon-transition-timing: var(--forge-button-popover-icon-transition-timing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n --_button-popover-icon-open-rotation: var(--forge-button-popover-icon-open-rotation, 180deg);\n}\n\n.forge-button {\n display: var(--_button-display);\n position: relative;\n outline: none;\n vertical-align: middle;\n -webkit-tap-highlight-color: transparent;\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-button-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-button-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-button-font-size-scale, 0.875)));\n font-weight: var(--forge-typography-button-font-weight, 500);\n line-height: var(--forge-typography-button-line-height, normal);\n letter-spacing: var(--forge-typography-button-letter-spacing, 0.0714285714em);\n text-transform: var(--forge-typography-button-text-transform, inherit);\n text-decoration: var(--forge-typography-button-text-decoration, inherit);\n position: relative;\n display: var(--_button-display);\n grid-auto-flow: column;\n align-items: center;\n justify-content: var(--_button-justify);\n gap: var(--_button-spacing);\n z-index: 0;\n box-sizing: border-box;\n min-inline-size: var(--_button-min-width);\n height: var(--_button-height);\n inline-size: 100%;\n border-width: var(--_button-border-width);\n border-style: var(--_button-border-style);\n border-color: var(--_button-border-color);\n border-start-start-radius: var(--_button-shape-start-start-radius);\n border-start-end-radius: var(--_button-shape-start-end-radius);\n border-end-start-radius: var(--_button-shape-end-start-radius);\n border-end-end-radius: var(--_button-shape-end-end-radius);\n padding-block: var(--_button-padding-block);\n padding-inline: var(--_button-padding-inline);\n box-shadow: var(--_button-shadow);\n outline: none;\n user-select: none;\n -webkit-appearance: none;\n vertical-align: middle;\n text-decoration: none;\n white-space: nowrap;\n background: var(--_button-background);\n color: var(--_button-color);\n cursor: var(--_button-cursor);\n transition-property: box-shadow, background;\n transition-duration: var(--_button-transition-duration);\n transition-timing-function: var(--_button-transition-timing);\n}\n\n.forge-button::-moz-focus-inner {\n padding: 0;\n border: 0;\n}\n\n.forge-button:hover {\n --_button-shadow: var(--_button-hover-shadow);\n background: var(--_button-hover-background);\n}\n\n.forge-button:active {\n --_button-shadow: var(--_button-active-shadow);\n background: var(--_button-active-background);\n}\n\n.forge-button {\n position: relative;\n inline-size: auto;\n}\n\n.forge-button:not(:disabled):not(.forge-button--link) {\n --_state-layer-display: var(--forge-state-layer-display, flex);\n --_state-layer-color: var(--forge-state-layer-color, var(--forge-theme-on-surface, #000000));\n --_state-layer-hover-color: var(--forge-state-layer-hover-color, var(--_state-layer-color));\n --_state-layer-hover-opacity: var(--forge-state-layer-hover-opacity, 0.08);\n --_state-layer-pressed-color: var(--forge-state-layer-pressed-color, var(--_state-layer-color));\n --_state-layer-pressed-opacity: var(--forge-state-layer-pressed-opacity, 0.12);\n --_state-layer-hover-duration: var(--forge-state-layer-hover-duration, 15ms);\n --_state-layer-pressed-duration: var(--forge-state-layer-pressed-duration, 105ms);\n --_state-layer-animation-duration: var(--forge-state-layer-animation-duration, 375ms);\n}\n\n.forge-button:not(:disabled):not(.forge-button--link)::before {\n opacity: 0;\n position: absolute;\n backface-visibility: hidden;\n transform: translateZ(0);\n background-color: var(--_state-layer-hover-color);\n inset: 0;\n transition: opacity var(--_state-layer-hover-duration) linear, background-color var(--_state-layer-hover-duration) linear;\n --_state-layer-hover-duration: var(--forge-state-layer-hover-duration, 100ms);\n content: "";\n opacity: 0;\n border-radius: inherit;\n}\n\n.forge-button:not(:disabled):not(.forge-button--link):hover::before {\n background-color: var(--_state-layer-hover-color);\n opacity: var(--_state-layer-hover-opacity);\n}\n\n.forge-button:not(:disabled):not(.forge-button--link):active::before {\n opacity: var(--_state-layer-pressed-opacity);\n transition-duration: var(--_state-layer-pressed-duration);\n --_state-layer-pressed-opacity: var(--forge-state-layer-pressed-opacity, 0.18);\n}\n\n@keyframes forge-focus-indicator-outward-grow {\n from {\n outline-width: 0;\n }\n to {\n outline-width: var(--_focus-indicator-active-width);\n }\n}\n@keyframes forge-focus-indicator-outward-shrink {\n from {\n outline-width: var(--_focus-indicator-active-width);\n }\n}\n@keyframes forge-focus-indicator-inward-grow {\n from {\n border-width: 0;\n }\n to {\n border-width: var(--_focus-indicator-active-width);\n }\n}\n@keyframes forge-focus-indicator-inward-shrink {\n from {\n border-width: var(--_focus-indicator-active-width);\n }\n}\n.forge-button:not(:disabled) {\n outline: none;\n}\n\n.forge-button:not(:disabled):focus-visible::after {\n --_focus-indicator-display: var(--forge-focus-indicator-display, flex);\n --_focus-indicator-width: var(--forge-focus-indicator-width, var(--forge-border-medium, 2px));\n --_focus-indicator-active-width: var(--forge-focus-indicator-active-width, 6px);\n --_focus-indicator-color: var(--forge-focus-indicator-color, var(--forge-theme-primary, #3f51b5));\n --_focus-indicator-shape: var(--forge-focus-indicator-shape, calc(var(--forge-shape-extra-small, 1px) * var(--forge-shape-factor, 1)));\n --_focus-indicator-duration: var(--forge-focus-indicator-duration, var(--forge-animation-duration-long4, 600ms));\n --_focus-indicator-easing: var(--forge-focus-indicator-easing, var(--forge-animation-easing-emphasized, cubic-bezier(0.2, 0, 0, 1)));\n --_focus-indicator-shape-start-start: var(--forge-focus-indicator-shape-start-start, var(--_focus-indicator-shape));\n --_focus-indicator-shape-start-end: var(--forge-focus-indicator-shape-start-end, var(--_focus-indicator-shape));\n --_focus-indicator-shape-end-end: var(--forge-focus-indicator-shape-end-end, var(--_focus-indicator-shape));\n --_focus-indicator-shape-end-start: var(--forge-focus-indicator-shape-end-start, var(--_focus-indicator-shape));\n --_focus-indicator-outward-offset: var(--forge-focus-indicator-outward-offset, var(--forge-spacing-xxsmall, 4px));\n --_focus-indicator-inward-offset: var(--forge-focus-indicator-inward-offset, 0px);\n --_focus-indicator-offset-block: var(--forge-focus-indicator-offset-block, 0);\n --_focus-indicator-offset-inline: var(--forge-focus-indicator-offset-inline, 0);\n}\n\n.forge-button:not(:disabled):focus-visible::after {\n animation-delay: 0s, calc(var(--_focus-indicator-duration) * 0.25);\n animation-duration: calc(var(--_focus-indicator-duration) * 0.25), calc(var(--_focus-indicator-duration) * 0.75);\n animation-timing-function: var(--_focus-indicator-easing);\n box-sizing: border-box;\n color: var(--_focus-indicator-color);\n display: none;\n pointer-events: none;\n position: absolute;\n margin-block: var(--_focus-indicator-offset-block);\n margin-inline: var(--_focus-indicator-offset-inline);\n animation-name: forge-focus-indicator-outward-grow, forge-focus-indicator-outward-shrink;\n border-end-end-radius: calc(var(--_focus-indicator-shape-end-end) + var(--_focus-indicator-outward-offset));\n border-end-start-radius: calc(var(--_focus-indicator-shape-end-start) + var(--_focus-indicator-outward-offset));\n border-start-end-radius: calc(var(--_focus-indicator-shape-start-end) + var(--_focus-indicator-outward-offset));\n border-start-start-radius: calc(var(--_focus-indicator-shape-start-start) + var(--_focus-indicator-outward-offset));\n inset: calc(-1 * var(--_focus-indicator-outward-offset));\n outline: var(--_focus-indicator-width) solid currentColor;\n content: "";\n display: block;\n}\n\n.forge-button:not(:disabled) {\n --forge-focus-indicator-color: var(--_button-primary-color);\n}\n\n.forge-button:disabled {\n cursor: var(--_button-disabled-cursor);\n --_button-background: var(--_button-disabled-background);\n --_button-color: var(--_button-disabled-text-color);\n --_button-shadow: var(--_button-disabled-shadow);\n pointer-events: none;\n pointer-events: initial;\n}\n\n.forge-button:where(:not(.forge-button--outlined, .forge-button--tonal, .forge-button--filled, .forge-button--raised, .forge-button--link)), .forge-button--text {\n --_button-padding-inline: var(--_button-text-padding-inline);\n}\n\n.forge-button--outlined {\n --_button-background: var(--_button-outlined-background);\n --_button-color: var(--_button-outlined-color);\n --_button-border-width: var(--_button-outlined-border-width);\n --_button-border-style: var(--_button-outlined-border-style);\n --_button-border-color: var(--_button-outlined-border-color);\n}\n\n.forge-button--outlined:disabled {\n --_button-border-color: var(--_button-disabled-border-color);\n}\n\n.forge-button--tonal {\n --_button-background: var(--_button-tonal-background);\n --_button-color: var(--_button-tonal-color);\n}\n\n.forge-button--tonal:disabled {\n --_button-background: var(--_button-tonal-disabled-background);\n --_button-color: var(--_button-tonal-disabled-color);\n}\n\n.forge-button--filled, .forge-button--raised {\n --_button-background: var(--_button-filled-background);\n --_button-color: var(--_button-filled-color);\n --forge-state-layer-color: var(--_button-filled-color);\n}\n\n.forge-button--filled:disabled, .forge-button--raised:disabled {\n --_button-background: var(--_button-filled-disabled-background);\n --_button-color: var(--_button-filled-disabled-color);\n}\n\n.forge-button--raised {\n --_button-background: var(--_button-raised-background);\n --_button-color: var(--_button-raised-color);\n --_button-shadow: var(--_button-raised-shadow);\n}\n\n.forge-button--raised:hover {\n --_button-shadow: var(--_button-raised-hover-shadow);\n}\n\n.forge-button--raised:active {\n --_button-shadow: var(--_button-raised-active-shadow);\n}\n\n.forge-button--raised:disabled {\n --_button-background: var(--_button-raised-disabled-background);\n --_button-color: var(--_button-raised-disabled-color);\n --_button-shadow: var(--_button-raised-disabled-shadow);\n}\n\n.forge-button--link {\n --_button-color: var(--_button-link-color);\n --_button-height: var(--_button-link-height);\n --_button-padding: var(--_button-link-padding);\n --_button-focus-indicator-offset: var(--_button-link-focus-indicator-offset);\n text-decoration: var(--_button-link-text-decoration);\n line-height: var(--_button-link-line-height);\n transition: opacity var(--_button-link-transition-duration) var(--_button-link-transition-timing);\n inline-size: var(--_button-link-width);\n}\n\n.forge-button--link:hover {\n text-decoration: var(--_button-link-hover-text-decoration);\n}\n\n.forge-button--link:active {\n opacity: var(--_button-link-active-opacity);\n}\n\n.forge-button--pill {\n --_button-shape: var(--_button-pill-shape);\n --_button-padding-inline: var(--_button-pill-padding-inline);\n --forge-focus-indicator-shape: var(--_button-pill-shape);\n}\n\n.forge-button {\n --forge-icon-font-size: var(--_button-icon-size);\n}\n\n.forge-button--dense {\n --_button-height: var(--_button-dense-height);\n}\n\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/* prettier-ignore */\n@keyframes float-in-label-animation {\n from {\n translate: 0;\n opacity: 40%;\n }\n to {\n translate: var(--_field-floating-label-translation);\n opacity: 100%;\n }\n}\n@keyframes float-out-label-animation {\n from {\n translate: var(--_field-floating-label-translation);\n opacity: 40%;\n }\n to {\n translate: 0;\n opacity: 100%;\n }\n}\n@keyframes multiline-inset-label-background-animation {\n from {\n opacity: 0%;\n }\n to {\n opacity: 100%;\n }\n}\n@layer base, textarea, density, invalid, disabled;\n@layer base {\n .forge-field {\n --_field-shape: var(--forge-field-shape, calc(var(--forge-shape-medium, 4px) * var(--forge-shape-factor, 1)));\n --_field-outline-style: var(--forge-field-outline-style, solid);\n --_field-outline-width: var(--forge-field-outline-width, var(--forge-border-thin, 1px));\n --_field-height: var(--forge-field-height, 40px);\n --_field-inset-height: var(--forge-field-inset-height, 48px);\n --_field-background: var(--forge-field-background, transparent);\n --_field-padding-inline: var(--forge-field-padding-inline, 12px);\n --_field-disabled-background: var(--forge-field-disabled-background, var(--forge-theme-surface-container-low, #ebebeb));\n --_field-disabled-opacity: var(--forge-field-disabled-opacity, 0.38);\n --_field-placeholder-color: var(--forge-field-placeholder-color, var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6)));\n }\n .forge-field {\n position: relative;\n display: flex;\n align-items: center;\n gap: var(--forge-spacing-xsmall, 8px);\n box-shadow: var(--_field-elevation);\n padding-inline: var(--_field-padding-inline);\n border-radius: var(--_field-shape);\n outline-style: var(--_field-outline-style);\n outline-width: var(--_field-outline-width);\n outline-color: var(--forge-theme-outline-low, #9e9e9e);\n outline-offset: calc(var(--_field-outline-width) * -1);\n background: var(--_field-background);\n opacity: var(--_field-disableable-opacity);\n cursor: var(--_field-disableable-cursor);\n }\n .forge-field:hover:not(:has(:where(input, textarea, select, .forge-field__input):disabled)) {\n outline-color: var(--forge-theme-outline-high, #212121);\n }\n .forge-field :where(input, textarea, select, .forge-field__input) {\n box-sizing: border-box;\n margin: 0;\n outline: none;\n border: none;\n background-color: transparent;\n padding-block: 0;\n padding-inline: 0;\n inline-size: 100%;\n block-size: 100%;\n color: inherit;\n font: inherit;\n font-size: var(--_field-font-size);\n text-overflow: ellipsis;\n padding-block-start: 0;\n padding-block-end: 0;\n transition: padding-block var(--_field-floating-animation-duration) var(--_field-floating-animation-timing);\n display: flex;\n block-size: var(--_field-height);\n inline-size: 100%;\n overflow: hidden;\n color: var(--forge-theme-text-high, rgba(0, 0, 0, 0.87));\n background: transparent;\n appearance: none;\n }\n .forge-field :where(input, textarea, select, .forge-field__input)::placeholder {\n color: var(--_field-placeholder-color);\n }\n .forge-field--plain {\n --_field-multiline-inset-label-background: var(--forge-field-multiline-inset-label-background, var(--forge-theme-surface, #ffffff));\n --_field-multiline-inset-label-background-hover: var(--forge-field-multiline-inset-label-background-hover, var(--forge-theme-surface, #ffffff));\n --_field-outline-color: var(--forge-field-outline-color, transparent);\n --_field-outline-color-hover: var(--forge-field-outline-color-hover, transparent);\n --_field-inner-border-display: var(--forge-field-inner-border-display, none);\n --_field-padding-inline: var(--forge-field-padding-inline, 0);\n --_field-surface-display: var(--forge-field-surface-display, none);\n outline-width: 0;\n }\n .forge-field--tonal {\n --_field-outline-color: var(--forge-field-outline-color, transparent);\n --_field-outline-color-hover: var(--forge-field-outline-color-hover, transparent);\n --_field-inner-border-block-size: var(--forge-field-inner-border-block-size, calc(100% - 8px));\n --_field-background: var(--_field-tonal-background);\n --_field-multiline-inset-label-background: var(--forge-field-multiline-inset-label-background, var(--_field-background));\n --_field-hover-background: var(--forge-field-hover-background, tonal-background-hover);\n --_field-multiline-inset-label-background: var(--forge-field-multiline-inset-label-background, var(--_field-multiline-inset-label-tonal-background));\n outline-width: 0;\n background: var(--forge-theme-primary-container-low, #e8eaf6);\n }\n .forge-field--tonal:hover:not(:has(:where(input, textarea, select, .forge-field__input):disabled)) {\n background: var(--forge-theme-surface-container-minimum, #f5f5f5);\n }\n .forge-field--filled {\n --_field-background: var(--_field-filled-background);\n --_field-multiline-inset-label-background: var(--forge-field-multiline-inset-label-background, var(--_field-background));\n background: var(--forge-theme-surface-bright, #ffffff);\n }\n .forge-field--raised {\n --_field-elevation: var(--forge-field-elevation, 0px 2px 1px -1px rgba(0, 0, 0, 0.2), 0px 1px 1px 0px rgba(0, 0, 0, 0.14), 0px 1px 3px 0px rgba(0, 0, 0, 0.12));\n --_field-elevation-active: var(--forge-field-elevation-active, 0px 3px 3px -2px rgba(0, 0, 0, 0.2), 0px 3px 4px 0px rgba(0, 0, 0, 0.14), 0px 1px 8px 0px rgba(0, 0, 0, 0.12));\n --_field-outline-color: var(--forge-field-outline-color, transparent);\n --_field-outline-color-hover: var(--forge-field-outline-color-hover, transparent);\n --_field-inner-border-block-size: var(--forge-field-inner-border-block-size, calc(100% - 8px));\n --_field-background: var(--_field-filled-background);\n --_field-multiline-inset-label-background: var(--forge-field-multiline-inset-label-background, var(--_field-background));\n outline-width: 0;\n }\n .forge-field--raised:hover:not(:has(:where(input, textarea, select, .forge-field__input):disabled)) {\n box-shadow: var(--_field-elevation-active);\n }\n .forge-field--rounded {\n --_field-shape: var(--forge-field-shape, calc(var(--forge-shape-full, 9999px) * var(--forge-shape-factor, 1)));\n --_field-padding-inline: var(--forge-field-padding-inline, var(--_field-rounded-container-padding-inline-start));\n }\n .forge-field:has(label) {\n --_field-floating-label-translation: var(--forge-field-floating-label-translation, 0 calc(calc(calc(max(var(--forge-typography-body2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-line-height-scale, 1.375))), var(--forge-typography-label2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-line-height-scale, 1.25)))) / 2) + calc((var(--_field-height) - 56px) / 8)) * -1));\n display: grid;\n grid-template-columns: auto 1fr auto;\n gap: 0;\n block-size: var(--_field-height);\n --_field-height: var(--forge-field-height, 48px);\n }\n .forge-field:has(label) label {\n position: absolute;\n grid-column: 2;\n pointer-events: none;\n color: var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6));\n }\n .forge-field:has(label).forge-field--rounded {\n padding-inline: var(--forge-spacing-large, 24px);\n }\n @keyframes forge-field-float-label-in {\n from {\n transform: translateY(15%);\n opacity: 0;\n }\n to {\n transform: translateY(0);\n opacity: 1;\n }\n }\n .forge-field:has(label).forge-field--float-label-in label {\n animation: forge-field-float-label-in var(--forge-animation-duration-short4, 200ms) var(--forge-animation-easing-accelerate, cubic-bezier(0.3, 0, 1, 1)) forwards;\n }\n @keyframes forge-field-float-label-out {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n }\n .forge-field:has(label).forge-field--float-label-out label {\n animation: forge-field-float-label-out var(--forge-animation-duration-short4, 200ms) var(--forge-animation-easing-accelerate, cubic-bezier(0.3, 0, 1, 1)) forwards;\n }\n .forge-field:has(label).forge-field--float-label label, .forge-field:has(label):has(:where(:where(input, textarea, select, .forge-field__input):autofill, :where(input, textarea, select, .forge-field__input):placeholder-shown)) label {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-label2-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-label2-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-font-size-scale, 0.8125)));\n font-weight: var(--forge-typography-label2-font-weight, 400);\n line-height: var(--forge-typography-label2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-line-height-scale, 1.25)));\n letter-spacing: var(--forge-typography-label2-letter-spacing, 0.0096153846em);\n text-transform: var(--forge-typography-label2-text-transform, inherit);\n text-decoration: var(--forge-typography-label2-text-decoration, inherit);\n translate: var(--_field-floating-label-translation);\n }\n .forge-field:has(label).forge-field--float-label:not(.forge-field--extra-small) :where(input, textarea, select, .forge-field__input), .forge-field:has(label):has(:where(:where(input, textarea, select, .forge-field__input):autofill, :where(input, textarea, select, .forge-field__input):placeholder-shown)):not(.forge-field--extra-small) :where(input, textarea, select, .forge-field__input) {\n padding-block-start: calc((max(var(--forge-typography-body2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-line-height-scale, 1.375))), var(--forge-typography-label2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-line-height-scale, 1.25)))) / 2 + (var(--_field-height) - 56px) / 8) * 2) !important;\n }\n .forge-field:has(label) :where(input, textarea, select, .forge-field__input) {\n grid-column: 2;\n block-size: var(--_field-height);\n }\n .forge-field:has(label) :where(input, textarea, select, .forge-field__input) ~ * {\n grid-column: 3;\n margin-inline-start: var(--forge-spacing-xsmall, 8px);\n }\n .forge-field:has(label) > :not(:where(input, textarea, select, .forge-field__input) ~ *, :where(input, textarea, select, .forge-field__input), label) {\n grid-column: 1;\n margin-inline-end: var(--forge-spacing-xsmall, 8px);\n }\n @keyframes forge-focus-indicator-outward-grow {\n from {\n outline-width: 0;\n }\n to {\n outline-width: var(--_focus-indicator-active-width);\n }\n }\n @keyframes forge-focus-indicator-outward-shrink {\n from {\n outline-width: var(--_focus-indicator-active-width);\n }\n }\n @keyframes forge-focus-indicator-inward-grow {\n from {\n border-width: 0;\n }\n to {\n border-width: var(--_focus-indicator-active-width);\n }\n }\n @keyframes forge-focus-indicator-inward-shrink {\n from {\n border-width: var(--_focus-indicator-active-width);\n }\n }\n .forge-field:has(:where(input, textarea, select, .forge-field__input):focus) {\n outline: none;\n }\n .forge-field:has(:where(input, textarea, select, .forge-field__input):focus)::after {\n --_focus-indicator-display: var(--forge-focus-indicator-display, flex);\n --_focus-indicator-width: var(--forge-focus-indicator-width, var(--forge-border-medium, 2px));\n --_focus-indicator-active-width: var(--forge-focus-indicator-active-width, 6px);\n --_focus-indicator-color: var(--forge-focus-indicator-color, var(--forge-theme-primary, #3f51b5));\n --_focus-indicator-shape: var(--forge-focus-indicator-shape, calc(var(--forge-shape-extra-small, 1px) * var(--forge-shape-factor, 1)));\n --_focus-indicator-duration: var(--forge-focus-indicator-duration, var(--forge-animation-duration-long4, 600ms));\n --_focus-indicator-easing: var(--forge-focus-indicator-easing, var(--forge-animation-easing-emphasized, cubic-bezier(0.2, 0, 0, 1)));\n --_focus-indicator-shape-start-start: var(--forge-focus-indicator-shape-start-start, var(--_focus-indicator-shape));\n --_focus-indicator-shape-start-end: var(--forge-focus-indicator-shape-start-end, var(--_focus-indicator-shape));\n --_focus-indicator-shape-end-end: var(--forge-focus-indicator-shape-end-end, var(--_focus-indicator-shape));\n --_focus-indicator-shape-end-start: var(--forge-focus-indicator-shape-end-start, var(--_focus-indicator-shape));\n --_focus-indicator-outward-offset: var(--forge-focus-indicator-outward-offset, var(--forge-spacing-xxsmall, 4px));\n --_focus-indicator-inward-offset: var(--forge-focus-indicator-inward-offset, 0px);\n --_focus-indicator-offset-block: var(--forge-focus-indicator-offset-block, 0);\n --_focus-indicator-offset-inline: var(--forge-focus-indicator-offset-inline, 0);\n animation-delay: 0s, calc(var(--_focus-indicator-duration) * 0.25);\n animation-duration: calc(var(--_focus-indicator-duration) * 0.25), calc(var(--_focus-indicator-duration) * 0.75);\n animation-timing-function: var(--_focus-indicator-easing);\n box-sizing: border-box;\n color: var(--_focus-indicator-color);\n display: none;\n pointer-events: none;\n position: absolute;\n margin-block: var(--_focus-indicator-offset-block);\n margin-inline: var(--_focus-indicator-offset-inline);\n animation-name: forge-focus-indicator-outward-grow, forge-focus-indicator-outward-shrink;\n border-end-end-radius: calc(var(--_focus-indicator-shape-end-end) + var(--_focus-indicator-outward-offset));\n border-end-start-radius: calc(var(--_focus-indicator-shape-end-start) + var(--_focus-indicator-outward-offset));\n border-start-end-radius: calc(var(--_focus-indicator-shape-start-end) + var(--_focus-indicator-outward-offset));\n border-start-start-radius: calc(var(--_focus-indicator-shape-start-start) + var(--_focus-indicator-outward-offset));\n inset: calc(-1 * var(--_focus-indicator-outward-offset));\n outline: var(--_focus-indicator-width) solid currentColor;\n content: "";\n display: block;\n border-radius: inherit;\n }\n .forge-field:has(:where(input, textarea, select, .forge-field__input):focus) {\n --forge-focus-indicator-color: var(--forge-theme-primary, #3f51b5);\n --forge-focus-indicator-outward-offset: 0px;\n }\n}\n@layer textarea {\n .forge-field:has(textarea:only-child) {\n padding-inline: 0;\n }\n .forge-field:has(textarea:only-child) textarea {\n padding-inline: var(--_field-padding-inline);\n }\n .forge-field:has(textarea) {\n align-items: start;\n block-size: fit-content;\n }\n .forge-field:has(textarea) textarea {\n padding-block-start: calc((var(--_field-height) - var(--forge-typography-body2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-line-height-scale, 1.375)))) / 2);\n padding-block-end: calc(max(var(--forge-typography-body2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-line-height-scale, 1.375))), var(--forge-typography-label2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-line-height-scale, 1.25)))) / 2 + (var(--_field-height) - 56px) / 8 + (var(--_field-height) - var(--forge-typography-body2-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-line-height-scale, 1.375)))) / 2);\n resize: vertical;\n block-size: fit-content;\n }\n .forge-field:has(textarea) *:not(textarea) {\n margin-block-start: var(--forge-spacing-xsmall, 8px);\n }\n}\n@layer density {\n .forge-field--dense, .forge-field--extra-small {\n --_field-height: var(--forge-field-height, 24px);\n --_field-padding-inline-start: var(--forge-field-padding-inline-start, 8px);\n --_field-padding-inline-end: var(--forge-field-padding-inline-end, 4px);\n }\n .forge-field--dense:has(label) label, .forge-field--extra-small:has(label) label {\n display: none;\n }\n .forge-field--small {\n --_field-height: var(--forge-field-height, 32px);\n }\n .forge-field--small:has(label) {\n --_field-height: var(--forge-field-height, 40px);\n }\n .forge-field--large {\n --_field-height: var(--forge-field-height, 48px);\n }\n .forge-field--large:has(label) {\n --_field-height: var(--forge-field-height, 56px);\n }\n .forge-field--extra-large {\n --_field-height: var(--forge-field-height, 56px);\n }\n .forge-field--extra-large:has(label) {\n --_field-height: var(--forge-field-height, 64px);\n }\n}\n@layer disabled {\n .forge-field:has(:where(input, textarea, select, .forge-field__input):disabled) {\n --_field-background: var(--_field-disabled-background);\n --_field-disableable-cursor: var(--forge-field-disableable-cursor, not-allowed);\n --_field-disableable-opacity: var(--forge-field-disableable-opacity, var(--_field-disabled-opacity));\n }\n .forge-field:has(:where(input, textarea, select, .forge-field__input):disabled) :where(input, textarea, select, .forge-field__input):disabled {\n cursor: not-allowed;\n }\n}\n@layer invalid {\n .forge-field--invalid, .forge-field:has(:where(input, textarea, select, .forge-field__input):invalid) {\n outline-color: var(--forge-theme-error, #b00020);\n }\n .forge-field--invalid :not(:where(input, textarea, select, .forge-field__input)), .forge-field:has(:where(input, textarea, select, .forge-field__input):invalid) :not(:where(input, textarea, select, .forge-field__input)) {\n color: var(--forge-theme-on-error-container, #5f0011);\n }\n .forge-field--invalid.forge-field:has(:where(input, textarea, select, .forge-field__input):focus), .forge-field:has(:where(input, textarea, select, .forge-field__input):invalid).forge-field:has(:where(input, textarea, select, .forge-field__input):focus) {\n --forge-focus-indicator-color: var(--forge-theme-error, #b00020);\n --forge-focus-indicator-outward-offset: calc(var(--_field-outline-width) * -1);\n }\n .forge-field--invalid label, .forge-field:has(:where(input, textarea, select, .forge-field__input):invalid) label {\n color: var(--forge-theme-error, #b00020);\n }\n .forge-field--invalid.forge-field--tonal, .forge-field:has(:where(input, textarea, select, .forge-field__input):invalid).forge-field--tonal {\n background: var(--forge-theme-error-container-low, #f6e0e4);\n }\n .forge-field--invalid.forge-field--tonal:hover:not(:has(:where(input, textarea, select, .forge-field__input):disabled)), .forge-field:has(:where(input, textarea, select, .forge-field__input):invalid).forge-field--tonal:hover:not(:has(:where(input, textarea, select, .forge-field__input):disabled)) {\n background: var(--forge-theme-error-container-minimum, #fcf5f6);\n }\n}\n:host {\n display: inline-flex;\n align-items: center;\n max-width: 100%;\n min-width: 0;\n position: relative;\n}\n\n.title-text,\n.trigger-text {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-heading1-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-heading1-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-heading1-font-size-scale, 0.875)));\n font-weight: var(--forge-typography-heading1-font-weight, 500);\n line-height: var(--forge-typography-heading1-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-heading1-line-height-scale, 1.125)));\n letter-spacing: var(--forge-typography-heading1-letter-spacing, 0.0178571429em);\n text-transform: var(--forge-typography-heading1-text-transform, inherit);\n text-decoration: var(--forge-typography-heading1-text-decoration, inherit);\n font-weight: 500;\n color: var(--forge-theme-on-surface, #000000);\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n min-width: 0;\n}\n\n.title-text {\n display: block;\n}\n\n.trigger-button {\n --forge-state-layer-hover-opacity: 0.04;\n --forge-focus-indicator-outward-offset: 0px;\n}\n\n.dropdown-icon {\n flex-shrink: 0;\n width: 20px;\n height: 20px;\n fill: var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6));\n transition: transform 150ms ease;\n margin-inline-end: -6px;\n}\n:host(:state(open)) .dropdown-icon {\n transform: rotate(180deg);\n}\n\n.agent-list::-webkit-scrollbar {\n height: var(--forge-scrollbar-height, 16px);\n width: var(--forge-scrollbar-width, 16px);\n}\n.agent-list::-webkit-scrollbar-track {\n background-color: var(--forge-scrollbar-track-container, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.agent-list::-webkit-scrollbar-track:hover {\n background-color: var(--forge-scrollbar-track-container-hover, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.agent-list::-webkit-scrollbar-corner {\n background-color: var(--forge-scrollbar-track-container, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.agent-list::-webkit-scrollbar-thumb {\n height: var(--forge-scrollbar-thumb-min-height, 32px);\n width: var(--forge-scrollbar-thumb-min-width, 32px);\n border-radius: var(--forge-scrollbar-border-radius, calc(var(--forge-shape-full, 9999px) * var(--forge-shape-factor, 1)));\n border-width: var(--forge-scrollbar-border-width, 3px);\n border-style: solid;\n border-color: transparent;\n background-color: var(--forge-scrollbar-thumb-container, var(--forge-theme-surface-container-medium, #c2c2c2));\n background-clip: content-box;\n}\n.agent-list::-webkit-scrollbar-thumb:hover {\n background-color: var(--forge-scrollbar-thumb-container-hover, var(--forge-theme-surface-container-high, #9e9e9e));\n}\n.agent-list {\n min-width: 256px;\n max-width: 400px;\n max-height: 300px;\n overflow-y: auto;\n padding: var(--forge-spacing-xxsmall, 4px) 0 var(--forge-spacing-xxsmall, 4px);\n}\n\n.agent-item {\n --_list-item-background: var(--forge-list-item-background, transparent);\n --_list-item-shape: var(--forge-list-item-shape, 0);\n --_list-item-padding: var(--forge-list-item-padding, 0 var(--forge-spacing-medium, 16px));\n --_list-item-margin: var(--forge-list-item-margin, 0);\n --_list-item-height: var(--forge-list-item-height, 48px);\n --_list-item-dense-height: var(--forge-list-item-dense-height, 32px);\n --_list-item-indent: var(--forge-list-item-indent, var(--forge-spacing-xxlarge, 48px));\n --_list-item-cursor: var(--forge-list-item-cursor, pointer);\n --_list-item-gap: var(--forge-list-item-gap, var(--forge-spacing-large, 24px));\n --_list-item-text-color: var(--forge-list-item-text-color, var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6)));\n --_list-item-text-font-size: var(--forge-list-item-text-font-size, var(--forge-typography-body2-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-font-size-scale, 1))));\n --_list-item-text-font-weight: var(--forge-list-item-text-font-weight, var(--forge-typography-body2-font-weight, 400));\n --_list-item-text-line-height: var(--forge-list-item-text-line-height, 1.5rem);\n --_list-item-selected-color: var(--forge-list-item-selected-color, var(--forge-theme-primary, #3f51b5));\n --_list-item-selected-background: var(--forge-list-item-selected-background, var(--_list-item-selected-color));\n --_list-item-selected-opacity: var(--forge-list-item-selected-opacity, 0.08);\n --_list-item-selected-start-color: var(--forge-list-item-selected-start-color, var(--_list-item-selected-color));\n --_list-item-selected-end-color: var(--forge-list-item-selected-end-color, var(--_list-item-selected-color));\n --_list-item-selected-text-color: var(--forge-list-item-selected-text-color, var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6)));\n --_list-item-disabled-opacity: var(--forge-list-item-disabled-opacity, 0.38);\n --_list-item-disabled-cursor: var(--forge-list-item-disabled-cursor, not-allowed);\n --_list-item-one-line-height: var(--forge-list-item-one-line-height, var(--_list-item-height));\n --_list-item-two-line-height: var(--forge-list-item-two-line-height, var(--forge-list-item-height, 72px));\n --_list-item-three-line-height: var(--forge-list-item-three-line-height, var(--forge-list-item-height, 88px));\n --_list-item-dense-one-line-height: var(--forge-list-item-dense-one-line-height, var(--_list-item-dense-height));\n --_list-item-dense-two-line-height: var(--forge-list-item-dense-two-line-height, var(--forge-list-item-dense-height, 56px));\n --_list-item-dense-three-line-height: var(--forge-list-item-dense-three-line-height, var(--forge-list-item-dense-height, 72px));\n --_list-item-dense-font-size: var(--forge-list-item-dense-font-size, 0.875rem);\n --_list-item-dense-indent: var(--forge-list-item-dense-indent, var(--forge-spacing-xxlarge, 48px));\n --_list-item-dense-gap: var(--forge-list-item-dense-gap, var(--forge-spacing-xsmall, 8px));\n --_list-item-start-selected-color: var(--forge-list-item-start-selected-color, var(--_list-item-selected-color));\n --_list-item-end-selected-color: var(--forge-list-item-end-selected-color, var(--_list-item-selected-color));\n --_list-item-wrap-padding: var(--forge-list-item-wrap-padding, var(--forge-spacing-xsmall, 8px) var(--forge-spacing-medium, 16px));\n position: relative;\n display: flex;\n gap: var(--_list-item-gap);\n align-items: center;\n box-sizing: border-box;\n outline: none;\n text-decoration: none;\n border-radius: var(--_list-item-shape);\n -webkit-tap-highlight-color: transparent;\n background-color: var(--_list-item-background);\n height: var(--_list-item-height);\n min-height: var(--_list-item-height);\n padding: var(--_list-item-padding);\n margin: var(--_list-item-margin);\n --_list-item-gap: var(--_list-item-dense-gap);\n height: var(--_list-item-dense-one-line-height);\n min-height: var(--_list-item-dense-one-line-height);\n --_state-layer-display: var(--forge-state-layer-display, flex);\n --_state-layer-color: var(--forge-state-layer-color, var(--forge-theme-on-surface, #000000));\n --_state-layer-hover-color: var(--forge-state-layer-hover-color, var(--_state-layer-color));\n --_state-layer-hover-opacity: var(--forge-state-layer-hover-opacity, 0.08);\n --_state-layer-pressed-color: var(--forge-state-layer-pressed-color, var(--_state-layer-color));\n --_state-layer-pressed-opacity: var(--forge-state-layer-pressed-opacity, 0.12);\n --_state-layer-hover-duration: var(--forge-state-layer-hover-duration, 15ms);\n --_state-layer-pressed-duration: var(--forge-state-layer-pressed-duration, 105ms);\n --_state-layer-animation-duration: var(--forge-state-layer-animation-duration, 375ms);\n}\n.agent-item::before {\n opacity: 0;\n position: absolute;\n backface-visibility: hidden;\n transform: translateZ(0);\n background-color: var(--_state-layer-hover-color);\n inset: 0;\n transition: opacity var(--_state-layer-hover-duration) linear, background-color var(--_state-layer-hover-duration) linear;\n --_state-layer-hover-duration: var(--forge-state-layer-hover-duration, 100ms);\n content: "";\n opacity: 0;\n border-radius: inherit;\n}\n.agent-item:hover::before {\n background-color: var(--_state-layer-hover-color);\n opacity: var(--_state-layer-hover-opacity);\n}\n.agent-item:active::before {\n opacity: var(--_state-layer-pressed-opacity);\n transition-duration: var(--_state-layer-pressed-duration);\n --_state-layer-pressed-opacity: var(--forge-state-layer-pressed-opacity, 0.18);\n}\n.agent-item {\n --forge-list-item-padding: 0 var(--forge-spacing-xxsmall, 4px);\n cursor: pointer;\n}\n.agent-item:focus-visible {\n outline: 2px solid var(--forge-theme-primary, #3f51b5);\n outline-offset: -2px;\n}\n.agent-item--focused {\n background-color: var(--forge-theme-surface-container-low, #ebebeb);\n}\n.agent-item--selected {\n color: var(--_list-item-selected-color);\n}\n.agent-item--selected::before {\n content: "";\n position: absolute;\n inset: 0;\n border-radius: inherit;\n opacity: var(--_list-item-selected-opacity);\n background-color: var(--_list-item-selected-background);\n pointer-events: none;\n}\n.agent-item--selected {\n --forge-state-layer-color: var(--_list-item-selected-color);\n}\n.agent-item--selected .agent-name {\n font-weight: 500;\n}\n.agent-item__selection-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n width: var(--forge-spacing-medium, 16px);\n}\n\n.selection-icon {\n fill: currentColor;\n width: 16px;\n height: 16px;\n}\n\n.agent-list-separator {\n height: 1px;\n background-color: var(--forge-theme-outline, #e0e0e0);\n margin: var(--forge-spacing-xxsmall, 4px) 0;\n}\n\n.agent-name {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-body2-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n letter-spacing: var(--forge-typography-body2-letter-spacing, 0.015625em);\n text-transform: var(--forge-typography-body2-text-transform, inherit);\n text-decoration: var(--forge-typography-body2-text-decoration, inherit);\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n box-sizing: border-box;\n isolation: isolate;\n font-size: var(--_list-item-text-font-size);\n font-weight: var(--_list-item-text-font-weight);\n line-height: var(--_list-item-text-line-height);\n flex: 1;\n contain: layout;\n font-size: var(--_list-item-dense-font-size);\n}\n\n.dropdown-header {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-heading1-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-heading1-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-heading1-font-size-scale, 0.875)));\n font-weight: var(--forge-typography-heading1-font-weight, 500);\n line-height: var(--forge-typography-heading1-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-heading1-line-height-scale, 1.125)));\n letter-spacing: var(--forge-typography-heading1-letter-spacing, 0.0178571429em);\n text-transform: var(--forge-typography-heading1-text-transform, inherit);\n text-decoration: var(--forge-typography-heading1-text-decoration, inherit);\n padding: var(--forge-spacing-small, 12px) var(--forge-spacing-small, 12px) var(--forge-spacing-xxsmall, 4px);\n}\n\n.filter-field {\n padding: var(--forge-spacing-xsmall, 8px) var(--forge-spacing-small, 12px) var(--forge-spacing-small, 12px);\n border-bottom: 1px solid var(--forge-theme-outline, #e0e0e0);\n}\n\n.search-icon {\n width: 24px;\n height: 24px;\n fill: var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6));\n}\n\n.no-results {\n padding: var(--forge-spacing-small, 12px);\n color: var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6));\n text-align: center;\n}';
|
|
2
|
+
export {
|
|
3
|
+
styles as default
|
|
4
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { AiAgentSelectorComponent, AiAgentSelectorComponentTagName, type ForgeAiAgentSelectorChangeEventData } from './ai-agent-selector.js';
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { LitElement, TemplateResult, PropertyValues } from 'lit';
|
|
2
|
-
import { HeadingLevel } from '../ai-chatbot/types';
|
|
2
|
+
import { Agent, HeadingLevel } from '../ai-chatbot/types';
|
|
3
3
|
declare global {
|
|
4
4
|
interface HTMLElementTagNameMap {
|
|
5
5
|
'forge-ai-chat-header': AiChatHeaderComponent;
|
|
@@ -12,8 +12,13 @@ declare global {
|
|
|
12
12
|
'forge-ai-chat-header-minimize': CustomEvent<void>;
|
|
13
13
|
'forge-ai-chat-header-clear': CustomEvent<void>;
|
|
14
14
|
'forge-ai-chat-header-export': CustomEvent<void>;
|
|
15
|
+
'forge-ai-chat-header-agent-change': CustomEvent<ForgeAiChatHeaderAgentChangeEventData>;
|
|
15
16
|
}
|
|
16
17
|
}
|
|
18
|
+
export interface ForgeAiChatHeaderAgentChangeEventData {
|
|
19
|
+
agent: Agent | undefined;
|
|
20
|
+
previousAgentId: string | undefined;
|
|
21
|
+
}
|
|
17
22
|
export type MinimizeIconType = 'default' | 'panel';
|
|
18
23
|
export type OptionState = 'enabled' | 'off';
|
|
19
24
|
export interface AgentInfo {
|
|
@@ -87,6 +92,18 @@ export declare class AiChatHeaderComponent extends LitElement {
|
|
|
87
92
|
* The title text to display in the header
|
|
88
93
|
*/
|
|
89
94
|
titleText: string;
|
|
95
|
+
/**
|
|
96
|
+
* Array of available agents for the agent selector
|
|
97
|
+
*/
|
|
98
|
+
agents: Agent[];
|
|
99
|
+
/**
|
|
100
|
+
* ID of the currently selected agent
|
|
101
|
+
*/
|
|
102
|
+
selectedAgentId?: string;
|
|
103
|
+
/**
|
|
104
|
+
* Disables the agent selector (e.g., during streaming)
|
|
105
|
+
*/
|
|
106
|
+
disableAgentSelector: boolean;
|
|
90
107
|
private _isTitleOverflowing;
|
|
91
108
|
updated(changedProperties: PropertyValues<this>): void;
|
|
92
109
|
render(): TemplateResult;
|