@tylertech/forge-ai 0.5.0 → 0.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/custom-elements.json +1329 -579
- package/dist/ai-artifact/ai-artifact.scss.mjs +1 -1
- package/dist/ai-attachment/ai-attachment.d.ts +4 -4
- package/dist/ai-chat-header/ai-chat-header.d.ts +4 -0
- package/dist/ai-chat-header/ai-chat-header.mjs +6 -0
- package/dist/ai-chat-header/ai-chat-header.scss.mjs +1 -1
- package/dist/ai-chatbot/ag-ui-adapter.mjs +34 -25
- package/dist/ai-chatbot/agent-adapter.d.ts +16 -8
- package/dist/ai-chatbot/agent-adapter.mjs +16 -16
- package/dist/ai-chatbot/agent-runner.mjs +3 -3
- package/dist/ai-chatbot/ai-chatbot-tool-call.d.ts +5 -2
- package/dist/ai-chatbot/ai-chatbot-tool-call.mjs +68 -5
- package/dist/ai-chatbot/ai-chatbot-tool-call.scss.mjs +1 -1
- package/dist/ai-chatbot/ai-chatbot.d.ts +1 -0
- package/dist/ai-chatbot/ai-chatbot.mjs +84 -23
- package/dist/ai-chatbot/create-tool-renderer.d.ts +1 -4
- package/dist/ai-chatbot/create-tool-renderer.mjs +1 -13
- package/dist/ai-chatbot/index.d.ts +1 -1
- package/dist/ai-chatbot/message-state-controller.d.ts +10 -6
- package/dist/ai-chatbot/message-state-controller.mjs +95 -6
- package/dist/ai-chatbot/types.d.ts +91 -2
- package/dist/ai-chatbot/utils.d.ts +2 -2
- package/dist/ai-chatbot/utils.mjs +3 -2
- package/dist/ai-dropdown-menu/ai-dropdown-menu-item.d.ts +1 -3
- package/dist/ai-dropdown-menu/ai-dropdown-menu-item.scss.mjs +1 -1
- package/dist/ai-dropdown-menu/ai-dropdown-menu.d.ts +5 -6
- package/dist/ai-dropdown-menu/ai-dropdown-menu.mjs +7 -1
- package/dist/ai-dropdown-menu/ai-dropdown-menu.scss.mjs +1 -1
- package/dist/ai-dropdown-menu/selection-manager.mjs +3 -3
- package/dist/ai-embedded-chat/ai-embedded-chat.mjs +1 -0
- package/dist/ai-empty-state/ai-empty-state.scss.mjs +1 -1
- package/dist/ai-event-stream-viewer/ai-event-stream-viewer.d.ts +19 -0
- package/dist/ai-event-stream-viewer/ai-event-stream-viewer.mjs +164 -0
- package/dist/ai-event-stream-viewer/ai-event-stream-viewer.scss.mjs +4 -0
- package/dist/ai-event-stream-viewer/index.d.ts +1 -0
- package/dist/ai-event-stream-viewer/index.mjs +5 -0
- package/dist/ai-file-picker/ai-file-picker.d.ts +0 -13
- package/dist/ai-gradient-container/ai-gradient-container.scss.mjs +1 -1
- package/dist/ai-icon/ai-icon.scss.mjs +1 -1
- package/dist/ai-icon-button/ai-icon-button.d.ts +19 -0
- package/dist/ai-icon-button/ai-icon-button.mjs +63 -0
- package/dist/ai-icon-button/ai-icon-button.scss.mjs +4 -0
- package/dist/ai-icon-button/index.d.ts +1 -0
- package/dist/ai-icon-button/index.mjs +5 -0
- package/dist/ai-message-thread/ai-message-thread.d.ts +3 -2
- package/dist/ai-message-thread/ai-message-thread.mjs +23 -9
- package/dist/ai-prompt/ai-prompt.d.ts +21 -0
- package/dist/ai-prompt/ai-prompt.mjs +133 -10
- package/dist/ai-prompt/ai-prompt.scss.mjs +1 -1
- package/dist/ai-response-message/ai-response-message.d.ts +5 -0
- package/dist/ai-response-message/ai-response-message.mjs +61 -3
- package/dist/ai-response-message/ai-response-message.scss.mjs +1 -1
- package/dist/ai-slash-command-menu/ai-slash-command-menu.d.ts +33 -0
- package/dist/ai-slash-command-menu/ai-slash-command-menu.mjs +200 -0
- package/dist/ai-slash-command-menu/ai-slash-command-menu.scss.mjs +4 -0
- package/dist/ai-slash-command-menu/index.d.ts +1 -0
- package/dist/ai-slash-command-menu/index.mjs +5 -0
- package/dist/ai-spinner/ai-spinner.d.ts +2 -2
- package/dist/ai-suggestions/ai-suggestions.d.ts +2 -0
- package/dist/ai-suggestions/ai-suggestions.scss.mjs +1 -1
- package/dist/ai-thinking-indicator/ai-thinking-indicator.d.ts +3 -0
- package/dist/ai-thinking-indicator/ai-thinking-indicator.mjs +24 -15
- package/dist/ai-thinking-indicator/ai-thinking-indicator.scss.mjs +14 -11
- package/dist/core/overlay/index.d.ts +1 -1
- package/dist/core/overlay/overlay.d.ts +10 -5
- package/dist/core/overlay/overlay.mjs +7 -2
- package/dist/core/popover/index.d.ts +1 -1
- package/dist/core/popover/popover.d.ts +7 -6
- package/dist/core/popover/popover.mjs +5 -0
- package/dist/core/tooltip/tooltip.d.ts +2 -2
- package/dist/index.d.ts +2 -0
- package/dist/index.mjs +6 -0
- package/dist/tools/ai-data-table/ai-data-table-definition.d.ts +2 -0
- package/dist/tools/ai-data-table/ai-data-table-definition.mjs +43 -0
- package/dist/tools/ai-data-table/ai-data-table.d.ts +33 -0
- package/dist/tools/ai-data-table/ai-data-table.mjs +206 -0
- package/dist/tools/ai-data-table/ai-data-table.scss.mjs +4 -0
- package/dist/tools/ai-data-table/index.d.ts +2 -0
- package/dist/tools/ai-data-table/index.mjs +6 -0
- package/dist/tools/ai-paginator/ai-paginator.d.ts +17 -0
- package/dist/tools/ai-paginator/ai-paginator.mjs +110 -0
- package/dist/tools/ai-paginator/ai-paginator.scss.mjs +4 -0
- package/dist/tools/ai-paginator/index.d.ts +1 -0
- package/dist/tools/ai-paginator/index.mjs +4 -0
- package/dist/tools/index.d.ts +2 -0
- package/dist/tools/index.mjs +8 -0
- package/dist/utils/keyboard-navigation-controller.d.ts +13 -0
- package/dist/utils/keyboard-navigation-controller.mjs +71 -0
- package/package.json +15 -14
|
@@ -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/* prettier-ignore */\n.forge-badge {\n --_badge-background: var(--forge-badge-background, var(--forge-theme-secondary, #ffc107));\n --_badge-color: var(--forge-badge-color, var(--forge-theme-on-secondary, #000000));\n --_badge-shape: var(--forge-badge-shape, calc(var(--forge-shape-full, 9999px) * var(--forge-shape-factor, 1)));\n --_badge-height: var(--forge-badge-height, 20px);\n --_badge-min-width: var(--forge-badge-min-width, 0);\n --_badge-max-width: var(--forge-badge-max-width, auto);\n --_badge-padding-inline: var(--forge-badge-padding-inline, var(--forge-spacing-xsmall, 8px));\n --_badge-padding-block: var(--forge-badge-padding-block, 0);\n --_badge-border-width: var(--forge-badge-border-width, var(--forge-border-thin, 1px));\n --_badge-border-style: var(--forge-badge-border-style, none);\n --_badge-border-color: var(--forge-badge-border-color, var(--_badge-color));\n --_badge-gap: var(--forge-badge-gap, var(--forge-spacing-xxsmall, 4px));\n --_badge-font-weight: var(--forge-badge-font-weight, bold);\n --_badge-dot-size: var(--forge-badge-dot-size, 8px);\n --_badge-dot-height: var(--forge-badge-dot-height, var(--_badge-dot-size));\n --_badge-dot-width: var(--forge-badge-dot-width, var(--_badge-dot-size));\n --_badge-dot-padding: var(--forge-badge-dot-padding, 0);\n --_badge-transition-duration: var(--forge-badge-transition-duration, var(--forge-animation-duration-short4, 200ms));\n --_badge-transition-easing: var(--forge-badge-transition-easing, var(--forge-animation-easing-decelerate, cubic-bezier(0, 0, 0, 1)));\n}\n\n.forge-badge {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-label1-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-label1-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-font-size-scale, 0.75)));\n font-weight: var(--forge-typography-label1-font-weight, 400);\n line-height: var(--forge-typography-label1-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-line-height-scale, 1.25)));\n letter-spacing: var(--forge-typography-label1-letter-spacing, 0.0357142857em);\n text-transform: var(--forge-typography-label1-text-transform, inherit);\n text-decoration: var(--forge-typography-label1-text-decoration, inherit);\n background: var(--_badge-background);\n color: var(--_badge-color);\n height: var(--_badge-height);\n min-width: var(--_badge-min-width);\n max-width: var(--_badge-max-width);\n border-width: var(--_badge-border-width);\n border-style: var(--_badge-border-style);\n border-color: var(--_badge-border-color);\n display: inline-flex;\n align-items: center;\n gap: var(--_badge-gap);\n border-radius: var(--_badge-shape);\n padding-inline: var(--_badge-padding-inline);\n padding-block: var(--_badge-padding-block);\n overflow: hidden;\n box-sizing: border-box;\n pointer-events: none;\n transition: transform var(--_badge-transition-duration) var(--_badge-transition-easing);\n font-weight: var(--_badge-font-weight);\n text-overflow: ellipsis;\n white-space: nowrap;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n\n.forge-badge--dot {\n --_badge-height: var(--_badge-dot-height);\n --_badge-min-width: var(--forge-badge-min-width, auto);\n padding: var(--_badge-dot-padding);\n width: var(--_badge-dot-width);\n}\n\n.forge-badge forge-icon,\n.forge-badge .forge-icon,\n.forge-badge .forge-badge__icon {\n font-size: inherit;\n}\n\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/* prettier-ignore */\n@layer list, list-item, navlist, with-start-end, two-line, three-line, dense, wrap, selected, indented, disabled;\n@layer list {\n .forge-list {\n --_list-spacing: var(--forge-list-spacing, 0);\n --_list-container-color: var(--forge-list-container-color, transparent);\n --_list-navlist-spacing: var(--forge-list-navlist-spacing, var(--forge-spacing-xxsmall, 4px));\n --_list-navlist-margin: var(--forge-list-navlist-margin, var(--forge-spacing-xxsmall, 4px) var(--forge-spacing-xsmall, 8px));\n --_list-navlist-height: var(--forge-list-navlist-height, 40px);\n --_list-navlist-padding: var(--forge-list-navlist-padding, 0 var(--forge-spacing-xsmall, 8px));\n --_list-navlist-shape: var(--forge-list-navlist-shape, calc(var(--forge-shape-medium, 4px) * var(--forge-shape-factor, 1)));\n --_list-navlist-font-size: var(--forge-list-navlist-font-size, calc(var(--forge-typography-font-size, 1rem) * 0.875));\n --_list-navlist-font-weight: var(--forge-list-navlist-font-weight, 500);\n }\n .forge-list {\n outline: none;\n background-color: var(--_list-container-color);\n margin: 0;\n border-radius: inherit;\n min-width: inherit;\n }\n .forge-list--dense .forge-list-item {\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 }\n .forge-list {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n}\n@layer navlist {\n .forge-list--navlist {\n margin-block: var(--_list-navlist-spacing);\n }\n .forge-list--navlist .forge-list-item {\n --forge-list-item-height: var(--_list-navlist-height);\n --forge-list-item-margin: var(--_list-navlist-margin);\n --forge-list-item-padding: var(--_list-navlist-padding);\n --forge-list-item-shape: var(--_list-navlist-shape);\n --forge-list-item-text-font-size: var(--_list-navlist-font-size);\n --forge-list-item-text-font-weight: var(--_list-navlist-font-weight);\n }\n}\n@layer with-start-end {\n .forge-list-item:has(.forge-list-item__start, .forge-list-item__end) {\n display: grid;\n grid-template-columns: 1fr;\n align-items: center;\n }\n .forge-list-item:has(.forge-list-item__start):not(:has(.forge-list-item__end)) {\n grid-template-columns: auto 1fr;\n }\n .forge-list-item:has(.forge-list-item__end):not(:has(.forge-list-item__start)) {\n grid-template-columns: 1fr auto;\n }\n .forge-list-item:has(.forge-list-item__start ~ .forge-list-item__end) {\n grid-template-columns: auto 1fr auto;\n }\n .forge-list-item__start,\n .forge-list-item__end {\n color: var(--_list-item-text-color);\n display: inline-flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n fill: currentColor;\n }\n}\n@layer list-item {\n .forge-list-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 }\n .forge-list-item {\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 -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 display: block;\n align-content: center;\n }\n .forge-list-item button {\n appearance: none;\n cursor: var(--_list-item-cursor);\n border: none;\n padding-block: 0;\n padding-inline: 0;\n margin: 0;\n box-sizing: border-box;\n width: 100%;\n background: transparent;\n color: inherit;\n outline: none;\n font: inherit;\n user-select: auto;\n text-align: inherit;\n letter-spacing: inherit;\n word-spacing: inherit;\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n display: block;\n }\n .forge-list-item a {\n outline: none;\n color: inherit !important;\n text-decoration: none !important;\n }\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n .forge-list-item button:not(:disabled),\n .forge-list-item a,\n .forge-list-item label {\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 .forge-list-item--interactive:not(.forge-list-item--disabled)::before,\n .forge-list-item button:not(:disabled)::before,\n .forge-list-item a::before,\n .forge-list-item label::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 .forge-list-item--interactive:not(.forge-list-item--disabled):hover::before,\n .forge-list-item button:not(:disabled):hover::before,\n .forge-list-item a:hover::before,\n .forge-list-item label:hover::before {\n background-color: var(--_state-layer-hover-color);\n opacity: var(--_state-layer-hover-opacity);\n }\n .forge-list-item--interactive:not(.forge-list-item--disabled):active::before,\n .forge-list-item button:not(:disabled):active::before,\n .forge-list-item a:active::before,\n .forge-list-item label: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 .forge-list-item :is(forge-checkbox, forge-radio, forge-switch, input):is(.forge-list-item__start, .forge-list-item__end):not([forge-ignore]) {\n --forge-focus-indicator-display: none;\n --forge-state-layer-display: none;\n }\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) a,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) button,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) label,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled]),\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) .forge-list-item--interactive {\n cursor: pointer;\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-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) a,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) button,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) label,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled]),\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) .forge-list-item--interactive {\n outline: none;\n }\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) a:focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) button:focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) label:focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled]):focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) .forge-list-item--interactive: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 .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) a:focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) button:focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) label:focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled]):focus-visible::after,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) .forge-list-item--interactive: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-inward-grow, forge-focus-indicator-inward-shrink;\n border-end-end-radius: calc(var(--_focus-indicator-shape-end-end) - var(--_focus-indicator-inward-offset));\n border-end-start-radius: calc(var(--_focus-indicator-shape-end-start) - var(--_focus-indicator-inward-offset));\n border-start-end-radius: calc(var(--_focus-indicator-shape-start-end) - var(--_focus-indicator-inward-offset));\n border-start-start-radius: calc(var(--_focus-indicator-shape-start-start) - var(--_focus-indicator-inward-offset));\n border: var(--_focus-indicator-width) solid currentColor;\n inset: var(--_focus-indicator-inward-offset);\n content: "";\n display: block;\n }\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) a,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) button,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) label,\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled]),\n .forge-list-item:has(button:not(:disabled),\n a,\n label,\n .forge-list-item--interactive:not(.forge-list-item--disabled),\n :is(forge-checkbox, forge-radio, forge-switch, input):not([disabled])) .forge-list-item--interactive {\n --forge-focus-indicator-shape: calc(var(--forge-shape-medium, 4px) * var(--forge-shape-factor, 1));\n }\n .forge-list-item__text {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-body1-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-body1-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-font-size-scale, 0.875)));\n font-weight: var(--forge-typography-body1-font-weight, 400);\n line-height: var(--forge-typography-body1-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-line-height-scale, 1.125)));\n letter-spacing: var(--forge-typography-body1-letter-spacing, 0.0357142857em);\n text-transform: var(--forge-typography-body1-text-transform, inherit);\n text-decoration: var(--forge-typography-body1-text-decoration, inherit);\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n color: var(--_list-item-text-color);\n display: block;\n }\n}\n@layer two-line {\n .forge-list--two-line .forge-list-item,\n .forge-list-item--two-line {\n height: var(--_list-item-two-line-height);\n min-height: var(--_list-item-two-line-height);\n }\n .forge-list--three-line .forge-list-item,\n .forge-list-item--three-line {\n height: var(--_list-item-three-line-height);\n min-height: var(--_list-item-three-line-height);\n }\n}\n@layer dense {\n .forge-list--dense .forge-list-item,\n .forge-list-item--dense {\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 font-size: var(--_list-item-dense-font-size);\n }\n .forge-list--dense.forge-list--two-line .forge-list-item,\n .forge-list--dense .forge-list-item--two-line,\n .forge-list-item--dense.forge-list-item--two-line {\n height: var(--_list-item-dense-two-line-height);\n min-height: var(--_list-item-dense-two-line-height);\n }\n .forge-list--dense.forge-list--three-line .forge-list-item,\n .forge-list--dense .forge-list-item--three-line,\n .forge-list-item--dense.forge-list-item--three-line {\n height: var(--_list-item-dense-three-line-height);\n min-height: var(--_list-item-dense-three-line-height);\n }\n .forge-list-dense.forge-list--indented .forge-list-item,\n .forge-list--dense .forge-list-item--indented,\n .forge-list-item--dense.forge-list-item--indented {\n margin-inline-start: var(--_list-item-dense-indent);\n }\n}\n@layer wrap {\n .forge-list--wrap .forge-list-item,\n .forge-list-item--wrap {\n --_list-item-padding: var(--_list-item-wrap-padding);\n height: auto;\n white-space: normal;\n overflow: visible;\n text-overflow: clip;\n line-height: normal;\n }\n .forge-list--wrap .forge-list-item .forge-list-item__text,\n .forge-list-item--wrap .forge-list-item__text {\n white-space: normal;\n overflow: visible;\n text-overflow: clip;\n line-height: normal;\n }\n}\n@layer selected {\n .forge-list-item--selected {\n color: var(--_list-item-selected-color);\n }\n .forge-list-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 .forge-list-item--selected {\n --forge-state-layer-color: var(--_list-item-selected-color);\n }\n .forge-list-item--selected .forge-list-item__start {\n color: var(--_list-item-start-selected-color);\n }\n .forge-list-item--selected .forge-list-item__end {\n color: var(--_list-item-end-selected-color);\n }\n}\n@layer indented {\n .forge-list--indented .forge-list-item,\n .forge-list-item--indented {\n margin-inline-start: var(--_list-item-indent);\n }\n}\n@layer disabled {\n .forge-list--disabled .forge-list-item,\n .forge-list-item--disabled,\n .forge-list-item button:disabled {\n cursor: var(--_list-item-disabled-cursor);\n opacity: var(--_list-item-disabled-opacity);\n }\n}\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n.forge-expansion-panel {\n --_expansion-panel-animation-duration: var(--forge-expansion-panel-animation-duration, var(--forge-animation-duration-medium4, 400ms));\n --_expansion-panel-animation-easing: var(--forge-expansion-panel-animation-easing, var(--forge-animation-easing-standard, cubic-bezier(0.2, 0, 0, 1)));\n}\n\n.forge-expansion-panel {\n display: grid;\n grid-template-rows: 0fr;\n transition-property: visibility, opacity, grid-template-rows;\n transition-duration: var(--_expansion-panel-animation-duration);\n transition-timing-function: var(--_expansion-panel-animation-easing);\n min-height: 0;\n opacity: 0;\n transform: translate3d(0, 0, 0);\n backface-visibility: hidden;\n}\n\n.forge-expansion-panel:not(.forge-expansion-panel--open) {\n visibility: hidden;\n}\n\n.forge-expansion-panel--open {\n opacity: 1;\n grid-template-rows: 1fr;\n}\n\n.forge-expansion-panel__content {\n display: grid;\n grid-template-rows: 1fr;\n overflow: hidden;\n}\n\n@media (prefers-reduced-motion: reduce) {\n .forge-expansion-panel {\n transition: none;\n }\n}\n/**\n * @license\n * Copyright Tyler Technologies, Inc. \n * License: Apache-2.0\n */\n/* prettier-ignore */\n.forge-icon {\n --_icon-color: var(--forge-icon-color, currentColor);\n --_icon-size: var(--forge-icon-size, 1em);\n --_icon-width: var(--forge-icon-width, var(--_icon-size));\n --_icon-height: var(--forge-icon-height, var(--_icon-size));\n --_icon-font-size: var(--forge-icon-font-size, calc(var(--forge-typography-font-size, 1rem) * 1.5));\n}\n\nimg.forge-icon,\nsvg.forge-icon {\n display: inline-block;\n box-sizing: content-box;\n contain: content;\n font-size: var(--_icon-font-size);\n display: inline-block;\n}\n\nimg.forge-icon {\n width: var(--_icon-width);\n height: var(--_icon-height);\n}\n\nsvg {\n width: var(--_icon-width);\n height: var(--_icon-height);\n display: block;\n fill: var(--_icon-color);\n stroke: var(--_icon-color);\n stroke-width: 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 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-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.event-stream {\n display: grid;\n grid-template-rows: auto 1fr;\n max-height: 400px;\n min-height: 0;\n width: 400px;\n}\n.event-stream .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-xsmall, 8px);\n border-block-end: 1px solid var(--forge-theme-outline, #e0e0e0);\n}\n.event-stream .empty-state {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-body1-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-body1-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-font-size-scale, 0.875)));\n font-weight: var(--forge-typography-body1-font-weight, 400);\n line-height: var(--forge-typography-body1-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-body-line-height-scale, 1.125)));\n letter-spacing: var(--forge-typography-body1-letter-spacing, 0.0357142857em);\n text-transform: var(--forge-typography-body1-text-transform, inherit);\n text-decoration: var(--forge-typography-body1-text-decoration, inherit);\n color: var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6));\n padding: var(--forge-spacing-medium, 16px);\n text-align: center;\n}\n\n.forge-list::-webkit-scrollbar {\n height: var(--forge-scrollbar-height, 16px);\n width: var(--forge-scrollbar-width, 16px);\n}\n.forge-list::-webkit-scrollbar-track {\n background-color: var(--forge-scrollbar-track-container, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.forge-list::-webkit-scrollbar-track:hover {\n background-color: var(--forge-scrollbar-track-container-hover, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.forge-list::-webkit-scrollbar-corner {\n background-color: var(--forge-scrollbar-track-container, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.forge-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.forge-list::-webkit-scrollbar-thumb:hover {\n background-color: var(--forge-scrollbar-thumb-container-hover, var(--forge-theme-surface-container-high, #9e9e9e));\n}\n.forge-list {\n overflow-y: auto;\n margin: 0;\n padding: var(--forge-spacing-xxsmall, 4px) 0;\n}\n\n.forge-list-item {\n padding-inline: var(--forge-spacing-xsmall, 8px);\n}\n.forge-list-item:last-child {\n border-block-end: none;\n}\n.forge-list-item .event-row {\n width: 100%;\n display: flex;\n align-items: center;\n gap: var(--forge-spacing-xsmall, 8px);\n}\n.forge-list-item .expansion-icon {\n flex-shrink: 0;\n width: 14px;\n height: 14px;\n fill: var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6));\n transition: transform 150ms ease;\n}\n.forge-list-item .expansion-icon.expanded {\n transform: rotate(90deg);\n}\n.forge-list-item .forge-badge {\n font-size: 11px;\n border-radius: calc(var(--forge-shape-small, 2px) * var(--forge-shape-factor, 1));\n}\n.forge-list-item .forge-badge--error {\n --forge-badge-background: var(--forge-theme-error-container, #ecc2c9);\n --forge-badge-color: var(--forge-theme-on-error-container, #5f0011);\n}\n.forge-list-item .forge-badge--success {\n --forge-badge-background: var(--forge-theme-success-container, #cde0ce);\n --forge-badge-color: var(--forge-theme-on-success-container, #19441b);\n}\n.forge-list-item .forge-badge--warning {\n --forge-badge-background: var(--forge-theme-warning-container, #f4d3c2);\n --forge-badge-color: var(--forge-theme-on-warning-container, #712700);\n}\n.forge-list-item .forge-badge--info-primary {\n --forge-badge-background: var(--forge-theme-primary-container, #d1d5ed);\n --forge-badge-color: var(--forge-theme-on-primary-container, #222c62);\n}\n.forge-list-item .forge-badge--info-secondary {\n --forge-badge-background: var(--forge-theme-secondary-container, #fff0c3);\n --forge-badge-color: var(--forge-theme-on-secondary-container, #8a6804);\n}\n.forge-list-item .timestamp {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n font-family: var(--forge-typography-label1-font-family, var(--forge-typography-font-family, "Roboto", sans-serif));\n font-size: var(--forge-typography-label1-font-size, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-font-size-scale, 0.75)));\n font-weight: var(--forge-typography-label1-font-weight, 400);\n line-height: var(--forge-typography-label1-line-height, calc(var(--forge-typography-font-size, 1rem) * var(--forge-typography-label-line-height-scale, 1.25)));\n letter-spacing: var(--forge-typography-label1-letter-spacing, 0.0357142857em);\n text-transform: var(--forge-typography-label1-text-transform, inherit);\n text-decoration: var(--forge-typography-label1-text-decoration, inherit);\n margin-inline-start: auto;\n color: var(--forge-theme-text-medium, rgba(0, 0, 0, 0.6));\n}\n\n.forge-expansion-panel {\n padding-inline: var(--forge-spacing-xsmall, 8px);\n}\n.forge-expansion-panel__content .event-data-container {\n position: relative;\n overflow: auto;\n}\n.forge-expansion-panel__content .event-data::-webkit-scrollbar {\n height: var(--forge-scrollbar-height, 16px);\n width: var(--forge-scrollbar-width, 16px);\n}\n.forge-expansion-panel__content .event-data::-webkit-scrollbar-track {\n background-color: var(--forge-scrollbar-track-container, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.forge-expansion-panel__content .event-data::-webkit-scrollbar-track:hover {\n background-color: var(--forge-scrollbar-track-container-hover, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.forge-expansion-panel__content .event-data::-webkit-scrollbar-corner {\n background-color: var(--forge-scrollbar-track-container, var(--forge-theme-surface-container-low, #ebebeb));\n}\n.forge-expansion-panel__content .event-data::-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.forge-expansion-panel__content .event-data::-webkit-scrollbar-thumb:hover {\n background-color: var(--forge-scrollbar-thumb-container-hover, var(--forge-theme-surface-container-high, #9e9e9e));\n}\n.forge-expansion-panel__content .event-data {\n margin: 0;\n padding: var(--forge-spacing-xsmall, 8px);\n background-color: var(--forge-theme-surface-container-minimum, #f5f5f5);\n border-radius: 4px;\n overflow-x: auto;\n font-family: monospace;\n font-size: 11px;\n line-height: normal;\n margin-inline-start: 22px;\n margin-block: var(--forge-spacing-xxsmall, 4px);\n}\n.forge-expansion-panel__content .copy-button {\n position: absolute;\n top: var(--forge-spacing-xxsmall, 4px);\n inset-inline-end: var(--forge-spacing-xxsmall, 4px);\n z-index: 1;\n}';
|
|
2
|
+
export {
|
|
3
|
+
styles as default
|
|
4
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './ai-event-stream-viewer';
|
|
@@ -36,19 +36,6 @@ export type AiFilePickerVariant = 'button' | 'icon-button';
|
|
|
36
36
|
* A simple file picker component that allows users to select and upload files.
|
|
37
37
|
* Provides both button and icon-button variants for different UI contexts.
|
|
38
38
|
*
|
|
39
|
-
* ## Features
|
|
40
|
-
* - **Multiple Variants**: 'button' and 'icon-button' for different use cases
|
|
41
|
-
* - **File Selection**: Click to open file dialog or drag & drop support
|
|
42
|
-
* - **Event Emission**: Emits events when files are selected
|
|
43
|
-
* - **Accessibility**: Full ARIA implementation with keyboard support
|
|
44
|
-
* - **Customizable**: Accepts custom file types and styling
|
|
45
|
-
*
|
|
46
|
-
* ## Events
|
|
47
|
-
* - **forge-ai-file-picker-change**: Fired when a file is selected with file details
|
|
48
|
-
*
|
|
49
|
-
* @cssprop --ai-file-picker-width - The width of the file picker button.
|
|
50
|
-
* @cssprop --ai-file-picker-height - The height of the file picker button.
|
|
51
|
-
*
|
|
52
39
|
* @slot - The default slot for button content when no file is selected.
|
|
53
40
|
* @slot icon - The icon slot for icon-button variant.
|
|
54
41
|
*
|
|
@@ -1,4 +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@keyframes fadein {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n:host {\n display: block;\n --forge-
|
|
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@keyframes fadein {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n:host {\n display: block;\n --forge-drawer-background: transparent;\n border: calc(var(--forge-shape-small, 2px) * var(--forge-shape-factor, 1)) solid transparent;\n border-radius: var(--forge-ai-gradient-container-radius, calc(var(--forge-shape-large, 8px) * var(--forge-shape-factor, 1)));\n background-origin: border-box;\n background-clip: padding-box, border-box;\n}\n\n:host(:state(low)) {\n background-image: linear-gradient(var(--forge-theme-surface, #ffffff), var(--forge-theme-surface, #ffffff)), linear-gradient(to top, var(--forge-theme-tertiary-container-low, #e8ebff), var(--forge-theme-outline, #e0e0e0));\n}\n\n:host(:state(medium)) {\n background-image: linear-gradient(var(--forge-theme-surface, #ffffff), var(--forge-theme-surface, #ffffff)), linear-gradient(to top, var(--forge-theme-tertiary-container, #d0d7ff), var(--forge-theme-outline, #e0e0e0));\n}\n\n:host(:state(high)) {\n background-image: linear-gradient(var(--forge-theme-surface, #ffffff), var(--forge-theme-surface, #ffffff)), linear-gradient(to top, var(--forge-theme-tertiary, #3d5afe), var(--forge-theme-outline, #e0e0e0));\n}\n\n:host(:state(disabled)) {\n background-image: linear-gradient(var(--forge-theme-surface, #ffffff), var(--forge-theme-surface, #ffffff)), linear-gradient(to top, var(--forge-theme-text-low, rgba(0, 0, 0, 0.38)), var(--forge-theme-text-low, rgba(0, 0, 0, 0.38)));\n}";
|
|
2
2
|
export {
|
|
3
3
|
styles as default
|
|
4
4
|
};
|
|
@@ -1,4 +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
|
|
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 --_ai-icon-fill-color: var(--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(--_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
2
|
export {
|
|
3
3
|
styles as default
|
|
4
4
|
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { LitElement, TemplateResult, PropertyValues } from 'lit';
|
|
2
|
+
declare global {
|
|
3
|
+
interface HTMLElementTagNameMap {
|
|
4
|
+
'forge-ai-icon-button': AiIconButtonComponent;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
export declare const AiIconButtonComponentTagName: keyof HTMLElementTagNameMap;
|
|
8
|
+
/**
|
|
9
|
+
* @tag forge-ai-icon-button
|
|
10
|
+
*/
|
|
11
|
+
export declare class AiIconButtonComponent extends LitElement {
|
|
12
|
+
#private;
|
|
13
|
+
static styles: import('lit').CSSResult;
|
|
14
|
+
/** Whether the button is disabled */
|
|
15
|
+
disabled: boolean;
|
|
16
|
+
constructor();
|
|
17
|
+
willUpdate(changedProperties: PropertyValues<this>): void;
|
|
18
|
+
render(): TemplateResult;
|
|
19
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { toggleState } from "../utils.mjs";
|
|
2
|
+
import { unsafeCSS, LitElement, html } from "lit";
|
|
3
|
+
import { property, customElement } from "lit/decorators.js";
|
|
4
|
+
import "../ai-icon/ai-icon.mjs";
|
|
5
|
+
import styles from "./ai-icon-button.scss.mjs";
|
|
6
|
+
var __defProp = Object.defineProperty;
|
|
7
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
8
|
+
var __typeError = (msg) => {
|
|
9
|
+
throw TypeError(msg);
|
|
10
|
+
};
|
|
11
|
+
var __decorateClass = (decorators, target, key, kind) => {
|
|
12
|
+
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
|
|
13
|
+
for (var i = decorators.length - 1, decorator; i >= 0; i--)
|
|
14
|
+
if (decorator = decorators[i])
|
|
15
|
+
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
|
|
16
|
+
if (kind && result) __defProp(target, key, result);
|
|
17
|
+
return result;
|
|
18
|
+
};
|
|
19
|
+
var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
|
|
20
|
+
var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
|
|
21
|
+
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);
|
|
22
|
+
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), member.set(obj, value), value);
|
|
23
|
+
var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
|
|
24
|
+
var _internals, _AiIconButtonComponent_instances, setCssState_fn;
|
|
25
|
+
const AiIconButtonComponentTagName = "forge-ai-icon-button";
|
|
26
|
+
let AiIconButtonComponent = class extends LitElement {
|
|
27
|
+
constructor() {
|
|
28
|
+
super();
|
|
29
|
+
__privateAdd(this, _AiIconButtonComponent_instances);
|
|
30
|
+
this.disabled = false;
|
|
31
|
+
__privateAdd(this, _internals);
|
|
32
|
+
__privateSet(this, _internals, this.attachInternals());
|
|
33
|
+
__privateMethod(this, _AiIconButtonComponent_instances, setCssState_fn).call(this);
|
|
34
|
+
}
|
|
35
|
+
willUpdate(changedProperties) {
|
|
36
|
+
if (changedProperties.has("disabled")) {
|
|
37
|
+
__privateMethod(this, _AiIconButtonComponent_instances, setCssState_fn).call(this);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
render() {
|
|
41
|
+
return html`
|
|
42
|
+
<button aria-label="AI Icon Button" class="forge-icon-button ai-icon-button" .disabled=${this.disabled}>
|
|
43
|
+
<forge-ai-icon></forge-ai-icon>
|
|
44
|
+
</button>
|
|
45
|
+
`;
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
_internals = /* @__PURE__ */ new WeakMap();
|
|
49
|
+
_AiIconButtonComponent_instances = /* @__PURE__ */ new WeakSet();
|
|
50
|
+
setCssState_fn = function() {
|
|
51
|
+
toggleState(__privateGet(this, _internals), "disabled", this.disabled);
|
|
52
|
+
};
|
|
53
|
+
AiIconButtonComponent.styles = unsafeCSS(styles);
|
|
54
|
+
__decorateClass([
|
|
55
|
+
property({ type: Boolean, reflect: true })
|
|
56
|
+
], AiIconButtonComponent.prototype, "disabled", 2);
|
|
57
|
+
AiIconButtonComponent = __decorateClass([
|
|
58
|
+
customElement(AiIconButtonComponentTagName)
|
|
59
|
+
], AiIconButtonComponent);
|
|
60
|
+
export {
|
|
61
|
+
AiIconButtonComponent,
|
|
62
|
+
AiIconButtonComponentTagName
|
|
63
|
+
};
|
|
@@ -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/* 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 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-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@keyframes fadein {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n:host {\n display: inline-block;\n}\n\nforge-ai-icon {\n --forge-ai-icon-fill-color: currentColor;\n}\n\n:host(:state(disabled)) forge-ai-icon {\n --forge-ai-icon-fill-color: var(--forge-theme-text-low);\n}';
|
|
2
|
+
export {
|
|
3
|
+
styles as default
|
|
4
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './ai-icon-button';
|
|
@@ -13,10 +13,10 @@ declare global {
|
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
15
|
export interface ForgeAiMessageThreadCopyEventData {
|
|
16
|
-
|
|
16
|
+
messageId: string;
|
|
17
17
|
}
|
|
18
18
|
export interface ForgeAiMessageThreadRefreshEventData {
|
|
19
|
-
|
|
19
|
+
messageId: string;
|
|
20
20
|
}
|
|
21
21
|
export interface ForgeAiMessageThreadThumbsEventData {
|
|
22
22
|
messageId: string;
|
|
@@ -47,6 +47,7 @@ export declare class AiMessageThreadComponent extends LitElement {
|
|
|
47
47
|
enableReactions: boolean;
|
|
48
48
|
showThinking: boolean;
|
|
49
49
|
autoScroll: FeatureToggle;
|
|
50
|
+
debugMode: boolean;
|
|
50
51
|
private _messageThreadContainer;
|
|
51
52
|
connectedCallback(): void;
|
|
52
53
|
updated(changedProperties: PropertyValues<this>): void;
|
|
@@ -39,6 +39,7 @@ let AiMessageThreadComponent = class extends LitElement {
|
|
|
39
39
|
this.enableReactions = false;
|
|
40
40
|
this.showThinking = false;
|
|
41
41
|
this.autoScroll = "on";
|
|
42
|
+
this.debugMode = false;
|
|
42
43
|
__privateAdd(this, _markdownController);
|
|
43
44
|
__privateAdd(this, _canAutoScroll, true);
|
|
44
45
|
__privateAdd(this, _handleScroll, () => {
|
|
@@ -81,16 +82,16 @@ _markdownController = /* @__PURE__ */ new WeakMap();
|
|
|
81
82
|
_canAutoScroll = /* @__PURE__ */ new WeakMap();
|
|
82
83
|
_handleScroll = /* @__PURE__ */ new WeakMap();
|
|
83
84
|
_AiMessageThreadComponent_instances = /* @__PURE__ */ new WeakSet();
|
|
84
|
-
handleCopy_fn = function(
|
|
85
|
+
handleCopy_fn = function(messageId) {
|
|
85
86
|
__privateMethod(this, _AiMessageThreadComponent_instances, dispatchEvent_fn).call(this, {
|
|
86
87
|
type: "forge-ai-message-thread-copy",
|
|
87
|
-
detail: {
|
|
88
|
+
detail: { messageId }
|
|
88
89
|
});
|
|
89
90
|
};
|
|
90
|
-
handleRefresh_fn = function(
|
|
91
|
+
handleRefresh_fn = function(messageId) {
|
|
91
92
|
__privateMethod(this, _AiMessageThreadComponent_instances, dispatchEvent_fn).call(this, {
|
|
92
93
|
type: "forge-ai-message-thread-refresh",
|
|
93
|
-
detail: {
|
|
94
|
+
detail: { messageId }
|
|
94
95
|
});
|
|
95
96
|
};
|
|
96
97
|
handleThumbsUp_fn = function(messageId) {
|
|
@@ -109,7 +110,8 @@ renderToolCall_fn = function(toolCall) {
|
|
|
109
110
|
const toolDefinition = this.tools?.get(toolCall.name);
|
|
110
111
|
return html`<forge-ai-chatbot-tool-call
|
|
111
112
|
.toolCall=${toolCall}
|
|
112
|
-
.toolDefinition=${toolDefinition}
|
|
113
|
+
.toolDefinition=${toolDefinition}
|
|
114
|
+
?debug-mode=${this.debugMode}></forge-ai-chatbot-tool-call>`;
|
|
113
115
|
};
|
|
114
116
|
emptyState_get = function() {
|
|
115
117
|
if (this.messageItems.length) {
|
|
@@ -136,13 +138,20 @@ thinkingIndicator_get = function() {
|
|
|
136
138
|
if (hasAssistantContent) {
|
|
137
139
|
return nothing;
|
|
138
140
|
}
|
|
141
|
+
const hasActiveToolCall = this.debugMode && lastItem?.type === "toolCall" && (lastItem.data.status === "parsing" || lastItem.data.status === "executing" || lastItem.data.status === "pending");
|
|
142
|
+
if (hasActiveToolCall) {
|
|
143
|
+
return nothing;
|
|
144
|
+
}
|
|
139
145
|
return html`<div class="thinking-indicator">
|
|
140
|
-
<forge-ai-thinking-indicator class="status-indicator"></forge-ai-thinking-indicator>
|
|
146
|
+
<forge-ai-thinking-indicator class="status-indicator" show-text></forge-ai-thinking-indicator>
|
|
141
147
|
</div>`;
|
|
142
148
|
};
|
|
143
149
|
messages_get = function() {
|
|
144
150
|
const itemsToRender = this.messageItems.filter((item) => {
|
|
145
151
|
if (item.type === "toolCall") {
|
|
152
|
+
if (this.debugMode) {
|
|
153
|
+
return true;
|
|
154
|
+
}
|
|
146
155
|
const toolDef = this.tools?.get(item.data.name);
|
|
147
156
|
return !!toolDef?.renderer;
|
|
148
157
|
}
|
|
@@ -151,7 +160,7 @@ messages_get = function() {
|
|
|
151
160
|
}
|
|
152
161
|
return false;
|
|
153
162
|
});
|
|
154
|
-
return itemsToRender.map((item
|
|
163
|
+
return itemsToRender.map((item) => {
|
|
155
164
|
if (item.type === "toolCall") {
|
|
156
165
|
return __privateMethod(this, _AiMessageThreadComponent_instances, renderToolCall_fn).call(this, item.data);
|
|
157
166
|
}
|
|
@@ -176,8 +185,10 @@ messages_get = function() {
|
|
|
176
185
|
<forge-ai-response-message
|
|
177
186
|
?complete=${msg.status === "complete"}
|
|
178
187
|
?enable-reactions=${this.enableReactions}
|
|
179
|
-
|
|
180
|
-
|
|
188
|
+
?has-debug-data=${this.debugMode && (msg.eventStream?.length ?? 0) > 0}
|
|
189
|
+
.eventStream=${msg.eventStream}
|
|
190
|
+
@forge-ai-response-message-copy=${() => __privateMethod(this, _AiMessageThreadComponent_instances, handleCopy_fn).call(this, msg.id)}
|
|
191
|
+
@forge-ai-response-message-refresh=${() => __privateMethod(this, _AiMessageThreadComponent_instances, handleRefresh_fn).call(this, msg.id)}
|
|
181
192
|
@forge-ai-response-message-thumbs-up=${() => __privateMethod(this, _AiMessageThreadComponent_instances, handleThumbsUp_fn).call(this, msg.id)}
|
|
182
193
|
@forge-ai-response-message-thumbs-down=${() => __privateMethod(this, _AiMessageThreadComponent_instances, handleThumbsDown_fn).call(this, msg.id)}>
|
|
183
194
|
${unsafeHTML(renderedHtml)}
|
|
@@ -212,6 +223,9 @@ __decorateClass([
|
|
|
212
223
|
__decorateClass([
|
|
213
224
|
property({ attribute: "auto-scroll" })
|
|
214
225
|
], AiMessageThreadComponent.prototype, "autoScroll", 2);
|
|
226
|
+
__decorateClass([
|
|
227
|
+
property({ type: Boolean, attribute: "debug-mode" })
|
|
228
|
+
], AiMessageThreadComponent.prototype, "debugMode", 2);
|
|
215
229
|
__decorateClass([
|
|
216
230
|
query(".message-thread")
|
|
217
231
|
], AiMessageThreadComponent.prototype, "_messageThreadContainer", 2);
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { LitElement, PropertyValues, TemplateResult } from 'lit';
|
|
2
|
+
import { SlashCommand } from '../ai-chatbot/types.js';
|
|
2
3
|
declare global {
|
|
3
4
|
interface HTMLElementTagNameMap {
|
|
4
5
|
'forge-ai-prompt': AiPromptComponent;
|
|
@@ -8,6 +9,8 @@ declare global {
|
|
|
8
9
|
'forge-ai-prompt-cancel': CustomEvent<void>;
|
|
9
10
|
'forge-ai-prompt-attachment': CustomEvent<ForgeAiPromptAttachmentEventData>;
|
|
10
11
|
'forge-ai-prompt-stop': CustomEvent<void>;
|
|
12
|
+
'forge-ai-prompt-debug-toggle': CustomEvent<void>;
|
|
13
|
+
'forge-ai-prompt-command': CustomEvent<ForgeAiPromptCommandEventData>;
|
|
11
14
|
}
|
|
12
15
|
}
|
|
13
16
|
export interface ForgeAiPromptSendEventData {
|
|
@@ -18,6 +21,11 @@ export interface ForgeAiPromptSendEventData {
|
|
|
18
21
|
export interface ForgeAiPromptAttachmentEventData {
|
|
19
22
|
files: File[];
|
|
20
23
|
}
|
|
24
|
+
export interface ForgeAiPromptCommandEventData {
|
|
25
|
+
commandId: string;
|
|
26
|
+
group: string;
|
|
27
|
+
timestamp: Date;
|
|
28
|
+
}
|
|
21
29
|
export type AiPromptVariant = 'stacked' | 'inline';
|
|
22
30
|
export declare const AiPromptComponentTagName: keyof HTMLElementTagNameMap;
|
|
23
31
|
/**
|
|
@@ -32,6 +40,7 @@ export declare const AiPromptComponentTagName: keyof HTMLElementTagNameMap;
|
|
|
32
40
|
* @event {CustomEvent<void>} forge-ai-prompt-cancel - Fired when the Escape key is pressed (if cancelOnEscape is true).
|
|
33
41
|
* @event {CustomEvent<ForgeAiPromptAttachmentEventData>} forge-ai-prompt-attachment - Fired when files are pasted into the textarea.
|
|
34
42
|
* @event {CustomEvent<void>} forge-ai-prompt-stop - Fired when the stop button is clicked. Cancelable - if cancelled, running state remains true.
|
|
43
|
+
* @event {CustomEvent<void>} forge-ai-prompt-debug-toggle - Fired when the debug icon button is clicked.
|
|
35
44
|
*/
|
|
36
45
|
export declare class AiPromptComponent extends LitElement {
|
|
37
46
|
#private;
|
|
@@ -52,8 +61,15 @@ export declare class AiPromptComponent extends LitElement {
|
|
|
52
61
|
cancelOnEscape: boolean;
|
|
53
62
|
/** Whether the component is in running state (shows stop button instead of send button) */
|
|
54
63
|
running: boolean;
|
|
64
|
+
/** Whether debug mode is active (shows debug icon button) */
|
|
65
|
+
debugMode: boolean;
|
|
66
|
+
/** Available slash commands */
|
|
67
|
+
slashCommands: SlashCommand[];
|
|
68
|
+
private _slashMenuOpen;
|
|
69
|
+
private _slashMenuQuery;
|
|
55
70
|
private _actionsSlottedNodes;
|
|
56
71
|
private _inputElement;
|
|
72
|
+
private _slashMenuElement;
|
|
57
73
|
constructor();
|
|
58
74
|
willUpdate(changedProperties: PropertyValues<this>): void;
|
|
59
75
|
firstUpdated(): void;
|
|
@@ -62,7 +78,12 @@ export declare class AiPromptComponent extends LitElement {
|
|
|
62
78
|
private _handleKeyDown;
|
|
63
79
|
private _handleStop;
|
|
64
80
|
private _handleEscape;
|
|
81
|
+
private _handleDebugToggle;
|
|
65
82
|
private _handlePaste;
|
|
83
|
+
/**
|
|
84
|
+
* Closes the slash command menu
|
|
85
|
+
*/
|
|
86
|
+
closeSlashMenu(): void;
|
|
66
87
|
/**
|
|
67
88
|
* Focuses the textarea element
|
|
68
89
|
*/
|