@amboss/design-system 3.10.2 → 3.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,13 @@
1
+ import type { ReactElement, RefObject } from "react";
2
+ import { type FlattenedListItem, type ListItemsByCategory, type CategoryListProps } from "./CategoryList";
3
+ import { type PortalProps } from "../Portal/Portal";
4
+ import type { PromptTextAreaProps } from "./PromptTextArea";
5
+ export type AutocompleteListProps = {
6
+ autocompleteListItems?: ListItemsByCategory[];
7
+ triggerRef: RefObject<HTMLDivElement>;
8
+ selectedListItem?: FlattenedListItem;
9
+ isOpen: boolean;
10
+ autocompleteListFooter?: ReactElement;
11
+ } & Pick<CategoryListProps, "onListItemClick"> & Pick<PromptTextAreaProps, "name" | "value"> & Pick<PortalProps, "portalContainer">;
12
+ export declare function getAutocompleteListId(name: string): string;
13
+ export declare function AutocompleteList({ name, value, autocompleteListItems, triggerRef, portalContainer, selectedListItem, isOpen, autocompleteListFooter, onListItemClick, }: AutocompleteListProps): ReactElement;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get AutocompleteList(){return AutocompleteList},get getAutocompleteListId(){return getAutocompleteListId}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Box=require("../Box/Box"),_Stack=require("../Stack/Stack"),_CategoryList=require("./CategoryList"),_Container=require("../Container"),_usePopupMenu=require("../../shared/popupMenu/usePopupMenu"),_Portal=require("../Portal/Portal"),_Inline=require("../Inline/Inline");function getAutocompleteListId(name){return`${name}_AutocompleteList`}const StyledContainer=(0,_styled.default)("div",{target:"e1ksc4t0",label:"StyledContainer"})(({theme})=>({position:"absolute",zIndex:(0,_Portal.usePortalChildZIndex)(theme.variables.zIndex.dropdown)}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQXV0b2NvbXBsZXRlTGlzdC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1Byb21wdElucHV0L0F1dG9jb21wbGV0ZUxpc3QudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUmVhY3RFbGVtZW50LCBSZWZPYmplY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tIFwiLi4vU3RhY2svU3RhY2tcIjtcbmltcG9ydCB7XG4gIHR5cGUgRmxhdHRlbmVkTGlzdEl0ZW0sXG4gIENhdGVnb3J5TGlzdCxcbiAgdHlwZSBMaXN0SXRlbXNCeUNhdGVnb3J5LFxuICB0eXBlIENhdGVnb3J5TGlzdFByb3BzLFxufSBmcm9tIFwiLi9DYXRlZ29yeUxpc3RcIjtcbmltcG9ydCB7IENvbnRhaW5lciB9IGZyb20gXCIuLi9Db250YWluZXJcIjtcbmltcG9ydCB7IHVzZVBvcHVwTWVudSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvcG9wdXBNZW51L3VzZVBvcHVwTWVudVwiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB0eXBlIFBvcnRhbFByb3BzLFxuICB1c2VQb3J0YWxDaGlsZFpJbmRleCxcbn0gZnJvbSBcIi4uL1BvcnRhbC9Qb3J0YWxcIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgdHlwZSB7IFByb21wdFRleHRBcmVhUHJvcHMgfSBmcm9tIFwiLi9Qcm9tcHRUZXh0QXJlYVwiO1xuXG5leHBvcnQgdHlwZSBBdXRvY29tcGxldGVMaXN0UHJvcHMgPSB7XG4gIGF1dG9jb21wbGV0ZUxpc3RJdGVtcz86IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXTtcbiAgdHJpZ2dlclJlZjogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBpc09wZW46IGJvb2xlYW47XG4gIGF1dG9jb21wbGV0ZUxpc3RGb290ZXI/OiBSZWFjdEVsZW1lbnQ7XG59ICYgUGljazxDYXRlZ29yeUxpc3RQcm9wcywgXCJvbkxpc3RJdGVtQ2xpY2tcIj4gJlxuICBQaWNrPFByb21wdFRleHRBcmVhUHJvcHMsIFwibmFtZVwiIHwgXCJ2YWx1ZVwiPiAmXG4gIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXV0b2NvbXBsZXRlTGlzdElkKG5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV9BdXRvY29tcGxldGVMaXN0YDtcbn1cblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiB7XG4gIGNvbnN0IHpJbmRleCA9IHVzZVBvcnRhbENoaWxkWkluZGV4KHRoZW1lLnZhcmlhYmxlcy56SW5kZXguZHJvcGRvd24pO1xuXG4gIHJldHVybiB7XG4gICAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgICB6SW5kZXgsXG4gIH07XG59KTtcblxuY29uc3QgU3R5bGVkTGlzdENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY2FudmFzLFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy5zLFxufSkpO1xuXG5leHBvcnQgZnVuY3Rpb24gQXV0b2NvbXBsZXRlTGlzdCh7XG4gIG5hbWUsXG4gIHZhbHVlLFxuICBhdXRvY29tcGxldGVMaXN0SXRlbXMsXG4gIHRyaWdnZXJSZWYsXG4gIHBvcnRhbENvbnRhaW5lcixcbiAgc2VsZWN0ZWRMaXN0SXRlbSxcbiAgaXNPcGVuLFxuICBhdXRvY29tcGxldGVMaXN0Rm9vdGVyLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBBdXRvY29tcGxldGVMaXN0UHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBtZW51UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCB7IG1lbnVTdHlsZSwgY2FsY3VsYXRlU3R5bGUgfSA9IHVzZVBvcHVwTWVudSh7XG4gICAgdHJpZ2dlclJlZixcbiAgICBtZW51UmVmLFxuICAgIGlzT3BlbixcbiAgfSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNPcGVuKSB7XG4gICAgICBjYWxjdWxhdGVTdHlsZSgpO1xuICAgIH1cbiAgfSwgW3ZhbHVlLCBjYWxjdWxhdGVTdHlsZSwgaXNPcGVuXSk7XG5cbiAgY29uc3QgbGlzdHMgPSBhdXRvY29tcGxldGVMaXN0SXRlbXMubWFwKChsaXN0SXRlbSkgPT4gKFxuICAgIDxDYXRlZ29yeUxpc3RcbiAgICAgIG5hbWU9e25hbWV9XG4gICAgICBrZXk9e2xpc3RJdGVtLmNhdGVnb3J5fVxuICAgICAgey4uLmxpc3RJdGVtfVxuICAgICAgc2VsZWN0ZWRMaXN0SXRlbT17c2VsZWN0ZWRMaXN0SXRlbX1cbiAgICAgIG9uTGlzdEl0ZW1DbGljaz17b25MaXN0SXRlbUNsaWNrfVxuICAgIC8+XG4gICkpO1xuXG4gIGNvbnN0IGxpc3RTdHlsZSA9IHtcbiAgICAuLi5tZW51U3R5bGUsXG4gICAgd2lkdGg6IHRyaWdnZXJSZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkud2lkdGgsXG4gIH07XG5cbiAgY29uc3QgbGlzdEVsbSA9IChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICByZWY9e21lbnVSZWZ9XG4gICAgICBzdHlsZT17bGlzdFN0eWxlfVxuICAgICAgaWQ9e2dldEF1dG9jb21wbGV0ZUxpc3RJZChuYW1lKX1cbiAgICAgIHJvbGU9XCJsaXN0Ym94XCJcbiAgICA+XG4gICAgICA8Q29udGFpbmVyPlxuICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCI+XG4gICAgICAgICAgPFN0eWxlZExpc3RDb250YWluZXI+XG4gICAgICAgICAgICA8Qm94IHNwYWNlPVwieHNcIiB2U3BhY2U9XCJzXCI+XG4gICAgICAgICAgICAgIDxTdGFjayBzcGFjZT1cInhzXCI+XG4gICAgICAgICAgICAgICAgPFN0YWNrIHNwYWNlPVwic1wiPntsaXN0c308L1N0YWNrPlxuICAgICAgICAgICAgICAgIDxJbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiPnthdXRvY29tcGxldGVMaXN0Rm9vdGVyfTwvSW5saW5lPlxuICAgICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9TdHlsZWRMaXN0Q29udGFpbmVyPlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xuXG4gIHJldHVybiBpc09wZW4gPyAoXG4gICAgPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2xpc3RFbG19PC9Qb3J0YWw+XG4gICkgOiBudWxsO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Dd0IifQ== */"),StyledListContainer=(0,_styled.default)("div",{target:"e1ksc4t1",label:"StyledListContainer"})(({theme})=>({backgroundColor:theme.values.color.canvas,borderRadius:theme.variables.size.borderRadius.s}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQXV0b2NvbXBsZXRlTGlzdC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1Byb21wdElucHV0L0F1dG9jb21wbGV0ZUxpc3QudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUmVhY3RFbGVtZW50LCBSZWZPYmplY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tIFwiLi4vU3RhY2svU3RhY2tcIjtcbmltcG9ydCB7XG4gIHR5cGUgRmxhdHRlbmVkTGlzdEl0ZW0sXG4gIENhdGVnb3J5TGlzdCxcbiAgdHlwZSBMaXN0SXRlbXNCeUNhdGVnb3J5LFxuICB0eXBlIENhdGVnb3J5TGlzdFByb3BzLFxufSBmcm9tIFwiLi9DYXRlZ29yeUxpc3RcIjtcbmltcG9ydCB7IENvbnRhaW5lciB9IGZyb20gXCIuLi9Db250YWluZXJcIjtcbmltcG9ydCB7IHVzZVBvcHVwTWVudSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvcG9wdXBNZW51L3VzZVBvcHVwTWVudVwiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB0eXBlIFBvcnRhbFByb3BzLFxuICB1c2VQb3J0YWxDaGlsZFpJbmRleCxcbn0gZnJvbSBcIi4uL1BvcnRhbC9Qb3J0YWxcIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgdHlwZSB7IFByb21wdFRleHRBcmVhUHJvcHMgfSBmcm9tIFwiLi9Qcm9tcHRUZXh0QXJlYVwiO1xuXG5leHBvcnQgdHlwZSBBdXRvY29tcGxldGVMaXN0UHJvcHMgPSB7XG4gIGF1dG9jb21wbGV0ZUxpc3RJdGVtcz86IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXTtcbiAgdHJpZ2dlclJlZjogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBpc09wZW46IGJvb2xlYW47XG4gIGF1dG9jb21wbGV0ZUxpc3RGb290ZXI/OiBSZWFjdEVsZW1lbnQ7XG59ICYgUGljazxDYXRlZ29yeUxpc3RQcm9wcywgXCJvbkxpc3RJdGVtQ2xpY2tcIj4gJlxuICBQaWNrPFByb21wdFRleHRBcmVhUHJvcHMsIFwibmFtZVwiIHwgXCJ2YWx1ZVwiPiAmXG4gIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXV0b2NvbXBsZXRlTGlzdElkKG5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV9BdXRvY29tcGxldGVMaXN0YDtcbn1cblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiB7XG4gIGNvbnN0IHpJbmRleCA9IHVzZVBvcnRhbENoaWxkWkluZGV4KHRoZW1lLnZhcmlhYmxlcy56SW5kZXguZHJvcGRvd24pO1xuXG4gIHJldHVybiB7XG4gICAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgICB6SW5kZXgsXG4gIH07XG59KTtcblxuY29uc3QgU3R5bGVkTGlzdENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY2FudmFzLFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy5zLFxufSkpO1xuXG5leHBvcnQgZnVuY3Rpb24gQXV0b2NvbXBsZXRlTGlzdCh7XG4gIG5hbWUsXG4gIHZhbHVlLFxuICBhdXRvY29tcGxldGVMaXN0SXRlbXMsXG4gIHRyaWdnZXJSZWYsXG4gIHBvcnRhbENvbnRhaW5lcixcbiAgc2VsZWN0ZWRMaXN0SXRlbSxcbiAgaXNPcGVuLFxuICBhdXRvY29tcGxldGVMaXN0Rm9vdGVyLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBBdXRvY29tcGxldGVMaXN0UHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBtZW51UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCB7IG1lbnVTdHlsZSwgY2FsY3VsYXRlU3R5bGUgfSA9IHVzZVBvcHVwTWVudSh7XG4gICAgdHJpZ2dlclJlZixcbiAgICBtZW51UmVmLFxuICAgIGlzT3BlbixcbiAgfSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNPcGVuKSB7XG4gICAgICBjYWxjdWxhdGVTdHlsZSgpO1xuICAgIH1cbiAgfSwgW3ZhbHVlLCBjYWxjdWxhdGVTdHlsZSwgaXNPcGVuXSk7XG5cbiAgY29uc3QgbGlzdHMgPSBhdXRvY29tcGxldGVMaXN0SXRlbXMubWFwKChsaXN0SXRlbSkgPT4gKFxuICAgIDxDYXRlZ29yeUxpc3RcbiAgICAgIG5hbWU9e25hbWV9XG4gICAgICBrZXk9e2xpc3RJdGVtLmNhdGVnb3J5fVxuICAgICAgey4uLmxpc3RJdGVtfVxuICAgICAgc2VsZWN0ZWRMaXN0SXRlbT17c2VsZWN0ZWRMaXN0SXRlbX1cbiAgICAgIG9uTGlzdEl0ZW1DbGljaz17b25MaXN0SXRlbUNsaWNrfVxuICAgIC8+XG4gICkpO1xuXG4gIGNvbnN0IGxpc3RTdHlsZSA9IHtcbiAgICAuLi5tZW51U3R5bGUsXG4gICAgd2lkdGg6IHRyaWdnZXJSZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkud2lkdGgsXG4gIH07XG5cbiAgY29uc3QgbGlzdEVsbSA9IChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICByZWY9e21lbnVSZWZ9XG4gICAgICBzdHlsZT17bGlzdFN0eWxlfVxuICAgICAgaWQ9e2dldEF1dG9jb21wbGV0ZUxpc3RJZChuYW1lKX1cbiAgICAgIHJvbGU9XCJsaXN0Ym94XCJcbiAgICA+XG4gICAgICA8Q29udGFpbmVyPlxuICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCI+XG4gICAgICAgICAgPFN0eWxlZExpc3RDb250YWluZXI+XG4gICAgICAgICAgICA8Qm94IHNwYWNlPVwieHNcIiB2U3BhY2U9XCJzXCI+XG4gICAgICAgICAgICAgIDxTdGFjayBzcGFjZT1cInhzXCI+XG4gICAgICAgICAgICAgICAgPFN0YWNrIHNwYWNlPVwic1wiPntsaXN0c308L1N0YWNrPlxuICAgICAgICAgICAgICAgIDxJbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiPnthdXRvY29tcGxldGVMaXN0Rm9vdGVyfTwvSW5saW5lPlxuICAgICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9TdHlsZWRMaXN0Q29udGFpbmVyPlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xuXG4gIHJldHVybiBpc09wZW4gPyAoXG4gICAgPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2xpc3RFbG19PC9Qb3J0YWw+XG4gICkgOiBudWxsO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDNEIifQ== */");function AutocompleteList({name,value,autocompleteListItems,triggerRef,portalContainer,selectedListItem,isOpen,autocompleteListFooter,onListItemClick}){let menuRef=(0,_react.useRef)(null),{menuStyle,calculateStyle}=(0,_usePopupMenu.usePopupMenu)({triggerRef,menuRef,isOpen});(0,_react.useEffect)(()=>{isOpen&&calculateStyle()},[value,calculateStyle,isOpen]);let lists=autocompleteListItems.map(listItem=>_react.default.createElement(_CategoryList.CategoryList,{name:name,key:listItem.category,...listItem,selectedListItem:selectedListItem,onListItemClick:onListItemClick})),listStyle={...menuStyle,width:triggerRef.current?.getBoundingClientRect().width},listElm=_react.default.createElement(StyledContainer,{ref:menuRef,style:listStyle,id:getAutocompleteListId(name),role:"listbox"},_react.default.createElement(_Container.Container,null,_react.default.createElement(_Box.Box,{space:"xxs"},_react.default.createElement(StyledListContainer,null,_react.default.createElement(_Box.Box,{space:"xs",vSpace:"s"},_react.default.createElement(_Stack.Stack,{space:"xs"},_react.default.createElement(_Stack.Stack,{space:"s"},lists),_react.default.createElement(_Inline.Inline,{alignItems:"center"},autocompleteListFooter)))))));return isOpen?_react.default.createElement(_Portal.Portal,{portalContainer:portalContainer},listElm):null}
@@ -0,0 +1,25 @@
1
+ import type { ReactElement, ReactNode } from "react";
2
+ import type { IconProps } from "../Icon/Icon";
3
+ export type ListItemProps = {
4
+ iconLeft?: IconProps;
5
+ label: ReactElement;
6
+ value: string;
7
+ };
8
+ export type ListItemsByCategory = {
9
+ category: string;
10
+ iconLeft?: IconProps;
11
+ rightContent?: ReactNode;
12
+ items: ListItemProps[];
13
+ };
14
+ export type FlattenedListItem = {
15
+ category: ListItemsByCategory["category"];
16
+ value: ListItemProps["value"];
17
+ id: string;
18
+ };
19
+ export type CategoryListProps = ListItemsByCategory & {
20
+ name: string;
21
+ selectedListItem?: FlattenedListItem;
22
+ onListItemClick: (category: string, value: string) => void;
23
+ };
24
+ export declare function getListItemId(name: string, category: string, index: number): string;
25
+ export declare function CategoryList({ name, category, iconLeft, rightContent, items, selectedListItem, onListItemClick, }: CategoryListProps): ReactElement;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CategoryList(){return CategoryList},get getListItemId(){return getListItemId}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Header=require("../Typography/Header"),_Icon=require("../Icon/Icon"),_Text=require("../Typography/Text"),_Columns=require("../Column/Columns"),_Stack=require("../Stack/Stack"),_Container=require("../Container"),_Divider=require("../Divider/Divider");function getListItemId(name,category,index){return`${name}_${category}_ListItem${index}`}const StyledIconLeft=(0,_styled.default)(_Icon.Icon,{target:"eetu9430",label:"StyledIconLeft"})(({theme})=>({marginRight:theme.variables.size.spacing.xs}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVByb3BzID0ge1xuICBpY29uTGVmdD86IEljb25Qcm9wcztcbiAgbGFiZWw6IFJlYWN0RWxlbWVudDtcbiAgdmFsdWU6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgdmFsdWU6IExpc3RJdGVtUHJvcHNbXCJ2YWx1ZVwiXTtcbiAgaWQ6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIENhdGVnb3J5TGlzdFByb3BzID0gTGlzdEl0ZW1zQnlDYXRlZ29yeSAmIHtcbiAgbmFtZTogc3RyaW5nO1xuICBzZWxlY3RlZExpc3RJdGVtPzogRmxhdHRlbmVkTGlzdEl0ZW07XG4gIG9uTGlzdEl0ZW1DbGljazogKGNhdGVnb3J5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0TGlzdEl0ZW1JZChcbiAgbmFtZTogc3RyaW5nLFxuICBjYXRlZ29yeTogc3RyaW5nLFxuICBpbmRleDogbnVtYmVyXG4pOiBzdHJpbmcge1xuICByZXR1cm4gYCR7bmFtZX1fJHtjYXRlZ29yeX1fTGlzdEl0ZW0ke2luZGV4fWA7XG59XG5cbmNvbnN0IFN0eWxlZEljb25MZWZ0ID0gc3R5bGVkKEljb24pKCh7IHRoZW1lIH0pID0+ICh7XG4gIG1hcmdpblJpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxufSkpO1xuXG50eXBlIFN0eWxlZExpc3RJdGVtUHJvcHMgPSB7XG4gIGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5kaXY8U3R5bGVkTGlzdEl0ZW1Qcm9wcz4oXG4gICh7IHRoZW1lLCBpc1NlbGVjdGVkIH0pID0+ICh7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSxcblxuICAgIC4uLihpc1NlbGVjdGVkICYmIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gQ2F0ZWdvcnlMaXN0KHtcbiAgbmFtZSxcbiAgY2F0ZWdvcnksXG4gIGljb25MZWZ0LFxuICByaWdodENvbnRlbnQsXG4gIGl0ZW1zLFxuICBzZWxlY3RlZExpc3RJdGVtLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBDYXRlZ29yeUxpc3RQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGxpc3RJdGVtcyA9IGl0ZW1zLm1hcChcbiAgICAoeyBsYWJlbCwgdmFsdWUsIGljb25MZWZ0OiBpdGVtSWNvbkxlZnQgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGxlZnRDb250ZW50ID0gKFxuICAgICAgICA8VGV4dD5cbiAgICAgICAgICB7aWNvbkxlZnQgJiYgKFxuICAgICAgICAgICAgPFN0eWxlZEljb25MZWZ0XG4gICAgICAgICAgICAgIHsuLi4oaXRlbUljb25MZWZ0IHx8IGljb25MZWZ0KX1cbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgaW5saW5lXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L1RleHQ+XG4gICAgICApO1xuICAgICAgY29uc3QgY29udGVudCA9IHJpZ2h0Q29udGVudCA/IChcbiAgICAgICAgPENvbHVtbnM+XG4gICAgICAgICAgPENvbHVtbj57bGVmdENvbnRlbnR9PC9Db2x1bW4+XG4gICAgICAgICAgPENvbHVtbiBzaXplPVwibmFycm93XCI+e3JpZ2h0Q29udGVudH08L0NvbHVtbj5cbiAgICAgICAgPC9Db2x1bW5zPlxuICAgICAgKSA6IChcbiAgICAgICAgbGVmdENvbnRlbnRcbiAgICAgICk7XG5cbiAgICAgIGNvbnN0IGlzU2VsZWN0ZWQgPVxuICAgICAgICBzZWxlY3RlZExpc3RJdGVtICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0udmFsdWUgPT09IHZhbHVlO1xuXG4gICAgICAvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9uby1hcnJheS1pbmRleC1rZXkgKi9cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICA8U3R5bGVkTGlzdEl0ZW1cbiAgICAgICAgICAgIGlkPXtnZXRMaXN0SXRlbUlkKG5hbWUsIGNhdGVnb3J5LCBpbmRleCl9XG4gICAgICAgICAgICByb2xlPVwib3B0aW9uXCJcbiAgICAgICAgICAgIGlzU2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgICBhcmlhLXNlbGVjdGVkPXtpc1NlbGVjdGVkfVxuICAgICAgICAgICAgb25Qb2ludGVyRG93bj17KGV2dCkgPT4gZXZ0LnByZXZlbnREZWZhdWx0KCl9IC8vIG5lZWRlZCB0byBhdm9pZCBmb2N1cyBjaGFuZ2VcbiAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IG9uTGlzdEl0ZW1DbGljayhjYXRlZ29yeSwgdmFsdWUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkTGlzdEl0ZW0+XG4gICAgICAgICAge2luZGV4ICE9PSBpdGVtcy5sZW5ndGggLSAxICYmIDxEaXZpZGVyIC8+fVxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICAgIC8qIGVzbGludC1lbmFibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIHNwYWNlPVwic1wiPlxuICAgICAgPEg2IGFzPVwiZGl2XCI+e2NhdGVnb3J5fTwvSDY+XG4gICAgICA8Q29udGFpbmVyIGVsZXZhdGlvbj17MH0gYm9yZGVyUmFkaXVzPVwic1wiPlxuICAgICAgICA8U3RhY2sgc3BhY2U9XCJ6ZXJvXCI+e2xpc3RJdGVtc308L1N0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgPC9TdGFjaz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Q3VCIn0= */"),StyledListItem=(0,_styled.default)("div",{target:"eetu9431",label:"StyledListItem"})(({theme,isSelected})=>({padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover},...isSelected&&{backgroundColor:theme.values.color.background.transparent.hover}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVByb3BzID0ge1xuICBpY29uTGVmdD86IEljb25Qcm9wcztcbiAgbGFiZWw6IFJlYWN0RWxlbWVudDtcbiAgdmFsdWU6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgdmFsdWU6IExpc3RJdGVtUHJvcHNbXCJ2YWx1ZVwiXTtcbiAgaWQ6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIENhdGVnb3J5TGlzdFByb3BzID0gTGlzdEl0ZW1zQnlDYXRlZ29yeSAmIHtcbiAgbmFtZTogc3RyaW5nO1xuICBzZWxlY3RlZExpc3RJdGVtPzogRmxhdHRlbmVkTGlzdEl0ZW07XG4gIG9uTGlzdEl0ZW1DbGljazogKGNhdGVnb3J5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0TGlzdEl0ZW1JZChcbiAgbmFtZTogc3RyaW5nLFxuICBjYXRlZ29yeTogc3RyaW5nLFxuICBpbmRleDogbnVtYmVyXG4pOiBzdHJpbmcge1xuICByZXR1cm4gYCR7bmFtZX1fJHtjYXRlZ29yeX1fTGlzdEl0ZW0ke2luZGV4fWA7XG59XG5cbmNvbnN0IFN0eWxlZEljb25MZWZ0ID0gc3R5bGVkKEljb24pKCh7IHRoZW1lIH0pID0+ICh7XG4gIG1hcmdpblJpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxufSkpO1xuXG50eXBlIFN0eWxlZExpc3RJdGVtUHJvcHMgPSB7XG4gIGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5kaXY8U3R5bGVkTGlzdEl0ZW1Qcm9wcz4oXG4gICh7IHRoZW1lLCBpc1NlbGVjdGVkIH0pID0+ICh7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSxcblxuICAgIC4uLihpc1NlbGVjdGVkICYmIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gQ2F0ZWdvcnlMaXN0KHtcbiAgbmFtZSxcbiAgY2F0ZWdvcnksXG4gIGljb25MZWZ0LFxuICByaWdodENvbnRlbnQsXG4gIGl0ZW1zLFxuICBzZWxlY3RlZExpc3RJdGVtLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBDYXRlZ29yeUxpc3RQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGxpc3RJdGVtcyA9IGl0ZW1zLm1hcChcbiAgICAoeyBsYWJlbCwgdmFsdWUsIGljb25MZWZ0OiBpdGVtSWNvbkxlZnQgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGxlZnRDb250ZW50ID0gKFxuICAgICAgICA8VGV4dD5cbiAgICAgICAgICB7aWNvbkxlZnQgJiYgKFxuICAgICAgICAgICAgPFN0eWxlZEljb25MZWZ0XG4gICAgICAgICAgICAgIHsuLi4oaXRlbUljb25MZWZ0IHx8IGljb25MZWZ0KX1cbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgaW5saW5lXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L1RleHQ+XG4gICAgICApO1xuICAgICAgY29uc3QgY29udGVudCA9IHJpZ2h0Q29udGVudCA/IChcbiAgICAgICAgPENvbHVtbnM+XG4gICAgICAgICAgPENvbHVtbj57bGVmdENvbnRlbnR9PC9Db2x1bW4+XG4gICAgICAgICAgPENvbHVtbiBzaXplPVwibmFycm93XCI+e3JpZ2h0Q29udGVudH08L0NvbHVtbj5cbiAgICAgICAgPC9Db2x1bW5zPlxuICAgICAgKSA6IChcbiAgICAgICAgbGVmdENvbnRlbnRcbiAgICAgICk7XG5cbiAgICAgIGNvbnN0IGlzU2VsZWN0ZWQgPVxuICAgICAgICBzZWxlY3RlZExpc3RJdGVtICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0udmFsdWUgPT09IHZhbHVlO1xuXG4gICAgICAvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9uby1hcnJheS1pbmRleC1rZXkgKi9cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICA8U3R5bGVkTGlzdEl0ZW1cbiAgICAgICAgICAgIGlkPXtnZXRMaXN0SXRlbUlkKG5hbWUsIGNhdGVnb3J5LCBpbmRleCl9XG4gICAgICAgICAgICByb2xlPVwib3B0aW9uXCJcbiAgICAgICAgICAgIGlzU2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgICBhcmlhLXNlbGVjdGVkPXtpc1NlbGVjdGVkfVxuICAgICAgICAgICAgb25Qb2ludGVyRG93bj17KGV2dCkgPT4gZXZ0LnByZXZlbnREZWZhdWx0KCl9IC8vIG5lZWRlZCB0byBhdm9pZCBmb2N1cyBjaGFuZ2VcbiAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IG9uTGlzdEl0ZW1DbGljayhjYXRlZ29yeSwgdmFsdWUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkTGlzdEl0ZW0+XG4gICAgICAgICAge2luZGV4ICE9PSBpdGVtcy5sZW5ndGggLSAxICYmIDxEaXZpZGVyIC8+fVxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICAgIC8qIGVzbGludC1lbmFibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIHNwYWNlPVwic1wiPlxuICAgICAgPEg2IGFzPVwiZGl2XCI+e2NhdGVnb3J5fTwvSDY+XG4gICAgICA8Q29udGFpbmVyIGVsZXZhdGlvbj17MH0gYm9yZGVyUmFkaXVzPVwic1wiPlxuICAgICAgICA8U3RhY2sgc3BhY2U9XCJ6ZXJvXCI+e2xpc3RJdGVtc308L1N0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgPC9TdGFjaz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRHVCIn0= */");function CategoryList({name,category,iconLeft,rightContent,items,selectedListItem,onListItemClick}){let listItems=items.map(({label,value,iconLeft:itemIconLeft},index)=>{let leftContent=_react.default.createElement(_Text.Text,null,iconLeft&&_react.default.createElement(StyledIconLeft,{...itemIconLeft||iconLeft,size:"s",color:"tertiary",inline:!0}),label),content=rightContent?_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,null,leftContent),_react.default.createElement(_Columns.Column,{size:"narrow"},rightContent)):leftContent,isSelected=selectedListItem&&selectedListItem.category===category&&selectedListItem.value===value;return _react.default.createElement(_react.Fragment,{key:index},_react.default.createElement(StyledListItem,{id:getListItemId(name,category,index),role:"option",isSelected:isSelected,"aria-selected":isSelected,onPointerDown:evt=>evt.preventDefault(),onClick:()=>onListItemClick(category,value)},content),index!==items.length-1&&_react.default.createElement(_Divider.Divider,null))});return _react.default.createElement(_Stack.Stack,{space:"s"},_react.default.createElement(_Header.H6,{as:"div"},category),_react.default.createElement(_Container.Container,{elevation:0,borderRadius:"s"},_react.default.createElement(_Stack.Stack,{space:"zero"},listItems)))}
@@ -0,0 +1,45 @@
1
+ import type { ReactElement } from "react";
2
+ import React from "react";
3
+ import type { PromptTextAreaProps } from "./PromptTextArea";
4
+ import type { AutocompleteListProps } from "./AutocompleteList";
5
+ import type { RoundButtonProps } from "../RoundButton/RoundButton";
6
+ export type PromptInputProps = {
7
+ "data-e2e-test-id"?: string;
8
+ /** Toolbar elements below text area */
9
+ bottomToolbar?: {
10
+ leftContent?: ReactElement;
11
+ rightContent?: ReactElement;
12
+ };
13
+ /** Currently shows send button processing state */
14
+ isProcessing?: boolean;
15
+ sendButtonProps?: Omit<RoundButtonProps, "icon" | "variant">;
16
+ clearButtonAriaLabel?: string;
17
+ hint?: ReactElement;
18
+ /** Shows in the clear button space in empty state */
19
+ emptyStateTopRightContent?: ReactElement;
20
+ onClear: () => void;
21
+ /** Called when user selects (or rejects) a list item from autocomplete list */
22
+ onComplete?: (value: string, category?: string) => void;
23
+ /** Called on Enter key to submit the form */
24
+ onEnterKey: () => void;
25
+ } & Omit<PromptTextAreaProps, "isCollapsed" | "isAutocompleteListOpen" | "selectedListItem"> & Pick<AutocompleteListProps, "autocompleteListItems" | "autocompleteListFooter" | "portalContainer">;
26
+ export declare const PromptInput: React.ForwardRefExoticComponent<{
27
+ "data-e2e-test-id"?: string;
28
+ /** Toolbar elements below text area */
29
+ bottomToolbar?: {
30
+ leftContent?: ReactElement;
31
+ rightContent?: ReactElement;
32
+ };
33
+ /** Currently shows send button processing state */
34
+ isProcessing?: boolean;
35
+ sendButtonProps?: Omit<RoundButtonProps, "icon" | "variant">;
36
+ clearButtonAriaLabel?: string;
37
+ hint?: ReactElement;
38
+ /** Shows in the clear button space in empty state */
39
+ emptyStateTopRightContent?: ReactElement;
40
+ onClear: () => void;
41
+ /** Called when user selects (or rejects) a list item from autocomplete list */
42
+ onComplete?: (value: string, category?: string) => void;
43
+ /** Called on Enter key to submit the form */
44
+ onEnterKey: () => void;
45
+ } & Omit<PromptTextAreaProps, "selectedListItem" | "isAutocompleteListOpen" | "isCollapsed"> & Pick<AutocompleteListProps, "portalContainer" | "autocompleteListItems" | "autocompleteListFooter"> & React.RefAttributes<HTMLTextAreaElement>>;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PromptInput",{enumerable:!0,get:function(){return PromptInput}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_PromptTextArea=require("./PromptTextArea"),_Container=require("../Container"),_AutocompleteList=require("./AutocompleteList"),_CategoryList=require("./CategoryList"),_Box=require("../Box/Box"),_Text=require("../Typography/Text"),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline"),_RoundButton=require("../RoundButton/RoundButton"),_PictogramButton=require("../PictogramButton/PictogramButton"),_Stack=require("../Stack/Stack"),StyledTextAreaContainer=(0,_styled.default)("div",{target:"e4n8w5o0",label:"StyledTextAreaContainer"})({position:"relative"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\">;\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                icon={isProcessing ? \"square\" : \"send\"}\n                variant=\"primary\"\n                disabled={!value}\n                {...sendButtonProps}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <Container\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </Container>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgCgC"} */"),StyledEmptyStateTopRightContentContainer=(0,_styled.default)("div",{target:"e4n8w5o1",label:"StyledEmptyStateTopRightContentContainer"})(({theme,isNavBarVariant})=>({position:"absolute",top:isNavBarVariant?theme.variables.size.spacing.xxs:theme.variables.size.spacing.m,right:theme.variables.size.spacing.m,userSelect:"none",pointerEvents:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\">;\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                icon={isProcessing ? \"square\" : \"send\"}\n                variant=\"primary\"\n                disabled={!value}\n                {...sendButtonProps}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <Container\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </Container>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0CE"} */"),StyledClearButton=(0,_styled.default)(_PictogramButton.PictogramButton,{target:"e4n8w5o2",label:"StyledClearButton"})(({theme,isNavBarVariant})=>({position:"absolute",right:theme.variables.size.spacing.s,top:isNavBarVariant?0:theme.variables.size.spacing.s}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\">;\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                icon={isProcessing ? \"square\" : \"send\"}\n                variant=\"primary\"\n                disabled={!value}\n                {...sendButtonProps}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <Container\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </Container>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AAyD0B"} */"),PromptInput=(0,_react.forwardRef)(({"data-e2e-test-id":dataE2eTestId,name,autocompleteListItems=[],value,bottomToolbar={leftContent:null,rightContent:null},isProcessing,sendButtonProps={type:"submit"},autocompleteListFooter,clearButtonAriaLabel="Clear input",hint,emptyStateTopRightContent,isNavBarVariant,portalContainer,onChange,onComplete,onClear,onEnterKey,onFocus,onBlur,onKeyDown,...rest},ref)=>{let containerRef=(0,_react.useRef)(null),textAreaContainerRef=(0,_react.useRef)(null),internalRef=(0,_react.useRef)(null),[selectedIndex,setSelectedIndex]=(0,_react.useState)(-1),[isCollapsed,setIsCollapsed]=(0,_react.useState)(isNavBarVariant),userTypedQuery=(0,_react.useRef)(""),[isAutocompleteListOpen,setIsAutocompleteListOpen]=(0,_react.useState)(!1),textAreaRef=ref||internalRef,closeAutocompleteList=(0,_react.useCallback)(()=>{setIsAutocompleteListOpen(!1),setSelectedIndex(-1)},[]),openAutocompleteList=(0,_react.useCallback)(()=>{autocompleteListItems.length&&(setIsAutocompleteListOpen(!0),setSelectedIndex(-1))},[autocompleteListItems]),acceptTextSelection=()=>{userTypedQuery.current=value,textAreaRef.current.setSelectionRange(value.length,value.length)};(0,_react.useEffect)(()=>{autocompleteListItems.length&&!isCollapsed?openAutocompleteList():closeAutocompleteList()},[autocompleteListItems,openAutocompleteList,closeAutocompleteList,isCollapsed]),(0,_react.useEffect)(()=>{value&&value!==userTypedQuery.current&&isAutocompleteListOpen&&textAreaRef.current.setSelectionRange(userTypedQuery.current.length,value.length)},[value,textAreaRef,isAutocompleteListOpen]),(0,_react.useEffect)(()=>{let handler,container=containerRef.current;return isNavBarVariant&&container&&(handler=evt=>{containerRef.current.contains(evt.relatedTarget)||setIsCollapsed(!0)},containerRef.current.addEventListener("focusout",handler)),()=>{container&&container.removeEventListener("focusout",handler)}},[isNavBarVariant,containerRef]);let flattenedListItems=(0,_react.useMemo)(()=>{let list=[];return autocompleteListItems.forEach(listItem=>{listItem.items.forEach((item,index)=>{list.push({category:listItem.category,value:item.value,id:(0,_CategoryList.getListItemId)(name,listItem.category,index)})})}),list},[autocompleteListItems,name]),handleSelectedIndexChange=index=>{if(setSelectedIndex(index),-1!==index){let{category,value:itemValue}=flattenedListItems[index];onComplete(itemValue,category)}},selectedListItem=-1!==selectedIndex?flattenedListItems[selectedIndex]:null,emptyStateTopRightContentElm=emptyStateTopRightContent?_react.default.createElement(StyledEmptyStateTopRightContentContainer,{isNavBarVariant:isNavBarVariant},_react.default.createElement(_Text.Text,{color:"tertiary"},emptyStateTopRightContent)):null,clearButtonElm=value?_react.default.createElement(StyledClearButton,{size:"s",icon:"x","aria-label":clearButtonAriaLabel,isNavBarVariant:isNavBarVariant,onPointerDown:evt=>evt.preventDefault(),onClick:onClear}):emptyStateTopRightContentElm,hintElm=!!hint&&_react.default.createElement(_Inline.Inline,{alignItems:"center"},_react.default.createElement(_Text.Text,{size:"s",color:"tertiary"},hint)),bottomToolbarElm=!isCollapsed&&_react.default.createElement(_Box.Box,{space:"m","data-e2e-test-id":"bottomToolbar"},_react.default.createElement(_Columns.Columns,{gap:"s",alignItems:"spaceBetween",vAlignItems:"center"},_react.default.createElement(_Columns.Column,null,bottomToolbar.leftContent),_react.default.createElement(_Columns.Column,{size:"narrow"},_react.default.createElement(_Inline.Inline,{space:"xs",vAlignItems:"center"},bottomToolbar.rightContent,_react.default.createElement(_RoundButton.RoundButton,{ariaAttributes:{"aria-label":isProcessing?"Processing query":"Submit query"},icon:isProcessing?"square":"send",variant:"primary",disabled:!value,...sendButtonProps})))));return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement("div",{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PromptInput",ref:containerRef},_react.default.createElement(_Stack.Stack,{space:"s"},_react.default.createElement("div",{ref:textAreaContainerRef},_react.default.createElement(_Container.Container,{elevation:+!isCollapsed,borderRadius:isCollapsed?"s":"m"},_react.default.createElement(StyledTextAreaContainer,null,_react.default.createElement(_PromptTextArea.PromptTextArea,{...rest,name:name,value:value,ref:textAreaRef,isNavBarVariant:isNavBarVariant,selectedListItem:selectedListItem,isAutocompleteListOpen:isAutocompleteListOpen,isCollapsed:isCollapsed,onFocus:evt=>{setIsCollapsed(!1),onFocus?.(evt)},onBlur:evt=>{value!==userTypedQuery.current&&onComplete?.(userTypedQuery.current),onBlur?.(evt)},onChange:evt=>{userTypedQuery.current=evt.target.value,onChange(evt)},onKeyDown:evt=>{if(isAutocompleteListOpen)switch(evt.key){case"Escape":closeAutocompleteList(),onComplete(userTypedQuery.current);break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),closeAutocompleteList(),acceptTextSelection(),value&&onEnterKey?.());break;case" ":acceptTextSelection();break;case"ArrowUp":evt.preventDefault(),selectedIndex>-1&&handleSelectedIndexChange(selectedIndex-1);break;case"ArrowDown":evt.preventDefault(),selectedIndex<flattenedListItems.length-1&&handleSelectedIndexChange(selectedIndex+1)}else switch(evt.key){case"Escape":onClear?.();break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),value&&onEnterKey?.())}onKeyDown?.(evt)}}),clearButtonElm),bottomToolbarElm)),hintElm)),_react.default.createElement(_AutocompleteList.AutocompleteList,{name:name,value:value,autocompleteListItems:autocompleteListItems,triggerRef:textAreaContainerRef,selectedListItem:selectedListItem,isOpen:isAutocompleteListOpen,autocompleteListFooter:autocompleteListFooter,portalContainer:portalContainer,onListItemClick:(category,itemValue)=>{handleSelectedIndexChange(flattenedListItems.findIndex(listItem=>listItem.category===category&&listItem.value===itemValue)),closeAutocompleteList()}}))});
@@ -0,0 +1,26 @@
1
+ import type { TextareaHTMLAttributes } from "react";
2
+ import React from "react";
3
+ import type { Property } from "csstype";
4
+ import type { FlattenedListItem } from "./CategoryList";
5
+ export type PromptTextAreaProps = TextareaHTMLAttributes<HTMLTextAreaElement> & {
6
+ label: string;
7
+ name: string;
8
+ value: string;
9
+ maxTextAreaHeight?: Property.Height;
10
+ selectedListItem?: FlattenedListItem;
11
+ isAutocompleteListOpen?: boolean;
12
+ isCollapsed?: boolean;
13
+ /** Collapsed variant showing only single row text area */
14
+ isNavBarVariant?: boolean;
15
+ };
16
+ export declare const PromptTextArea: React.ForwardRefExoticComponent<TextareaHTMLAttributes<HTMLTextAreaElement> & {
17
+ label: string;
18
+ name: string;
19
+ value: string;
20
+ maxTextAreaHeight?: Property.Height;
21
+ selectedListItem?: FlattenedListItem;
22
+ isAutocompleteListOpen?: boolean;
23
+ isCollapsed?: boolean;
24
+ /** Collapsed variant showing only single row text area */
25
+ isNavBarVariant?: boolean;
26
+ } & React.RefAttributes<HTMLTextAreaElement>>;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PromptTextArea",{enumerable:!0,get:function(){return PromptTextArea}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ScreenReaderText=require("../Utilities/ScreenReaderText/ScreenReaderText"),_AutocompleteList=require("./AutocompleteList"),StyledTextAreaContainer=(0,_styled.default)("label",{target:"e16ka3080",label:"StyledTextAreaContainer"})(({theme,maxTextAreaHeight,isCollapsed,isNavBarVariant})=>({display:"grid",verticalAlign:"top",alignItems:"stretch",width:"100%",borderRadius:"inherit",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,...isCollapsed&&{backgroundColor:theme.values.color.canvas},"&::after":{content:"attr(data-value) ' '",boxSizing:"border-box",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,gridArea:"1 / 1",whiteSpace:"pre-wrap",visibility:"hidden",maxHeight:maxTextAreaHeight},textarea:{all:"unset",resize:"none",gridArea:"1 / 1",...isCollapsed&&{overflow:"hidden"}},"&::after, textarea":{padding:isNavBarVariant?`${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.xxl} ${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xxl} ${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,...!isCollapsed&&{paddingBottom:theme.variables.size.spacing.m}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvUHJvbXB0VGV4dEFyZWEudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Qcm9tcHRJbnB1dC9Qcm9tcHRUZXh0QXJlYS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZWZPYmplY3QsIFRleHRhcmVhSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmLCB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBQcm9wZXJ0eSB9IGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQgeyBTY3JlZW5SZWFkZXJUZXh0IH0gZnJvbSBcIi4uL1V0aWxpdGllcy9TY3JlZW5SZWFkZXJUZXh0L1NjcmVlblJlYWRlclRleHRcIjtcbmltcG9ydCB7IGdldEF1dG9jb21wbGV0ZUxpc3RJZCB9IGZyb20gXCIuL0F1dG9jb21wbGV0ZUxpc3RcIjtcbmltcG9ydCB0eXBlIHsgRmxhdHRlbmVkTGlzdEl0ZW0gfSBmcm9tIFwiLi9DYXRlZ29yeUxpc3RcIjtcblxuZXhwb3J0IHR5cGUgUHJvbXB0VGV4dEFyZWFQcm9wcyA9XG4gIFRleHRhcmVhSFRNTEF0dHJpYnV0ZXM8SFRNTFRleHRBcmVhRWxlbWVudD4gJiB7XG4gICAgbGFiZWw6IHN0cmluZztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgdmFsdWU6IHN0cmluZztcbiAgICBtYXhUZXh0QXJlYUhlaWdodD86IFByb3BlcnR5LkhlaWdodDtcbiAgICBzZWxlY3RlZExpc3RJdGVtPzogRmxhdHRlbmVkTGlzdEl0ZW07XG4gICAgaXNBdXRvY29tcGxldGVMaXN0T3Blbj86IGJvb2xlYW47XG4gICAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICAgIC8qKiBDb2xsYXBzZWQgdmFyaWFudCBzaG93aW5nIG9ubHkgc2luZ2xlIHJvdyB0ZXh0IGFyZWEgKi9cbiAgICBpc05hdkJhclZhcmlhbnQ/OiBib29sZWFuO1xuICB9O1xuXG50eXBlIFN0eWxlZFRleHRBcmVhQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBQcm9tcHRUZXh0QXJlYVByb3BzLFxuICBcIm1heFRleHRBcmVhSGVpZ2h0XCIgfCBcImlzQ29sbGFwc2VkXCIgfCBcImlzTmF2QmFyVmFyaWFudFwiXG4+O1xuXG4vLyBUZXh0YXJlYSBhdXRvIGdyb3cgaW1wbGVtZW50ZWQgYWNjb3JkaW5nIHRvIGh0dHBzOi8vY3NzLXRyaWNrcy5jb20vdGhlLWNsZWFuZXN0LXRyaWNrLWZvci1hdXRvZ3Jvd2luZy10ZXh0YXJlYXMvXG5jb25zdCBTdHlsZWRUZXh0QXJlYUNvbnRhaW5lciA9IHN0eWxlZC5sYWJlbDxTdHlsZWRUZXh0QXJlYUNvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIG1heFRleHRBcmVhSGVpZ2h0LCBpc0NvbGxhcHNlZCwgaXNOYXZCYXJWYXJpYW50IH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJncmlkXCIsXG4gICAgdmVydGljYWxBbGlnbjogXCJ0b3BcIixcbiAgICBhbGlnbkl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250Lm0sXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54bCxcblxuICAgIC4uLihpc0NvbGxhcHNlZCAmJiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jYW52YXMsXG4gICAgfSksXG5cbiAgICBcIiY6OmFmdGVyXCI6IHtcbiAgICAgIGNvbnRlbnQ6IFwiYXR0cihkYXRhLXZhbHVlKSAnICdcIiwgLy8gdGhlIGVtcHR5IHNwYWNlIHByZXZlbnRzIHRleHRhcmVhIGp1bXAgb24gZ3Jvd1xuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgZ3JpZEFyZWE6IFwiMSAvIDFcIixcbiAgICAgIHdoaXRlU3BhY2U6IFwicHJlLXdyYXBcIixcbiAgICAgIHZpc2liaWxpdHk6IFwiaGlkZGVuXCIsXG4gICAgICBtYXhIZWlnaHQ6IG1heFRleHRBcmVhSGVpZ2h0LFxuICAgIH0sXG5cbiAgICB0ZXh0YXJlYToge1xuICAgICAgYWxsOiBcInVuc2V0XCIsXG4gICAgICByZXNpemU6IFwibm9uZVwiLFxuICAgICAgZ3JpZEFyZWE6IFwiMSAvIDFcIixcblxuICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgb3ZlcmZsb3c6IFwiaGlkZGVuXCIsXG4gICAgICB9KSxcbiAgICB9LFxuXG4gICAgXCImOjphZnRlciwgdGV4dGFyZWFcIjoge1xuICAgICAgcGFkZGluZzogaXNOYXZCYXJWYXJpYW50XG4gICAgICAgID8gYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHN9ICAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhsfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzfSAgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YFxuICAgICAgICA6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4bH0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG5cbiAgICAgIC4uLighaXNDb2xsYXBzZWQgJiYge1xuICAgICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sXG4gICAgICB9KSxcbiAgICB9LFxuICB9KVxuKTtcblxuZXhwb3J0IGNvbnN0IFByb21wdFRleHRBcmVhID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGxhYmVsLFxuICAgICAgbmFtZSxcbiAgICAgIHZhbHVlLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICBtYXhUZXh0QXJlYUhlaWdodCA9IFwiMjAwcHhcIixcbiAgICAgIHNlbGVjdGVkTGlzdEl0ZW0sXG4gICAgICBpc0F1dG9jb21wbGV0ZUxpc3RPcGVuLFxuICAgICAgaXNDb2xsYXBzZWQsXG4gICAgICBpc05hdkJhclZhcmlhbnQsXG4gICAgICBvbkNoYW5nZSxcbiAgICAgIC4uLnJlc3RcbiAgICB9OiBQcm9tcHRUZXh0QXJlYVByb3BzLFxuICAgIHJlZjogUmVmT2JqZWN0PEhUTUxUZXh0QXJlYUVsZW1lbnQ+XG4gICkgPT4ge1xuICAgIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgICBjb25zdCB0ZXh0QXJlYSA9IHJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAoaXNDb2xsYXBzZWQpIHtcbiAgICAgICAgKHRleHRBcmVhLnBhcmVudE5vZGUgYXMgSFRNTEVsZW1lbnQpLmRhdGFzZXQudmFsdWUgPSBcIlwiO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gU2V0IHRoZSB2YWx1ZSBvZiB0aGUgOjphZnRlciBwc3VlZG8gZWxlbWVudCBzbyB0aGF0IHRoZSBUZXh0QXJlYSByZXNpemVzIGFjY29yZGluZ2x5IGFzIHRoZSBncmlkIHN0cmV0Y2hlcy5cbiAgICAgICAgKHRleHRBcmVhLnBhcmVudE5vZGUgYXMgSFRNTEVsZW1lbnQpLmRhdGFzZXQudmFsdWUgPSB2YWx1ZTtcbiAgICAgIH1cbiAgICB9LCBbdmFsdWUsIHJlZiwgaXNDb2xsYXBzZWRdKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkVGV4dEFyZWFDb250YWluZXJcbiAgICAgICAgbWF4VGV4dEFyZWFIZWlnaHQ9e21heFRleHRBcmVhSGVpZ2h0fVxuICAgICAgICBpc0NvbGxhcHNlZD17aXNDb2xsYXBzZWR9XG4gICAgICAgIGlzTmF2QmFyVmFyaWFudD17aXNOYXZCYXJWYXJpYW50fVxuICAgICAgPlxuICAgICAgICA8U2NyZWVuUmVhZGVyVGV4dD57bGFiZWx9PC9TY3JlZW5SZWFkZXJUZXh0PlxuICAgICAgICA8dGV4dGFyZWFcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICBuYW1lPXtuYW1lfVxuICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICBwbGFjZWhvbGRlcj17cGxhY2Vob2xkZXJ9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHJvd3M9ezF9XG4gICAgICAgICAgcm9sZT1cImNvbWJvYm94XCJcbiAgICAgICAgICBhcmlhLWF1dG9jb21wbGV0ZT1cImxpc3RcIlxuICAgICAgICAgIGFyaWEtY29udHJvbHM9e1xuICAgICAgICAgICAgaXNBdXRvY29tcGxldGVMaXN0T3BlbiA/IGdldEF1dG9jb21wbGV0ZUxpc3RJZChuYW1lKSA6IFwiXCJcbiAgICAgICAgICB9XG4gICAgICAgICAgYXJpYS1hY3RpdmVkZXNjZW5kYW50PXtzZWxlY3RlZExpc3RJdGVtID8gc2VsZWN0ZWRMaXN0SXRlbS5pZCA6IFwiXCJ9XG4gICAgICAgICAgYXJpYS1leHBhbmRlZD17aXNBdXRvY29tcGxldGVMaXN0T3Blbn1cbiAgICAgICAgLz5cbiAgICAgIDwvU3R5bGVkVGV4dEFyZWFDb250YWluZXI+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQmdDIn0= */"),PromptTextArea=(0,_react.forwardRef)(({label,name,value,placeholder,maxTextAreaHeight="200px",selectedListItem,isAutocompleteListOpen,isCollapsed,isNavBarVariant,onChange,...rest},ref)=>((0,_react.useEffect)(()=>{let textArea=ref.current;isCollapsed?textArea.parentNode.dataset.value="":textArea.parentNode.dataset.value=value},[value,ref,isCollapsed]),_react.default.createElement(StyledTextAreaContainer,{maxTextAreaHeight:maxTextAreaHeight,isCollapsed:isCollapsed,isNavBarVariant:isNavBarVariant},_react.default.createElement(_ScreenReaderText.ScreenReaderText,null,label),_react.default.createElement("textarea",{...rest,ref:ref,name:name,value:value,placeholder:placeholder,onChange:onChange,rows:1,role:"combobox","aria-autocomplete":"list","aria-controls":isAutocompleteListOpen?(0,_AutocompleteList.getAutocompleteListId)(name):"","aria-activedescendant":selectedListItem?selectedListItem.id:"","aria-expanded":isAutocompleteListOpen}))));
@@ -78,3 +78,4 @@ export * from "./components/Utilities/ContainerQuery/ContainerQuery";
78
78
  export * from "./components/Utilities/ScreenReaderText/ScreenReaderText";
79
79
  export * from "./components/CatalogCard/CatalogCard";
80
80
  export * from "./components/MediaViewerCarousel/MediaViewerCarousel";
81
+ export * from "./components/PromptInput/PromptInput";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports),_export_star._(require("./components/PromptInput/PromptInput"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
@@ -154,6 +154,7 @@
154
154
  "rotate-ccw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-rotate-ccw\" viewBox=\"0 0 24 24\"><path d=\"M1 4v6h6\"/><path d=\"M3.51 15a9 9 0 1 0 2.13-9.36L1 10\"/></svg>",
155
155
  "rotate-cw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-rotate-cw\" viewBox=\"0 0 24 24\"><path d=\"M23 4v6h-6\"/><path d=\"M20.49 15a9 9 0 1 1-2.12-9.36L23 10\"/></svg>",
156
156
  "search": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-search\" viewBox=\"0 0 24 24\"><circle cx=\"11\" cy=\"11\" r=\"8\"/><path d=\"m21 21-4.35-4.35\"/></svg>",
157
+ "search-ai": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" d=\"M10.5 2a8.5 8.5 0 0 1 8.5 8.5 8.46 8.46 0 0 1-1.826 5.26l4.533 4.533a1 1 0 1 1-1.414 1.414l-4.533-4.533a8.46 8.46 0 0 1-3.756 1.69l1.063-2.392a6.5 6.5 0 0 0 1.98-1.328q.022-.027.046-.051l.05-.046A6.5 6.5 0 1 0 4.12 9.245l-2.116 1.059A8.5 8.5 0 0 1 10.5 2m-.625 10.125L14 14l-4.125 1.875L8 20l-1.875-4.125L2 14l4.125-1.875L8 8zm-2.617 1.133L5.622 14l1.636.742L8 16.378l.742-1.636L10.378 14l-1.636-.742L8 11.622z\"/></svg>",
157
158
  "search-list": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M4 6h16m-5 6h5m-4 6h4\"/><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M7.125 19.5a4.375 4.375 0 1 0 0-8.75 4.375 4.375 0 0 0 0 8.75\" clip-rule=\"evenodd\"/><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"m13.25 21.25-3.033-3.033\"/></svg>",
158
159
  "send": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M22.727 1.314a1 1 0 0 0-1.079-.25L1.67 8.055a1 1 0 0 0-.076 1.858l8.648 3.844 3.844 8.648a1 1 0 0 0 1.858-.076L22.937 2.35a1 1 0 0 0-.21-1.037ZM18.194 4.39 4.711 9.111l6.067 2.696 7.416-7.416Zm-6.001 8.83 7.415-7.415-4.719 13.483z\" clip-rule=\"evenodd\"/></svg>",
159
160
  "settings": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-settings\" viewBox=\"0 0 24 24\"><circle cx=\"12\" cy=\"12\" r=\"3\"/><path d=\"M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1\"/></svg>",
@@ -154,6 +154,7 @@
154
154
  "rotate-ccw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M2 3v4h4M3.859 5.437a4.93 4.93 0 1 1-.165 4.927\"/></svg>",
155
155
  "rotate-cw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M14 3v4h-4m2.141-1.563a4.93 4.93 0 1 0 .165 4.927\"/></svg>",
156
156
  "search": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M7 12A5 5 0 1 0 7 2a5 5 0 0 0 0 10\" clip-rule=\"evenodd\"/><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"m14 14-3.467-3.467\"/></svg>",
157
+ "search-ai": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" d=\"M6.667 1a5.667 5.667 0 0 1 4.651 8.904l3.389 3.389a1 1 0 1 1-1.414 1.414l-3.389-3.389a5.64 5.64 0 0 1-3.107 1.012l.96-2.162a3.668 3.668 0 1 0-4.642-4.42L1.003 6.805 1 6.667A5.667 5.667 0 0 1 6.667 1m-.573 6.406L8.5 8.5 6.094 9.594 5 12 3.906 9.594 1.5 8.5l2.406-1.094L5 5z\"/></svg>",
157
158
  "search-list": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"><path d=\"M2 3h12m-3 4h3m-2 4h2\"/><path d=\"M4.5 14a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7\" clip-rule=\"evenodd\"/><path d=\"m9 15-2-2\"/></g></svg>",
158
159
  "send": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g clip-path=\"url(#a)\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M15.374.626a1 1 0 0 1 .236 1.038l-4.666 13.333a1 1 0 0 1-1.858.076l-2.51-5.649-5.649-2.51a1 1 0 0 1 .076-1.858L14.336.39a1 1 0 0 1 1.038.237ZM8.526 8.888l1.363 3.068 2.386-6.817zm2.335-5.163L4.044 6.11l3.068 1.363 3.749-3.75Z\" clip-rule=\"evenodd\"/></g><defs><clipPath id=\"a\"><path fill=\"#fff\" d=\"M0 0h16v16H0z\"/></clipPath></defs></svg>",
159
160
  "settings": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g fill-rule=\"evenodd\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" clip-rule=\"evenodd\"><path d=\"M8 10a2 2 0 1 0 0-4 2 2 0 0 0 0 4\"/><path d=\"M12.71 9.91a1.05 1.05 0 0 0 .21 1.157l.037.039a1.272 1.272 0 1 1-1.8 1.8l-.039-.038a1.05 1.05 0 0 0-1.158-.21 1.05 1.05 0 0 0-.636.961v.108a1.273 1.273 0 0 1-2.546 0v-.057a1.05 1.05 0 0 0-.687-.96 1.05 1.05 0 0 0-1.158.21l-.038.037a1.273 1.273 0 1 1-1.801-1.8l.038-.039c.3-.307.383-.765.21-1.158a1.05 1.05 0 0 0-.961-.636h-.108a1.273 1.273 0 1 1 0-2.546h.057a1.05 1.05 0 0 0 .96-.687 1.05 1.05 0 0 0-.21-1.158l-.037-.038a1.273 1.273 0 1 1 1.8-1.801l.039.038c.307.3.765.383 1.158.21h.05a1.05 1.05 0 0 0 .637-.961v-.108a1.273 1.273 0 1 1 2.546 0v.057c.001.419.251.796.636.96.393.174.851.091 1.158-.21l.039-.037a1.273 1.273 0 1 1 1.8 1.8l-.038.039a1.05 1.05 0 0 0-.21 1.158v.05c.165.386.543.636.961.637h.108a1.273 1.273 0 0 1 0 2.546h-.057a1.05 1.05 0 0 0-.96.636z\"/></g></svg>",
@@ -0,0 +1,13 @@
1
+ import type { ReactElement, RefObject } from "react";
2
+ import { type FlattenedListItem, type ListItemsByCategory, type CategoryListProps } from "./CategoryList";
3
+ import { type PortalProps } from "../Portal/Portal";
4
+ import type { PromptTextAreaProps } from "./PromptTextArea";
5
+ export type AutocompleteListProps = {
6
+ autocompleteListItems?: ListItemsByCategory[];
7
+ triggerRef: RefObject<HTMLDivElement>;
8
+ selectedListItem?: FlattenedListItem;
9
+ isOpen: boolean;
10
+ autocompleteListFooter?: ReactElement;
11
+ } & Pick<CategoryListProps, "onListItemClick"> & Pick<PromptTextAreaProps, "name" | "value"> & Pick<PortalProps, "portalContainer">;
12
+ export declare function getAutocompleteListId(name: string): string;
13
+ export declare function AutocompleteList({ name, value, autocompleteListItems, triggerRef, portalContainer, selectedListItem, isOpen, autocompleteListFooter, onListItemClick, }: AutocompleteListProps): ReactElement;
@@ -0,0 +1 @@
1
+ import React,{useEffect,useRef}from"react";import styled from"@emotion/styled";import{Box}from"../Box/Box";import{Stack}from"../Stack/Stack";import{CategoryList}from"./CategoryList";import{Container}from"../Container";import{usePopupMenu}from"../../shared/popupMenu/usePopupMenu";import{Portal,usePortalChildZIndex}from"../Portal/Portal";import{Inline}from"../Inline/Inline";export function getAutocompleteListId(name){return`${name}_AutocompleteList`}let StyledContainer=styled("div",{target:"e1ksc4t0",label:"StyledContainer"})(({theme})=>({position:"absolute",zIndex:usePortalChildZIndex(theme.variables.zIndex.dropdown)}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQXV0b2NvbXBsZXRlTGlzdC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1Byb21wdElucHV0L0F1dG9jb21wbGV0ZUxpc3QudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUmVhY3RFbGVtZW50LCBSZWZPYmplY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tIFwiLi4vU3RhY2svU3RhY2tcIjtcbmltcG9ydCB7XG4gIHR5cGUgRmxhdHRlbmVkTGlzdEl0ZW0sXG4gIENhdGVnb3J5TGlzdCxcbiAgdHlwZSBMaXN0SXRlbXNCeUNhdGVnb3J5LFxuICB0eXBlIENhdGVnb3J5TGlzdFByb3BzLFxufSBmcm9tIFwiLi9DYXRlZ29yeUxpc3RcIjtcbmltcG9ydCB7IENvbnRhaW5lciB9IGZyb20gXCIuLi9Db250YWluZXJcIjtcbmltcG9ydCB7IHVzZVBvcHVwTWVudSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvcG9wdXBNZW51L3VzZVBvcHVwTWVudVwiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB0eXBlIFBvcnRhbFByb3BzLFxuICB1c2VQb3J0YWxDaGlsZFpJbmRleCxcbn0gZnJvbSBcIi4uL1BvcnRhbC9Qb3J0YWxcIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgdHlwZSB7IFByb21wdFRleHRBcmVhUHJvcHMgfSBmcm9tIFwiLi9Qcm9tcHRUZXh0QXJlYVwiO1xuXG5leHBvcnQgdHlwZSBBdXRvY29tcGxldGVMaXN0UHJvcHMgPSB7XG4gIGF1dG9jb21wbGV0ZUxpc3RJdGVtcz86IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXTtcbiAgdHJpZ2dlclJlZjogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBpc09wZW46IGJvb2xlYW47XG4gIGF1dG9jb21wbGV0ZUxpc3RGb290ZXI/OiBSZWFjdEVsZW1lbnQ7XG59ICYgUGljazxDYXRlZ29yeUxpc3RQcm9wcywgXCJvbkxpc3RJdGVtQ2xpY2tcIj4gJlxuICBQaWNrPFByb21wdFRleHRBcmVhUHJvcHMsIFwibmFtZVwiIHwgXCJ2YWx1ZVwiPiAmXG4gIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXV0b2NvbXBsZXRlTGlzdElkKG5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV9BdXRvY29tcGxldGVMaXN0YDtcbn1cblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiB7XG4gIGNvbnN0IHpJbmRleCA9IHVzZVBvcnRhbENoaWxkWkluZGV4KHRoZW1lLnZhcmlhYmxlcy56SW5kZXguZHJvcGRvd24pO1xuXG4gIHJldHVybiB7XG4gICAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgICB6SW5kZXgsXG4gIH07XG59KTtcblxuY29uc3QgU3R5bGVkTGlzdENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY2FudmFzLFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy5zLFxufSkpO1xuXG5leHBvcnQgZnVuY3Rpb24gQXV0b2NvbXBsZXRlTGlzdCh7XG4gIG5hbWUsXG4gIHZhbHVlLFxuICBhdXRvY29tcGxldGVMaXN0SXRlbXMsXG4gIHRyaWdnZXJSZWYsXG4gIHBvcnRhbENvbnRhaW5lcixcbiAgc2VsZWN0ZWRMaXN0SXRlbSxcbiAgaXNPcGVuLFxuICBhdXRvY29tcGxldGVMaXN0Rm9vdGVyLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBBdXRvY29tcGxldGVMaXN0UHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBtZW51UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCB7IG1lbnVTdHlsZSwgY2FsY3VsYXRlU3R5bGUgfSA9IHVzZVBvcHVwTWVudSh7XG4gICAgdHJpZ2dlclJlZixcbiAgICBtZW51UmVmLFxuICAgIGlzT3BlbixcbiAgfSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNPcGVuKSB7XG4gICAgICBjYWxjdWxhdGVTdHlsZSgpO1xuICAgIH1cbiAgfSwgW3ZhbHVlLCBjYWxjdWxhdGVTdHlsZSwgaXNPcGVuXSk7XG5cbiAgY29uc3QgbGlzdHMgPSBhdXRvY29tcGxldGVMaXN0SXRlbXMubWFwKChsaXN0SXRlbSkgPT4gKFxuICAgIDxDYXRlZ29yeUxpc3RcbiAgICAgIG5hbWU9e25hbWV9XG4gICAgICBrZXk9e2xpc3RJdGVtLmNhdGVnb3J5fVxuICAgICAgey4uLmxpc3RJdGVtfVxuICAgICAgc2VsZWN0ZWRMaXN0SXRlbT17c2VsZWN0ZWRMaXN0SXRlbX1cbiAgICAgIG9uTGlzdEl0ZW1DbGljaz17b25MaXN0SXRlbUNsaWNrfVxuICAgIC8+XG4gICkpO1xuXG4gIGNvbnN0IGxpc3RTdHlsZSA9IHtcbiAgICAuLi5tZW51U3R5bGUsXG4gICAgd2lkdGg6IHRyaWdnZXJSZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkud2lkdGgsXG4gIH07XG5cbiAgY29uc3QgbGlzdEVsbSA9IChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICByZWY9e21lbnVSZWZ9XG4gICAgICBzdHlsZT17bGlzdFN0eWxlfVxuICAgICAgaWQ9e2dldEF1dG9jb21wbGV0ZUxpc3RJZChuYW1lKX1cbiAgICAgIHJvbGU9XCJsaXN0Ym94XCJcbiAgICA+XG4gICAgICA8Q29udGFpbmVyPlxuICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCI+XG4gICAgICAgICAgPFN0eWxlZExpc3RDb250YWluZXI+XG4gICAgICAgICAgICA8Qm94IHNwYWNlPVwieHNcIiB2U3BhY2U9XCJzXCI+XG4gICAgICAgICAgICAgIDxTdGFjayBzcGFjZT1cInhzXCI+XG4gICAgICAgICAgICAgICAgPFN0YWNrIHNwYWNlPVwic1wiPntsaXN0c308L1N0YWNrPlxuICAgICAgICAgICAgICAgIDxJbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiPnthdXRvY29tcGxldGVMaXN0Rm9vdGVyfTwvSW5saW5lPlxuICAgICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9TdHlsZWRMaXN0Q29udGFpbmVyPlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xuXG4gIHJldHVybiBpc09wZW4gPyAoXG4gICAgPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2xpc3RFbG19PC9Qb3J0YWw+XG4gICkgOiBudWxsO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Dd0IifQ== */"),StyledListContainer=styled("div",{target:"e1ksc4t1",label:"StyledListContainer"})(({theme})=>({backgroundColor:theme.values.color.canvas,borderRadius:theme.variables.size.borderRadius.s}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQXV0b2NvbXBsZXRlTGlzdC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1Byb21wdElucHV0L0F1dG9jb21wbGV0ZUxpc3QudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUmVhY3RFbGVtZW50LCBSZWZPYmplY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tIFwiLi4vU3RhY2svU3RhY2tcIjtcbmltcG9ydCB7XG4gIHR5cGUgRmxhdHRlbmVkTGlzdEl0ZW0sXG4gIENhdGVnb3J5TGlzdCxcbiAgdHlwZSBMaXN0SXRlbXNCeUNhdGVnb3J5LFxuICB0eXBlIENhdGVnb3J5TGlzdFByb3BzLFxufSBmcm9tIFwiLi9DYXRlZ29yeUxpc3RcIjtcbmltcG9ydCB7IENvbnRhaW5lciB9IGZyb20gXCIuLi9Db250YWluZXJcIjtcbmltcG9ydCB7IHVzZVBvcHVwTWVudSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvcG9wdXBNZW51L3VzZVBvcHVwTWVudVwiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB0eXBlIFBvcnRhbFByb3BzLFxuICB1c2VQb3J0YWxDaGlsZFpJbmRleCxcbn0gZnJvbSBcIi4uL1BvcnRhbC9Qb3J0YWxcIjtcbmltcG9ydCB7IElubGluZSB9IGZyb20gXCIuLi9JbmxpbmUvSW5saW5lXCI7XG5pbXBvcnQgdHlwZSB7IFByb21wdFRleHRBcmVhUHJvcHMgfSBmcm9tIFwiLi9Qcm9tcHRUZXh0QXJlYVwiO1xuXG5leHBvcnQgdHlwZSBBdXRvY29tcGxldGVMaXN0UHJvcHMgPSB7XG4gIGF1dG9jb21wbGV0ZUxpc3RJdGVtcz86IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXTtcbiAgdHJpZ2dlclJlZjogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBpc09wZW46IGJvb2xlYW47XG4gIGF1dG9jb21wbGV0ZUxpc3RGb290ZXI/OiBSZWFjdEVsZW1lbnQ7XG59ICYgUGljazxDYXRlZ29yeUxpc3RQcm9wcywgXCJvbkxpc3RJdGVtQ2xpY2tcIj4gJlxuICBQaWNrPFByb21wdFRleHRBcmVhUHJvcHMsIFwibmFtZVwiIHwgXCJ2YWx1ZVwiPiAmXG4gIFBpY2s8UG9ydGFsUHJvcHMsIFwicG9ydGFsQ29udGFpbmVyXCI+O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0QXV0b2NvbXBsZXRlTGlzdElkKG5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV9BdXRvY29tcGxldGVMaXN0YDtcbn1cblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiB7XG4gIGNvbnN0IHpJbmRleCA9IHVzZVBvcnRhbENoaWxkWkluZGV4KHRoZW1lLnZhcmlhYmxlcy56SW5kZXguZHJvcGRvd24pO1xuXG4gIHJldHVybiB7XG4gICAgcG9zaXRpb246IFwiYWJzb2x1dGVcIixcbiAgICB6SW5kZXgsXG4gIH07XG59KTtcblxuY29uc3QgU3R5bGVkTGlzdENvbnRhaW5lciA9IHN0eWxlZC5kaXYoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY2FudmFzLFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy5zLFxufSkpO1xuXG5leHBvcnQgZnVuY3Rpb24gQXV0b2NvbXBsZXRlTGlzdCh7XG4gIG5hbWUsXG4gIHZhbHVlLFxuICBhdXRvY29tcGxldGVMaXN0SXRlbXMsXG4gIHRyaWdnZXJSZWYsXG4gIHBvcnRhbENvbnRhaW5lcixcbiAgc2VsZWN0ZWRMaXN0SXRlbSxcbiAgaXNPcGVuLFxuICBhdXRvY29tcGxldGVMaXN0Rm9vdGVyLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBBdXRvY29tcGxldGVMaXN0UHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBtZW51UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCB7IG1lbnVTdHlsZSwgY2FsY3VsYXRlU3R5bGUgfSA9IHVzZVBvcHVwTWVudSh7XG4gICAgdHJpZ2dlclJlZixcbiAgICBtZW51UmVmLFxuICAgIGlzT3BlbixcbiAgfSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNPcGVuKSB7XG4gICAgICBjYWxjdWxhdGVTdHlsZSgpO1xuICAgIH1cbiAgfSwgW3ZhbHVlLCBjYWxjdWxhdGVTdHlsZSwgaXNPcGVuXSk7XG5cbiAgY29uc3QgbGlzdHMgPSBhdXRvY29tcGxldGVMaXN0SXRlbXMubWFwKChsaXN0SXRlbSkgPT4gKFxuICAgIDxDYXRlZ29yeUxpc3RcbiAgICAgIG5hbWU9e25hbWV9XG4gICAgICBrZXk9e2xpc3RJdGVtLmNhdGVnb3J5fVxuICAgICAgey4uLmxpc3RJdGVtfVxuICAgICAgc2VsZWN0ZWRMaXN0SXRlbT17c2VsZWN0ZWRMaXN0SXRlbX1cbiAgICAgIG9uTGlzdEl0ZW1DbGljaz17b25MaXN0SXRlbUNsaWNrfVxuICAgIC8+XG4gICkpO1xuXG4gIGNvbnN0IGxpc3RTdHlsZSA9IHtcbiAgICAuLi5tZW51U3R5bGUsXG4gICAgd2lkdGg6IHRyaWdnZXJSZWYuY3VycmVudD8uZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCkud2lkdGgsXG4gIH07XG5cbiAgY29uc3QgbGlzdEVsbSA9IChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICByZWY9e21lbnVSZWZ9XG4gICAgICBzdHlsZT17bGlzdFN0eWxlfVxuICAgICAgaWQ9e2dldEF1dG9jb21wbGV0ZUxpc3RJZChuYW1lKX1cbiAgICAgIHJvbGU9XCJsaXN0Ym94XCJcbiAgICA+XG4gICAgICA8Q29udGFpbmVyPlxuICAgICAgICA8Qm94IHNwYWNlPVwieHhzXCI+XG4gICAgICAgICAgPFN0eWxlZExpc3RDb250YWluZXI+XG4gICAgICAgICAgICA8Qm94IHNwYWNlPVwieHNcIiB2U3BhY2U9XCJzXCI+XG4gICAgICAgICAgICAgIDxTdGFjayBzcGFjZT1cInhzXCI+XG4gICAgICAgICAgICAgICAgPFN0YWNrIHNwYWNlPVwic1wiPntsaXN0c308L1N0YWNrPlxuICAgICAgICAgICAgICAgIDxJbmxpbmUgYWxpZ25JdGVtcz1cImNlbnRlclwiPnthdXRvY29tcGxldGVMaXN0Rm9vdGVyfTwvSW5saW5lPlxuICAgICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9TdHlsZWRMaXN0Q29udGFpbmVyPlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xuXG4gIHJldHVybiBpc09wZW4gPyAoXG4gICAgPFBvcnRhbCBwb3J0YWxDb250YWluZXI9e3BvcnRhbENvbnRhaW5lcn0+e2xpc3RFbG19PC9Qb3J0YWw+XG4gICkgOiBudWxsO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDNEIifQ== */");export function AutocompleteList({name,value,autocompleteListItems,triggerRef,portalContainer,selectedListItem,isOpen,autocompleteListFooter,onListItemClick}){let menuRef=useRef(null),{menuStyle,calculateStyle}=usePopupMenu({triggerRef,menuRef,isOpen});useEffect(()=>{isOpen&&calculateStyle()},[value,calculateStyle,isOpen]);let lists=autocompleteListItems.map(listItem=>React.createElement(CategoryList,{name:name,key:listItem.category,...listItem,selectedListItem:selectedListItem,onListItemClick:onListItemClick})),listStyle={...menuStyle,width:triggerRef.current?.getBoundingClientRect().width},listElm=React.createElement(StyledContainer,{ref:menuRef,style:listStyle,id:getAutocompleteListId(name),role:"listbox"},React.createElement(Container,null,React.createElement(Box,{space:"xxs"},React.createElement(StyledListContainer,null,React.createElement(Box,{space:"xs",vSpace:"s"},React.createElement(Stack,{space:"xs"},React.createElement(Stack,{space:"s"},lists),React.createElement(Inline,{alignItems:"center"},autocompleteListFooter)))))));return isOpen?React.createElement(Portal,{portalContainer:portalContainer},listElm):null}
@@ -0,0 +1,25 @@
1
+ import type { ReactElement, ReactNode } from "react";
2
+ import type { IconProps } from "../Icon/Icon";
3
+ export type ListItemProps = {
4
+ iconLeft?: IconProps;
5
+ label: ReactElement;
6
+ value: string;
7
+ };
8
+ export type ListItemsByCategory = {
9
+ category: string;
10
+ iconLeft?: IconProps;
11
+ rightContent?: ReactNode;
12
+ items: ListItemProps[];
13
+ };
14
+ export type FlattenedListItem = {
15
+ category: ListItemsByCategory["category"];
16
+ value: ListItemProps["value"];
17
+ id: string;
18
+ };
19
+ export type CategoryListProps = ListItemsByCategory & {
20
+ name: string;
21
+ selectedListItem?: FlattenedListItem;
22
+ onListItemClick: (category: string, value: string) => void;
23
+ };
24
+ export declare function getListItemId(name: string, category: string, index: number): string;
25
+ export declare function CategoryList({ name, category, iconLeft, rightContent, items, selectedListItem, onListItemClick, }: CategoryListProps): ReactElement;
@@ -0,0 +1 @@
1
+ import React,{Fragment}from"react";import styled from"@emotion/styled";import{H6}from"../Typography/Header";import{Icon}from"../Icon/Icon";import{Text}from"../Typography/Text";import{Columns,Column}from"../Column/Columns";import{Stack}from"../Stack/Stack";import{Container}from"../Container";import{Divider}from"../Divider/Divider";export function getListItemId(name,category,index){return`${name}_${category}_ListItem${index}`}let StyledIconLeft=styled(Icon,{target:"eetu9430",label:"StyledIconLeft"})(({theme})=>({marginRight:theme.variables.size.spacing.xs}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVByb3BzID0ge1xuICBpY29uTGVmdD86IEljb25Qcm9wcztcbiAgbGFiZWw6IFJlYWN0RWxlbWVudDtcbiAgdmFsdWU6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgdmFsdWU6IExpc3RJdGVtUHJvcHNbXCJ2YWx1ZVwiXTtcbiAgaWQ6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIENhdGVnb3J5TGlzdFByb3BzID0gTGlzdEl0ZW1zQnlDYXRlZ29yeSAmIHtcbiAgbmFtZTogc3RyaW5nO1xuICBzZWxlY3RlZExpc3RJdGVtPzogRmxhdHRlbmVkTGlzdEl0ZW07XG4gIG9uTGlzdEl0ZW1DbGljazogKGNhdGVnb3J5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0TGlzdEl0ZW1JZChcbiAgbmFtZTogc3RyaW5nLFxuICBjYXRlZ29yeTogc3RyaW5nLFxuICBpbmRleDogbnVtYmVyXG4pOiBzdHJpbmcge1xuICByZXR1cm4gYCR7bmFtZX1fJHtjYXRlZ29yeX1fTGlzdEl0ZW0ke2luZGV4fWA7XG59XG5cbmNvbnN0IFN0eWxlZEljb25MZWZ0ID0gc3R5bGVkKEljb24pKCh7IHRoZW1lIH0pID0+ICh7XG4gIG1hcmdpblJpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxufSkpO1xuXG50eXBlIFN0eWxlZExpc3RJdGVtUHJvcHMgPSB7XG4gIGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5kaXY8U3R5bGVkTGlzdEl0ZW1Qcm9wcz4oXG4gICh7IHRoZW1lLCBpc1NlbGVjdGVkIH0pID0+ICh7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSxcblxuICAgIC4uLihpc1NlbGVjdGVkICYmIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gQ2F0ZWdvcnlMaXN0KHtcbiAgbmFtZSxcbiAgY2F0ZWdvcnksXG4gIGljb25MZWZ0LFxuICByaWdodENvbnRlbnQsXG4gIGl0ZW1zLFxuICBzZWxlY3RlZExpc3RJdGVtLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBDYXRlZ29yeUxpc3RQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGxpc3RJdGVtcyA9IGl0ZW1zLm1hcChcbiAgICAoeyBsYWJlbCwgdmFsdWUsIGljb25MZWZ0OiBpdGVtSWNvbkxlZnQgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGxlZnRDb250ZW50ID0gKFxuICAgICAgICA8VGV4dD5cbiAgICAgICAgICB7aWNvbkxlZnQgJiYgKFxuICAgICAgICAgICAgPFN0eWxlZEljb25MZWZ0XG4gICAgICAgICAgICAgIHsuLi4oaXRlbUljb25MZWZ0IHx8IGljb25MZWZ0KX1cbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgaW5saW5lXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L1RleHQ+XG4gICAgICApO1xuICAgICAgY29uc3QgY29udGVudCA9IHJpZ2h0Q29udGVudCA/IChcbiAgICAgICAgPENvbHVtbnM+XG4gICAgICAgICAgPENvbHVtbj57bGVmdENvbnRlbnR9PC9Db2x1bW4+XG4gICAgICAgICAgPENvbHVtbiBzaXplPVwibmFycm93XCI+e3JpZ2h0Q29udGVudH08L0NvbHVtbj5cbiAgICAgICAgPC9Db2x1bW5zPlxuICAgICAgKSA6IChcbiAgICAgICAgbGVmdENvbnRlbnRcbiAgICAgICk7XG5cbiAgICAgIGNvbnN0IGlzU2VsZWN0ZWQgPVxuICAgICAgICBzZWxlY3RlZExpc3RJdGVtICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0udmFsdWUgPT09IHZhbHVlO1xuXG4gICAgICAvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9uby1hcnJheS1pbmRleC1rZXkgKi9cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICA8U3R5bGVkTGlzdEl0ZW1cbiAgICAgICAgICAgIGlkPXtnZXRMaXN0SXRlbUlkKG5hbWUsIGNhdGVnb3J5LCBpbmRleCl9XG4gICAgICAgICAgICByb2xlPVwib3B0aW9uXCJcbiAgICAgICAgICAgIGlzU2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgICBhcmlhLXNlbGVjdGVkPXtpc1NlbGVjdGVkfVxuICAgICAgICAgICAgb25Qb2ludGVyRG93bj17KGV2dCkgPT4gZXZ0LnByZXZlbnREZWZhdWx0KCl9IC8vIG5lZWRlZCB0byBhdm9pZCBmb2N1cyBjaGFuZ2VcbiAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IG9uTGlzdEl0ZW1DbGljayhjYXRlZ29yeSwgdmFsdWUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkTGlzdEl0ZW0+XG4gICAgICAgICAge2luZGV4ICE9PSBpdGVtcy5sZW5ndGggLSAxICYmIDxEaXZpZGVyIC8+fVxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICAgIC8qIGVzbGludC1lbmFibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIHNwYWNlPVwic1wiPlxuICAgICAgPEg2IGFzPVwiZGl2XCI+e2NhdGVnb3J5fTwvSDY+XG4gICAgICA8Q29udGFpbmVyIGVsZXZhdGlvbj17MH0gYm9yZGVyUmFkaXVzPVwic1wiPlxuICAgICAgICA8U3RhY2sgc3BhY2U9XCJ6ZXJvXCI+e2xpc3RJdGVtc308L1N0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgPC9TdGFjaz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Q3VCIn0= */"),StyledListItem=styled("div",{target:"eetu9431",label:"StyledListItem"})(({theme,isSelected})=>({padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover},...isSelected&&{backgroundColor:theme.values.color.background.transparent.hover}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVByb3BzID0ge1xuICBpY29uTGVmdD86IEljb25Qcm9wcztcbiAgbGFiZWw6IFJlYWN0RWxlbWVudDtcbiAgdmFsdWU6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgdmFsdWU6IExpc3RJdGVtUHJvcHNbXCJ2YWx1ZVwiXTtcbiAgaWQ6IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIENhdGVnb3J5TGlzdFByb3BzID0gTGlzdEl0ZW1zQnlDYXRlZ29yeSAmIHtcbiAgbmFtZTogc3RyaW5nO1xuICBzZWxlY3RlZExpc3RJdGVtPzogRmxhdHRlbmVkTGlzdEl0ZW07XG4gIG9uTGlzdEl0ZW1DbGljazogKGNhdGVnb3J5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0TGlzdEl0ZW1JZChcbiAgbmFtZTogc3RyaW5nLFxuICBjYXRlZ29yeTogc3RyaW5nLFxuICBpbmRleDogbnVtYmVyXG4pOiBzdHJpbmcge1xuICByZXR1cm4gYCR7bmFtZX1fJHtjYXRlZ29yeX1fTGlzdEl0ZW0ke2luZGV4fWA7XG59XG5cbmNvbnN0IFN0eWxlZEljb25MZWZ0ID0gc3R5bGVkKEljb24pKCh7IHRoZW1lIH0pID0+ICh7XG4gIG1hcmdpblJpZ2h0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxufSkpO1xuXG50eXBlIFN0eWxlZExpc3RJdGVtUHJvcHMgPSB7XG4gIGlzU2VsZWN0ZWQ6IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRMaXN0SXRlbSA9IHN0eWxlZC5kaXY8U3R5bGVkTGlzdEl0ZW1Qcm9wcz4oXG4gICh7IHRoZW1lLCBpc1NlbGVjdGVkIH0pID0+ICh7XG4gICAgcGFkZGluZzogYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YCxcbiAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSxcblxuICAgIC4uLihpc1NlbGVjdGVkICYmIHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuaG92ZXIsXG4gICAgfSksXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gQ2F0ZWdvcnlMaXN0KHtcbiAgbmFtZSxcbiAgY2F0ZWdvcnksXG4gIGljb25MZWZ0LFxuICByaWdodENvbnRlbnQsXG4gIGl0ZW1zLFxuICBzZWxlY3RlZExpc3RJdGVtLFxuICBvbkxpc3RJdGVtQ2xpY2ssXG59OiBDYXRlZ29yeUxpc3RQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGxpc3RJdGVtcyA9IGl0ZW1zLm1hcChcbiAgICAoeyBsYWJlbCwgdmFsdWUsIGljb25MZWZ0OiBpdGVtSWNvbkxlZnQgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGxlZnRDb250ZW50ID0gKFxuICAgICAgICA8VGV4dD5cbiAgICAgICAgICB7aWNvbkxlZnQgJiYgKFxuICAgICAgICAgICAgPFN0eWxlZEljb25MZWZ0XG4gICAgICAgICAgICAgIHsuLi4oaXRlbUljb25MZWZ0IHx8IGljb25MZWZ0KX1cbiAgICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgICBjb2xvcj1cInRlcnRpYXJ5XCJcbiAgICAgICAgICAgICAgaW5saW5lXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICl9XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L1RleHQ+XG4gICAgICApO1xuICAgICAgY29uc3QgY29udGVudCA9IHJpZ2h0Q29udGVudCA/IChcbiAgICAgICAgPENvbHVtbnM+XG4gICAgICAgICAgPENvbHVtbj57bGVmdENvbnRlbnR9PC9Db2x1bW4+XG4gICAgICAgICAgPENvbHVtbiBzaXplPVwibmFycm93XCI+e3JpZ2h0Q29udGVudH08L0NvbHVtbj5cbiAgICAgICAgPC9Db2x1bW5zPlxuICAgICAgKSA6IChcbiAgICAgICAgbGVmdENvbnRlbnRcbiAgICAgICk7XG5cbiAgICAgIGNvbnN0IGlzU2VsZWN0ZWQgPVxuICAgICAgICBzZWxlY3RlZExpc3RJdGVtICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0udmFsdWUgPT09IHZhbHVlO1xuXG4gICAgICAvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9uby1hcnJheS1pbmRleC1rZXkgKi9cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxGcmFnbWVudCBrZXk9e2luZGV4fT5cbiAgICAgICAgICA8U3R5bGVkTGlzdEl0ZW1cbiAgICAgICAgICAgIGlkPXtnZXRMaXN0SXRlbUlkKG5hbWUsIGNhdGVnb3J5LCBpbmRleCl9XG4gICAgICAgICAgICByb2xlPVwib3B0aW9uXCJcbiAgICAgICAgICAgIGlzU2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgICBhcmlhLXNlbGVjdGVkPXtpc1NlbGVjdGVkfVxuICAgICAgICAgICAgb25Qb2ludGVyRG93bj17KGV2dCkgPT4gZXZ0LnByZXZlbnREZWZhdWx0KCl9IC8vIG5lZWRlZCB0byBhdm9pZCBmb2N1cyBjaGFuZ2VcbiAgICAgICAgICAgIG9uQ2xpY2s9eygpID0+IG9uTGlzdEl0ZW1DbGljayhjYXRlZ29yeSwgdmFsdWUpfVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvU3R5bGVkTGlzdEl0ZW0+XG4gICAgICAgICAge2luZGV4ICE9PSBpdGVtcy5sZW5ndGggLSAxICYmIDxEaXZpZGVyIC8+fVxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICAgIC8qIGVzbGludC1lbmFibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIHNwYWNlPVwic1wiPlxuICAgICAgPEg2IGFzPVwiZGl2XCI+e2NhdGVnb3J5fTwvSDY+XG4gICAgICA8Q29udGFpbmVyIGVsZXZhdGlvbj17MH0gYm9yZGVyUmFkaXVzPVwic1wiPlxuICAgICAgICA8U3RhY2sgc3BhY2U9XCJ6ZXJvXCI+e2xpc3RJdGVtc308L1N0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgPC9TdGFjaz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxRHVCIn0= */");export function CategoryList({name,category,iconLeft,rightContent,items,selectedListItem,onListItemClick}){let listItems=items.map(({label,value,iconLeft:itemIconLeft},index)=>{let leftContent=React.createElement(Text,null,iconLeft&&React.createElement(StyledIconLeft,{...itemIconLeft||iconLeft,size:"s",color:"tertiary",inline:!0}),label),content=rightContent?React.createElement(Columns,null,React.createElement(Column,null,leftContent),React.createElement(Column,{size:"narrow"},rightContent)):leftContent,isSelected=selectedListItem&&selectedListItem.category===category&&selectedListItem.value===value;return React.createElement(Fragment,{key:index},React.createElement(StyledListItem,{id:getListItemId(name,category,index),role:"option",isSelected:isSelected,"aria-selected":isSelected,onPointerDown:evt=>evt.preventDefault(),onClick:()=>onListItemClick(category,value)},content),index!==items.length-1&&React.createElement(Divider,null))});return React.createElement(Stack,{space:"s"},React.createElement(H6,{as:"div"},category),React.createElement(Container,{elevation:0,borderRadius:"s"},React.createElement(Stack,{space:"zero"},listItems)))}
@@ -0,0 +1,45 @@
1
+ import type { ReactElement } from "react";
2
+ import React from "react";
3
+ import type { PromptTextAreaProps } from "./PromptTextArea";
4
+ import type { AutocompleteListProps } from "./AutocompleteList";
5
+ import type { RoundButtonProps } from "../RoundButton/RoundButton";
6
+ export type PromptInputProps = {
7
+ "data-e2e-test-id"?: string;
8
+ /** Toolbar elements below text area */
9
+ bottomToolbar?: {
10
+ leftContent?: ReactElement;
11
+ rightContent?: ReactElement;
12
+ };
13
+ /** Currently shows send button processing state */
14
+ isProcessing?: boolean;
15
+ sendButtonProps?: Omit<RoundButtonProps, "icon" | "variant">;
16
+ clearButtonAriaLabel?: string;
17
+ hint?: ReactElement;
18
+ /** Shows in the clear button space in empty state */
19
+ emptyStateTopRightContent?: ReactElement;
20
+ onClear: () => void;
21
+ /** Called when user selects (or rejects) a list item from autocomplete list */
22
+ onComplete?: (value: string, category?: string) => void;
23
+ /** Called on Enter key to submit the form */
24
+ onEnterKey: () => void;
25
+ } & Omit<PromptTextAreaProps, "isCollapsed" | "isAutocompleteListOpen" | "selectedListItem"> & Pick<AutocompleteListProps, "autocompleteListItems" | "autocompleteListFooter" | "portalContainer">;
26
+ export declare const PromptInput: React.ForwardRefExoticComponent<{
27
+ "data-e2e-test-id"?: string;
28
+ /** Toolbar elements below text area */
29
+ bottomToolbar?: {
30
+ leftContent?: ReactElement;
31
+ rightContent?: ReactElement;
32
+ };
33
+ /** Currently shows send button processing state */
34
+ isProcessing?: boolean;
35
+ sendButtonProps?: Omit<RoundButtonProps, "icon" | "variant">;
36
+ clearButtonAriaLabel?: string;
37
+ hint?: ReactElement;
38
+ /** Shows in the clear button space in empty state */
39
+ emptyStateTopRightContent?: ReactElement;
40
+ onClear: () => void;
41
+ /** Called when user selects (or rejects) a list item from autocomplete list */
42
+ onComplete?: (value: string, category?: string) => void;
43
+ /** Called on Enter key to submit the form */
44
+ onEnterKey: () => void;
45
+ } & Omit<PromptTextAreaProps, "selectedListItem" | "isAutocompleteListOpen" | "isCollapsed"> & Pick<AutocompleteListProps, "portalContainer" | "autocompleteListItems" | "autocompleteListFooter"> & React.RefAttributes<HTMLTextAreaElement>>;
@@ -0,0 +1 @@
1
+ import React,{useRef,useMemo,useState,useEffect,useCallback,forwardRef}from"react";import styled from"@emotion/styled";import{PromptTextArea}from"./PromptTextArea";import{Container}from"../Container";import{AutocompleteList}from"./AutocompleteList";import{getListItemId}from"./CategoryList";import{Box}from"../Box/Box";import{Text}from"../Typography/Text";import{Column,Columns}from"../Column/Columns";import{Inline}from"../Inline/Inline";import{RoundButton}from"../RoundButton/RoundButton";import{PictogramButton}from"../PictogramButton/PictogramButton";import{Stack}from"../Stack/Stack";let StyledTextAreaContainer=styled("div",{target:"e4n8w5o0",label:"StyledTextAreaContainer"})({position:"relative"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\">;\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                icon={isProcessing ? \"square\" : \"send\"}\n                variant=\"primary\"\n                disabled={!value}\n                {...sendButtonProps}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <Container\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </Container>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgCgC"} */"),StyledEmptyStateTopRightContentContainer=styled("div",{target:"e4n8w5o1",label:"StyledEmptyStateTopRightContentContainer"})(({theme,isNavBarVariant})=>({position:"absolute",top:isNavBarVariant?theme.variables.size.spacing.xxs:theme.variables.size.spacing.m,right:theme.variables.size.spacing.m,userSelect:"none",pointerEvents:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\">;\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                icon={isProcessing ? \"square\" : \"send\"}\n                variant=\"primary\"\n                disabled={!value}\n                {...sendButtonProps}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <Container\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </Container>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0CE"} */"),StyledClearButton=styled(PictogramButton,{target:"e4n8w5o2",label:"StyledClearButton"})(({theme,isNavBarVariant})=>({position:"absolute",right:theme.variables.size.spacing.s,top:isNavBarVariant?0:theme.variables.size.spacing.s}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\">;\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                icon={isProcessing ? \"square\" : \"send\"}\n                variant=\"primary\"\n                disabled={!value}\n                {...sendButtonProps}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <Container\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </Container>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AAyD0B"} */");export const PromptInput=forwardRef(({"data-e2e-test-id":dataE2eTestId,name,autocompleteListItems=[],value,bottomToolbar={leftContent:null,rightContent:null},isProcessing,sendButtonProps={type:"submit"},autocompleteListFooter,clearButtonAriaLabel="Clear input",hint,emptyStateTopRightContent,isNavBarVariant,portalContainer,onChange,onComplete,onClear,onEnterKey,onFocus,onBlur,onKeyDown,...rest},ref)=>{let containerRef=useRef(null),textAreaContainerRef=useRef(null),internalRef=useRef(null),[selectedIndex,setSelectedIndex]=useState(-1),[isCollapsed,setIsCollapsed]=useState(isNavBarVariant),userTypedQuery=useRef(""),[isAutocompleteListOpen,setIsAutocompleteListOpen]=useState(!1),textAreaRef=ref||internalRef,closeAutocompleteList=useCallback(()=>{setIsAutocompleteListOpen(!1),setSelectedIndex(-1)},[]),openAutocompleteList=useCallback(()=>{autocompleteListItems.length&&(setIsAutocompleteListOpen(!0),setSelectedIndex(-1))},[autocompleteListItems]),acceptTextSelection=()=>{userTypedQuery.current=value,textAreaRef.current.setSelectionRange(value.length,value.length)};useEffect(()=>{autocompleteListItems.length&&!isCollapsed?openAutocompleteList():closeAutocompleteList()},[autocompleteListItems,openAutocompleteList,closeAutocompleteList,isCollapsed]),useEffect(()=>{value&&value!==userTypedQuery.current&&isAutocompleteListOpen&&textAreaRef.current.setSelectionRange(userTypedQuery.current.length,value.length)},[value,textAreaRef,isAutocompleteListOpen]),useEffect(()=>{let handler,container=containerRef.current;return isNavBarVariant&&container&&(handler=evt=>{containerRef.current.contains(evt.relatedTarget)||setIsCollapsed(!0)},containerRef.current.addEventListener("focusout",handler)),()=>{container&&container.removeEventListener("focusout",handler)}},[isNavBarVariant,containerRef]);let flattenedListItems=useMemo(()=>{let list=[];return autocompleteListItems.forEach(listItem=>{listItem.items.forEach((item,index)=>{list.push({category:listItem.category,value:item.value,id:getListItemId(name,listItem.category,index)})})}),list},[autocompleteListItems,name]),handleSelectedIndexChange=index=>{if(setSelectedIndex(index),-1!==index){let{category,value:itemValue}=flattenedListItems[index];onComplete(itemValue,category)}},selectedListItem=-1!==selectedIndex?flattenedListItems[selectedIndex]:null,emptyStateTopRightContentElm=emptyStateTopRightContent?React.createElement(StyledEmptyStateTopRightContentContainer,{isNavBarVariant:isNavBarVariant},React.createElement(Text,{color:"tertiary"},emptyStateTopRightContent)):null,clearButtonElm=value?React.createElement(StyledClearButton,{size:"s",icon:"x","aria-label":clearButtonAriaLabel,isNavBarVariant:isNavBarVariant,onPointerDown:evt=>evt.preventDefault(),onClick:onClear}):emptyStateTopRightContentElm,hintElm=!!hint&&React.createElement(Inline,{alignItems:"center"},React.createElement(Text,{size:"s",color:"tertiary"},hint)),bottomToolbarElm=!isCollapsed&&React.createElement(Box,{space:"m","data-e2e-test-id":"bottomToolbar"},React.createElement(Columns,{gap:"s",alignItems:"spaceBetween",vAlignItems:"center"},React.createElement(Column,null,bottomToolbar.leftContent),React.createElement(Column,{size:"narrow"},React.createElement(Inline,{space:"xs",vAlignItems:"center"},bottomToolbar.rightContent,React.createElement(RoundButton,{ariaAttributes:{"aria-label":isProcessing?"Processing query":"Submit query"},icon:isProcessing?"square":"send",variant:"primary",disabled:!value,...sendButtonProps})))));return React.createElement(React.Fragment,null,React.createElement("div",{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PromptInput",ref:containerRef},React.createElement(Stack,{space:"s"},React.createElement("div",{ref:textAreaContainerRef},React.createElement(Container,{elevation:+!isCollapsed,borderRadius:isCollapsed?"s":"m"},React.createElement(StyledTextAreaContainer,null,React.createElement(PromptTextArea,{...rest,name:name,value:value,ref:textAreaRef,isNavBarVariant:isNavBarVariant,selectedListItem:selectedListItem,isAutocompleteListOpen:isAutocompleteListOpen,isCollapsed:isCollapsed,onFocus:evt=>{setIsCollapsed(!1),onFocus?.(evt)},onBlur:evt=>{value!==userTypedQuery.current&&onComplete?.(userTypedQuery.current),onBlur?.(evt)},onChange:evt=>{userTypedQuery.current=evt.target.value,onChange(evt)},onKeyDown:evt=>{if(isAutocompleteListOpen)switch(evt.key){case"Escape":closeAutocompleteList(),onComplete(userTypedQuery.current);break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),closeAutocompleteList(),acceptTextSelection(),value&&onEnterKey?.());break;case" ":acceptTextSelection();break;case"ArrowUp":evt.preventDefault(),selectedIndex>-1&&handleSelectedIndexChange(selectedIndex-1);break;case"ArrowDown":evt.preventDefault(),selectedIndex<flattenedListItems.length-1&&handleSelectedIndexChange(selectedIndex+1)}else switch(evt.key){case"Escape":onClear?.();break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),value&&onEnterKey?.())}onKeyDown?.(evt)}}),clearButtonElm),bottomToolbarElm)),hintElm)),React.createElement(AutocompleteList,{name:name,value:value,autocompleteListItems:autocompleteListItems,triggerRef:textAreaContainerRef,selectedListItem:selectedListItem,isOpen:isAutocompleteListOpen,autocompleteListFooter:autocompleteListFooter,portalContainer:portalContainer,onListItemClick:(category,itemValue)=>{handleSelectedIndexChange(flattenedListItems.findIndex(listItem=>listItem.category===category&&listItem.value===itemValue)),closeAutocompleteList()}}))});
@@ -0,0 +1,26 @@
1
+ import type { TextareaHTMLAttributes } from "react";
2
+ import React from "react";
3
+ import type { Property } from "csstype";
4
+ import type { FlattenedListItem } from "./CategoryList";
5
+ export type PromptTextAreaProps = TextareaHTMLAttributes<HTMLTextAreaElement> & {
6
+ label: string;
7
+ name: string;
8
+ value: string;
9
+ maxTextAreaHeight?: Property.Height;
10
+ selectedListItem?: FlattenedListItem;
11
+ isAutocompleteListOpen?: boolean;
12
+ isCollapsed?: boolean;
13
+ /** Collapsed variant showing only single row text area */
14
+ isNavBarVariant?: boolean;
15
+ };
16
+ export declare const PromptTextArea: React.ForwardRefExoticComponent<TextareaHTMLAttributes<HTMLTextAreaElement> & {
17
+ label: string;
18
+ name: string;
19
+ value: string;
20
+ maxTextAreaHeight?: Property.Height;
21
+ selectedListItem?: FlattenedListItem;
22
+ isAutocompleteListOpen?: boolean;
23
+ isCollapsed?: boolean;
24
+ /** Collapsed variant showing only single row text area */
25
+ isNavBarVariant?: boolean;
26
+ } & React.RefAttributes<HTMLTextAreaElement>>;
@@ -0,0 +1 @@
1
+ import React,{forwardRef,useEffect}from"react";import styled from"@emotion/styled";import{ScreenReaderText}from"../Utilities/ScreenReaderText/ScreenReaderText";import{getAutocompleteListId}from"./AutocompleteList";let StyledTextAreaContainer=styled("label",{target:"e16ka3080",label:"StyledTextAreaContainer"})(({theme,maxTextAreaHeight,isCollapsed,isNavBarVariant})=>({display:"grid",verticalAlign:"top",alignItems:"stretch",width:"100%",borderRadius:"inherit",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,...isCollapsed&&{backgroundColor:theme.values.color.canvas},"&::after":{content:"attr(data-value) ' '",boxSizing:"border-box",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,gridArea:"1 / 1",whiteSpace:"pre-wrap",visibility:"hidden",maxHeight:maxTextAreaHeight},textarea:{all:"unset",resize:"none",gridArea:"1 / 1",...isCollapsed&&{overflow:"hidden"}},"&::after, textarea":{padding:isNavBarVariant?`${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.xxl} ${theme.variables.size.spacing.xxs} ${theme.variables.size.spacing.m}`:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xxl} ${theme.variables.size.spacing.m} ${theme.variables.size.spacing.m}`,...!isCollapsed&&{paddingBottom:theme.variables.size.spacing.m}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvUHJvbXB0VGV4dEFyZWEudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Qcm9tcHRJbnB1dC9Qcm9tcHRUZXh0QXJlYS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZWZPYmplY3QsIFRleHRhcmVhSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmLCB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBQcm9wZXJ0eSB9IGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQgeyBTY3JlZW5SZWFkZXJUZXh0IH0gZnJvbSBcIi4uL1V0aWxpdGllcy9TY3JlZW5SZWFkZXJUZXh0L1NjcmVlblJlYWRlclRleHRcIjtcbmltcG9ydCB7IGdldEF1dG9jb21wbGV0ZUxpc3RJZCB9IGZyb20gXCIuL0F1dG9jb21wbGV0ZUxpc3RcIjtcbmltcG9ydCB0eXBlIHsgRmxhdHRlbmVkTGlzdEl0ZW0gfSBmcm9tIFwiLi9DYXRlZ29yeUxpc3RcIjtcblxuZXhwb3J0IHR5cGUgUHJvbXB0VGV4dEFyZWFQcm9wcyA9XG4gIFRleHRhcmVhSFRNTEF0dHJpYnV0ZXM8SFRNTFRleHRBcmVhRWxlbWVudD4gJiB7XG4gICAgbGFiZWw6IHN0cmluZztcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgdmFsdWU6IHN0cmluZztcbiAgICBtYXhUZXh0QXJlYUhlaWdodD86IFByb3BlcnR5LkhlaWdodDtcbiAgICBzZWxlY3RlZExpc3RJdGVtPzogRmxhdHRlbmVkTGlzdEl0ZW07XG4gICAgaXNBdXRvY29tcGxldGVMaXN0T3Blbj86IGJvb2xlYW47XG4gICAgaXNDb2xsYXBzZWQ/OiBib29sZWFuO1xuICAgIC8qKiBDb2xsYXBzZWQgdmFyaWFudCBzaG93aW5nIG9ubHkgc2luZ2xlIHJvdyB0ZXh0IGFyZWEgKi9cbiAgICBpc05hdkJhclZhcmlhbnQ/OiBib29sZWFuO1xuICB9O1xuXG50eXBlIFN0eWxlZFRleHRBcmVhQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBQcm9tcHRUZXh0QXJlYVByb3BzLFxuICBcIm1heFRleHRBcmVhSGVpZ2h0XCIgfCBcImlzQ29sbGFwc2VkXCIgfCBcImlzTmF2QmFyVmFyaWFudFwiXG4+O1xuXG4vLyBUZXh0YXJlYSBhdXRvIGdyb3cgaW1wbGVtZW50ZWQgYWNjb3JkaW5nIHRvIGh0dHBzOi8vY3NzLXRyaWNrcy5jb20vdGhlLWNsZWFuZXN0LXRyaWNrLWZvci1hdXRvZ3Jvd2luZy10ZXh0YXJlYXMvXG5jb25zdCBTdHlsZWRUZXh0QXJlYUNvbnRhaW5lciA9IHN0eWxlZC5sYWJlbDxTdHlsZWRUZXh0QXJlYUNvbnRhaW5lclByb3BzPihcbiAgKHsgdGhlbWUsIG1heFRleHRBcmVhSGVpZ2h0LCBpc0NvbGxhcHNlZCwgaXNOYXZCYXJWYXJpYW50IH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJncmlkXCIsXG4gICAgdmVydGljYWxBbGlnbjogXCJ0b3BcIixcbiAgICBhbGlnbkl0ZW1zOiBcInN0cmV0Y2hcIixcbiAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgYm9yZGVyUmFkaXVzOiBcImluaGVyaXRcIixcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRTaXplOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5mb250Lm0sXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54bCxcblxuICAgIC4uLihpc0NvbGxhcHNlZCAmJiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jYW52YXMsXG4gICAgfSksXG5cbiAgICBcIiY6OmFmdGVyXCI6IHtcbiAgICAgIGNvbnRlbnQ6IFwiYXR0cihkYXRhLXZhbHVlKSAnICdcIiwgLy8gdGhlIGVtcHR5IHNwYWNlIHByZXZlbnRzIHRleHRhcmVhIGp1bXAgb24gZ3Jvd1xuICAgICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgZ3JpZEFyZWE6IFwiMSAvIDFcIixcbiAgICAgIHdoaXRlU3BhY2U6IFwicHJlLXdyYXBcIixcbiAgICAgIHZpc2liaWxpdHk6IFwiaGlkZGVuXCIsXG4gICAgICBtYXhIZWlnaHQ6IG1heFRleHRBcmVhSGVpZ2h0LFxuICAgIH0sXG5cbiAgICB0ZXh0YXJlYToge1xuICAgICAgYWxsOiBcInVuc2V0XCIsXG4gICAgICByZXNpemU6IFwibm9uZVwiLFxuICAgICAgZ3JpZEFyZWE6IFwiMSAvIDFcIixcblxuICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgb3ZlcmZsb3c6IFwiaGlkZGVuXCIsXG4gICAgICB9KSxcbiAgICB9LFxuXG4gICAgXCImOjphZnRlciwgdGV4dGFyZWFcIjoge1xuICAgICAgcGFkZGluZzogaXNOYXZCYXJWYXJpYW50XG4gICAgICAgID8gYCR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHN9ICAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhsfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzfSAgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19YFxuICAgICAgICA6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4bH0gJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm19ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tfWAsXG5cbiAgICAgIC4uLighaXNDb2xsYXBzZWQgJiYge1xuICAgICAgICBwYWRkaW5nQm90dG9tOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLm0sXG4gICAgICB9KSxcbiAgICB9LFxuICB9KVxuKTtcblxuZXhwb3J0IGNvbnN0IFByb21wdFRleHRBcmVhID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGxhYmVsLFxuICAgICAgbmFtZSxcbiAgICAgIHZhbHVlLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICBtYXhUZXh0QXJlYUhlaWdodCA9IFwiMjAwcHhcIixcbiAgICAgIHNlbGVjdGVkTGlzdEl0ZW0sXG4gICAgICBpc0F1dG9jb21wbGV0ZUxpc3RPcGVuLFxuICAgICAgaXNDb2xsYXBzZWQsXG4gICAgICBpc05hdkJhclZhcmlhbnQsXG4gICAgICBvbkNoYW5nZSxcbiAgICAgIC4uLnJlc3RcbiAgICB9OiBQcm9tcHRUZXh0QXJlYVByb3BzLFxuICAgIHJlZjogUmVmT2JqZWN0PEhUTUxUZXh0QXJlYUVsZW1lbnQ+XG4gICkgPT4ge1xuICAgIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgICBjb25zdCB0ZXh0QXJlYSA9IHJlZi5jdXJyZW50O1xuXG4gICAgICBpZiAoaXNDb2xsYXBzZWQpIHtcbiAgICAgICAgKHRleHRBcmVhLnBhcmVudE5vZGUgYXMgSFRNTEVsZW1lbnQpLmRhdGFzZXQudmFsdWUgPSBcIlwiO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gU2V0IHRoZSB2YWx1ZSBvZiB0aGUgOjphZnRlciBwc3VlZG8gZWxlbWVudCBzbyB0aGF0IHRoZSBUZXh0QXJlYSByZXNpemVzIGFjY29yZGluZ2x5IGFzIHRoZSBncmlkIHN0cmV0Y2hlcy5cbiAgICAgICAgKHRleHRBcmVhLnBhcmVudE5vZGUgYXMgSFRNTEVsZW1lbnQpLmRhdGFzZXQudmFsdWUgPSB2YWx1ZTtcbiAgICAgIH1cbiAgICB9LCBbdmFsdWUsIHJlZiwgaXNDb2xsYXBzZWRdKTtcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkVGV4dEFyZWFDb250YWluZXJcbiAgICAgICAgbWF4VGV4dEFyZWFIZWlnaHQ9e21heFRleHRBcmVhSGVpZ2h0fVxuICAgICAgICBpc0NvbGxhcHNlZD17aXNDb2xsYXBzZWR9XG4gICAgICAgIGlzTmF2QmFyVmFyaWFudD17aXNOYXZCYXJWYXJpYW50fVxuICAgICAgPlxuICAgICAgICA8U2NyZWVuUmVhZGVyVGV4dD57bGFiZWx9PC9TY3JlZW5SZWFkZXJUZXh0PlxuICAgICAgICA8dGV4dGFyZWFcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICBuYW1lPXtuYW1lfVxuICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICBwbGFjZWhvbGRlcj17cGxhY2Vob2xkZXJ9XG4gICAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICAgIHJvd3M9ezF9XG4gICAgICAgICAgcm9sZT1cImNvbWJvYm94XCJcbiAgICAgICAgICBhcmlhLWF1dG9jb21wbGV0ZT1cImxpc3RcIlxuICAgICAgICAgIGFyaWEtY29udHJvbHM9e1xuICAgICAgICAgICAgaXNBdXRvY29tcGxldGVMaXN0T3BlbiA/IGdldEF1dG9jb21wbGV0ZUxpc3RJZChuYW1lKSA6IFwiXCJcbiAgICAgICAgICB9XG4gICAgICAgICAgYXJpYS1hY3RpdmVkZXNjZW5kYW50PXtzZWxlY3RlZExpc3RJdGVtID8gc2VsZWN0ZWRMaXN0SXRlbS5pZCA6IFwiXCJ9XG4gICAgICAgICAgYXJpYS1leHBhbmRlZD17aXNBdXRvY29tcGxldGVMaXN0T3Blbn1cbiAgICAgICAgLz5cbiAgICAgIDwvU3R5bGVkVGV4dEFyZWFDb250YWluZXI+XG4gICAgKTtcbiAgfVxuKTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQmdDIn0= */");export const PromptTextArea=forwardRef(({label,name,value,placeholder,maxTextAreaHeight="200px",selectedListItem,isAutocompleteListOpen,isCollapsed,isNavBarVariant,onChange,...rest},ref)=>(useEffect(()=>{let textArea=ref.current;isCollapsed?textArea.parentNode.dataset.value="":textArea.parentNode.dataset.value=value},[value,ref,isCollapsed]),React.createElement(StyledTextAreaContainer,{maxTextAreaHeight:maxTextAreaHeight,isCollapsed:isCollapsed,isNavBarVariant:isNavBarVariant},React.createElement(ScreenReaderText,null,label),React.createElement("textarea",{...rest,ref:ref,name:name,value:value,placeholder:placeholder,onChange:onChange,rows:1,role:"combobox","aria-autocomplete":"list","aria-controls":isAutocompleteListOpen?getAutocompleteListId(name):"","aria-activedescendant":selectedListItem?selectedListItem.id:"","aria-expanded":isAutocompleteListOpen}))));
@@ -78,3 +78,4 @@ export * from "./components/Utilities/ContainerQuery/ContainerQuery";
78
78
  export * from "./components/Utilities/ScreenReaderText/ScreenReaderText";
79
79
  export * from "./components/CatalogCard/CatalogCard";
80
80
  export * from "./components/MediaViewerCarousel/MediaViewerCarousel";
81
+ export * from "./components/PromptInput/PromptInput";
@@ -1 +1 @@
1
- import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Combobox/Combobox";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/Callout/Callout";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree";export*from"./components/EntityList";export*from"./components/Form/Select";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Grid/Grid";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Toast";export*from"./components/Form/DateInput/DateInput";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/RadioCard/RadioCard";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/CatalogCard/CatalogCard";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";
1
+ import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Combobox/Combobox";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/Callout/Callout";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree";export*from"./components/EntityList";export*from"./components/Form/Select";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Grid/Grid";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Toast";export*from"./components/Form/DateInput/DateInput";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/RadioCard/RadioCard";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/CatalogCard/CatalogCard";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";export*from"./components/PromptInput/PromptInput";
@@ -154,6 +154,7 @@
154
154
  "rotate-ccw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-rotate-ccw\" viewBox=\"0 0 24 24\"><path d=\"M1 4v6h6\"/><path d=\"M3.51 15a9 9 0 1 0 2.13-9.36L1 10\"/></svg>",
155
155
  "rotate-cw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-rotate-cw\" viewBox=\"0 0 24 24\"><path d=\"M23 4v6h-6\"/><path d=\"M20.49 15a9 9 0 1 1-2.12-9.36L23 10\"/></svg>",
156
156
  "search": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-search\" viewBox=\"0 0 24 24\"><circle cx=\"11\" cy=\"11\" r=\"8\"/><path d=\"m21 21-4.35-4.35\"/></svg>",
157
+ "search-ai": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" d=\"M10.5 2a8.5 8.5 0 0 1 8.5 8.5 8.46 8.46 0 0 1-1.826 5.26l4.533 4.533a1 1 0 1 1-1.414 1.414l-4.533-4.533a8.46 8.46 0 0 1-3.756 1.69l1.063-2.392a6.5 6.5 0 0 0 1.98-1.328q.022-.027.046-.051l.05-.046A6.5 6.5 0 1 0 4.12 9.245l-2.116 1.059A8.5 8.5 0 0 1 10.5 2m-.625 10.125L14 14l-4.125 1.875L8 20l-1.875-4.125L2 14l4.125-1.875L8 8zm-2.617 1.133L5.622 14l1.636.742L8 16.378l.742-1.636L10.378 14l-1.636-.742L8 11.622z\"/></svg>",
157
158
  "search-list": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M4 6h16m-5 6h5m-4 6h4\"/><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M7.125 19.5a4.375 4.375 0 1 0 0-8.75 4.375 4.375 0 0 0 0 8.75\" clip-rule=\"evenodd\"/><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"m13.25 21.25-3.033-3.033\"/></svg>",
158
159
  "send": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M22.727 1.314a1 1 0 0 0-1.079-.25L1.67 8.055a1 1 0 0 0-.076 1.858l8.648 3.844 3.844 8.648a1 1 0 0 0 1.858-.076L22.937 2.35a1 1 0 0 0-.21-1.037ZM18.194 4.39 4.711 9.111l6.067 2.696 7.416-7.416Zm-6.001 8.83 7.415-7.415-4.719 13.483z\" clip-rule=\"evenodd\"/></svg>",
159
160
  "settings": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" class=\"feather feather-settings\" viewBox=\"0 0 24 24\"><circle cx=\"12\" cy=\"12\" r=\"3\"/><path d=\"M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1\"/></svg>",
@@ -154,6 +154,7 @@
154
154
  "rotate-ccw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M2 3v4h4M3.859 5.437a4.93 4.93 0 1 1-.165 4.927\"/></svg>",
155
155
  "rotate-cw": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M14 3v4h-4m2.141-1.563a4.93 4.93 0 1 0 .165 4.927\"/></svg>",
156
156
  "search": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M7 12A5 5 0 1 0 7 2a5 5 0 0 0 0 10\" clip-rule=\"evenodd\"/><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"m14 14-3.467-3.467\"/></svg>",
157
+ "search-ai": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" d=\"M6.667 1a5.667 5.667 0 0 1 4.651 8.904l3.389 3.389a1 1 0 1 1-1.414 1.414l-3.389-3.389a5.64 5.64 0 0 1-3.107 1.012l.96-2.162a3.668 3.668 0 1 0-4.642-4.42L1.003 6.805 1 6.667A5.667 5.667 0 0 1 6.667 1m-.573 6.406L8.5 8.5 6.094 9.594 5 12 3.906 9.594 1.5 8.5l2.406-1.094L5 5z\"/></svg>",
157
158
  "search-list": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\"><path d=\"M2 3h12m-3 4h3m-2 4h2\"/><path d=\"M4.5 14a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7\" clip-rule=\"evenodd\"/><path d=\"m9 15-2-2\"/></g></svg>",
158
159
  "send": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g clip-path=\"url(#a)\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M15.374.626a1 1 0 0 1 .236 1.038l-4.666 13.333a1 1 0 0 1-1.858.076l-2.51-5.649-5.649-2.51a1 1 0 0 1 .076-1.858L14.336.39a1 1 0 0 1 1.038.237ZM8.526 8.888l1.363 3.068 2.386-6.817zm2.335-5.163L4.044 6.11l3.068 1.363 3.749-3.75Z\" clip-rule=\"evenodd\"/></g><defs><clipPath id=\"a\"><path fill=\"#fff\" d=\"M0 0h16v16H0z\"/></clipPath></defs></svg>",
159
160
  "settings": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g fill-rule=\"evenodd\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" clip-rule=\"evenodd\"><path d=\"M8 10a2 2 0 1 0 0-4 2 2 0 0 0 0 4\"/><path d=\"M12.71 9.91a1.05 1.05 0 0 0 .21 1.157l.037.039a1.272 1.272 0 1 1-1.8 1.8l-.039-.038a1.05 1.05 0 0 0-1.158-.21 1.05 1.05 0 0 0-.636.961v.108a1.273 1.273 0 0 1-2.546 0v-.057a1.05 1.05 0 0 0-.687-.96 1.05 1.05 0 0 0-1.158.21l-.038.037a1.273 1.273 0 1 1-1.801-1.8l.038-.039c.3-.307.383-.765.21-1.158a1.05 1.05 0 0 0-.961-.636h-.108a1.273 1.273 0 1 1 0-2.546h.057a1.05 1.05 0 0 0 .96-.687 1.05 1.05 0 0 0-.21-1.158l-.037-.038a1.273 1.273 0 1 1 1.8-1.801l.039.038c.307.3.765.383 1.158.21h.05a1.05 1.05 0 0 0 .637-.961v-.108a1.273 1.273 0 1 1 2.546 0v.057c.001.419.251.796.636.96.393.174.851.091 1.158-.21l.039-.037a1.273 1.273 0 1 1 1.8 1.8l-.038.039a1.05 1.05 0 0 0-.21 1.158v.05c.165.386.543.636.961.637h.108a1.273 1.273 0 0 1 0 2.546h-.057a1.05 1.05 0 0 0-.96.636z\"/></g></svg>",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "3.10.2",
3
+ "version": "3.11.0",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",