@amboss/design-system 3.13.6 → 3.13.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/ColorIndicator/ColorDot.js +1 -1
- package/build/cjs/components/Divider/Divider.d.ts +11 -1
- package/build/cjs/components/Divider/Divider.js +1 -1
- package/build/cjs/components/PromptInput/PromptInput.js +1 -1
- package/build/cjs/components/Toggletip/BasePopover.js +1 -1
- package/build/cjs/components/Tooltip/utils.d.ts +6 -0
- package/build/cjs/components/Tooltip/utils.js +1 -1
- package/build/cjs/web-tokens/_sizes.json +30 -0
- package/build/cjs/web-tokens/assets/icons.json +73 -72
- package/build/cjs/web-tokens/assets/icons16.json +2 -1
- package/build/cjs/web-tokens/visualConfig.d.ts +5 -0
- package/build/cjs/web-tokens/visualConfig.js +1 -1
- package/build/esm/components/ColorIndicator/ColorDot.js +1 -1
- package/build/esm/components/Divider/Divider.d.ts +11 -1
- package/build/esm/components/Divider/Divider.js +1 -1
- package/build/esm/components/PromptInput/PromptInput.js +1 -1
- package/build/esm/components/Toggletip/BasePopover.js +1 -1
- package/build/esm/components/Tooltip/utils.d.ts +6 -0
- package/build/esm/components/Tooltip/utils.js +1 -1
- package/build/esm/web-tokens/_sizes.json +30 -0
- package/build/esm/web-tokens/assets/icons.json +73 -72
- package/build/esm/web-tokens/assets/icons16.json +2 -1
- package/build/esm/web-tokens/visualConfig.d.ts +5 -0
- package/build/esm/web-tokens/visualConfig.js +1 -1
- package/build/scss/_variables.scss +3 -0
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ColorDot",{enumerable:!0,get:function(){return ColorDot}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react=/*#__PURE__*/_interop_require_default._(require("react")),_mediaQueries=require("../../shared/mediaQueries"),StyledContainer=(0,_styled.default)("div",{target:"
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ColorDot",{enumerable:!0,get:function(){return ColorDot}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_react=/*#__PURE__*/_interop_require_default._(require("react")),_mediaQueries=require("../../shared/mediaQueries"),StyledContainer=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"shape"!==prop,target:"e10rt5g20",label:"StyledContainer"})(({theme,hexCode,shape,size})=>({display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:hexCode,boxSizing:"border-box",borderRadius:"50%",...(0,_mediaQueries.useResponsiveStyles)({borderRadius:[size,theme.variables.size.borderRadius],height:[size,theme.variables.size.dimension.icon],width:[size,theme.variables.size.dimension.icon],..."pill"===shape&&{paddingRight:[size,theme.variables.size.dimension.icon],paddingLeft:[size,theme.variables.size.dimension.icon]}})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29sb3JJbmRpY2F0b3IvQ29sb3JEb3QudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Db2xvckluZGljYXRvci9Db2xvckRvdC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgaXNQcm9wVmFsaWQgZnJvbSBcIkBlbW90aW9uL2lzLXByb3AtdmFsaWRcIjtcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgUHJvcHNXaXRoQ2hpbGRyZW4sIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBNUSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbnR5cGUgU2l6ZXMgPSBcInNcIiB8IFwibVwiO1xuXG5leHBvcnQgdHlwZSBDb2xvckRvdFByb3BzID0ge1xuICBoZXhDb2RlOiBzdHJpbmc7XG4gIHNoYXBlPzogXCJjaXJjbGVcIiB8IFwicGlsbFwiO1xuICBzaXplPzogU2l6ZXMgfCBNUTxTaXplcz47XG59O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQoXCJkaXZcIiwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogKHByb3ApID0+IGlzUHJvcFZhbGlkKHByb3ApICYmIHByb3AgIT09IFwic2hhcGVcIixcbn0pPENvbG9yRG90UHJvcHM+KCh7IHRoZW1lLCBoZXhDb2RlLCBzaGFwZSwgc2l6ZSB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAganVzdGlmeUNvbnRlbnQ6IFwiY2VudGVyXCIsXG4gIGJhY2tncm91bmRDb2xvcjogaGV4Q29kZSxcbiAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgYm9yZGVyUmFkaXVzOiBcIjUwJVwiLFxuICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICBib3JkZXJSYWRpdXM6IFtzaXplLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXNdLFxuICAgIGhlaWdodDogW3NpemUsIHRoZW1lLnZhcmlhYmxlcy5zaXplLmRpbWVuc2lvbi5pY29uXSxcbiAgICB3aWR0aDogW3NpemUsIHRoZW1lLnZhcmlhYmxlcy5zaXplLmRpbWVuc2lvbi5pY29uXSxcbiAgICAuLi4oc2hhcGUgPT09IFwicGlsbFwiICYmIHtcbiAgICAgIHBhZGRpbmdSaWdodDogW3NpemUsIHRoZW1lLnZhcmlhYmxlcy5zaXplLmRpbWVuc2lvbi5pY29uXSxcbiAgICAgIHBhZGRpbmdMZWZ0OiBbc2l6ZSwgdGhlbWUudmFyaWFibGVzLnNpemUuZGltZW5zaW9uLmljb25dLFxuICAgIH0pLFxuICB9KSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIENvbG9yRG90KHtcbiAgaGV4Q29kZSxcbiAgc2hhcGUgPSBcImNpcmNsZVwiLFxuICBzaXplID0gXCJzXCIsXG4gIGNoaWxkcmVuLFxufTogUHJvcHNXaXRoQ2hpbGRyZW48Q29sb3JEb3RQcm9wcz4pOiBSZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIGhleENvZGU9e2hleENvZGV9XG4gICAgICBzaGFwZT17c2hhcGV9XG4gICAgICBzaXplPXtzaXplfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD1cImNvbG9yLWluZGljYXRvclwiXG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWV3QiJ9 */");function ColorDot({hexCode,shape="circle",size="s",children}){return _react.default.createElement(StyledContainer,{hexCode:hexCode,shape:shape,size:size,"data-e2e-test-id":"color-indicator"},children)}
|
|
@@ -1,7 +1,17 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
+
type Sizes = "m" | "l" | "xl";
|
|
2
3
|
export type DividerProps = {
|
|
3
4
|
"data-e2e-test-id"?: string;
|
|
5
|
+
/** To be used only when orientation is horizontal. */
|
|
4
6
|
text?: string;
|
|
5
7
|
"aria-hidden"?: boolean;
|
|
8
|
+
orientation?: "horizontal" | "vertical";
|
|
9
|
+
/**
|
|
10
|
+
* To be used only when orientation is vertical.
|
|
11
|
+
* Represents the height of the vertical Divider.
|
|
12
|
+
* @default 'm'
|
|
13
|
+
*/
|
|
14
|
+
size?: Sizes;
|
|
6
15
|
};
|
|
7
|
-
export declare function Divider({ text, "aria-hidden": ariaHidden, "data-e2e-test-id": dataE2eTestId, }: DividerProps): React.ReactElement;
|
|
16
|
+
export declare function Divider({ text, "aria-hidden": ariaHidden, "data-e2e-test-id": dataE2eTestId, orientation, size, }: Readonly<DividerProps>): React.ReactElement;
|
|
17
|
+
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Divider",{enumerable:!0,get:function(){return Divider}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Text=require("../Typography/Text/Text"),_Box=require("../Box/Box"),StyledContainer=(0,_styled.default)("div",{target:"e1bgcgv50",label:"StyledContainer"})(()=>({display:"flex",justifyContent:"center",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5cbmV4cG9ydCB0eXBlIERpdmlkZXJQcm9wcyA9IHtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIHRleHQ/OiBzdHJpbmc7XG4gIFwiYXJpYS1oaWRkZW5cIj86IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFBhcnRpYWw8RGl2aWRlclByb3BzPj4oKCkgPT4gKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGp1c3RpZnlDb250ZW50OiBcImNlbnRlclwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmhyKCh7IHRoZW1lIH0pID0+ICh7XG4gIGJvcmRlcjogMCxcbiAgbWFyZ2luOiAwLFxuICBwYWRkaW5nOiAwLFxuICBoZWlnaHQ6IDAsXG4gIGJvcmRlclRvcENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5wcmltYXJ5LFxuICBib3JkZXJUb3BXaWR0aDogXCIxcHhcIixcbiAgYm9yZGVyVG9wU3R5bGU6IFwic29saWRcIixcbiAgZmxleDogXCIxXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZENvbnRlbnQgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIG1heFdpZHRoOiBcIjUwJVwiLFxufSkpO1xuXG5leHBvcnQgZnVuY3Rpb24gRGl2aWRlcih7XG4gIHRleHQsXG4gIFwiYXJpYS1oaWRkZW5cIjogYXJpYUhpZGRlbiA9IHRydWUsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogRGl2aWRlclByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgaWYgKHRleHQpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgICByb2xlPVwic2VwYXJhdG9yXCJcbiAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgICAgYXJpYS1vcmllbnRhdGlvbj1cImhvcml6b250YWxcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgICB7dGV4dCAmJiAoXG4gICAgICAgICAgPFN0eWxlZENvbnRlbnQ+XG4gICAgICAgICAgICA8Qm94IHNwYWNlPVwieHhsXCIgdlNwYWNlPVwiemVyb1wiPlxuICAgICAgICAgICAgICA8VGV4dCBjb2xvcj1cInRlcnRpYXJ5XCI+e3RleHR9PC9UZXh0PlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9TdHlsZWRDb250ZW50PlxuICAgICAgICApfVxuICAgICAgICA8U3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgKTtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxTdHlsZWREaXZpZGVyXG4gICAgICBhcmlhLWhpZGRlbj17YXJpYUhpZGRlbiA/IFwidHJ1ZVwiIDogdW5kZWZpbmVkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJEaXZpZGVyXCJcbiAgICAvPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVd3QiJ9 */"),StyledDivider=(0,_styled.default)("hr",{target:"e1bgcgv51",label:"StyledDivider"})(({theme})=>({border:0,margin:0,padding:0,height:0,borderTopColor:theme.values.color.divider.primary,borderTopWidth:"1px",borderTopStyle:"solid",flex:"1"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5cbmV4cG9ydCB0eXBlIERpdmlkZXJQcm9wcyA9IHtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIHRleHQ/OiBzdHJpbmc7XG4gIFwiYXJpYS1oaWRkZW5cIj86IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFBhcnRpYWw8RGl2aWRlclByb3BzPj4oKCkgPT4gKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGp1c3RpZnlDb250ZW50OiBcImNlbnRlclwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmhyKCh7IHRoZW1lIH0pID0+ICh7XG4gIGJvcmRlcjogMCxcbiAgbWFyZ2luOiAwLFxuICBwYWRkaW5nOiAwLFxuICBoZWlnaHQ6IDAsXG4gIGJvcmRlclRvcENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5wcmltYXJ5LFxuICBib3JkZXJUb3BXaWR0aDogXCIxcHhcIixcbiAgYm9yZGVyVG9wU3R5bGU6IFwic29saWRcIixcbiAgZmxleDogXCIxXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZENvbnRlbnQgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIG1heFdpZHRoOiBcIjUwJVwiLFxufSkpO1xuXG5leHBvcnQgZnVuY3Rpb24gRGl2aWRlcih7XG4gIHRleHQsXG4gIFwiYXJpYS1oaWRkZW5cIjogYXJpYUhpZGRlbiA9IHRydWUsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogRGl2aWRlclByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgaWYgKHRleHQpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgICByb2xlPVwic2VwYXJhdG9yXCJcbiAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgICAgYXJpYS1vcmllbnRhdGlvbj1cImhvcml6b250YWxcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgICB7dGV4dCAmJiAoXG4gICAgICAgICAgPFN0eWxlZENvbnRlbnQ+XG4gICAgICAgICAgICA8Qm94IHNwYWNlPVwieHhsXCIgdlNwYWNlPVwiemVyb1wiPlxuICAgICAgICAgICAgICA8VGV4dCBjb2xvcj1cInRlcnRpYXJ5XCI+e3RleHR9PC9UZXh0PlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9TdHlsZWRDb250ZW50PlxuICAgICAgICApfVxuICAgICAgICA8U3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgKTtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxTdHlsZWREaXZpZGVyXG4gICAgICBhcmlhLWhpZGRlbj17YXJpYUhpZGRlbiA/IFwidHJ1ZVwiIDogdW5kZWZpbmVkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJEaXZpZGVyXCJcbiAgICAvPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCc0IifQ== */"),StyledContent=(0,_styled.default)("div",{target:"e1bgcgv52",label:"StyledContent"})(()=>({maxWidth:"50%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5cbmV4cG9ydCB0eXBlIERpdmlkZXJQcm9wcyA9IHtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIHRleHQ/OiBzdHJpbmc7XG4gIFwiYXJpYS1oaWRkZW5cIj86IGJvb2xlYW47XG59O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFBhcnRpYWw8RGl2aWRlclByb3BzPj4oKCkgPT4gKHtcbiAgZGlzcGxheTogXCJmbGV4XCIsXG4gIGp1c3RpZnlDb250ZW50OiBcImNlbnRlclwiLFxuICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxufSkpO1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmhyKCh7IHRoZW1lIH0pID0+ICh7XG4gIGJvcmRlcjogMCxcbiAgbWFyZ2luOiAwLFxuICBwYWRkaW5nOiAwLFxuICBoZWlnaHQ6IDAsXG4gIGJvcmRlclRvcENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5wcmltYXJ5LFxuICBib3JkZXJUb3BXaWR0aDogXCIxcHhcIixcbiAgYm9yZGVyVG9wU3R5bGU6IFwic29saWRcIixcbiAgZmxleDogXCIxXCIsXG59KSk7XG5cbmNvbnN0IFN0eWxlZENvbnRlbnQgPSBzdHlsZWQuZGl2KCgpID0+ICh7XG4gIG1heFdpZHRoOiBcIjUwJVwiLFxufSkpO1xuXG5leHBvcnQgZnVuY3Rpb24gRGl2aWRlcih7XG4gIHRleHQsXG4gIFwiYXJpYS1oaWRkZW5cIjogYXJpYUhpZGRlbiA9IHRydWUsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogRGl2aWRlclByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgaWYgKHRleHQpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZENvbnRhaW5lclxuICAgICAgICByb2xlPVwic2VwYXJhdG9yXCJcbiAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgICAgYXJpYS1vcmllbnRhdGlvbj1cImhvcml6b250YWxcIlxuICAgICAgPlxuICAgICAgICA8U3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgICB7dGV4dCAmJiAoXG4gICAgICAgICAgPFN0eWxlZENvbnRlbnQ+XG4gICAgICAgICAgICA8Qm94IHNwYWNlPVwieHhsXCIgdlNwYWNlPVwiemVyb1wiPlxuICAgICAgICAgICAgICA8VGV4dCBjb2xvcj1cInRlcnRpYXJ5XCI+e3RleHR9PC9UZXh0PlxuICAgICAgICAgICAgPC9Cb3g+XG4gICAgICAgICAgPC9TdHlsZWRDb250ZW50PlxuICAgICAgICApfVxuICAgICAgICA8U3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgKTtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxTdHlsZWREaXZpZGVyXG4gICAgICBhcmlhLWhpZGRlbj17YXJpYUhpZGRlbiA/IFwidHJ1ZVwiIDogdW5kZWZpbmVkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJEaXZpZGVyXCJcbiAgICAvPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCc0IifQ== */");function Divider({text,"aria-hidden":ariaHidden=!0,"data-e2e-test-id":dataE2eTestId}){return text?_react.default.createElement(StyledContainer,{role:"separator","data-e2e-test-id":dataE2eTestId,"aria-orientation":"horizontal"},_react.default.createElement(StyledDivider,{"aria-hidden":"true"}),text&&_react.default.createElement(StyledContent,null,_react.default.createElement(_Box.Box,{space:"xxl",vSpace:"zero"},_react.default.createElement(_Text.Text,{color:"tertiary"},text))),_react.default.createElement(StyledDivider,{"aria-hidden":"true"})):_react.default.createElement(StyledDivider,{"aria-hidden":ariaHidden?"true":void 0,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Divider"})}
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Divider",{enumerable:!0,get:function(){return Divider}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Text=require("../Typography/Text/Text"),_Box=require("../Box/Box"),StyledContainer=(0,_styled.default)("div",{target:"e6ofc1o0",label:"StyledContainer"})(()=>({display:"flex",justifyContent:"center",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5cbnR5cGUgU2l6ZXMgPSBcIm1cIiB8IFwibFwiIHwgXCJ4bFwiO1xuXG5leHBvcnQgdHlwZSBEaXZpZGVyUHJvcHMgPSB7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogVG8gYmUgdXNlZCBvbmx5IHdoZW4gb3JpZW50YXRpb24gaXMgaG9yaXpvbnRhbC4gKi9cbiAgdGV4dD86IHN0cmluZztcbiAgXCJhcmlhLWhpZGRlblwiPzogYm9vbGVhbjtcbiAgb3JpZW50YXRpb24/OiBcImhvcml6b250YWxcIiB8IFwidmVydGljYWxcIjtcbiAgLyoqXG4gICAqIFRvIGJlIHVzZWQgb25seSB3aGVuIG9yaWVudGF0aW9uIGlzIHZlcnRpY2FsLlxuICAgKiBSZXByZXNlbnRzIHRoZSBoZWlnaHQgb2YgdGhlIHZlcnRpY2FsIERpdmlkZXIuXG4gICAqIEBkZWZhdWx0ICdtJ1xuICAgKi9cbiAgc2l6ZT86IFNpemVzO1xufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxQYXJ0aWFsPERpdmlkZXJQcm9wcz4+KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJjZW50ZXJcIixcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuY29uc3QgSG9yaXpvbnRhbFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuaHIoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYm9yZGVyOiAwLFxuICBtYXJnaW46IDAsXG4gIHBhZGRpbmc6IDAsXG4gIGhlaWdodDogMCxcbiAgYm9yZGVyVG9wQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5kaXZpZGVyLnByaW1hcnksXG4gIGJvcmRlclRvcFdpZHRoOiBcIjFweFwiLFxuICBib3JkZXJUb3BTdHlsZTogXCJzb2xpZFwiLFxuICBmbGV4OiBcIjFcIixcbn0pKTtcblxuY29uc3QgVmVydGljYWxTdHlsZWREaXZpZGVyID0gc3R5bGVkLnNwYW48UGljazxEaXZpZGVyUHJvcHMsIFwic2l6ZVwiPj4oXG4gICh7IHRoZW1lLCBzaXplIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgbWFyZ2luOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6IFwiMXB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5zZWNvbmRhcnksXG4gICAgYWxpZ25TZWxmOiBcInN0cmV0Y2hcIixcbiAgICBtaW5IZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmRpbWVuc2lvbi5kaXZpZGVyW3NpemVdLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXYoKCkgPT4gKHtcbiAgbWF4V2lkdGg6IFwiNTAlXCIsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBEaXZpZGVyKHtcbiAgdGV4dCxcbiAgXCJhcmlhLWhpZGRlblwiOiBhcmlhSGlkZGVuID0gdHJ1ZSxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gIG9yaWVudGF0aW9uID0gXCJob3Jpem9udGFsXCIsXG4gIHNpemUgPSBcIm1cIixcbn06IFJlYWRvbmx5PERpdmlkZXJQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAob3JpZW50YXRpb24gPT09IFwidmVydGljYWxcIikge1xuICAgIHJldHVybiA8VmVydGljYWxTdHlsZWREaXZpZGVyIHNpemU9e3NpemV9IC8+O1xuICB9XG4gIGlmICh0ZXh0KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICAgIGFyaWEtb3JpZW50YXRpb249XCJob3Jpem9udGFsXCJcbiAgICAgID5cbiAgICAgICAgPEhvcml6b250YWxTdHlsZWREaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIC8+XG4gICAgICAgIDxTdHlsZWRDb250ZW50PlxuICAgICAgICAgIDxCb3ggc3BhY2U9XCJ4eGxcIiB2U3BhY2U9XCJ6ZXJvXCI+XG4gICAgICAgICAgICA8VGV4dCBjb2xvcj1cInRlcnRpYXJ5XCI+e3RleHR9PC9UZXh0PlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICA8L1N0eWxlZENvbnRlbnQ+XG4gICAgICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgKTtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlclxuICAgICAgYXJpYS1oaWRkZW49e2FyaWFIaWRkZW4gPyBcInRydWVcIiA6IHVuZGVmaW5lZH1cbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiRGl2aWRlclwiXG4gICAgLz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQndCIn0= */"),HorizontalStyledDivider=(0,_styled.default)("hr",{target:"e6ofc1o1",label:"HorizontalStyledDivider"})(({theme})=>({border:0,margin:0,padding:0,height:0,borderTopColor:theme.values.color.divider.primary,borderTopWidth:"1px",borderTopStyle:"solid",flex:"1"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5cbnR5cGUgU2l6ZXMgPSBcIm1cIiB8IFwibFwiIHwgXCJ4bFwiO1xuXG5leHBvcnQgdHlwZSBEaXZpZGVyUHJvcHMgPSB7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogVG8gYmUgdXNlZCBvbmx5IHdoZW4gb3JpZW50YXRpb24gaXMgaG9yaXpvbnRhbC4gKi9cbiAgdGV4dD86IHN0cmluZztcbiAgXCJhcmlhLWhpZGRlblwiPzogYm9vbGVhbjtcbiAgb3JpZW50YXRpb24/OiBcImhvcml6b250YWxcIiB8IFwidmVydGljYWxcIjtcbiAgLyoqXG4gICAqIFRvIGJlIHVzZWQgb25seSB3aGVuIG9yaWVudGF0aW9uIGlzIHZlcnRpY2FsLlxuICAgKiBSZXByZXNlbnRzIHRoZSBoZWlnaHQgb2YgdGhlIHZlcnRpY2FsIERpdmlkZXIuXG4gICAqIEBkZWZhdWx0ICdtJ1xuICAgKi9cbiAgc2l6ZT86IFNpemVzO1xufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxQYXJ0aWFsPERpdmlkZXJQcm9wcz4+KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJjZW50ZXJcIixcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuY29uc3QgSG9yaXpvbnRhbFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuaHIoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYm9yZGVyOiAwLFxuICBtYXJnaW46IDAsXG4gIHBhZGRpbmc6IDAsXG4gIGhlaWdodDogMCxcbiAgYm9yZGVyVG9wQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5kaXZpZGVyLnByaW1hcnksXG4gIGJvcmRlclRvcFdpZHRoOiBcIjFweFwiLFxuICBib3JkZXJUb3BTdHlsZTogXCJzb2xpZFwiLFxuICBmbGV4OiBcIjFcIixcbn0pKTtcblxuY29uc3QgVmVydGljYWxTdHlsZWREaXZpZGVyID0gc3R5bGVkLnNwYW48UGljazxEaXZpZGVyUHJvcHMsIFwic2l6ZVwiPj4oXG4gICh7IHRoZW1lLCBzaXplIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgbWFyZ2luOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6IFwiMXB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5zZWNvbmRhcnksXG4gICAgYWxpZ25TZWxmOiBcInN0cmV0Y2hcIixcbiAgICBtaW5IZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmRpbWVuc2lvbi5kaXZpZGVyW3NpemVdLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXYoKCkgPT4gKHtcbiAgbWF4V2lkdGg6IFwiNTAlXCIsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBEaXZpZGVyKHtcbiAgdGV4dCxcbiAgXCJhcmlhLWhpZGRlblwiOiBhcmlhSGlkZGVuID0gdHJ1ZSxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gIG9yaWVudGF0aW9uID0gXCJob3Jpem9udGFsXCIsXG4gIHNpemUgPSBcIm1cIixcbn06IFJlYWRvbmx5PERpdmlkZXJQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAob3JpZW50YXRpb24gPT09IFwidmVydGljYWxcIikge1xuICAgIHJldHVybiA8VmVydGljYWxTdHlsZWREaXZpZGVyIHNpemU9e3NpemV9IC8+O1xuICB9XG4gIGlmICh0ZXh0KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICAgIGFyaWEtb3JpZW50YXRpb249XCJob3Jpem9udGFsXCJcbiAgICAgID5cbiAgICAgICAgPEhvcml6b250YWxTdHlsZWREaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIC8+XG4gICAgICAgIDxTdHlsZWRDb250ZW50PlxuICAgICAgICAgIDxCb3ggc3BhY2U9XCJ4eGxcIiB2U3BhY2U9XCJ6ZXJvXCI+XG4gICAgICAgICAgICA8VGV4dCBjb2xvcj1cInRlcnRpYXJ5XCI+e3RleHR9PC9UZXh0PlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICA8L1N0eWxlZENvbnRlbnQ+XG4gICAgICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgKTtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlclxuICAgICAgYXJpYS1oaWRkZW49e2FyaWFIaWRkZW4gPyBcInRydWVcIiA6IHVuZGVmaW5lZH1cbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiRGl2aWRlclwiXG4gICAgLz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQmdDIn0= */"),VerticalStyledDivider=(0,_styled.default)("span",{target:"e6ofc1o2",label:"VerticalStyledDivider"})(({theme,size})=>({display:"flex",margin:0,padding:0,width:"1px",backgroundColor:theme.values.color.divider.secondary,alignSelf:"stretch",minHeight:theme.variables.size.dimension.divider[size]}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5cbnR5cGUgU2l6ZXMgPSBcIm1cIiB8IFwibFwiIHwgXCJ4bFwiO1xuXG5leHBvcnQgdHlwZSBEaXZpZGVyUHJvcHMgPSB7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogVG8gYmUgdXNlZCBvbmx5IHdoZW4gb3JpZW50YXRpb24gaXMgaG9yaXpvbnRhbC4gKi9cbiAgdGV4dD86IHN0cmluZztcbiAgXCJhcmlhLWhpZGRlblwiPzogYm9vbGVhbjtcbiAgb3JpZW50YXRpb24/OiBcImhvcml6b250YWxcIiB8IFwidmVydGljYWxcIjtcbiAgLyoqXG4gICAqIFRvIGJlIHVzZWQgb25seSB3aGVuIG9yaWVudGF0aW9uIGlzIHZlcnRpY2FsLlxuICAgKiBSZXByZXNlbnRzIHRoZSBoZWlnaHQgb2YgdGhlIHZlcnRpY2FsIERpdmlkZXIuXG4gICAqIEBkZWZhdWx0ICdtJ1xuICAgKi9cbiAgc2l6ZT86IFNpemVzO1xufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxQYXJ0aWFsPERpdmlkZXJQcm9wcz4+KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJjZW50ZXJcIixcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuY29uc3QgSG9yaXpvbnRhbFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuaHIoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYm9yZGVyOiAwLFxuICBtYXJnaW46IDAsXG4gIHBhZGRpbmc6IDAsXG4gIGhlaWdodDogMCxcbiAgYm9yZGVyVG9wQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5kaXZpZGVyLnByaW1hcnksXG4gIGJvcmRlclRvcFdpZHRoOiBcIjFweFwiLFxuICBib3JkZXJUb3BTdHlsZTogXCJzb2xpZFwiLFxuICBmbGV4OiBcIjFcIixcbn0pKTtcblxuY29uc3QgVmVydGljYWxTdHlsZWREaXZpZGVyID0gc3R5bGVkLnNwYW48UGljazxEaXZpZGVyUHJvcHMsIFwic2l6ZVwiPj4oXG4gICh7IHRoZW1lLCBzaXplIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgbWFyZ2luOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6IFwiMXB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5zZWNvbmRhcnksXG4gICAgYWxpZ25TZWxmOiBcInN0cmV0Y2hcIixcbiAgICBtaW5IZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmRpbWVuc2lvbi5kaXZpZGVyW3NpemVdLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXYoKCkgPT4gKHtcbiAgbWF4V2lkdGg6IFwiNTAlXCIsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBEaXZpZGVyKHtcbiAgdGV4dCxcbiAgXCJhcmlhLWhpZGRlblwiOiBhcmlhSGlkZGVuID0gdHJ1ZSxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gIG9yaWVudGF0aW9uID0gXCJob3Jpem9udGFsXCIsXG4gIHNpemUgPSBcIm1cIixcbn06IFJlYWRvbmx5PERpdmlkZXJQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAob3JpZW50YXRpb24gPT09IFwidmVydGljYWxcIikge1xuICAgIHJldHVybiA8VmVydGljYWxTdHlsZWREaXZpZGVyIHNpemU9e3NpemV9IC8+O1xuICB9XG4gIGlmICh0ZXh0KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICAgIGFyaWEtb3JpZW50YXRpb249XCJob3Jpem9udGFsXCJcbiAgICAgID5cbiAgICAgICAgPEhvcml6b250YWxTdHlsZWREaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIC8+XG4gICAgICAgIDxTdHlsZWRDb250ZW50PlxuICAgICAgICAgIDxCb3ggc3BhY2U9XCJ4eGxcIiB2U3BhY2U9XCJ6ZXJvXCI+XG4gICAgICAgICAgICA8VGV4dCBjb2xvcj1cInRlcnRpYXJ5XCI+e3RleHR9PC9UZXh0PlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICA8L1N0eWxlZENvbnRlbnQ+XG4gICAgICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgKTtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlclxuICAgICAgYXJpYS1oaWRkZW49e2FyaWFIaWRkZW4gPyBcInRydWVcIiA6IHVuZGVmaW5lZH1cbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiRGl2aWRlclwiXG4gICAgLz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQzhCIn0= */"),StyledContent=(0,_styled.default)("div",{target:"e6ofc1o3",label:"StyledContent"})(()=>({maxWidth:"50%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRGl2aWRlci9EaXZpZGVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5cbnR5cGUgU2l6ZXMgPSBcIm1cIiB8IFwibFwiIHwgXCJ4bFwiO1xuXG5leHBvcnQgdHlwZSBEaXZpZGVyUHJvcHMgPSB7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogVG8gYmUgdXNlZCBvbmx5IHdoZW4gb3JpZW50YXRpb24gaXMgaG9yaXpvbnRhbC4gKi9cbiAgdGV4dD86IHN0cmluZztcbiAgXCJhcmlhLWhpZGRlblwiPzogYm9vbGVhbjtcbiAgb3JpZW50YXRpb24/OiBcImhvcml6b250YWxcIiB8IFwidmVydGljYWxcIjtcbiAgLyoqXG4gICAqIFRvIGJlIHVzZWQgb25seSB3aGVuIG9yaWVudGF0aW9uIGlzIHZlcnRpY2FsLlxuICAgKiBSZXByZXNlbnRzIHRoZSBoZWlnaHQgb2YgdGhlIHZlcnRpY2FsIERpdmlkZXIuXG4gICAqIEBkZWZhdWx0ICdtJ1xuICAgKi9cbiAgc2l6ZT86IFNpemVzO1xufTtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxQYXJ0aWFsPERpdmlkZXJQcm9wcz4+KCgpID0+ICh7XG4gIGRpc3BsYXk6IFwiZmxleFwiLFxuICBqdXN0aWZ5Q29udGVudDogXCJjZW50ZXJcIixcbiAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbn0pKTtcblxuY29uc3QgSG9yaXpvbnRhbFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuaHIoKHsgdGhlbWUgfSkgPT4gKHtcbiAgYm9yZGVyOiAwLFxuICBtYXJnaW46IDAsXG4gIHBhZGRpbmc6IDAsXG4gIGhlaWdodDogMCxcbiAgYm9yZGVyVG9wQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5kaXZpZGVyLnByaW1hcnksXG4gIGJvcmRlclRvcFdpZHRoOiBcIjFweFwiLFxuICBib3JkZXJUb3BTdHlsZTogXCJzb2xpZFwiLFxuICBmbGV4OiBcIjFcIixcbn0pKTtcblxuY29uc3QgVmVydGljYWxTdHlsZWREaXZpZGVyID0gc3R5bGVkLnNwYW48UGljazxEaXZpZGVyUHJvcHMsIFwic2l6ZVwiPj4oXG4gICh7IHRoZW1lLCBzaXplIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgbWFyZ2luOiAwLFxuICAgIHBhZGRpbmc6IDAsXG4gICAgd2lkdGg6IFwiMXB4XCIsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuZGl2aWRlci5zZWNvbmRhcnksXG4gICAgYWxpZ25TZWxmOiBcInN0cmV0Y2hcIixcbiAgICBtaW5IZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmRpbWVuc2lvbi5kaXZpZGVyW3NpemVdLFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXYoKCkgPT4gKHtcbiAgbWF4V2lkdGg6IFwiNTAlXCIsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBEaXZpZGVyKHtcbiAgdGV4dCxcbiAgXCJhcmlhLWhpZGRlblwiOiBhcmlhSGlkZGVuID0gdHJ1ZSxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG4gIG9yaWVudGF0aW9uID0gXCJob3Jpem9udGFsXCIsXG4gIHNpemUgPSBcIm1cIixcbn06IFJlYWRvbmx5PERpdmlkZXJQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBpZiAob3JpZW50YXRpb24gPT09IFwidmVydGljYWxcIikge1xuICAgIHJldHVybiA8VmVydGljYWxTdHlsZWREaXZpZGVyIHNpemU9e3NpemV9IC8+O1xuICB9XG4gIGlmICh0ZXh0KSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgICAgcm9sZT1cInNlcGFyYXRvclwiXG4gICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICAgIGFyaWEtb3JpZW50YXRpb249XCJob3Jpem9udGFsXCJcbiAgICAgID5cbiAgICAgICAgPEhvcml6b250YWxTdHlsZWREaXZpZGVyIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIC8+XG4gICAgICAgIDxTdHlsZWRDb250ZW50PlxuICAgICAgICAgIDxCb3ggc3BhY2U9XCJ4eGxcIiB2U3BhY2U9XCJ6ZXJvXCI+XG4gICAgICAgICAgICA8VGV4dCBjb2xvcj1cInRlcnRpYXJ5XCI+e3RleHR9PC9UZXh0PlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICA8L1N0eWxlZENvbnRlbnQ+XG4gICAgICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlciBhcmlhLWhpZGRlbj1cInRydWVcIiAvPlxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgKTtcbiAgfVxuICByZXR1cm4gKFxuICAgIDxIb3Jpem9udGFsU3R5bGVkRGl2aWRlclxuICAgICAgYXJpYS1oaWRkZW49e2FyaWFIaWRkZW4gPyBcInRydWVcIiA6IHVuZGVmaW5lZH1cbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiRGl2aWRlclwiXG4gICAgLz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRHNCIn0= */");function Divider({text,"aria-hidden":ariaHidden=!0,"data-e2e-test-id":dataE2eTestId,orientation="horizontal",size="m"}){return"vertical"===orientation?_react.default.createElement(VerticalStyledDivider,{size:size}):text?_react.default.createElement(StyledContainer,{role:"separator","data-e2e-test-id":dataE2eTestId,"aria-orientation":"horizontal"},_react.default.createElement(HorizontalStyledDivider,{"aria-hidden":"true"}),_react.default.createElement(StyledContent,null,_react.default.createElement(_Box.Box,{space:"xxl",vSpace:"zero"},_react.default.createElement(_Text.Text,{color:"tertiary"},text))),_react.default.createElement(HorizontalStyledDivider,{"aria-hidden":"true"})):_react.default.createElement(HorizontalStyledDivider,{"aria-hidden":ariaHidden?"true":void 0,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Divider"})}
|
|
@@ -1 +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"),CustomContainer=(0,_styled.default)(_Container.Container,{target:"e1dwpec10",label:"CustomContainer"})(({theme})=>({"&:has(textarea:focus-visible)":{outlineWidth:1,outlineStyle:"solid",outlineOffset:-1,outlineColor:theme.values.color.border.accent.default,boxShadow:theme.values.shadow.focusRing,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:theme.values.color.border.accent.default}}}),"/*# 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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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 CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AAsCwB"} */"),StyledTextAreaContainer=(0,_styled.default)("div",{target:"e1dwpec11",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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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 CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AAoDgC"} */"),StyledEmptyStateTopRightContentContainer=(0,_styled.default)("div",{target:"e1dwpec12",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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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 CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AA8DE"} */"),StyledClearButton=(0,_styled.default)(_PictogramButton.PictogramButton,{target:"e1dwpec13",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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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 CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AA6E0B"} */"),PromptInput=(0,_react.forwardRef)(({"data-e2e-test-id":dataE2eTestId,name,autocompleteListItems=[],value,bottomToolbar={leftContent:null,rightContent:null},isProcessing,sendButtonProps={type:"submit",icon:"arrow-up"},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,indexInCategory:index,value:item.value,id:(0,_CategoryList.getListItemId)(name,listItem.category,index)})})}),list},[autocompleteListItems,name]),handleSelectedIndexChange=(index,evt)=>{if(setSelectedIndex(index),-1!==index){let{category,value:itemValue}=flattenedListItems[index];onComplete({value:itemValue,category,evt,index})}},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-circle-filled","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,{...sendButtonProps,ariaAttributes:{"aria-label":isProcessing?"Processing query":"Submit query"},variant:"primary",disabled:!value,icon:isProcessing?"stop-filled":sendButtonProps.icon})))));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(CustomContainer,{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?.({value:userTypedQuery.current,evt}),onBlur?.(evt)},onChange:evt=>{userTypedQuery.current=evt.target.value,onChange(evt)},onKeyDown:evt=>{if(isAutocompleteListOpen)switch(evt.key){case"Escape":closeAutocompleteList(),onComplete({value:userTypedQuery.current,evt});break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),closeAutocompleteList(),acceptTextSelection(),value&&onEnterKey?.());break;case" ":acceptTextSelection();break;case"ArrowUp":evt.preventDefault(),selectedIndex>-1&&handleSelectedIndexChange(selectedIndex-1,evt);break;case"ArrowDown":evt.preventDefault(),selectedIndex<flattenedListItems.length-1&&handleSelectedIndexChange(selectedIndex+1,evt)}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,indexInCategory,evt)=>{handleSelectedIndexChange(flattenedListItems.findIndex(listItem=>listItem.category===category&&listItem.indexInCategory===indexInCategory),evt),closeAutocompleteList()}}))});
|
|
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"),_useOutsideClick=require("../../shared/useOutsideClick"),CustomContainer=(0,_styled.default)(_Container.Container,{target:"efe0l6k0",label:"CustomContainer"})(({theme})=>({"&:has(textarea:focus-visible)":{outlineWidth:1,outlineStyle:"solid",outlineOffset:-1,outlineColor:theme.values.color.border.accent.default,boxShadow:theme.values.shadow.focusRing,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:theme.values.color.border.accent.default}}}),"/*# 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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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\";\nimport { useOutsideClick } from \"../../shared/useOutsideClick\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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    useOutsideClick(\n      containerRef,\n      (evt) => {\n        if (\n          !containerRef.current.contains(evt.target as Node) &&\n          !portalContainer?.contains(evt.target as Node) &&\n          evt.target !== null\n        ) {\n          setIsCollapsed(true);\n        }\n      },\n      !isCollapsed && isNavBarVariant\n    );\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 (\n            !containerRef.current.contains(evt.relatedTarget as Node) &&\n            !portalContainer?.contains(evt.relatedTarget as Node) &&\n            evt.relatedTarget !== null\n          ) {\n            setIsCollapsed(true);\n          }\n        };\n        window.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          window.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef, portalContainer]);\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AAuCwB"} */"),StyledTextAreaContainer=(0,_styled.default)("div",{target:"efe0l6k1",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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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\";\nimport { useOutsideClick } from \"../../shared/useOutsideClick\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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    useOutsideClick(\n      containerRef,\n      (evt) => {\n        if (\n          !containerRef.current.contains(evt.target as Node) &&\n          !portalContainer?.contains(evt.target as Node) &&\n          evt.target !== null\n        ) {\n          setIsCollapsed(true);\n        }\n      },\n      !isCollapsed && isNavBarVariant\n    );\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 (\n            !containerRef.current.contains(evt.relatedTarget as Node) &&\n            !portalContainer?.contains(evt.relatedTarget as Node) &&\n            evt.relatedTarget !== null\n          ) {\n            setIsCollapsed(true);\n          }\n        };\n        window.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          window.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef, portalContainer]);\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AAqDgC"} */"),StyledEmptyStateTopRightContentContainer=(0,_styled.default)("div",{target:"efe0l6k2",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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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\";\nimport { useOutsideClick } from \"../../shared/useOutsideClick\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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    useOutsideClick(\n      containerRef,\n      (evt) => {\n        if (\n          !containerRef.current.contains(evt.target as Node) &&\n          !portalContainer?.contains(evt.target as Node) &&\n          evt.target !== null\n        ) {\n          setIsCollapsed(true);\n        }\n      },\n      !isCollapsed && isNavBarVariant\n    );\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 (\n            !containerRef.current.contains(evt.relatedTarget as Node) &&\n            !portalContainer?.contains(evt.relatedTarget as Node) &&\n            evt.relatedTarget !== null\n          ) {\n            setIsCollapsed(true);\n          }\n        };\n        window.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          window.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef, portalContainer]);\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AA+DE"} */"),StyledClearButton=(0,_styled.default)(_PictogramButton.PictogramButton,{target:"efe0l6k3",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  SyntheticEvent,\n  MouseEvent,\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 {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} 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\";\nimport { useOutsideClick } from \"../../shared/useOutsideClick\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\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    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\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?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => 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        icon: \"arrow-up\",\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    useOutsideClick(\n      containerRef,\n      (evt) => {\n        if (\n          !containerRef.current.contains(evt.target as Node) &&\n          !portalContainer?.contains(evt.target as Node) &&\n          evt.target !== null\n        ) {\n          setIsCollapsed(true);\n        }\n      },\n      !isCollapsed && isNavBarVariant\n    );\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 (\n            !containerRef.current.contains(evt.relatedTarget as Node) &&\n            !portalContainer?.contains(evt.relatedTarget as Node) &&\n            evt.relatedTarget !== null\n          ) {\n            setIsCollapsed(true);\n          }\n        };\n        window.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          window.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef, portalContainer]);\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            indexInCategory: index,\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, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\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, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\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?.({ value: userTypedQuery.current, evt });\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-circle-filled\"\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                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\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              <CustomContainer\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              </CustomContainer>\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":"AA8E0B"} */"),PromptInput=(0,_react.forwardRef)(({"data-e2e-test-id":dataE2eTestId,name,autocompleteListItems=[],value,bottomToolbar={leftContent:null,rightContent:null},isProcessing,sendButtonProps={type:"submit",icon:"arrow-up"},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;(0,_useOutsideClick.useOutsideClick)(containerRef,evt=>{containerRef.current.contains(evt.target)||portalContainer?.contains(evt.target)||null===evt.target||setIsCollapsed(!0)},!isCollapsed&&isNavBarVariant);let 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)||portalContainer?.contains(evt.relatedTarget)||null===evt.relatedTarget||setIsCollapsed(!0)},window.addEventListener("focusout",handler)),()=>{container&&window.removeEventListener("focusout",handler)}},[isNavBarVariant,containerRef,portalContainer]);let flattenedListItems=(0,_react.useMemo)(()=>{let list=[];return autocompleteListItems.forEach(listItem=>{listItem.items.forEach((item,index)=>{list.push({category:listItem.category,indexInCategory:index,value:item.value,id:(0,_CategoryList.getListItemId)(name,listItem.category,index)})})}),list},[autocompleteListItems,name]),handleSelectedIndexChange=(index,evt)=>{if(setSelectedIndex(index),-1!==index){let{category,value:itemValue}=flattenedListItems[index];onComplete({value:itemValue,category,evt,index})}},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-circle-filled","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,{...sendButtonProps,ariaAttributes:{"aria-label":isProcessing?"Processing query":"Submit query"},variant:"primary",disabled:!value,icon:isProcessing?"stop-filled":sendButtonProps.icon})))));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(CustomContainer,{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?.({value:userTypedQuery.current,evt}),onBlur?.(evt)},onChange:evt=>{userTypedQuery.current=evt.target.value,onChange(evt)},onKeyDown:evt=>{if(isAutocompleteListOpen)switch(evt.key){case"Escape":closeAutocompleteList(),onComplete({value:userTypedQuery.current,evt});break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),closeAutocompleteList(),acceptTextSelection(),value&&onEnterKey?.());break;case" ":acceptTextSelection();break;case"ArrowUp":evt.preventDefault(),selectedIndex>-1&&handleSelectedIndexChange(selectedIndex-1,evt);break;case"ArrowDown":evt.preventDefault(),selectedIndex<flattenedListItems.length-1&&handleSelectedIndexChange(selectedIndex+1,evt)}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,indexInCategory,evt)=>{handleSelectedIndexChange(flattenedListItems.findIndex(listItem=>listItem.category===category&&listItem.indexInCategory===indexInCategory),evt),closeAutocompleteList()}}))});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BasePopover",{enumerable:!0,get:function(){return BasePopover}});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")),_TooltipContent=require("../Tooltip/TooltipContent"),_Sheet=require("../Sheet/Sheet"),_FocusTrapWrapper=require("../../shared/FocusTrapWrapper"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledContainer=(0,_styled.default)("div",{target:"e1my8fs50",label:"StyledContainer"})(()=>({borderRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Toggletip/BasePopover.tsx","sources":["src/components/Toggletip/BasePopover.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type {\n  ReactElement,\n  PropsWithChildren,\n  MouseEvent as ReactMouseEvent,\n} from \"react\";\nimport React, {\n  useState,\n  useRef,\n  useEffect,\n  useCallback,\n  useMemo,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TooltipContentProps } from \"../Tooltip/TooltipContent\";\nimport type { TooltipConditionalProps } from \"../Tooltip/types\";\nimport { TooltipContent } from \"../Tooltip/TooltipContent\";\nimport { Sheet } from \"../Sheet/Sheet\";\nimport { FocusTrapWrapper } from \"../../shared/FocusTrapWrapper\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\ntype BaseProps = Pick<\n  TooltipContentProps,\n  | \"placement\"\n  | \"portalContainer\"\n  | \"maxWidth\"\n  | \"contentPadding\"\n  | \"hideArrow\"\n  | \"subTheme\"\n  | \"defaultVerticalPlacement\"\n  | \"onOverflowViewport\"\n> & {\n  name?: string;\n  /**  Popover content */\n  content: ReactElement;\n  \"data-e2e-test-id\"?: string;\n  /**  Programmatically toggle Popover visibility with this prop */\n  isVisible?: boolean;\n  /**  Called when tooltip appears and disappears */\n  onVisibilityChange?: (isVisible: boolean, reason: string) => void;\n  /**  Controls whether BasePopover  closes on outside click */\n  dismissOnOutsideClick?: boolean;\n  /**  Option for focus-trap, controls whether the first focuable item recieves focus */\n  disableInitialFocus?: boolean;\n  /**  Option for focus-trap, controls whether the trigger should receive back the focus on popover close */\n  disableReturnFocusToTrigger?: boolean;\n  /**  Render as sheet on mobile web */\n  renderAsSheetOnMobile?: boolean;\n  /**  Props for configuring the sheet on mobile web */\n  sheetProps?: {\n    /**  Show the dark scrim backdrop on mobile web when rendering as Sheet */\n    hasBackdrop?: boolean;\n  };\n};\n\nexport type BasePopoverProps = BaseProps & TooltipConditionalProps;\n\nconst StyledContainer = styled.div(() => ({\n  borderRadius: \"inherit\",\n}));\n\nconst FocusTrapContent = React.forwardRef<\n  HTMLDivElement,\n  PropsWithChildren<unknown>\n>(({ children }, ref) => (\n  <StyledContainer ref={ref}>{children}</StyledContainer>\n));\n\nconst VisibilityChangeReason = {\n  triggerClick: \"triggerClick\",\n  outsideClick: \"outsideClick\",\n};\n\nfunction getMobileBreakpoint(renderAsSheetOnMobile: boolean) {\n  return (\n    typeof window !== \"undefined\" &&\n    renderAsSheetOnMobile &&\n    window.innerWidth <= breakpoints.medium.value\n  );\n}\n\nexport function BasePopover({\n  placement = \"auto\",\n  content,\n  children,\n  contentPadding = \"m\",\n  maxWidth,\n  externalTriggerRef,\n  portalContainer,\n  name = \"Popover\",\n  isVisible: isPopoverVisible,\n  dismissOnOutsideClick = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  subTheme,\n  defaultVerticalPlacement,\n  onVisibilityChange,\n  disableInitialFocus = false,\n  disableReturnFocusToTrigger = false,\n  renderAsSheetOnMobile = false,\n  sheetProps,\n  ...restContentProps\n}: BasePopoverProps): React.ReactElement {\n  const tooltipId = useMemo(\n    () => `DS${name}_${Math.floor(Date.now() * Math.random())}`,\n    [name]\n  );\n  const [isVisible, setVisible] = useState(isPopoverVisible);\n  const [isMobileBreakPoint, setIsMobileBreakpoint] = useState(\n    getMobileBreakpoint(renderAsSheetOnMobile)\n  );\n  const internalTriggerRef = useRef<HTMLElement>(null);\n  const triggerRef = externalTriggerRef || internalTriggerRef;\n  const isOutsideClickOnTrigger = useRef(false);\n\n  const toggleVisibility = useCallback(\n    (status: boolean, reason: string) => {\n      setVisible(status);\n\n      if (onVisibilityChange) {\n        onVisibilityChange(status, reason);\n      }\n    },\n    [onVisibilityChange]\n  );\n\n  // Outside click is also fired when the Popover is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Popover twice.\n  const handleTriggerClick = useCallback(() => {\n    if (!isOutsideClickOnTrigger.current) {\n      toggleVisibility(!isVisible, VisibilityChangeReason.triggerClick);\n    } else {\n      // reset this value so that Popover can open in next click\n      isOutsideClickOnTrigger.current = false;\n    }\n  }, [toggleVisibility, isVisible]);\n\n  const handleClickOutsideDeactivates = useCallback(\n    (evt: MouseEvent) => {\n      if (\n        triggerRef.current &&\n        triggerRef.current.contains(evt.target as Node)\n      ) {\n        isOutsideClickOnTrigger.current = true;\n      }\n      return true;\n    },\n    [triggerRef, isOutsideClickOnTrigger]\n  );\n\n  const handlePostDeactivate = useCallback(() => {\n    const reason = isOutsideClickOnTrigger.current\n      ? VisibilityChangeReason.triggerClick\n      : VisibilityChangeReason.outsideClick;\n\n    toggleVisibility(false, reason);\n  }, [toggleVisibility]);\n\n  useEffect(() => {\n    setVisible(isPopoverVisible);\n  }, [isPopoverVisible]);\n\n  useEffect(() => {\n    // Check if this is a mobile breakpoint\n    setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile));\n  }, [isVisible, renderAsSheetOnMobile]);\n\n  useEffect(() => {\n    let trigger: HTMLElement;\n\n    if (externalTriggerRef?.current && !children) {\n      trigger = externalTriggerRef.current;\n      const triggerTabIndex = trigger.getAttribute(\"tabindex\");\n\n      trigger.setAttribute(\"tabindex\", triggerTabIndex ?? \"0\");\n      trigger.addEventListener(\"click\", handleTriggerClick);\n    }\n\n    return () => {\n      if (trigger) {\n        trigger.removeEventListener(\"click\", handleTriggerClick);\n      }\n    };\n  }, [externalTriggerRef, children, handleTriggerClick]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n\n      trigger.setAttribute(\"aria-haspopup\", \"true\");\n      if (isVisible) {\n        trigger.setAttribute(\"aria-expanded\", \"true\");\n        trigger.setAttribute(\"aria-controls\", tooltipId);\n      } else {\n        trigger.removeAttribute(\"aria-expanded\");\n        trigger.removeAttribute(\"aria-controls\");\n      }\n    }\n  }, [externalTriggerRef, children, tooltipId, isVisible]);\n\n  const triggerElm = children\n    ? React.cloneElement(children, {\n        ref: triggerRef,\n        ...(isVisible && {\n          \"aria-expanded\": true,\n          \"aria-controls\": tooltipId,\n        }),\n        tabIndex: children.props.tabIndex ?? 0,\n        \"aria-haspopup\": true,\n        onClick: (evt: ReactMouseEvent) => {\n          handleTriggerClick();\n          if (children.props.onClick) {\n            children.props.onClick(evt);\n          }\n        },\n      })\n    : null;\n\n  if (isMobileBreakPoint) {\n    // render as Sheet\n    const sheetElm = (\n      <Sheet\n        id={tooltipId}\n        isVisible={isVisible}\n        portalContainer={portalContainer}\n        dismissOnOutsideClick={dismissOnOutsideClick}\n        disableInitialFocus={disableInitialFocus}\n        disableReturnFocusToTrigger={disableReturnFocusToTrigger}\n        onClose={handlePostDeactivate}\n        onClickOutsideDeactivates={handleClickOutsideDeactivates}\n        {...(sheetProps ?? {})}\n      >\n        {content}\n      </Sheet>\n    );\n\n    return (\n      <>\n        {triggerElm}\n        {sheetElm}\n      </>\n    );\n  }\n\n  // render as Popover\n  const contentElm = (\n    <FocusTrapWrapper\n      active={isVisible}\n      focusTrapOptions={{\n        clickOutsideDeactivates:\n          dismissOnOutsideClick && handleClickOutsideDeactivates, // de-activate focus trap on outside click\n        allowOutsideClick: true,\n        escapeDeactivates: true,\n        fallbackFocus: `#${tooltipId}`, // set focus to tooltip content container if it has no focusable element\n        onPostDeactivate: handlePostDeactivate,\n        preventScroll: true,\n        initialFocus: () => !disableInitialFocus,\n        returnFocusOnDeactivate: !disableReturnFocusToTrigger,\n      }}\n    >\n      <FocusTrapContent>{content}</FocusTrapContent>\n    </FocusTrapWrapper>\n  );\n\n  const tooltipElm = (\n    <TooltipContent\n      {...restContentProps} // eslint-disable-line react/jsx-props-no-spreading\n      defaultVerticalPlacement={defaultVerticalPlacement}\n      dataDSId={name}\n      content={contentElm}\n      contentPadding={contentPadding}\n      maxWidth={maxWidth}\n      placement={placement}\n      portalContainer={portalContainer}\n      dataE2eTestId={dataE2eTestId}\n      subTheme={subTheme}\n      isVisible={isVisible}\n      tooltipId={tooltipId}\n      triggerRef={triggerRef}\n      isHiddenOnInvisibleTrigger\n    />\n  );\n\n  return (\n    <>\n      {triggerElm}\n      {tooltipElm}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAyDwB"} */"),FocusTrapContent=_react.default.forwardRef(({children},ref)=>_react.default.createElement(StyledContainer,{ref:ref},children)),VisibilityChangeReason={triggerClick:"triggerClick",outsideClick:"outsideClick"};function getMobileBreakpoint(renderAsSheetOnMobile){return"undefined"!=typeof window&&renderAsSheetOnMobile&&window.innerWidth<=_breakpointsjson.default.medium.value}function BasePopover({placement="auto",content,children,contentPadding="m",maxWidth,externalTriggerRef,portalContainer,name="Popover",isVisible:isPopoverVisible,dismissOnOutsideClick=!0,"data-e2e-test-id":dataE2eTestId,subTheme,defaultVerticalPlacement,onVisibilityChange,disableInitialFocus=!1,disableReturnFocusToTrigger=!1,renderAsSheetOnMobile=!1,sheetProps,...restContentProps}){let tooltipId=(0,_react.useMemo)(()=>`DS${name}_${Math.floor(Date.now()*Math.random())}`,[name]),[isVisible,setVisible]=(0,_react.useState)(isPopoverVisible),[isMobileBreakPoint,setIsMobileBreakpoint]=(0,_react.useState)(getMobileBreakpoint(renderAsSheetOnMobile)),internalTriggerRef=(0,_react.useRef)(null),triggerRef=externalTriggerRef||internalTriggerRef,isOutsideClickOnTrigger=(0,_react.useRef)(!1),toggleVisibility=(0,_react.useCallback)((status,reason)=>{setVisible(status),onVisibilityChange&&onVisibilityChange(status,reason)},[onVisibilityChange]),handleTriggerClick=(0,_react.useCallback)(()=>{isOutsideClickOnTrigger.current?isOutsideClickOnTrigger.current=!1:toggleVisibility(!isVisible,VisibilityChangeReason.triggerClick)},[toggleVisibility,isVisible]),handleClickOutsideDeactivates=(0,_react.useCallback)(evt=>(triggerRef.current&&triggerRef.current.contains(evt.target)&&(isOutsideClickOnTrigger.current=!0),!0),[triggerRef,isOutsideClickOnTrigger]),handlePostDeactivate=(0,_react.useCallback)(()=>{toggleVisibility(!1,isOutsideClickOnTrigger.current?VisibilityChangeReason.triggerClick:VisibilityChangeReason.outsideClick)},[toggleVisibility]);(0,_react.useEffect)(()=>{setVisible(isPopoverVisible)},[isPopoverVisible]),(0,_react.useEffect)(()=>{setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile))},[isVisible,renderAsSheetOnMobile]),(0,_react.useEffect)(()=>{let trigger;if(externalTriggerRef?.current&&!children){let triggerTabIndex=(trigger=externalTriggerRef.current).getAttribute("tabindex");trigger.setAttribute("tabindex",triggerTabIndex??"0"),trigger.addEventListener("click",handleTriggerClick)}return()=>{trigger&&trigger.removeEventListener("click",handleTriggerClick)}},[externalTriggerRef,children,handleTriggerClick]),(0,_react.useEffect)(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current;trigger.setAttribute("aria-haspopup","true"),isVisible?(trigger.setAttribute("aria-expanded","true"),trigger.setAttribute("aria-controls",tooltipId)):(trigger.removeAttribute("aria-expanded"),trigger.removeAttribute("aria-controls"))}},[externalTriggerRef,children,tooltipId,isVisible]);let triggerElm=children?_react.default.cloneElement(children,{ref:triggerRef,...isVisible&&{"aria-expanded":!0,"aria-controls":tooltipId},tabIndex:children.props.tabIndex??0,"aria-haspopup":!0,onClick:evt=>{handleTriggerClick(),children.props.onClick&&children.props.onClick(evt)}}):null;if(isMobileBreakPoint){let sheetElm=_react.default.createElement(_Sheet.Sheet,{id:tooltipId,isVisible:isVisible,portalContainer:portalContainer,dismissOnOutsideClick:dismissOnOutsideClick,disableInitialFocus:disableInitialFocus,disableReturnFocusToTrigger:disableReturnFocusToTrigger,onClose:handlePostDeactivate,onClickOutsideDeactivates:handleClickOutsideDeactivates,...sheetProps??{}},content);return _react.default.createElement(_react.default.Fragment,null,triggerElm,sheetElm)}let contentElm=_react.default.createElement(_FocusTrapWrapper.FocusTrapWrapper,{active:isVisible,focusTrapOptions:{clickOutsideDeactivates:dismissOnOutsideClick&&handleClickOutsideDeactivates,allowOutsideClick:!0,escapeDeactivates:!0,fallbackFocus:`#${tooltipId}`,onPostDeactivate:handlePostDeactivate,preventScroll:!0,initialFocus:()=>!disableInitialFocus,returnFocusOnDeactivate:!disableReturnFocusToTrigger}},_react.default.createElement(FocusTrapContent,null,content)),tooltipElm=_react.default.createElement(_TooltipContent.TooltipContent,{...restContentProps,defaultVerticalPlacement:defaultVerticalPlacement,dataDSId:name,content:contentElm,contentPadding:contentPadding,maxWidth:maxWidth,placement:placement,portalContainer:portalContainer,dataE2eTestId:dataE2eTestId,subTheme:subTheme,isVisible:isVisible,tooltipId:tooltipId,triggerRef:triggerRef,isHiddenOnInvisibleTrigger:!0});return _react.default.createElement(_react.default.Fragment,null,triggerElm,tooltipElm)}
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BasePopover",{enumerable:!0,get:function(){return BasePopover}});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")),_TooltipContent=require("../Tooltip/TooltipContent"),_Sheet=require("../Sheet/Sheet"),_FocusTrapWrapper=require("../../shared/FocusTrapWrapper"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledContainer=(0,_styled.default)("div",{target:"e1vbb8ys0",label:"StyledContainer"})(()=>({borderRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Toggletip/BasePopover.tsx","sources":["src/components/Toggletip/BasePopover.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type {\n  ReactElement,\n  PropsWithChildren,\n  MouseEvent as ReactMouseEvent,\n} from \"react\";\nimport React, {\n  useState,\n  useRef,\n  useEffect,\n  useCallback,\n  useMemo,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TooltipContentProps } from \"../Tooltip/TooltipContent\";\nimport type { TooltipConditionalProps } from \"../Tooltip/types\";\nimport { TooltipContent } from \"../Tooltip/TooltipContent\";\nimport { Sheet } from \"../Sheet/Sheet\";\nimport { FocusTrapWrapper } from \"../../shared/FocusTrapWrapper\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\ntype BaseProps = Pick<\n  TooltipContentProps,\n  | \"placement\"\n  | \"portalContainer\"\n  | \"maxWidth\"\n  | \"contentPadding\"\n  | \"hideArrow\"\n  | \"subTheme\"\n  | \"defaultVerticalPlacement\"\n  | \"onOverflowViewport\"\n> & {\n  name?: string;\n  /**  Popover content */\n  content: ReactElement;\n  \"data-e2e-test-id\"?: string;\n  /**  Programmatically toggle Popover visibility with this prop */\n  isVisible?: boolean;\n  /**  Called when tooltip appears and disappears */\n  onVisibilityChange?: (isVisible: boolean, reason: string) => void;\n  /**  Controls whether BasePopover  closes on outside click */\n  dismissOnOutsideClick?: boolean;\n  /**  Option for focus-trap, controls whether the first focuable item recieves focus */\n  disableInitialFocus?: boolean;\n  /**  Option for focus-trap, controls whether the trigger should receive back the focus on popover close */\n  disableReturnFocusToTrigger?: boolean;\n  /**  Render as sheet on mobile web */\n  renderAsSheetOnMobile?: boolean;\n  /**  Props for configuring the sheet on mobile web */\n  sheetProps?: {\n    /**  Show the dark scrim backdrop on mobile web when rendering as Sheet */\n    hasBackdrop?: boolean;\n  };\n};\n\nexport type BasePopoverProps = BaseProps & TooltipConditionalProps;\n\nconst StyledContainer = styled.div(() => ({\n  borderRadius: \"inherit\",\n}));\n\nconst FocusTrapContent = React.forwardRef<\n  HTMLDivElement,\n  PropsWithChildren<unknown>\n>(({ children }, ref) => (\n  <StyledContainer ref={ref}>{children}</StyledContainer>\n));\n\nconst VisibilityChangeReason = {\n  triggerClick: \"triggerClick\",\n  outsideClick: \"outsideClick\",\n};\n\nfunction getMobileBreakpoint(renderAsSheetOnMobile: boolean) {\n  if (!window) {\n    // TODO window should be extracted from hook useWindow\n    return false;\n  }\n\n  const maxMobileHeightInLandscape = 450; // is 430 for iphone pro max, but let's add 20px for next generations\n  const isMobileInPortrait = window.innerWidth <= breakpoints.medium.value;\n  const isSmallHeight = window.innerHeight <= maxMobileHeightInLandscape;\n  const isLandscape = window.matchMedia?.(\"(orientation: landscape)\").matches;\n  const isMobileInLandscape = isLandscape && isSmallHeight;\n\n  return renderAsSheetOnMobile && (isMobileInPortrait || isMobileInLandscape);\n}\n\nexport function BasePopover({\n  placement = \"auto\",\n  content,\n  children,\n  contentPadding = \"m\",\n  maxWidth,\n  externalTriggerRef,\n  portalContainer,\n  name = \"Popover\",\n  isVisible: isPopoverVisible,\n  dismissOnOutsideClick = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  subTheme,\n  defaultVerticalPlacement,\n  onVisibilityChange,\n  disableInitialFocus = false,\n  disableReturnFocusToTrigger = false,\n  renderAsSheetOnMobile = false,\n  sheetProps,\n  ...restContentProps\n}: BasePopoverProps): React.ReactElement {\n  const tooltipId = useMemo(\n    () => `DS${name}_${Math.floor(Date.now() * Math.random())}`,\n    [name]\n  );\n  const [isVisible, setVisible] = useState(isPopoverVisible);\n  const [isMobileBreakPoint, setIsMobileBreakpoint] = useState(\n    getMobileBreakpoint(renderAsSheetOnMobile)\n  );\n  const internalTriggerRef = useRef<HTMLElement>(null);\n  const triggerRef = externalTriggerRef || internalTriggerRef;\n  const isOutsideClickOnTrigger = useRef(false);\n\n  const toggleVisibility = useCallback(\n    (status: boolean, reason: string) => {\n      setVisible(status);\n\n      if (onVisibilityChange) {\n        onVisibilityChange(status, reason);\n      }\n    },\n    [onVisibilityChange]\n  );\n\n  // Outside click is also fired when the Popover is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Popover twice.\n  const handleTriggerClick = useCallback(() => {\n    if (!isOutsideClickOnTrigger.current) {\n      toggleVisibility(!isVisible, VisibilityChangeReason.triggerClick);\n    } else {\n      // reset this value so that Popover can open in next click\n      isOutsideClickOnTrigger.current = false;\n    }\n  }, [toggleVisibility, isVisible]);\n\n  const handleClickOutsideDeactivates = useCallback(\n    (evt: MouseEvent) => {\n      if (\n        triggerRef.current &&\n        triggerRef.current.contains(evt.target as Node)\n      ) {\n        isOutsideClickOnTrigger.current = true;\n      }\n      return true;\n    },\n    [triggerRef, isOutsideClickOnTrigger]\n  );\n\n  const handlePostDeactivate = useCallback(() => {\n    const reason = isOutsideClickOnTrigger.current\n      ? VisibilityChangeReason.triggerClick\n      : VisibilityChangeReason.outsideClick;\n\n    toggleVisibility(false, reason);\n  }, [toggleVisibility]);\n\n  useEffect(() => {\n    setVisible(isPopoverVisible);\n  }, [isPopoverVisible]);\n\n  useEffect(() => {\n    // Check if this is a mobile breakpoint\n    setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile));\n  }, [isVisible, renderAsSheetOnMobile]);\n\n  useEffect(() => {\n    let trigger: HTMLElement;\n\n    if (externalTriggerRef?.current && !children) {\n      trigger = externalTriggerRef.current;\n      const triggerTabIndex = trigger.getAttribute(\"tabindex\");\n\n      trigger.setAttribute(\"tabindex\", triggerTabIndex ?? \"0\");\n      trigger.addEventListener(\"click\", handleTriggerClick);\n    }\n\n    return () => {\n      if (trigger) {\n        trigger.removeEventListener(\"click\", handleTriggerClick);\n      }\n    };\n  }, [externalTriggerRef, children, handleTriggerClick]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n\n      trigger.setAttribute(\"aria-haspopup\", \"true\");\n      if (isVisible) {\n        trigger.setAttribute(\"aria-expanded\", \"true\");\n        trigger.setAttribute(\"aria-controls\", tooltipId);\n      } else {\n        trigger.removeAttribute(\"aria-expanded\");\n        trigger.removeAttribute(\"aria-controls\");\n      }\n    }\n  }, [externalTriggerRef, children, tooltipId, isVisible]);\n\n  const triggerElm = children\n    ? React.cloneElement(children, {\n        ref: triggerRef,\n        ...(isVisible && {\n          \"aria-expanded\": true,\n          \"aria-controls\": tooltipId,\n        }),\n        tabIndex: children.props.tabIndex ?? 0,\n        \"aria-haspopup\": true,\n        onClick: (evt: ReactMouseEvent) => {\n          handleTriggerClick();\n          if (children.props.onClick) {\n            children.props.onClick(evt);\n          }\n        },\n      })\n    : null;\n\n  if (isMobileBreakPoint) {\n    // render as Sheet\n    const sheetElm = (\n      <Sheet\n        id={tooltipId}\n        isVisible={isVisible}\n        portalContainer={portalContainer}\n        dismissOnOutsideClick={dismissOnOutsideClick}\n        disableInitialFocus={disableInitialFocus}\n        disableReturnFocusToTrigger={disableReturnFocusToTrigger}\n        onClose={handlePostDeactivate}\n        onClickOutsideDeactivates={handleClickOutsideDeactivates}\n        {...(sheetProps ?? {})}\n      >\n        {content}\n      </Sheet>\n    );\n\n    return (\n      <>\n        {triggerElm}\n        {sheetElm}\n      </>\n    );\n  }\n\n  // render as Popover\n  const contentElm = (\n    <FocusTrapWrapper\n      active={isVisible}\n      focusTrapOptions={{\n        clickOutsideDeactivates:\n          dismissOnOutsideClick && handleClickOutsideDeactivates, // de-activate focus trap on outside click\n        allowOutsideClick: true,\n        escapeDeactivates: true,\n        fallbackFocus: `#${tooltipId}`, // set focus to tooltip content container if it has no focusable element\n        onPostDeactivate: handlePostDeactivate,\n        preventScroll: true,\n        initialFocus: () => !disableInitialFocus,\n        returnFocusOnDeactivate: !disableReturnFocusToTrigger,\n      }}\n    >\n      <FocusTrapContent>{content}</FocusTrapContent>\n    </FocusTrapWrapper>\n  );\n\n  const tooltipElm = (\n    <TooltipContent\n      {...restContentProps} // eslint-disable-line react/jsx-props-no-spreading\n      defaultVerticalPlacement={defaultVerticalPlacement}\n      dataDSId={name}\n      content={contentElm}\n      contentPadding={contentPadding}\n      maxWidth={maxWidth}\n      placement={placement}\n      portalContainer={portalContainer}\n      dataE2eTestId={dataE2eTestId}\n      subTheme={subTheme}\n      isVisible={isVisible}\n      tooltipId={tooltipId}\n      triggerRef={triggerRef}\n      isHiddenOnInvisibleTrigger\n    />\n  );\n\n  return (\n    <>\n      {triggerElm}\n      {tooltipElm}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAyDwB"} */"),FocusTrapContent=_react.default.forwardRef(({children},ref)=>_react.default.createElement(StyledContainer,{ref:ref},children)),VisibilityChangeReason={triggerClick:"triggerClick",outsideClick:"outsideClick"};function getMobileBreakpoint(renderAsSheetOnMobile){if(!window)return!1;let isMobileInPortrait=window.innerWidth<=_breakpointsjson.default.medium.value,isSmallHeight=window.innerHeight<=450,isLandscape=window.matchMedia?.("(orientation: landscape)").matches;return renderAsSheetOnMobile&&(isMobileInPortrait||isLandscape&&isSmallHeight)}function BasePopover({placement="auto",content,children,contentPadding="m",maxWidth,externalTriggerRef,portalContainer,name="Popover",isVisible:isPopoverVisible,dismissOnOutsideClick=!0,"data-e2e-test-id":dataE2eTestId,subTheme,defaultVerticalPlacement,onVisibilityChange,disableInitialFocus=!1,disableReturnFocusToTrigger=!1,renderAsSheetOnMobile=!1,sheetProps,...restContentProps}){let tooltipId=(0,_react.useMemo)(()=>`DS${name}_${Math.floor(Date.now()*Math.random())}`,[name]),[isVisible,setVisible]=(0,_react.useState)(isPopoverVisible),[isMobileBreakPoint,setIsMobileBreakpoint]=(0,_react.useState)(getMobileBreakpoint(renderAsSheetOnMobile)),internalTriggerRef=(0,_react.useRef)(null),triggerRef=externalTriggerRef||internalTriggerRef,isOutsideClickOnTrigger=(0,_react.useRef)(!1),toggleVisibility=(0,_react.useCallback)((status,reason)=>{setVisible(status),onVisibilityChange&&onVisibilityChange(status,reason)},[onVisibilityChange]),handleTriggerClick=(0,_react.useCallback)(()=>{isOutsideClickOnTrigger.current?isOutsideClickOnTrigger.current=!1:toggleVisibility(!isVisible,VisibilityChangeReason.triggerClick)},[toggleVisibility,isVisible]),handleClickOutsideDeactivates=(0,_react.useCallback)(evt=>(triggerRef.current&&triggerRef.current.contains(evt.target)&&(isOutsideClickOnTrigger.current=!0),!0),[triggerRef,isOutsideClickOnTrigger]),handlePostDeactivate=(0,_react.useCallback)(()=>{toggleVisibility(!1,isOutsideClickOnTrigger.current?VisibilityChangeReason.triggerClick:VisibilityChangeReason.outsideClick)},[toggleVisibility]);(0,_react.useEffect)(()=>{setVisible(isPopoverVisible)},[isPopoverVisible]),(0,_react.useEffect)(()=>{setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile))},[isVisible,renderAsSheetOnMobile]),(0,_react.useEffect)(()=>{let trigger;if(externalTriggerRef?.current&&!children){let triggerTabIndex=(trigger=externalTriggerRef.current).getAttribute("tabindex");trigger.setAttribute("tabindex",triggerTabIndex??"0"),trigger.addEventListener("click",handleTriggerClick)}return()=>{trigger&&trigger.removeEventListener("click",handleTriggerClick)}},[externalTriggerRef,children,handleTriggerClick]),(0,_react.useEffect)(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current;trigger.setAttribute("aria-haspopup","true"),isVisible?(trigger.setAttribute("aria-expanded","true"),trigger.setAttribute("aria-controls",tooltipId)):(trigger.removeAttribute("aria-expanded"),trigger.removeAttribute("aria-controls"))}},[externalTriggerRef,children,tooltipId,isVisible]);let triggerElm=children?_react.default.cloneElement(children,{ref:triggerRef,...isVisible&&{"aria-expanded":!0,"aria-controls":tooltipId},tabIndex:children.props.tabIndex??0,"aria-haspopup":!0,onClick:evt=>{handleTriggerClick(),children.props.onClick&&children.props.onClick(evt)}}):null;if(isMobileBreakPoint){let sheetElm=_react.default.createElement(_Sheet.Sheet,{id:tooltipId,isVisible:isVisible,portalContainer:portalContainer,dismissOnOutsideClick:dismissOnOutsideClick,disableInitialFocus:disableInitialFocus,disableReturnFocusToTrigger:disableReturnFocusToTrigger,onClose:handlePostDeactivate,onClickOutsideDeactivates:handleClickOutsideDeactivates,...sheetProps??{}},content);return _react.default.createElement(_react.default.Fragment,null,triggerElm,sheetElm)}let contentElm=_react.default.createElement(_FocusTrapWrapper.FocusTrapWrapper,{active:isVisible,focusTrapOptions:{clickOutsideDeactivates:dismissOnOutsideClick&&handleClickOutsideDeactivates,allowOutsideClick:!0,escapeDeactivates:!0,fallbackFocus:`#${tooltipId}`,onPostDeactivate:handlePostDeactivate,preventScroll:!0,initialFocus:()=>!disableInitialFocus,returnFocusOnDeactivate:!disableReturnFocusToTrigger}},_react.default.createElement(FocusTrapContent,null,content)),tooltipElm=_react.default.createElement(_TooltipContent.TooltipContent,{...restContentProps,defaultVerticalPlacement:defaultVerticalPlacement,dataDSId:name,content:contentElm,contentPadding:contentPadding,maxWidth:maxWidth,placement:placement,portalContainer:portalContainer,dataE2eTestId:dataE2eTestId,subTheme:subTheme,isVisible:isVisible,tooltipId:tooltipId,triggerRef:triggerRef,isHiddenOnInvisibleTrigger:!0});return _react.default.createElement(_react.default.Fragment,null,triggerElm,tooltipElm)}
|