@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.
Files changed (33) hide show
  1. package/custom-elements.json +1200 -935
  2. package/dist/ai-agent-selector/ai-agent-selector.d.ts +50 -0
  3. package/dist/ai-agent-selector/ai-agent-selector.mjs +439 -0
  4. package/dist/ai-agent-selector/ai-agent-selector.scss.mjs +4 -0
  5. package/dist/ai-agent-selector/index.d.ts +1 -0
  6. package/dist/ai-agent-selector/index.mjs +5 -0
  7. package/dist/ai-chat-header/ai-chat-header.d.ts +18 -1
  8. package/dist/ai-chat-header/ai-chat-header.mjs +41 -8
  9. package/dist/ai-chat-header/ai-chat-header.scss.mjs +1 -1
  10. package/dist/ai-chat-header/index.d.ts +1 -1
  11. package/dist/ai-chatbot/ag-ui-adapter.mjs +1 -1
  12. package/dist/ai-chatbot/agent-runner.mjs +1 -0
  13. package/dist/ai-chatbot/ai-chatbot-tool-call.mjs +5 -3
  14. package/dist/ai-chatbot/ai-chatbot-tool-call.scss.mjs +1 -1
  15. package/dist/ai-chatbot/ai-chatbot.d.ts +19 -1
  16. package/dist/ai-chatbot/ai-chatbot.mjs +69 -6
  17. package/dist/ai-chatbot/index.d.ts +2 -2
  18. package/dist/ai-chatbot/message-state-controller.d.ts +2 -1
  19. package/dist/ai-chatbot/message-state-controller.mjs +10 -1
  20. package/dist/ai-chatbot/types.d.ts +7 -0
  21. package/dist/ai-empty-state/ai-empty-state.scss.mjs +1 -1
  22. package/dist/ai-error-message/ai-error-message.scss.mjs +1 -1
  23. package/dist/ai-icon/ai-icon.scss.mjs +1 -1
  24. package/dist/ai-message-thread/ai-message-thread.mjs +1 -1
  25. package/dist/ai-message-thread/ai-message-thread.scss.mjs +1 -1
  26. package/dist/ai-modal/ai-modal.scss.mjs +1 -1
  27. package/dist/ai-suggestions/ai-suggestions.d.ts +1 -0
  28. package/dist/ai-suggestions/ai-suggestions.scss.mjs +1 -1
  29. package/dist/ai-user-message/ai-user-message.scss.mjs +1 -1
  30. package/dist/core/tooltip/tooltip.scss.mjs +1 -1
  31. package/dist/index.d.ts +1 -0
  32. package/dist/index.mjs +3 -0
  33. 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';
@@ -0,0 +1,5 @@
1
+ import { AiAgentSelectorComponent, AiAgentSelectorComponentTagName } from "./ai-agent-selector.mjs";
2
+ export {
3
+ AiAgentSelectorComponent,
4
+ AiAgentSelectorComponentTagName
5
+ };
@@ -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;