@tylertech/forge-ai 0.1.0

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 (200) hide show
  1. package/LICENSE +202 -0
  2. package/README.md +3 -0
  3. package/custom-elements.json +4963 -0
  4. package/dist/ai-actions-toolbar/ai-actions-toolbar.d.ts +25 -0
  5. package/dist/ai-actions-toolbar/ai-actions-toolbar.mjs +74 -0
  6. package/dist/ai-actions-toolbar/ai-actions-toolbar.scss.mjs +4 -0
  7. package/dist/ai-actions-toolbar/index.d.ts +1 -0
  8. package/dist/ai-actions-toolbar/index.mjs +5 -0
  9. package/dist/ai-artifact/ai-artifact.d.ts +20 -0
  10. package/dist/ai-artifact/ai-artifact.mjs +39 -0
  11. package/dist/ai-artifact/ai-artifact.scss.mjs +4 -0
  12. package/dist/ai-artifact/index.d.ts +1 -0
  13. package/dist/ai-artifact/index.mjs +5 -0
  14. package/dist/ai-button/ai-button.d.ts +21 -0
  15. package/dist/ai-button/ai-button.mjs +67 -0
  16. package/dist/ai-button/ai-button.scss.mjs +4 -0
  17. package/dist/ai-button/index.d.ts +1 -0
  18. package/dist/ai-button/index.mjs +5 -0
  19. package/dist/ai-chain-of-thought/ai-chain-of-thought.d.ts +17 -0
  20. package/dist/ai-chain-of-thought/ai-chain-of-thought.mjs +45 -0
  21. package/dist/ai-chain-of-thought/ai-chain-of-thought.scss.mjs +4 -0
  22. package/dist/ai-chain-of-thought/index.d.ts +5 -0
  23. package/dist/ai-chain-of-thought/index.mjs +17 -0
  24. package/dist/ai-chain-of-thought/thought-base/index.d.ts +1 -0
  25. package/dist/ai-chain-of-thought/thought-base/index.mjs +5 -0
  26. package/dist/ai-chain-of-thought/thought-base/thought-base.d.ts +20 -0
  27. package/dist/ai-chain-of-thought/thought-base/thought-base.mjs +43 -0
  28. package/dist/ai-chain-of-thought/thought-base/thought-base.scss.mjs +4 -0
  29. package/dist/ai-chain-of-thought/thought-detail/index.d.ts +1 -0
  30. package/dist/ai-chain-of-thought/thought-detail/index.mjs +5 -0
  31. package/dist/ai-chain-of-thought/thought-detail/thought-detail.d.ts +14 -0
  32. package/dist/ai-chain-of-thought/thought-detail/thought-detail.mjs +34 -0
  33. package/dist/ai-chain-of-thought/thought-detail/thought-detail.scss.mjs +4 -0
  34. package/dist/ai-chain-of-thought/thought-image/index.d.ts +1 -0
  35. package/dist/ai-chain-of-thought/thought-image/index.mjs +5 -0
  36. package/dist/ai-chain-of-thought/thought-image/thought-image.d.ts +16 -0
  37. package/dist/ai-chain-of-thought/thought-image/thought-image.mjs +43 -0
  38. package/dist/ai-chain-of-thought/thought-image/thought-image.scss.mjs +4 -0
  39. package/dist/ai-chain-of-thought/thought-search-result/index.d.ts +1 -0
  40. package/dist/ai-chain-of-thought/thought-search-result/index.mjs +5 -0
  41. package/dist/ai-chain-of-thought/thought-search-result/thought-search-result.d.ts +22 -0
  42. package/dist/ai-chain-of-thought/thought-search-result/thought-search-result.mjs +62 -0
  43. package/dist/ai-chain-of-thought/thought-search-result/thought-search-result.scss.mjs +4 -0
  44. package/dist/ai-chat-header/ai-chat-header.d.ts +54 -0
  45. package/dist/ai-chat-header/ai-chat-header.mjs +198 -0
  46. package/dist/ai-chat-header/ai-chat-header.scss.mjs +4 -0
  47. package/dist/ai-chat-header/index.d.ts +1 -0
  48. package/dist/ai-chat-header/index.mjs +5 -0
  49. package/dist/ai-chat-interface/ai-chat-interface.d.ts +38 -0
  50. package/dist/ai-chat-interface/ai-chat-interface.mjs +117 -0
  51. package/dist/ai-chat-interface/ai-chat-interface.scss.mjs +4 -0
  52. package/dist/ai-chat-interface/index.d.ts +1 -0
  53. package/dist/ai-chat-interface/index.mjs +5 -0
  54. package/dist/ai-dialog/ai-dialog.d.ts +56 -0
  55. package/dist/ai-dialog/ai-dialog.mjs +270 -0
  56. package/dist/ai-dialog/ai-dialog.scss.mjs +4 -0
  57. package/dist/ai-dialog/index.d.ts +1 -0
  58. package/dist/ai-dialog/index.mjs +5 -0
  59. package/dist/ai-dropdown-menu/ai-dropdown-menu-item-group.d.ts +26 -0
  60. package/dist/ai-dropdown-menu/ai-dropdown-menu-item-group.mjs +80 -0
  61. package/dist/ai-dropdown-menu/ai-dropdown-menu-item-group.scss.mjs +4 -0
  62. package/dist/ai-dropdown-menu/ai-dropdown-menu-item.d.ts +133 -0
  63. package/dist/ai-dropdown-menu/ai-dropdown-menu-item.mjs +335 -0
  64. package/dist/ai-dropdown-menu/ai-dropdown-menu-item.scss.mjs +4 -0
  65. package/dist/ai-dropdown-menu/ai-dropdown-menu-separator.d.ts +18 -0
  66. package/dist/ai-dropdown-menu/ai-dropdown-menu-separator.mjs +26 -0
  67. package/dist/ai-dropdown-menu/ai-dropdown-menu-separator.scss.mjs +4 -0
  68. package/dist/ai-dropdown-menu/ai-dropdown-menu.d.ts +143 -0
  69. package/dist/ai-dropdown-menu/ai-dropdown-menu.mjs +327 -0
  70. package/dist/ai-dropdown-menu/ai-dropdown-menu.scss.mjs +4 -0
  71. package/dist/ai-dropdown-menu/index.d.ts +4 -0
  72. package/dist/ai-dropdown-menu/index.mjs +10 -0
  73. package/dist/ai-dropdown-menu/navigation-controller.d.ts +79 -0
  74. package/dist/ai-dropdown-menu/navigation-controller.mjs +205 -0
  75. package/dist/ai-dropdown-menu/selection-manager.d.ts +145 -0
  76. package/dist/ai-dropdown-menu/selection-manager.mjs +183 -0
  77. package/dist/ai-embedded-chat/ai-embedded-chat.d.ts +47 -0
  78. package/dist/ai-embedded-chat/ai-embedded-chat.mjs +139 -0
  79. package/dist/ai-embedded-chat/ai-embedded-chat.scss.mjs +4 -0
  80. package/dist/ai-embedded-chat/index.d.ts +1 -0
  81. package/dist/ai-embedded-chat/index.mjs +5 -0
  82. package/dist/ai-empty-state/ai-empty-state.d.ts +19 -0
  83. package/dist/ai-empty-state/ai-empty-state.mjs +136 -0
  84. package/dist/ai-empty-state/ai-empty-state.scss.mjs +4 -0
  85. package/dist/ai-empty-state/index.d.ts +1 -0
  86. package/dist/ai-empty-state/index.mjs +5 -0
  87. package/dist/ai-fab/ai-fab.d.ts +23 -0
  88. package/dist/ai-fab/ai-fab.mjs +75 -0
  89. package/dist/ai-fab/ai-fab.scss.mjs +4 -0
  90. package/dist/ai-fab/index.d.ts +1 -0
  91. package/dist/ai-fab/index.mjs +5 -0
  92. package/dist/ai-file-picker/ai-file-picker.d.ts +77 -0
  93. package/dist/ai-file-picker/ai-file-picker.mjs +176 -0
  94. package/dist/ai-file-picker/ai-file-picker.scss.mjs +4 -0
  95. package/dist/ai-file-picker/index.d.ts +1 -0
  96. package/dist/ai-file-picker/index.mjs +4 -0
  97. package/dist/ai-floating-chat/ai-floating-chat.d.ts +65 -0
  98. package/dist/ai-floating-chat/ai-floating-chat.mjs +153 -0
  99. package/dist/ai-floating-chat/ai-floating-chat.scss.mjs +4 -0
  100. package/dist/ai-floating-chat/index.d.ts +1 -0
  101. package/dist/ai-floating-chat/index.mjs +5 -0
  102. package/dist/ai-gradient-container/ai-gradient-container.d.ts +26 -0
  103. package/dist/ai-gradient-container/ai-gradient-container.mjs +61 -0
  104. package/dist/ai-gradient-container/ai-gradient-container.scss.mjs +4 -0
  105. package/dist/ai-gradient-container/index.d.ts +1 -0
  106. package/dist/ai-gradient-container/index.mjs +5 -0
  107. package/dist/ai-icon/ai-icon.d.ts +22 -0
  108. package/dist/ai-icon/ai-icon.mjs +71 -0
  109. package/dist/ai-icon/ai-icon.scss.mjs +4 -0
  110. package/dist/ai-icon/index.d.ts +1 -0
  111. package/dist/ai-icon/index.mjs +5 -0
  112. package/dist/ai-modal/ai-modal.d.ts +49 -0
  113. package/dist/ai-modal/ai-modal.mjs +132 -0
  114. package/dist/ai-modal/ai-modal.scss.mjs +4 -0
  115. package/dist/ai-modal/index.d.ts +1 -0
  116. package/dist/ai-modal/index.mjs +4 -0
  117. package/dist/ai-prompt/ai-prompt.d.ts +42 -0
  118. package/dist/ai-prompt/ai-prompt.mjs +123 -0
  119. package/dist/ai-prompt/ai-prompt.scss.mjs +4 -0
  120. package/dist/ai-prompt/index.d.ts +1 -0
  121. package/dist/ai-prompt/index.mjs +5 -0
  122. package/dist/ai-prompt/prompt-button/index.d.ts +1 -0
  123. package/dist/ai-prompt/prompt-button/index.mjs +5 -0
  124. package/dist/ai-prompt/prompt-button/prompt-button.d.ts +16 -0
  125. package/dist/ai-prompt/prompt-button/prompt-button.mjs +40 -0
  126. package/dist/ai-prompt/prompt-button/prompt-button.scss.mjs +4 -0
  127. package/dist/ai-reasoning/ai-reasoning.d.ts +17 -0
  128. package/dist/ai-reasoning/ai-reasoning.mjs +44 -0
  129. package/dist/ai-reasoning/ai-reasoning.scss.mjs +4 -0
  130. package/dist/ai-reasoning/index.d.ts +2 -0
  131. package/dist/ai-reasoning/index.mjs +8 -0
  132. package/dist/ai-reasoning/reasoning-content/index.d.ts +1 -0
  133. package/dist/ai-reasoning/reasoning-content/index.mjs +5 -0
  134. package/dist/ai-reasoning/reasoning-content/reasoning-content.d.ts +22 -0
  135. package/dist/ai-reasoning/reasoning-content/reasoning-content.mjs +90 -0
  136. package/dist/ai-reasoning/reasoning-content/reasoning-content.scss.mjs +4 -0
  137. package/dist/ai-reasoning-header/ai-reasoning-header.d.ts +24 -0
  138. package/dist/ai-reasoning-header/ai-reasoning-header.mjs +68 -0
  139. package/dist/ai-reasoning-header/ai-reasoning-header.scss.mjs +4 -0
  140. package/dist/ai-reasoning-header/index.d.ts +1 -0
  141. package/dist/ai-reasoning-header/index.mjs +5 -0
  142. package/dist/ai-response-message/ai-response-message.d.ts +40 -0
  143. package/dist/ai-response-message/ai-response-message.mjs +137 -0
  144. package/dist/ai-response-message/ai-response-message.scss.mjs +4 -0
  145. package/dist/ai-response-message/index.d.ts +1 -0
  146. package/dist/ai-response-message/index.mjs +5 -0
  147. package/dist/ai-sidebar/ai-sidebar.d.ts +44 -0
  148. package/dist/ai-sidebar/ai-sidebar.mjs +105 -0
  149. package/dist/ai-sidebar/ai-sidebar.scss.mjs +4 -0
  150. package/dist/ai-sidebar/index.d.ts +1 -0
  151. package/dist/ai-sidebar/index.mjs +5 -0
  152. package/dist/ai-sidebar-chat/ai-sidebar-chat.d.ts +64 -0
  153. package/dist/ai-sidebar-chat/ai-sidebar-chat.mjs +170 -0
  154. package/dist/ai-sidebar-chat/ai-sidebar-chat.scss.mjs +4 -0
  155. package/dist/ai-sidebar-chat/index.d.ts +1 -0
  156. package/dist/ai-sidebar-chat/index.mjs +5 -0
  157. package/dist/ai-suggestions/ai-suggestions.d.ts +39 -0
  158. package/dist/ai-suggestions/ai-suggestions.mjs +96 -0
  159. package/dist/ai-suggestions/ai-suggestions.scss.mjs +4 -0
  160. package/dist/ai-suggestions/index.d.ts +1 -0
  161. package/dist/ai-suggestions/index.mjs +5 -0
  162. package/dist/ai-threads/ai-threads.d.ts +48 -0
  163. package/dist/ai-threads/ai-threads.mjs +203 -0
  164. package/dist/ai-threads/ai-threads.scss.mjs +4 -0
  165. package/dist/ai-threads/index.d.ts +1 -0
  166. package/dist/ai-threads/index.mjs +5 -0
  167. package/dist/ai-user-message/ai-user-message.d.ts +15 -0
  168. package/dist/ai-user-message/ai-user-message.mjs +43 -0
  169. package/dist/ai-user-message/ai-user-message.scss.mjs +4 -0
  170. package/dist/ai-user-message/index.d.ts +1 -0
  171. package/dist/ai-user-message/index.mjs +5 -0
  172. package/dist/ai-voice-input/ai-voice-input.d.ts +68 -0
  173. package/dist/ai-voice-input/ai-voice-input.mjs +107 -0
  174. package/dist/ai-voice-input/ai-voice-input.scss.mjs +4 -0
  175. package/dist/ai-voice-input/index.d.ts +1 -0
  176. package/dist/ai-voice-input/index.mjs +5 -0
  177. package/dist/core/drag-controller.d.ts +66 -0
  178. package/dist/core/drag-controller.mjs +219 -0
  179. package/dist/core/index.d.ts +1 -0
  180. package/dist/core/index.mjs +4 -0
  181. package/dist/core/overlay/index.d.ts +1 -0
  182. package/dist/core/overlay/index.mjs +4 -0
  183. package/dist/core/overlay/overlay.d.ts +61 -0
  184. package/dist/core/overlay/overlay.mjs +142 -0
  185. package/dist/core/overlay/overlay.scss.mjs +4 -0
  186. package/dist/core/popover/index.d.ts +1 -0
  187. package/dist/core/popover/index.mjs +4 -0
  188. package/dist/core/popover/popover.d.ts +56 -0
  189. package/dist/core/popover/popover.mjs +71 -0
  190. package/dist/core/popover/popover.scss.mjs +4 -0
  191. package/dist/core/tooltip/index.d.ts +1 -0
  192. package/dist/core/tooltip/index.mjs +4 -0
  193. package/dist/core/tooltip/tooltip.d.ts +91 -0
  194. package/dist/core/tooltip/tooltip.mjs +243 -0
  195. package/dist/core/tooltip/tooltip.scss.mjs +4 -0
  196. package/dist/index.d.ts +27 -0
  197. package/dist/index.mjs +98 -0
  198. package/dist/utils.d.ts +14 -0
  199. package/dist/utils.mjs +22 -0
  200. package/package.json +122 -0
@@ -0,0 +1,71 @@
1
+ import { unsafeCSS, LitElement, html } from "lit";
2
+ import { property, customElement } from "lit/decorators.js";
3
+ import { when } from "lit/directives/when.js";
4
+ import { toggleState } from "../utils.mjs";
5
+ import "../ai-gradient-container/ai-gradient-container.mjs";
6
+ import styles from "./ai-icon.scss.mjs";
7
+ var __defProp = Object.defineProperty;
8
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
9
+ var __typeError = (msg) => {
10
+ throw TypeError(msg);
11
+ };
12
+ var __decorateClass = (decorators, target, key, kind) => {
13
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
14
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
15
+ if (decorator = decorators[i])
16
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
17
+ if (kind && result) __defProp(target, key, result);
18
+ return result;
19
+ };
20
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
21
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
22
+ 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);
23
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), member.set(obj, value), value);
24
+ var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
25
+ var _internals, _svg, _AiIconComponent_instances, setCssState_fn;
26
+ const AiIconComponentTagName = "forge-ai-icon";
27
+ let AiIconComponent = class extends LitElement {
28
+ constructor() {
29
+ super();
30
+ __privateAdd(this, _AiIconComponent_instances);
31
+ this.outline = false;
32
+ __privateAdd(this, _internals);
33
+ __privateAdd(this, _svg, html`
34
+ <svg width="24" height="24" viewBox="-2 -2 24 24" xmlns="http://www.w3.org/2000/svg">
35
+ <path
36
+ d="M9.375 10.625L15 12.5L9.375 14.375L7.5 20L5.625 14.375L0 12.5L5.625 10.625L7.5 5L9.375 10.625ZM16.25 3.75L20 5L16.25 6.25L15 10L13.75 6.25L10 5L13.75 3.75L15 0L16.25 3.75Z" />
37
+ </svg>
38
+ `);
39
+ __privateSet(this, _internals, this.attachInternals());
40
+ __privateMethod(this, _AiIconComponent_instances, setCssState_fn).call(this);
41
+ }
42
+ willUpdate(changedProperties) {
43
+ if (changedProperties.has("outline")) {
44
+ __privateMethod(this, _AiIconComponent_instances, setCssState_fn).call(this);
45
+ }
46
+ }
47
+ render() {
48
+ return when(
49
+ this.outline,
50
+ () => html`<forge-ai-gradient-container variant="high">${__privateGet(this, _svg)}</forge-ai-gradient-container>`,
51
+ () => __privateGet(this, _svg)
52
+ );
53
+ }
54
+ };
55
+ _internals = /* @__PURE__ */ new WeakMap();
56
+ _svg = /* @__PURE__ */ new WeakMap();
57
+ _AiIconComponent_instances = /* @__PURE__ */ new WeakSet();
58
+ setCssState_fn = function() {
59
+ toggleState(__privateGet(this, _internals), "outline", this.outline);
60
+ };
61
+ AiIconComponent.styles = unsafeCSS(styles);
62
+ __decorateClass([
63
+ property({ type: Boolean })
64
+ ], AiIconComponent.prototype, "outline", 2);
65
+ AiIconComponent = __decorateClass([
66
+ customElement(AiIconComponentTagName)
67
+ ], AiIconComponent);
68
+ export {
69
+ AiIconComponent,
70
+ AiIconComponentTagName
71
+ };
@@ -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:host {\n --forge-ai-icon-fill-color: var(--forge-theme-tertiary, #3d5afe);\n box-sizing: border-box;\n display: grid;\n place-items: center;\n height: 36px;\n width: 36px;\n}\n\nforge-ai-gradient-container {\n display: grid;\n place-items: center;\n height: 36px;\n width: 36px;\n}\n\nsvg {\n fill: var(--forge-ai-icon-fill-color);\n height: 24px;\n width: 24px;\n}\n\n:host(:state(outline)) forge-ai-gradient-container {\n --forge-gradient-container-radius: 100%;\n}";
2
+ export {
3
+ styles as default
4
+ };
@@ -0,0 +1 @@
1
+ export * from './ai-icon';
@@ -0,0 +1,5 @@
1
+ import { AiIconComponent, AiIconComponentTagName } from "./ai-icon.mjs";
2
+ export {
3
+ AiIconComponent,
4
+ AiIconComponentTagName
5
+ };
@@ -0,0 +1,49 @@
1
+ import { LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ declare global {
3
+ interface HTMLElementTagNameMap {
4
+ 'forge-ai-modal': AiModalComponent;
5
+ }
6
+ interface HTMLElementEventMap {
7
+ 'forge-ai-modal-open': CustomEvent<void>;
8
+ 'forge-ai-modal-close': CustomEvent<void>;
9
+ 'forge-ai-modal-fullscreen-change': CustomEvent<{
10
+ isFullscreen: boolean;
11
+ }>;
12
+ }
13
+ }
14
+ /**
15
+ * @tag forge-ai-modal
16
+ *
17
+ * @slot - Default slot for modal content
18
+ *
19
+ * @event {CustomEvent<void>} forge-ai-modal-open - Fired when the modal is opened
20
+ * @event {CustomEvent<void>} forge-ai-modal-close - Fired when the modal is closed
21
+ * @event {CustomEvent<{ isFullscreen: boolean }>} forge-ai-modal-fullscreen-change - Fired when the fullscreen state changes
22
+ */
23
+ export declare class AiModalComponent extends LitElement {
24
+ #private;
25
+ static readonly styles: import('lit').CSSResult;
26
+ private _dialog;
27
+ /**
28
+ * Controls whether the modal is open or closed.
29
+ */
30
+ open: boolean;
31
+ /**
32
+ * Controls whether the modal is displayed in fullscreen mode.
33
+ * When not explicitly set, this will be automatically determined based on viewport size.
34
+ */
35
+ fullscreen?: boolean;
36
+ private _autoFullscreen;
37
+ render(): TemplateResult;
38
+ connectedCallback(): void;
39
+ disconnectedCallback(): void;
40
+ updated(changedProperties: PropertyValues<this>): void;
41
+ /**
42
+ * Shows the modal dialog.
43
+ */
44
+ show(): void;
45
+ /**
46
+ * Closes the modal dialog.
47
+ */
48
+ close(): void;
49
+ }
@@ -0,0 +1,132 @@
1
+ import { unsafeCSS, LitElement, html } from "lit";
2
+ import { query, property, state, customElement } from "lit/decorators.js";
3
+ import { classMap } from "lit/directives/class-map.js";
4
+ import styles from "./ai-modal.scss.mjs";
5
+ var __defProp = Object.defineProperty;
6
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
+ var __typeError = (msg) => {
8
+ throw TypeError(msg);
9
+ };
10
+ var __decorateClass = (decorators, target, key, kind) => {
11
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
12
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
13
+ if (decorator = decorators[i])
14
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
15
+ if (kind && result) __defProp(target, key, result);
16
+ return result;
17
+ };
18
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
19
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
20
+ 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);
21
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), member.set(obj, value), value);
22
+ var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
23
+ var _mediaQuery, _AiModalComponent_instances, handleDialogClose_fn, handleDialogClick_fn, setupMediaQuery_fn, cleanupMediaQuery_fn, _handleMediaChange;
24
+ const FULLSCREEN_WIDTH_THRESHOLD = 768;
25
+ let AiModalComponent = class extends LitElement {
26
+ constructor() {
27
+ super(...arguments);
28
+ __privateAdd(this, _AiModalComponent_instances);
29
+ this.open = false;
30
+ this._autoFullscreen = window.innerWidth <= FULLSCREEN_WIDTH_THRESHOLD;
31
+ __privateAdd(this, _mediaQuery);
32
+ __privateAdd(this, _handleMediaChange, (e) => {
33
+ const previousFullscreen = this._autoFullscreen;
34
+ this._autoFullscreen = e.matches;
35
+ if (this.fullscreen === void 0 && previousFullscreen !== this._autoFullscreen) {
36
+ const event = new CustomEvent("forge-ai-modal-fullscreen-change", {
37
+ bubbles: true,
38
+ composed: true,
39
+ detail: { isFullscreen: this._autoFullscreen }
40
+ });
41
+ this.dispatchEvent(event);
42
+ }
43
+ });
44
+ }
45
+ render() {
46
+ const isFullscreen = this.fullscreen ?? this._autoFullscreen;
47
+ const classes = {
48
+ "forge-dialog": true,
49
+ "forge-dialog--fullscreen": isFullscreen
50
+ };
51
+ return html`
52
+ <dialog
53
+ class=${classMap(classes)}
54
+ aria-labelledby="chat-interface-title"
55
+ @close=${__privateMethod(this, _AiModalComponent_instances, handleDialogClose_fn)}
56
+ @click=${__privateMethod(this, _AiModalComponent_instances, handleDialogClick_fn)}>
57
+ <slot></slot>
58
+ </dialog>
59
+ `;
60
+ }
61
+ connectedCallback() {
62
+ super.connectedCallback();
63
+ __privateMethod(this, _AiModalComponent_instances, setupMediaQuery_fn).call(this);
64
+ }
65
+ disconnectedCallback() {
66
+ super.disconnectedCallback();
67
+ __privateMethod(this, _AiModalComponent_instances, cleanupMediaQuery_fn).call(this);
68
+ }
69
+ updated(changedProperties) {
70
+ if (changedProperties.has("open")) {
71
+ if (this.open) {
72
+ this._dialog?.showModal();
73
+ this.dispatchEvent(new CustomEvent("forge-ai-modal-open", { bubbles: true, composed: true }));
74
+ } else {
75
+ this._dialog?.close();
76
+ window.setTimeout(() => {
77
+ this.dispatchEvent(new CustomEvent("forge-ai-modal-close", { bubbles: true, composed: true }));
78
+ }, 100);
79
+ }
80
+ }
81
+ }
82
+ /**
83
+ * Shows the modal dialog.
84
+ */
85
+ show() {
86
+ this.open = true;
87
+ }
88
+ /**
89
+ * Closes the modal dialog.
90
+ */
91
+ close() {
92
+ this.open = false;
93
+ }
94
+ };
95
+ _mediaQuery = /* @__PURE__ */ new WeakMap();
96
+ _AiModalComponent_instances = /* @__PURE__ */ new WeakSet();
97
+ handleDialogClose_fn = function() {
98
+ this.open = false;
99
+ };
100
+ handleDialogClick_fn = function(event) {
101
+ if (event.target === this._dialog) {
102
+ this.close();
103
+ }
104
+ };
105
+ setupMediaQuery_fn = function() {
106
+ __privateSet(this, _mediaQuery, window.matchMedia(`(max-width: ${FULLSCREEN_WIDTH_THRESHOLD}px)`));
107
+ __privateGet(this, _mediaQuery).addEventListener("change", __privateGet(this, _handleMediaChange));
108
+ __privateGet(this, _handleMediaChange).call(this, __privateGet(this, _mediaQuery));
109
+ };
110
+ cleanupMediaQuery_fn = function() {
111
+ __privateGet(this, _mediaQuery)?.removeEventListener("change", __privateGet(this, _handleMediaChange));
112
+ };
113
+ _handleMediaChange = /* @__PURE__ */ new WeakMap();
114
+ AiModalComponent.styles = unsafeCSS(styles);
115
+ __decorateClass([
116
+ query("dialog")
117
+ ], AiModalComponent.prototype, "_dialog", 2);
118
+ __decorateClass([
119
+ property({ type: Boolean })
120
+ ], AiModalComponent.prototype, "open", 2);
121
+ __decorateClass([
122
+ property({ type: Boolean })
123
+ ], AiModalComponent.prototype, "fullscreen", 2);
124
+ __decorateClass([
125
+ state()
126
+ ], AiModalComponent.prototype, "_autoFullscreen", 2);
127
+ AiModalComponent = __decorateClass([
128
+ customElement("forge-ai-modal")
129
+ ], AiModalComponent);
130
+ export {
131
+ AiModalComponent
132
+ };
@@ -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@keyframes forge-dialog-zoom-in {\n from {\n opacity: var(--_dialog-zoom-opacity);\n scale: var(--_dialog-zoom-scale);\n }\n to {\n opacity: 1;\n scale: 1;\n }\n}\n@keyframes forge-dialog-zoom-out {\n from {\n opacity: 1;\n scale: 1;\n }\n to {\n opacity: var(--_dialog-zoom-opacity);\n scale: var(--_dialog-zoom-scale);\n }\n}\n@keyframes forge-dialog-fade-in {\n from {\n opacity: var(--_dialog-fade-opacity);\n }\n to {\n opacity: 1;\n }\n}\n@keyframes forge-dialog-fade-out {\n from {\n opacity: 1;\n }\n to {\n opacity: var(--_dialog-fade-opacity);\n }\n}\n@keyframes forge-dialog-slide-in {\n from {\n opacity: var(--_dialog-slide-opacity);\n translate: var(--_dialog-slide-translate);\n }\n to {\n opacity: 1;\n translate: 0 0;\n }\n}\n@keyframes forge-dialog-slide-out {\n from {\n opacity: 1;\n translate: 0 0;\n }\n to {\n opacity: var(--_dialog-slide-opacity);\n translate: var(--_dialog-slide-translate);\n }\n}\n.forge-dialog {\n --_dialog-background: var(--forge-dialog-background, var(--forge-theme-surface-bright, #ffffff));\n --_dialog-shape: var(--forge-dialog-shape, calc(var(--forge-shape-medium, 4px) * var(--forge-shape-factor, 1)));\n --_dialog-elevation: var(--forge-dialog-elevation, 0px 11px 15px -7px rgba(0, 0, 0, 0.2), 0px 24px 38px 3px rgba(0, 0, 0, 0.14), 0px 9px 46px 8px rgba(0, 0, 0, 0.12));\n --_dialog-spacing: var(--forge-dialog-spacing, auto);\n --_dialog-block-start-spacing: var(--forge-dialog-block-start-spacing, var(--_dialog-spacing));\n --_dialog-block-end-spacing: var(--forge-dialog-block-end-spacing, var(--_dialog-spacing));\n --_dialog-inline-start-spacing: var(--forge-dialog-inline-start-spacing, var(--_dialog-spacing));\n --_dialog-inline-end-spacing: var(--forge-dialog-inline-end-spacing, var(--_dialog-spacing));\n --_dialog-padding: var(--forge-dialog-padding, 0);\n --_dialog-width: var(--forge-dialog-width, fit-content);\n --_dialog-height: var(--forge-dialog-height, fit-content);\n --_dialog-min-width: var(--forge-dialog-min-width, 0);\n --_dialog-max-width: var(--forge-dialog-max-width, calc(100% - var(--forge-spacing-xxlarge, 48px)));\n --_dialog-min-height: var(--forge-dialog-min-height, 0);\n --_dialog-max-height: var(--forge-dialog-max-height, calc(100% - var(--forge-spacing-xxlarge, 48px)));\n --_dialog-z-index: var(--forge-dialog-z-index, var(--forge-z-index-dialog, 8));\n --_dialog-move-handle-color: var(--forge-dialog-move-handle-color, currentColor);\n --_dialog-move-handle-size: var(--forge-dialog-move-handle-size, 24px);\n --_dialog-move-handle-hover-cursor: var(--forge-dialog-move-handle-hover-cursor, grab);\n --_dialog-move-handle-active-cursor: var(--forge-dialog-move-handle-active-cursor, grabbing);\n --_dialog-move-handle-spacing: var(--forge-dialog-move-handle-spacing, calc(var(--forge-spacing-xxsmall, 4px) * -1) 0 0);\n --_dialog-move-transition-duration: var(--forge-dialog-move-transition-duration, var(--forge-animation-duration-short4, 200ms));\n --_dialog-move-transition-easing: var(--forge-dialog-move-transition-easing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n --_dialog-moving-opacity: var(--forge-dialog-moving-opacity, 0.54);\n --_dialog-enter-animation-duration: var(--forge-dialog-enter-animation-duration, var(--forge-animation-duration-medium1, 250ms));\n --_dialog-enter-animation-easing: var(--forge-dialog-enter-animation-easing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n --_dialog-exit-animation-duration: var(--forge-dialog-exit-animation-duration, var(--forge-animation-duration-short2, 100ms));\n --_dialog-exit-animation-easing: var(--forge-dialog-exit-animation-easing, var(--forge-animation-easing-emphasized-accelerate, cubic-bezier(0.3, 0, 0.8, 0.15)));\n --_dialog-zoom-opacity: var(--forge-dialog-zoom-opacity, 0);\n --_dialog-zoom-scale: var(--forge-dialog-zoom-scale, 0.8);\n --_dialog-fade-opacity: var(--forge-dialog-fade-opacity, 0);\n --_dialog-slide-opacity: var(--forge-dialog-slide-opacity, 0);\n --_dialog-slide-translate: var(--forge-dialog-slide-translate, 0 -30%);\n --_dialog-backdrop-opacity: var(--forge-dialog-backdrop-opacity, var(--forge-backdrop-opacity, 0.54));\n --_dialog-nonmodal-elevation: var(--forge-dialog-nonmodal-elevation, 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 --_dialog-fullscreen-enter-animation-duration: var(--forge-dialog-fullscreen-enter-animation-duration, var(--forge-animation-duration-medium1, 250ms));\n --_dialog-fullscreen-exit-animation-duration: var(--forge-dialog-fullscreen-exit-animation-duration, var(--forge-animation-duration-short2, 100ms));\n --_dialog-position-x: var(--forge-dialog-position-x, 0);\n --_dialog-position-y: var(--forge-dialog-position-y, 0);\n --_dialog-preset-sheet-enter-animation-duration: var(--forge-dialog-preset-sheet-enter-animation-duration, var(--forge-animation-duration-medium1, 250ms));\n --_dialog-preset-sheet-exit-animation-duration: var(--forge-dialog-preset-sheet-exit-animation-duration, var(--forge-animation-duration-short3, 150ms));\n --_backdrop-background: var(--forge-backdrop-background, #000);\n --_backdrop-opacity: var(--forge-backdrop-opacity, 0.54);\n --_backdrop-z-index: var(--forge-backdrop-z-index, var(--forge-z-index-backdrop, 7));\n --_backdrop-enter-animation-duration: var(--forge-backdrop-enter-animation-duration, var(--forge-animation-duration-short4, 200ms));\n --_backdrop-enter-animation-easing: var(--forge-backdrop-enter-animation-easing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n --_backdrop-exit-animation-duration: var(--forge-backdrop-exit-animation-duration, var(--forge-animation-duration-short1, 50ms));\n --_backdrop-exit-animation-easing: var(--forge-backdrop-exit-animation-easing, var(--forge-animation-easing-emphasized-accelerate, cubic-bezier(0.3, 0, 0.8, 0.15)));\n --forge-theme-surface: var(--forge-theme-surface-bright, #ffffff);\n}\n\n.forge-dialog {\n position: fixed;\n inset: 0;\n z-index: var(--_dialog-z-index);\n background-color: transparent;\n color: inherit;\n border: none;\n width: auto;\n height: auto;\n padding: 0;\n margin: 0;\n overflow: visible;\n max-width: 100%;\n max-height: 100%;\n box-sizing: border-box;\n position: absolute;\n inset: 0;\n display: flex;\n background: var(--_dialog-background);\n box-shadow: var(--_dialog-elevation);\n z-index: var(--_dialog-z-index);\n overflow: hidden;\n border-radius: var(--_dialog-shape);\n margin-block-start: var(--_dialog-block-start-spacing);\n margin-block-end: var(--_dialog-block-end-spacing);\n margin-inline-start: var(--_dialog-inline-start-spacing);\n margin-inline-end: var(--_dialog-inline-end-spacing);\n padding: var(--_dialog-padding);\n width: var(--_dialog-width);\n height: var(--_dialog-height);\n min-width: var(--_dialog-min-width);\n max-width: var(--_dialog-max-width);\n min-height: var(--_dialog-min-height);\n max-height: var(--_dialog-max-height);\n box-sizing: border-box;\n animation-duration: var(--_dialog-exit-animation-duration);\n animation-timing-function: var(--_dialog-exit-animation-easing);\n position: fixed;\n transition-property: display, opacity, overlay, scale;\n transition-behavior: allow-discrete;\n}\n\n.forge-dialog > forge-scaffold {\n height: auto;\n}\n\n.forge-dialog--fullscreen {\n --_dialog-enter-animation-duration: var(--_dialog-fullscreen-enter-animation-duration);\n --_dialog-exit-animation-duration: var(--_dialog-fullscreen-exit-animation-duration);\n height: 100%;\n width: 100%;\n max-width: none;\n max-height: none;\n border-radius: 0;\n box-shadow: none;\n}\n\n.forge-dialog:not(:modal) {\n --_dialog-elevation: var(--_dialog-nonmodal-elevation);\n pointer-events: all;\n}\n\n.forge-dialog--moveable {\n user-select: none;\n transition-property: opacity;\n transition-duration: var(--_dialog-move-transition-duration);\n transition-timing-function: var(--_dialog-move-transition-easing);\n}\n\n.forge-dialog--moved {\n margin: 0;\n}\n\n.forge-dialog--moving {\n opacity: var(--_dialog-moving-opacity);\n}\n\n.forge-dialog__move-handle {\n fill: var(--_dialog-move-handle-color);\n height: var(--_dialog-move-handle-size);\n width: var(--_dialog-move-handle-size);\n margin: var(--_dialog-move-handle-spacing);\n touch-action: none;\n}\n\n.forge-dialog__move-handle:hover {\n cursor: var(--_dialog-move-handle-hover-cursor);\n}\n\n.forge-dialog__move-handle:active {\n cursor: var(--_dialog-move-handle-active-cursor);\n}\n\n.forge-dialog__move-handle-container {\n position: absolute;\n top: 0;\n z-index: 1;\n display: flex;\n justify-content: center;\n width: 100%;\n}\n\n.forge-dialog--top {\n --_dialog-block-start-spacing: var(--forge-dialog-block-start-spacing, 0);\n top: 0;\n bottom: auto;\n}\n\n.forge-dialog--top-right {\n --_dialog-spacing: var(--forge-dialog-spacing, 0);\n top: 0;\n left: auto;\n right: 0;\n bottom: auto;\n}\n\n.forge-dialog--top-left {\n --_dialog-spacing: var(--forge-dialog-spacing, 0);\n top: 0;\n left: 0;\n right: auto;\n bottom: auto;\n}\n\n.forge-dialog--bottom {\n --_dialog-block-end-spacing: var(--forge-dialog-block-end-spacing, 0);\n top: auto;\n bottom: 0;\n}\n\n.forge-dialog--bottom-right {\n --_dialog-spacing: var(--forge-dialog-spacing, 0);\n top: auto;\n left: auto;\n right: 0;\n bottom: 0;\n}\n\n.forge-dialog--bottom-left {\n --_dialog-spacing: var(--forge-dialog-spacing, 0);\n top: auto;\n left: 0;\n right: auto;\n bottom: 0;\n}\n\n.forge-dialog--right {\n --_dialog-spacing: var(--forge-dialog-spacing, 0);\n top: auto;\n left: auto;\n right: 0;\n bottom: auto;\n}\n\n.forge-dialog--left {\n --_dialog-spacing: var(--forge-dialog-spacing, 0);\n top: auto;\n left: 0;\n right: auto;\n bottom: auto;\n}\n\n.forge-dialog--custom {\n margin: 0;\n top: var(--_dialog-position-x);\n left: var(--_dialog-position-y);\n}\n\n.forge-dialog--bottom-sheet {\n --_dialog-enter-animation-duration: var(--_dialog-preset-sheet-enter-animation-duration);\n --_dialog-exit-animation-duration: var(--_dialog-preset-sheet-exit-animation-duration);\n --_dialog-max-width: var(--forge-dialog-max-width, none);\n --_dialog-max-height: var(--forge-dialog-max-height, none);\n inset: auto;\n display: inline-flex;\n bottom: 0;\n left: 0;\n right: 0;\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n --_dialog-slide-translate: var(--forge-dialog-slide-translate, 0 100%);\n}\n\n.forge-dialog--bottom-sheet.forge-dialog {\n transition-property: display, opacity, overlay, translate;\n}\n\n.forge-dialog--bottom-sheet.forge-dialog[open] {\n translate: 0 0;\n}\n\n@starting-style {\n .forge-dialog--bottom-sheet.forge-dialog[open] {\n opacity: var(--_dialog-slide-opacity);\n translate: var(--_dialog-slide-translate);\n }\n}\n.forge-dialog--bottom-sheet.forge-dialog:not([open]) {\n opacity: var(--_dialog-slide-opacity);\n scale: 1;\n translate: var(--_dialog-slide-translate);\n}\n\n.forge-dialog--left-sheet {\n --_dialog-enter-animation-duration: var(--_dialog-preset-sheet-enter-animation-duration);\n --_dialog-exit-animation-duration: var(--_dialog-preset-sheet-exit-animation-duration);\n --_dialog-max-width: var(--forge-dialog-max-width, none);\n --_dialog-max-height: var(--forge-dialog-max-height, none);\n inset: auto;\n display: inline-flex;\n left: 0;\n bottom: 0;\n top: 0;\n height: 100%;\n border-top-left-radius: 0;\n border-bottom-left-radius: 0;\n --_dialog-slide-translate: var(--forge-dialog-slide-translate, -100% 0);\n}\n\n.forge-dialog--left-sheet.forge-dialog {\n transition-property: display, opacity, overlay, translate;\n}\n\n.forge-dialog--left-sheet.forge-dialog[open] {\n translate: 0 0;\n}\n\n@starting-style {\n .forge-dialog--left-sheet.forge-dialog[open] {\n opacity: var(--_dialog-slide-opacity);\n translate: var(--_dialog-slide-translate);\n }\n}\n.forge-dialog--left-sheet.forge-dialog:not([open]) {\n opacity: var(--_dialog-slide-opacity);\n scale: 1;\n translate: var(--_dialog-slide-translate);\n}\n\n.forge-dialog--right-sheet {\n --_dialog-enter-animation-duration: var(--_dialog-preset-sheet-enter-animation-duration);\n --_dialog-exit-animation-duration: var(--_dialog-preset-sheet-exit-animation-duration);\n --_dialog-max-width: var(--forge-dialog-max-width, none);\n --_dialog-max-height: var(--forge-dialog-max-height, none);\n inset: auto;\n display: inline-flex;\n right: 0;\n bottom: 0;\n top: 0;\n height: 100%;\n border-top-right-radius: 0;\n border-bottom-right-radius: 0;\n --_dialog-slide-translate: var(--forge-dialog-slide-translate, 100% 0);\n}\n\n.forge-dialog--right-sheet.forge-dialog {\n transition-property: display, opacity, overlay, translate;\n}\n\n.forge-dialog--right-sheet.forge-dialog[open] {\n translate: 0 0;\n}\n\n@starting-style {\n .forge-dialog--right-sheet.forge-dialog[open] {\n opacity: var(--_dialog-slide-opacity);\n translate: var(--_dialog-slide-translate);\n }\n}\n.forge-dialog--right-sheet.forge-dialog:not([open]) {\n opacity: var(--_dialog-slide-opacity);\n scale: 1;\n translate: var(--_dialog-slide-translate);\n}\n\n.forge-dialog--top-sheet {\n --_dialog-enter-animation-duration: var(--_dialog-preset-sheet-enter-animation-duration);\n --_dialog-exit-animation-duration: var(--_dialog-preset-sheet-exit-animation-duration);\n --_dialog-max-width: var(--forge-dialog-max-width, none);\n --_dialog-max-height: var(--forge-dialog-max-height, none);\n inset: auto;\n display: inline-flex;\n top: 0;\n left: 0;\n right: 0;\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n --_dialog-slide-translate: var(--forge-dialog-slide-translate, 0 -100%);\n}\n\n.forge-dialog--top-sheet.forge-dialog {\n transition-property: display, opacity, overlay, translate;\n}\n\n.forge-dialog--top-sheet.forge-dialog[open] {\n translate: 0 0;\n}\n\n@starting-style {\n .forge-dialog--top-sheet.forge-dialog[open] {\n opacity: var(--_dialog-slide-opacity);\n translate: var(--_dialog-slide-translate);\n }\n}\n.forge-dialog--top-sheet.forge-dialog:not([open]) {\n opacity: var(--_dialog-slide-opacity);\n scale: 1;\n translate: var(--_dialog-slide-translate);\n}\n\n.forge-dialog::backdrop {\n --forge-backdrop-opacity: var(--_backdrop-opacity);\n --forge-backdrop-enter-animation-duration: var(--_backdrop-enter-animation-duration);\n --forge-backdrop-enter-animation-easing: var(--_backdrop-enter-animation-easing);\n --forge-backdrop-exit-animation-duration: var(--_backdrop-exit-animation-duration);\n --forge-backdrop-exit-animation-easing: var(--_backdrop-exit-animation-easing);\n position: absolute;\n inset: 0;\n z-index: var(--_backdrop-z-index);\n background: var(--_backdrop-background);\n opacity: 0;\n animation-fill-mode: forwards;\n transition-property: display, opacity, overlay;\n}\n\n.forge-dialog[open] {\n opacity: 1;\n scale: 1;\n transition-duration: var(--_dialog-enter-animation-duration);\n transition-timing-function: var(--_dialog-enter-animation-easing);\n}\n\n@starting-style {\n .forge-dialog[open] {\n opacity: var(--_dialog-zoom-opacity);\n scale: var(--_dialog-zoom-scale);\n }\n}\n.forge-dialog[open]::backdrop {\n opacity: var(--_backdrop-opacity);\n transition-duration: var(--_backdrop-enter-animation-duration);\n transition-timing-function: var(--_backdrop-enter-animation-easing);\n}\n\n@starting-style {\n .forge-dialog[open]::backdrop {\n opacity: 0;\n }\n}\n.forge-dialog:not([open]) {\n animation-duration: var(--_dialog-enter-animation-duration);\n animation-timing-function: var(--_dialog-enter-animation-easing);\n display: none;\n opacity: var(--_dialog-zoom-opacity);\n scale: var(--_dialog-zoom-scale);\n transition-duration: var(--_dialog-exit-animation-duration);\n transition-timing-function: var(--_dialog-exit-animation-easing);\n}\n\n.forge-dialog:not([open])::backdrop {\n transition-duration: var(--_backdrop-exit-animation-duration);\n transition-timing-function: var(--_backdrop-exit-animation-easing);\n}\n\n.forge-dialog--animation-fade.forge-dialog {\n transition-property: display, opacity, overlay;\n}\n\n@starting-style {\n .forge-dialog--animation-fade.forge-dialog[open] {\n opacity: var(--_dialog-fade-opacity);\n }\n}\n.forge-dialog--animation-fade.forge-dialog:not([open]) {\n opacity: var(--_dialog-fade-opacity);\n scale: 1;\n}\n\n.forge-dialog--animation-slide.forge-dialog {\n transition-property: display, opacity, overlay, translate;\n}\n\n.forge-dialog--animation-slide.forge-dialog[open] {\n translate: 0 0;\n}\n\n@starting-style {\n .forge-dialog--animation-slide.forge-dialog[open] {\n opacity: var(--_dialog-slide-opacity);\n translate: var(--_dialog-slide-translate);\n }\n}\n.forge-dialog--animation-slide.forge-dialog:not([open]) {\n opacity: var(--_dialog-slide-opacity);\n scale: 1;\n translate: var(--_dialog-slide-translate);\n}\n\n.forge-dialog--animation-none {\n --_dialog-enter-animation-duration: var(--forge-dialog-enter-animation-duration, 0s);\n --_dialog-exit-animation-duration: var(--forge-dialog-exit-animation-duration, 0s);\n --_backdrop-enter-animation-duration: var(--forge-backdrop-enter-animation-duration, 0s);\n --_backdrop-exit-animation-duration: var(--forge-backdrop-exit-animation-duration, 0s);\n}\n\n@media (prefers-reduced-motion) {\n .forge-dialog.forge-dialog {\n transition-property: display, opacity, overlay;\n }\n @starting-style {\n .forge-dialog.forge-dialog[open] {\n opacity: var(--_dialog-fade-opacity);\n }\n }\n .forge-dialog.forge-dialog:not([open]) {\n opacity: var(--_dialog-fade-opacity);\n scale: 1;\n }\n}\n:host {\n display: contents;\n}\n\ndialog.forge-dialog:not(.forge-dialog--fullscreen) {\n height: 80vh;\n width: 80vw;\n border-radius: calc(var(--forge-shape-large, 8px) * var(--forge-shape-factor, 1));\n}";
2
+ export {
3
+ styles as default
4
+ };
@@ -0,0 +1 @@
1
+ export { AiModalComponent } from './ai-modal.js';
@@ -0,0 +1,4 @@
1
+ import { AiModalComponent } from "./ai-modal.mjs";
2
+ export {
3
+ AiModalComponent
4
+ };
@@ -0,0 +1,42 @@
1
+ import { LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ declare global {
3
+ interface HTMLElementTagNameMap {
4
+ 'forge-ai-prompt': AiPromptComponent;
5
+ }
6
+ interface HTMLElementEventMap {
7
+ 'forge-ai-prompt-send': CustomEvent<AiPromptSendEventData>;
8
+ }
9
+ }
10
+ export interface AiPromptSendEventData {
11
+ value: string;
12
+ time: string;
13
+ date: Date;
14
+ }
15
+ export type AiPromptVariant = 'stacked' | 'inline';
16
+ export declare const AiPromptComponentTagName: keyof HTMLElementTagNameMap;
17
+ /**
18
+ * @tag forge-ai-prompt
19
+ *
20
+ * @slot actions - Slot for action components like dropdown menus, voice input, buttons, etc.
21
+ *
22
+ * @state inline - The prompt is in inline layout mode with actions hidden.
23
+ * @state stacked - The prompt is in stacked layout mode with actions displayed below the input.
24
+ *
25
+ * @event {CustomEvent<AiPromptSendEventData>} forge-ai-prompt-send - Fired when the send button is clicked or Enter is pressed.
26
+ */
27
+ export declare class AiPromptComponent extends LitElement {
28
+ #private;
29
+ static styles: import('lit').CSSResult;
30
+ /** Placeholder text for the input field */
31
+ placeholder: string;
32
+ /** Current value of the input field */
33
+ value: string;
34
+ /** Layout variant for the prompt component */
35
+ variant: AiPromptVariant;
36
+ constructor();
37
+ willUpdate(changedProperties: PropertyValues<this>): void;
38
+ private _handleSend;
39
+ private _handleInput;
40
+ private _handleKeyPress;
41
+ render(): TemplateResult;
42
+ }
@@ -0,0 +1,123 @@
1
+ import { unsafeCSS, LitElement, html } from "lit";
2
+ import { property, customElement } from "lit/decorators.js";
3
+ import { toggleState } from "../utils.mjs";
4
+ import styles from "./ai-prompt.scss.mjs";
5
+ var __defProp = Object.defineProperty;
6
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
7
+ var __typeError = (msg) => {
8
+ throw TypeError(msg);
9
+ };
10
+ var __decorateClass = (decorators, target, key, kind) => {
11
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
12
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
13
+ if (decorator = decorators[i])
14
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
15
+ if (kind && result) __defProp(target, key, result);
16
+ return result;
17
+ };
18
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
19
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
20
+ 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);
21
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), member.set(obj, value), value);
22
+ var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
23
+ var _internals, _AiPromptComponent_instances, setCssState_fn, _inputActions;
24
+ const AiPromptComponentTagName = "forge-ai-prompt";
25
+ let AiPromptComponent = class extends LitElement {
26
+ constructor() {
27
+ super();
28
+ __privateAdd(this, _AiPromptComponent_instances);
29
+ this.placeholder = "Ask a question...";
30
+ this.value = "";
31
+ this.variant = "stacked";
32
+ __privateAdd(this, _internals);
33
+ __privateAdd(this, _inputActions, html`
34
+ <hr class="forge-divider" />
35
+ <div class="actions">
36
+ <slot name="actions"></slot>
37
+ </div>
38
+ `);
39
+ __privateSet(this, _internals, this.attachInternals());
40
+ __privateMethod(this, _AiPromptComponent_instances, setCssState_fn).call(this);
41
+ }
42
+ willUpdate(changedProperties) {
43
+ if (changedProperties.has("variant")) {
44
+ __privateMethod(this, _AiPromptComponent_instances, setCssState_fn).call(this);
45
+ }
46
+ }
47
+ _handleSend() {
48
+ if (this.value.trim()) {
49
+ const now = /* @__PURE__ */ new Date();
50
+ const event = new CustomEvent("forge-ai-prompt-send", {
51
+ detail: {
52
+ value: this.value,
53
+ time: now.toLocaleTimeString([], { hour: "2-digit", minute: "2-digit" }),
54
+ date: now
55
+ },
56
+ bubbles: true,
57
+ composed: true,
58
+ cancelable: true
59
+ });
60
+ this.dispatchEvent(event);
61
+ this.value = "";
62
+ }
63
+ }
64
+ _handleInput(event) {
65
+ this.value = event.target.value;
66
+ }
67
+ _handleKeyPress(event) {
68
+ if (event.key === "Enter") {
69
+ event.preventDefault();
70
+ this._handleSend();
71
+ }
72
+ }
73
+ render() {
74
+ return html`
75
+ <div class="input-container">
76
+ <div class="forge-card">
77
+ <div class="forge-field">
78
+ <input
79
+ type="text"
80
+ id="chat-input"
81
+ .value=${this.value}
82
+ placeholder=${this.placeholder}
83
+ @input=${this._handleInput}
84
+ @keypress=${this._handleKeyPress} />
85
+ <button
86
+ aria-label="Send message"
87
+ class="forge-icon-button forge-icon-button--large ai-icon-button"
88
+ @click=${this._handleSend}>
89
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24">
90
+ <path d="m2 21 21-9L2 3v7l15 2-15 2z" />
91
+ </svg>
92
+ </button>
93
+ </div>
94
+ ${this.variant === "stacked" ? __privateGet(this, _inputActions) : ""}
95
+ </div>
96
+ </div>
97
+ `;
98
+ }
99
+ };
100
+ _internals = /* @__PURE__ */ new WeakMap();
101
+ _AiPromptComponent_instances = /* @__PURE__ */ new WeakSet();
102
+ setCssState_fn = function() {
103
+ toggleState(__privateGet(this, _internals), "inline", this.variant === "inline");
104
+ toggleState(__privateGet(this, _internals), "stacked", this.variant === "stacked");
105
+ };
106
+ _inputActions = /* @__PURE__ */ new WeakMap();
107
+ AiPromptComponent.styles = unsafeCSS(styles);
108
+ __decorateClass([
109
+ property()
110
+ ], AiPromptComponent.prototype, "placeholder", 2);
111
+ __decorateClass([
112
+ property()
113
+ ], AiPromptComponent.prototype, "value", 2);
114
+ __decorateClass([
115
+ property({ type: String, attribute: "variant" })
116
+ ], AiPromptComponent.prototype, "variant", 2);
117
+ AiPromptComponent = __decorateClass([
118
+ customElement(AiPromptComponentTagName)
119
+ ], AiPromptComponent);
120
+ export {
121
+ AiPromptComponent,
122
+ AiPromptComponentTagName
123
+ };
@@ -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.forge-card {\n --_card-background: var(--forge-card-background, var(--forge-theme-surface, #ffffff));\n --_card-height: var(--forge-card-height, 100%);\n --_card-width: var(--forge-card-width, 100%);\n --_card-outline-color: var(--forge-card-outline-color, var(--forge-theme-outline, #e0e0e0));\n --_card-outline-width: var(--forge-card-outline-width, var(--forge-border-thin, 1px));\n --_card-outline-style: var(--forge-card-outline-style, solid);\n --_card-elevation: var(--forge-card-elevation, none);\n --_card-padding: var(--forge-card-padding, var(--forge-spacing-medium, 16px));\n --_card-shape: var(--forge-card-shape, calc(var(--forge-shape-medium, 4px) * var(--forge-shape-factor, 1)));\n --_card-overflow: var(--forge-card-overflow, initial);\n --_card-raised-elevation: var(--forge-card-raised-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 --_card-raised-outline-width: var(--forge-card-raised-outline-width, 0);\n --_card-height: var(--forge-card-height, auto);\n --_card-width: var(--forge-card-width, auto);\n}\n\n.forge-card {\n background: var(--_card-background);\n border-color: var(--_card-outline-color);\n border-width: var(--_card-outline-width);\n border-style: var(--_card-outline-style);\n border-radius: var(--_card-shape);\n box-shadow: var(--_card-elevation);\n box-sizing: border-box;\n padding: var(--_card-padding);\n overflow: var(--_card-overflow);\n height: var(--_card-height);\n width: var(--_card-width);\n -webkit-tap-highlight-color: transparent;\n}\n\n.forge-card--raised {\n --_card-elevation: var(--_card-raised-elevation);\n --_card-outline-width: var(--_card-raised-outline-width);\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/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n.forge-divider {\n --_divider-color: var(--forge-divider-color, var(--forge-theme-outline, #e0e0e0));\n --_divider-width: var(--forge-divider-width, var(--forge-border-thin, 1px));\n --_divider-border-style: var(--forge-divider-border-style, solid);\n --_divider-margin: var(--forge-divider-margin, 0);\n}\n\n.forge-divider {\n display: block;\n margin: var(--_divider-margin);\n border: none;\n border-bottom-color: var(--_divider-color);\n border-bottom-width: var(--_divider-width);\n border-bottom-style: var(--_divider-border-style);\n height: 0;\n}\n\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/* prettier-ignore */\n.forge-icon-button {\n --_icon-button-display: var(--forge-icon-button-display, inline-flex);\n --_icon-button-size: var(--forge-icon-button-size, 48px);\n --_icon-button-gap: var(--forge-icon-button-gap, 0);\n --_icon-button-icon-color: var(--forge-icon-button-icon-color, currentColor);\n --_icon-button-background-color: var(--forge-icon-button-background-color, none);\n --_icon-button-icon-size: var(--forge-icon-button-icon-size, calc(var(--forge-typography-font-size, 1rem) * 1.5));\n --_icon-button-cursor: var(--forge-icon-button-cursor, pointer);\n --_icon-button-padding: var(--forge-icon-button-padding, var(--forge-spacing-xxsmall, 4px));\n --_icon-button-border: var(--forge-icon-button-border, none);\n --_icon-button-shadow: var(--forge-icon-button-shadow, none);\n --_icon-button-transition-duration: var(--forge-icon-button-transition-duration, var(--forge-animation-duration-short3, 150ms));\n --_icon-button-transition-timing: var(--forge-icon-button-transition-timing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n --_icon-button-shape: var(--forge-icon-button-shape, calc(var(--forge-shape-full, 9999px) * var(--forge-shape-factor, 1)));\n --_icon-button-shape-start-start: var(--forge-icon-button-shape-start-start, var(--_icon-button-shape));\n --_icon-button-shape-start-end: var(--forge-icon-button-shape-start-end, var(--_icon-button-shape));\n --_icon-button-shape-end-start: var(--forge-icon-button-shape-end-start, var(--_icon-button-shape));\n --_icon-button-shape-end-end: var(--forge-icon-button-shape-end-end, var(--_icon-button-shape));\n --_icon-button-shape-squared: var(--forge-icon-button-shape-squared, calc(var(--forge-shape-medium, 4px) * var(--forge-shape-factor, 1)));\n --_icon-button-outlined-border-width: var(--forge-icon-button-outlined-border-width, 1px);\n --_icon-button-outlined-border-style: var(--forge-icon-button-outlined-border-style, solid);\n --_icon-button-outlined-border-color: var(--forge-icon-button-outlined-border-color, var(--_icon-button-icon-color));\n --_icon-button-tonal-icon-color: var(--forge-icon-button-tonal-icon-color, var(--forge-theme-on-primary-container, #222c62));\n --_icon-button-tonal-background-color: var(--forge-icon-button-tonal-background-color, var(--forge-theme-primary-container, #d1d5ed));\n --_icon-button-filled-icon-color: var(--forge-icon-button-filled-icon-color, var(--forge-theme-on-primary, #ffffff));\n --_icon-button-filled-background-color: var(--forge-icon-button-filled-background-color, var(--forge-theme-primary, #3f51b5));\n --_icon-button-raised-shadow: var(--forge-icon-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 --_icon-button-raised-hover-shadow: var(--forge-icon-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 --_icon-button-raised-active-shadow: var(--forge-icon-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 --_icon-button-raised-disabled-shadow: var(--forge-icon-button-raised-disabled-shadow, none);\n --_icon-button-density-small-size: var(--forge-icon-button-density-small-size, 24px);\n --_icon-button-density-small-padding: var(--forge-icon-button-density-small-padding, var(--forge-spacing-xxxsmall, 2px));\n --_icon-button-density-small-icon-size: var(--forge-icon-button-density-small-icon-size, calc(var(--forge-typography-font-size, 1rem) * 1.125));\n --_icon-button-density-medium-size: var(--forge-icon-button-density-medium-size, 36px);\n --_icon-button-density-medium-padding: var(--forge-icon-button-density-medium-padding, var(--forge-spacing-xxsmall, 4px));\n --_icon-button-density-large-size: var(--forge-icon-button-density-large-size, var(--_icon-button-size));\n --_icon-button-toggle-on-background-color: var(--forge-icon-button-toggle-on-background-color, var(--forge-theme-primary-container, #d1d5ed));\n --_icon-button-toggle-on-icon-color: var(--forge-icon-button-toggle-on-icon-color, var(--forge-theme-primary, #3f51b5));\n --_icon-button-outlined-toggle-on-background-color: var(--forge-icon-button-outlined-toggle-on-background-color, var(--forge-theme-primary-container, #d1d5ed));\n --_icon-button-outlined-toggle-on-icon-color: var(--forge-icon-button-outlined-toggle-on-icon-color, var(--forge-theme-primary, #3f51b5));\n --_icon-button-tonal-toggle-background-color: var(--forge-icon-button-tonal-toggle-background-color, var(--forge-theme-surface-container-low, #ebebeb));\n --_icon-button-tonal-toggle-on-background-color: var(--forge-icon-button-tonal-toggle-on-background-color, var(--forge-theme-primary-container, #d1d5ed));\n --_icon-button-tonal-toggle-on-icon-color: var(--forge-icon-button-tonal-toggle-on-icon-color, var(--forge-theme-primary, #3f51b5));\n --_icon-button-filled-toggle-background-color: var(--forge-icon-button-filled-toggle-background-color, var(--forge-theme-surface-container-low, #ebebeb));\n --_icon-button-filled-toggle-icon-color: var(--forge-icon-button-filled-toggle-icon-color, var(--forge-theme-primary, #3f51b5));\n --_icon-button-filled-toggle-on-background-color: var(--forge-icon-button-filled-toggle-on-background-color, var(--forge-theme-primary, #3f51b5));\n --_icon-button-filled-toggle-on-icon-color: var(--forge-icon-button-filled-toggle-on-icon-color, var(--forge-theme-on-primary, #ffffff));\n --_icon-button-disabled-cursor: var(--forge-icon-button-disabled-cursor, not-allowed);\n --_icon-button-disabled-opacity: var(--forge-icon-button-disabled-opacity, 0.38);\n --_icon-button-popover-icon-padding: var(--forge-icon-button-popover-icon-padding, var(--forge-spacing-xsmall, 8px));\n --_icon-button-focus-indicator-color: var(--forge-icon-button-focus-indicator-color, var(--forge-theme-primary, #3f51b5));\n}\n\n.forge-icon-button {\n display: var(--_icon-button-display);\n position: relative;\n outline: none;\n -webkit-tap-highlight-color: transparent;\n position: relative;\n z-index: 0;\n display: var(--_icon-button-display);\n align-items: center;\n justify-content: center;\n gap: var(--_icon-button-gap);\n box-sizing: border-box;\n height: var(--_icon-button-density-large-size);\n min-width: var(--_icon-button-density-large-size);\n border: var(--_icon-button-border);\n border-start-start-radius: var(--_icon-button-shape-start-start);\n border-start-end-radius: var(--_icon-button-shape-start-end);\n border-end-start-radius: var(--_icon-button-shape-end-start);\n border-end-end-radius: var(--_icon-button-shape-end-end);\n padding: var(--_icon-button-padding);\n box-shadow: var(--_icon-button-shadow);\n color: var(--_icon-button-icon-color);\n background: var(--_icon-button-background-color);\n font-size: var(--_icon-button-icon-size);\n cursor: var(--_icon-button-cursor);\n user-select: none;\n transition-property: box-shadow, background;\n transition-duration: var(--_icon-button-transition-duration);\n transition-timing-function: var(--_icon-button-transition-timing);\n}\n\n.forge-icon-button img,\n.forge-icon-button svg {\n height: var(--_icon-button-icon-size);\n width: var(--_icon-button-icon-size);\n}\n\n.forge-icon-button svg {\n fill: currentColor;\n}\n\n.forge-icon-button:not(:disabled) {\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-icon-button:not(:disabled)::before {\n opacity: 0;\n position: absolute;\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-icon-button:not(:disabled):hover::before {\n background-color: var(--_state-layer-hover-color);\n opacity: var(--_state-layer-hover-opacity);\n}\n\n.forge-icon-button:not(:disabled):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.forge-icon-button:not(:disabled) {\n --forge-state-layer-color: var(--_icon-button-icon-color);\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-icon-button:not(:disabled) {\n outline: none;\n}\n\n.forge-icon-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-icon-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-icon-button:not(:disabled) {\n --forge-focus-indicator-color: var(--_icon-button-focus-indicator-color);\n --forge-focus-indicator-shape: var(--_icon-button-shape);\n}\n\n.forge-icon-button:not(:disabled):where(.forge-icon-button--text,\n:not(:where(.forge-icon-button--outlined, .forge-icon-button--tonal, .forge-icon-button--filled, .forge-icon-button--raised))) {\n --forge-focus-indicator-outward-offset: 0px;\n}\n\n.forge-icon-button--outlined {\n border-width: var(--_icon-button-outlined-border-width);\n border-style: var(--_icon-button-outlined-border-style);\n border-color: var(--_icon-button-outlined-border-color);\n}\n\n.forge-icon-button--tonal {\n --_icon-button-icon-color: var(--_icon-button-tonal-icon-color);\n --_icon-button-background-color: var(--_icon-button-tonal-background-color);\n}\n\n.forge-icon-button--filled, .forge-icon-button--raised {\n --_icon-button-icon-color: var(--_icon-button-filled-icon-color);\n --_icon-button-background-color: var(--_icon-button-filled-background-color);\n}\n\n.forge-icon-button--raised {\n --_icon-button-shadow: var(--_icon-button-raised-shadow);\n}\n\n.forge-icon-button--raised:hover {\n --_icon-button-raised-shadow: var(--_icon-button-raised-hover-shadow);\n}\n\n.forge-icon-button--raised:active {\n --_icon-button-raised-shadow: var(--_icon-button-raised-active-shadow);\n}\n\n.forge-icon-button--squared {\n --_icon-button-shape: var(--_icon-button-shape-squared);\n}\n\n.forge-icon-button--small {\n --_icon-button-size: var(--_icon-button-density-small-size);\n --_icon-button-icon-size: var(--_icon-button-density-small-icon-size);\n --_icon-button-padding: var(--_icon-button-density-small-padding);\n}\n\n.forge-icon-button--small > * {\n font-size: var(--_icon-button-density-small-icon-size);\n}\n\n.forge-icon-button--medium {\n --_icon-button-size: var(--_icon-button-density-medium-size);\n --_icon-button-padding: var(--_icon-button-density-medium-padding);\n}\n\n.forge-icon-button:disabled {\n pointer-events: none;\n opacity: var(--_icon-button-disabled-opacity);\n pointer-events: auto;\n cursor: not-allowed;\n}\n\n.forge-icon-button forge-circular-progress {\n --forge-circular-progress-indicator-color: var(--_icon-button-icon-color);\n --forge-circular-progress-track-color: transparent;\n --forge-circular-progress-size: 1em;\n}\n\n:host {\n display: block;\n}\n\n.input-container .forge-card {\n --forge-card-padding: 0;\n}\n.input-container .forge-field {\n --forge-theme-outline-low: transparent;\n --forge-field-height: 52px;\n}\n.input-container .actions {\n display: flex;\n justify-content: flex-start;\n align-items: center;\n padding: var(--forge-spacing-xxsmall, 4px);\n height: 52px;\n overflow-x: auto;\n}\n\n::slotted([slot=additional-action]:not(:last-child)) {\n margin-inline-end: var(--forge-spacing-small, 12px);\n}\n\n:host(:state(inline)) ::slotted([slot=additional-action]) {\n display: none;\n}\n\n:host(:state(inline)) .forge-field {\n --forge-field-height: 52px;\n}\n:host(:state(inline)) .forge-divider {\n display: none;\n}\n:host(:state(inline)) .input-container .actions {\n padding: 0;\n}';
2
+ export {
3
+ styles as default
4
+ };
@@ -0,0 +1 @@
1
+ export * from './ai-prompt.js';
@@ -0,0 +1,5 @@
1
+ import { AiPromptComponent, AiPromptComponentTagName } from "./ai-prompt.mjs";
2
+ export {
3
+ AiPromptComponent,
4
+ AiPromptComponentTagName
5
+ };
@@ -0,0 +1 @@
1
+ export { PromptButtonComponent, PromptButtonComponentTagName } from './prompt-button';
@@ -0,0 +1,5 @@
1
+ import { PromptButtonComponent, PromptButtonComponentTagName } from "./prompt-button.mjs";
2
+ export {
3
+ PromptButtonComponent,
4
+ PromptButtonComponentTagName
5
+ };
@@ -0,0 +1,16 @@
1
+ import { LitElement, TemplateResult } from 'lit';
2
+ declare global {
3
+ interface HTMLElementTagNameMap {
4
+ 'forge-prompt-button': PromptButtonComponent;
5
+ }
6
+ }
7
+ export declare const PromptButtonComponentTagName: keyof HTMLElementTagNameMap;
8
+ /**
9
+ * @tag forge-prompt-button
10
+ */
11
+ export declare class PromptButtonComponent extends LitElement {
12
+ static styles: import('lit').CSSResult;
13
+ /** Whether the button is disabled */
14
+ disabled: boolean;
15
+ render(): TemplateResult;
16
+ }