@amboss/design-system 3.13.10 → 3.13.12

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.
@@ -1,3 +1,3 @@
1
1
  import React from "react";
2
2
  import type { EntityListProps } from "./types";
3
- export declare function BaseEntityList({ data, size, onClick, isSelectable, selectedIds, onSelectionChange, renderRightContent, getLeftIconProps, hideBorder, "data-e2e-test-id": dataE2eTestId, }: EntityListProps): React.ReactElement;
3
+ export declare function BaseEntityList({ data, size, onClick, isSelectable, selectedIds, onSelectionChange, renderRightContent, getLeftIconProps, hideBorder, filterFn, "data-e2e-test-id": dataE2eTestId, }: EntityListProps): React.ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BaseEntityList",{enumerable:!0,get:function(){return BaseEntityList}});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")),_styledcomponents=require("./styled-components"),_useKeyboard=require("../../shared/useKeyboard"),_Icon=require("../Icon/Icon"),_EntityListItem=require("./EntityListItem"),StyledMinHeightCell=(0,_styled.default)("div",{target:"e1svcpfc0",label:"StyledMinHeightCell"})(({theme,textSize})=>({minHeight:"s"===textSize?`calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`:theme.variables.size.spacing.l,display:"flex",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/EntityList/BaseEntityList.tsx","sources":["src/components/EntityList/BaseEntityList.tsx"],"sourcesContent":["import React, {\n  useRef,\n  useState,\n  useEffect,\n  useMemo,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { StyledList } from \"./styled-components\";\nimport type { EntityListProps, ListNode, TextSizeProps } from \"./types\";\nimport { useKeyboard } from \"../../shared/useKeyboard\";\nimport { Icon } from \"../Icon/Icon\";\nimport { EntityListItem } from \"./EntityListItem\";\n\n// This minHeight is needed for align small icons in the middle of 1 row text,\n// but it should stay at the top if there is multiline text\nconst StyledMinHeightCell = styled.div<TextSizeProps>(\n  ({ theme, textSize }) => ({\n    minHeight:\n      textSize === \"s\"\n        ? `calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`\n        : theme.variables.size.spacing.l,\n    display: \"flex\",\n    alignItems: \"center\",\n  })\n);\n\nconst findEnabledItemIndex = (\n  items: ListNode[],\n  startIndex: number,\n  direction = \"next\"\n): number => {\n  if (direction === \"next\") {\n    for (let i = startIndex + 1; i < items.length; i += 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  } else if (direction === \"previous\") {\n    for (let i = startIndex - 1; i >= 0; i -= 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  }\n  return startIndex;\n};\n\nexport function BaseEntityList({\n  data,\n  size = \"m\",\n  onClick,\n  isSelectable,\n  selectedIds,\n  onSelectionChange,\n  renderRightContent,\n  getLeftIconProps,\n  hideBorder,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: EntityListProps): React.ReactElement {\n  const selectedIdsSet = useMemo(() => new Set(selectedIds), [selectedIds]);\n  const [isKeyboardFocus, setIsKeyboardFocus] = useState<boolean>(false);\n  const [selectedIndex, setSelectedIndex] = useState<number>(() =>\n    isSelectable || onClick ? findEnabledItemIndex(data, -1) : -1\n  );\n  const refList = useRef<HTMLUListElement>(null);\n  useKeyboard(\n    {\n      ArrowDown: () => {\n        setIsKeyboardFocus(true);\n        const nextIndex = findEnabledItemIndex(data, selectedIndex);\n        setSelectedIndex(nextIndex);\n      },\n      ArrowUp: () => {\n        setIsKeyboardFocus(true);\n        const prevIndex = findEnabledItemIndex(data, selectedIndex, \"previous\");\n        setSelectedIndex(prevIndex);\n      },\n    },\n    refList,\n    selectedIndex !== -1\n  );\n\n  useEffect(() => {\n    if (refList && refList.current && isKeyboardFocus && selectedIndex >= 0) {\n      const buttons = refList.current.querySelectorAll(\n        'div[data-id=\"list-item\"]'\n      );\n\n      (buttons[Math.abs(selectedIndex) % buttons.length] as HTMLElement).focus({\n        preventScroll: true,\n      });\n    }\n  }, [selectedIndex, isKeyboardFocus]);\n\n  const handleOnClick = useCallback(\n    (item: ListNode) => {\n      const { id } = item;\n\n      // Handle checkbox change\n      if (isSelectable) {\n        if (selectedIdsSet.has(id)) {\n          selectedIdsSet.delete(id);\n        } else {\n          selectedIdsSet.add(id);\n        }\n        onSelectionChange?.(Array.from(selectedIdsSet));\n      }\n\n      onClick?.(item);\n    },\n    [selectedIdsSet, onSelectionChange, onClick, isSelectable]\n  );\n\n  const handleBlur = useCallback(() => {\n    // Use setTimeout to wait for focus to fully propagate\n    setTimeout(() => {\n      if (\n        refList.current &&\n        !refList.current.contains(document.activeElement)\n      ) {\n        setIsKeyboardFocus(false);\n        setSelectedIndex(() => findEnabledItemIndex(data, -1));\n      }\n    }, 0);\n  }, [refList, setSelectedIndex, data]);\n\n  return (\n    <StyledList\n      ref={refList}\n      size={size}\n      data-e2e-test-id={dataE2eTestId}\n      onBlur={handleBlur}\n      data-ds-id=\"EntityList\"\n      role=\"list\"\n    >\n      {data.map((item, i) => {\n        const tabIndex = !item.isDisabled && i === selectedIndex ? 0 : -1;\n\n        return (\n          <EntityListItem\n            key={item.id}\n            aria-label={item[\"aria-label\"] || item.label}\n            size={size}\n            hideBorder={hideBorder || i === data.length - 1}\n            isActive={item.isActive || (isKeyboardFocus && selectedIndex === i)}\n            isDisabled={item.isDisabled}\n            isClickable={Boolean(onClick || selectedIds)}\n            description={item.description}\n            onKeyDown={() => handleOnClick(item)}\n            tabIndex={tabIndex}\n            onFocus={() => {\n              if (onClick || isSelectable) {\n                setSelectedIndex(i);\n                setIsKeyboardFocus(true);\n              }\n            }}\n            onClick={() => {\n              setIsKeyboardFocus(false);\n              handleOnClick(item);\n            }}\n            checkboxProps={\n              isSelectable && {\n                name: \"list-checkbox\",\n                size: \"s\",\n                onChange: () => handleOnClick(item),\n                checked: selectedIdsSet.has(item.id),\n              }\n            }\n            renderLabel={() => item.label}\n            renderLeft={\n              getLeftIconProps\n                ? ({ textSize }) => (\n                    <Icon\n                      /* eslint-disable-next-line react/jsx-props-no-spreading */\n                      {...getLeftIconProps(item)}\n                      size={textSize}\n                    />\n                  )\n                : null\n            }\n            renderRight={({ actionSize, textSize }) =>\n              renderRightContent ? (\n                <StyledMinHeightCell textSize={textSize}>\n                  {renderRightContent({ textSize, actionSize, ...item })}\n                </StyledMinHeightCell>\n              ) : null\n            }\n          />\n        );\n      })}\n    </StyledList>\n  );\n}\n"],"names":[],"mappings":"AAgB4B"} */"),findEnabledItemIndex=(items,startIndex,direction="next")=>{if("next"===direction){for(let i=startIndex+1;i<items.length;i+=1)if(!items[i].isDisabled)return i}else if("previous"===direction){for(let i=startIndex-1;i>=0;i-=1)if(!items[i].isDisabled)return i}return startIndex};function BaseEntityList({data,size="m",onClick,isSelectable,selectedIds,onSelectionChange,renderRightContent,getLeftIconProps,hideBorder,"data-e2e-test-id":dataE2eTestId}){let selectedIdsSet=(0,_react.useMemo)(()=>new Set(selectedIds),[selectedIds]),[isKeyboardFocus,setIsKeyboardFocus]=(0,_react.useState)(!1),[selectedIndex,setSelectedIndex]=(0,_react.useState)(()=>isSelectable||onClick?findEnabledItemIndex(data,-1):-1),refList=(0,_react.useRef)(null);(0,_useKeyboard.useKeyboard)({ArrowDown:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(data,selectedIndex))},ArrowUp:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(data,selectedIndex,"previous"))}},refList,-1!==selectedIndex),(0,_react.useEffect)(()=>{if(refList&&refList.current&&isKeyboardFocus&&selectedIndex>=0){let buttons=refList.current.querySelectorAll('div[data-id="list-item"]');buttons[Math.abs(selectedIndex)%buttons.length].focus({preventScroll:!0})}},[selectedIndex,isKeyboardFocus]);let handleOnClick=(0,_react.useCallback)(item=>{let{id}=item;isSelectable&&(selectedIdsSet.has(id)?selectedIdsSet.delete(id):selectedIdsSet.add(id),onSelectionChange?.(Array.from(selectedIdsSet))),onClick?.(item)},[selectedIdsSet,onSelectionChange,onClick,isSelectable]),handleBlur=(0,_react.useCallback)(()=>{setTimeout(()=>{refList.current&&!refList.current.contains(document.activeElement)&&(setIsKeyboardFocus(!1),setSelectedIndex(()=>findEnabledItemIndex(data,-1)))},0)},[refList,setSelectedIndex,data]);return _react.default.createElement(_styledcomponents.StyledList,{ref:refList,size:size,"data-e2e-test-id":dataE2eTestId,onBlur:handleBlur,"data-ds-id":"EntityList",role:"list"},data.map((item,i)=>{let tabIndex=item.isDisabled||i!==selectedIndex?-1:0;return _react.default.createElement(_EntityListItem.EntityListItem,{key:item.id,"aria-label":item["aria-label"]||item.label,size:size,hideBorder:hideBorder||i===data.length-1,isActive:item.isActive||isKeyboardFocus&&selectedIndex===i,isDisabled:item.isDisabled,isClickable:!!(onClick||selectedIds),description:item.description,onKeyDown:()=>handleOnClick(item),tabIndex:tabIndex,onFocus:()=>{(onClick||isSelectable)&&(setSelectedIndex(i),setIsKeyboardFocus(!0))},onClick:()=>{setIsKeyboardFocus(!1),handleOnClick(item)},checkboxProps:isSelectable&&{name:"list-checkbox",size:"s",onChange:()=>handleOnClick(item),checked:selectedIdsSet.has(item.id)},renderLabel:()=>item.label,renderLeft:getLeftIconProps?({textSize})=>_react.default.createElement(_Icon.Icon,{...getLeftIconProps(item),size:textSize}):null,renderRight:({actionSize,textSize})=>renderRightContent?_react.default.createElement(StyledMinHeightCell,{textSize:textSize},renderRightContent({textSize,actionSize,...item})):null})}))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BaseEntityList",{enumerable:!0,get:function(){return BaseEntityList}});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")),_styledcomponents=require("./styled-components"),_useKeyboard=require("../../shared/useKeyboard"),_Icon=require("../Icon/Icon"),_EntityListItem=require("./EntityListItem"),StyledMinHeightCell=(0,_styled.default)("div",{target:"e9t25660",label:"StyledMinHeightCell"})(({theme,textSize})=>({minHeight:"s"===textSize?`calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`:theme.variables.size.spacing.l,display:"flex",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/EntityList/BaseEntityList.tsx","sources":["src/components/EntityList/BaseEntityList.tsx"],"sourcesContent":["import React, {\n  useRef,\n  useState,\n  useEffect,\n  useMemo,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { StyledList } from \"./styled-components\";\nimport type { EntityListProps, ListNode, TextSizeProps } from \"./types\";\nimport { useKeyboard } from \"../../shared/useKeyboard\";\nimport { Icon } from \"../Icon/Icon\";\nimport { EntityListItem } from \"./EntityListItem\";\n\n// This minHeight is needed for align small icons in the middle of 1 row text,\n// but it should stay at the top if there is multiline text\nconst StyledMinHeightCell = styled.div<TextSizeProps>(\n  ({ theme, textSize }) => ({\n    minHeight:\n      textSize === \"s\"\n        ? `calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`\n        : theme.variables.size.spacing.l,\n    display: \"flex\",\n    alignItems: \"center\",\n  })\n);\n\nconst findEnabledItemIndex = (\n  items: ListNode[],\n  startIndex: number,\n  direction = \"next\"\n): number => {\n  if (direction === \"next\") {\n    for (let i = startIndex + 1; i < items.length; i += 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  } else if (direction === \"previous\") {\n    for (let i = startIndex - 1; i >= 0; i -= 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  }\n  return startIndex;\n};\n\nexport function BaseEntityList({\n  data,\n  size = \"m\",\n  onClick,\n  isSelectable,\n  selectedIds,\n  onSelectionChange,\n  renderRightContent,\n  getLeftIconProps,\n  hideBorder,\n  filterFn,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: EntityListProps): React.ReactElement {\n  const dataShown = useMemo(() => {\n    if (!data.length) return data;\n\n    return filterFn ? data.filter(filterFn) : data;\n  }, [data, filterFn]);\n  const selectedIdsSet = useMemo(() => new Set(selectedIds), [selectedIds]);\n  const [isKeyboardFocus, setIsKeyboardFocus] = useState<boolean>(false);\n  const [selectedIndex, setSelectedIndex] = useState<number>(() =>\n    isSelectable || onClick ? findEnabledItemIndex(dataShown, -1) : -1\n  );\n  const refList = useRef<HTMLUListElement>(null);\n  useKeyboard(\n    {\n      ArrowDown: () => {\n        setIsKeyboardFocus(true);\n        const nextIndex = findEnabledItemIndex(dataShown, selectedIndex);\n        setSelectedIndex(nextIndex);\n      },\n      ArrowUp: () => {\n        setIsKeyboardFocus(true);\n        const prevIndex = findEnabledItemIndex(\n          dataShown,\n          selectedIndex,\n          \"previous\"\n        );\n        setSelectedIndex(prevIndex);\n      },\n    },\n    refList,\n    selectedIndex !== -1\n  );\n\n  useEffect(() => {\n    if (refList && refList.current && isKeyboardFocus && selectedIndex >= 0) {\n      const buttons = refList.current.querySelectorAll(\n        'div[data-id=\"list-item\"]'\n      );\n\n      (buttons[Math.abs(selectedIndex) % buttons.length] as HTMLElement).focus({\n        preventScroll: true,\n      });\n    }\n  }, [selectedIndex, isKeyboardFocus]);\n\n  const handleOnClick = useCallback(\n    (item: ListNode) => {\n      const { id } = item;\n\n      // Handle checkbox change\n      if (isSelectable) {\n        if (selectedIdsSet.has(id)) {\n          selectedIdsSet.delete(id);\n        } else {\n          selectedIdsSet.add(id);\n        }\n        onSelectionChange?.(Array.from(selectedIdsSet));\n      }\n\n      onClick?.(item);\n    },\n    [selectedIdsSet, onSelectionChange, onClick, isSelectable]\n  );\n\n  const handleBlur = useCallback(() => {\n    // Use setTimeout to wait for focus to fully propagate\n    setTimeout(() => {\n      if (\n        refList.current &&\n        !refList.current.contains(document.activeElement)\n      ) {\n        setIsKeyboardFocus(false);\n        setSelectedIndex(() => findEnabledItemIndex(dataShown, -1));\n      }\n    }, 0);\n  }, [refList, setSelectedIndex, dataShown]);\n\n  return (\n    <StyledList\n      ref={refList}\n      size={size}\n      data-e2e-test-id={dataE2eTestId}\n      onBlur={handleBlur}\n      data-ds-id=\"EntityList\"\n      role=\"list\"\n    >\n      {dataShown.map((item, i) => {\n        const tabIndex = !item.isDisabled && i === selectedIndex ? 0 : -1;\n\n        return (\n          <EntityListItem\n            key={item.id}\n            aria-label={item[\"aria-label\"] || item.label}\n            size={size}\n            hideBorder={hideBorder || i === dataShown.length - 1}\n            isActive={item.isActive || (isKeyboardFocus && selectedIndex === i)}\n            isDisabled={item.isDisabled}\n            isClickable={Boolean(onClick || selectedIds)}\n            description={item.description}\n            onKeyDown={() => handleOnClick(item)}\n            tabIndex={tabIndex}\n            onFocus={() => {\n              if (onClick || isSelectable) {\n                setSelectedIndex(i);\n                setIsKeyboardFocus(true);\n              }\n            }}\n            onClick={() => {\n              setIsKeyboardFocus(false);\n              handleOnClick(item);\n            }}\n            checkboxProps={\n              isSelectable && {\n                name: \"list-checkbox\",\n                size: \"s\",\n                onChange: () => handleOnClick(item),\n                checked: selectedIdsSet.has(item.id),\n              }\n            }\n            renderLabel={() => item.label}\n            renderLeft={\n              getLeftIconProps\n                ? ({ textSize }) => (\n                    <Icon\n                      /* eslint-disable-next-line react/jsx-props-no-spreading */\n                      {...getLeftIconProps(item)}\n                      size={textSize}\n                    />\n                  )\n                : null\n            }\n            renderRight={({ actionSize, textSize }) =>\n              renderRightContent ? (\n                <StyledMinHeightCell textSize={textSize}>\n                  {renderRightContent({ textSize, actionSize, ...item })}\n                </StyledMinHeightCell>\n              ) : null\n            }\n          />\n        );\n      })}\n    </StyledList>\n  );\n}\n"],"names":[],"mappings":"AAgB4B"} */"),findEnabledItemIndex=(items,startIndex,direction="next")=>{if("next"===direction){for(let i=startIndex+1;i<items.length;i+=1)if(!items[i].isDisabled)return i}else if("previous"===direction){for(let i=startIndex-1;i>=0;i-=1)if(!items[i].isDisabled)return i}return startIndex};function BaseEntityList({data,size="m",onClick,isSelectable,selectedIds,onSelectionChange,renderRightContent,getLeftIconProps,hideBorder,filterFn,"data-e2e-test-id":dataE2eTestId}){let dataShown=(0,_react.useMemo)(()=>data.length&&filterFn?data.filter(filterFn):data,[data,filterFn]),selectedIdsSet=(0,_react.useMemo)(()=>new Set(selectedIds),[selectedIds]),[isKeyboardFocus,setIsKeyboardFocus]=(0,_react.useState)(!1),[selectedIndex,setSelectedIndex]=(0,_react.useState)(()=>isSelectable||onClick?findEnabledItemIndex(dataShown,-1):-1),refList=(0,_react.useRef)(null);(0,_useKeyboard.useKeyboard)({ArrowDown:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(dataShown,selectedIndex))},ArrowUp:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(dataShown,selectedIndex,"previous"))}},refList,-1!==selectedIndex),(0,_react.useEffect)(()=>{if(refList&&refList.current&&isKeyboardFocus&&selectedIndex>=0){let buttons=refList.current.querySelectorAll('div[data-id="list-item"]');buttons[Math.abs(selectedIndex)%buttons.length].focus({preventScroll:!0})}},[selectedIndex,isKeyboardFocus]);let handleOnClick=(0,_react.useCallback)(item=>{let{id}=item;isSelectable&&(selectedIdsSet.has(id)?selectedIdsSet.delete(id):selectedIdsSet.add(id),onSelectionChange?.(Array.from(selectedIdsSet))),onClick?.(item)},[selectedIdsSet,onSelectionChange,onClick,isSelectable]),handleBlur=(0,_react.useCallback)(()=>{setTimeout(()=>{refList.current&&!refList.current.contains(document.activeElement)&&(setIsKeyboardFocus(!1),setSelectedIndex(()=>findEnabledItemIndex(dataShown,-1)))},0)},[refList,setSelectedIndex,dataShown]);return _react.default.createElement(_styledcomponents.StyledList,{ref:refList,size:size,"data-e2e-test-id":dataE2eTestId,onBlur:handleBlur,"data-ds-id":"EntityList",role:"list"},dataShown.map((item,i)=>{let tabIndex=item.isDisabled||i!==selectedIndex?-1:0;return _react.default.createElement(_EntityListItem.EntityListItem,{key:item.id,"aria-label":item["aria-label"]||item.label,size:size,hideBorder:hideBorder||i===dataShown.length-1,isActive:item.isActive||isKeyboardFocus&&selectedIndex===i,isDisabled:item.isDisabled,isClickable:!!(onClick||selectedIds),description:item.description,onKeyDown:()=>handleOnClick(item),tabIndex:tabIndex,onFocus:()=>{(onClick||isSelectable)&&(setSelectedIndex(i),setIsKeyboardFocus(!0))},onClick:()=>{setIsKeyboardFocus(!1),handleOnClick(item)},checkboxProps:isSelectable&&{name:"list-checkbox",size:"s",onChange:()=>handleOnClick(item),checked:selectedIdsSet.has(item.id)},renderLabel:()=>item.label,renderLeft:getLeftIconProps?({textSize})=>_react.default.createElement(_Icon.Icon,{...getLeftIconProps(item),size:textSize}):null,renderRight:({actionSize,textSize})=>renderRightContent?_react.default.createElement(StyledMinHeightCell,{textSize:textSize},renderRightContent({textSize,actionSize,...item})):null})}))}
@@ -44,6 +44,17 @@ export type EntityListProps = {
44
44
  renderRightContent?: (props: ListNodeProps & ActionSizeProps) => React.ReactNode;
45
45
  /** Hides the border around the list items. */
46
46
  hideBorder?: boolean;
47
+ /**
48
+ * Optional function to filter list items. Returns true to include the item.
49
+ * Filtered items are completely removed from the list and keyboard navigation.
50
+ *
51
+ * Performance considerations:
52
+ * - The filter is applied on every render when data or filterFn changes
53
+ * - For large datasets (>1000 items), consider memoizing filterFn with useCallback
54
+ * - For real-time search, consider debouncing filter changes to reduce computations
55
+ * - Complex filters may impact performance on slower devices
56
+ */
57
+ filterFn?: (node: ListNode) => boolean;
47
58
  ariaAttributes?: EntityListAriaAttributes;
48
59
  "data-e2e-test-id"?: string;
49
60
  };
@@ -7,6 +7,7 @@ export type ListItemProps = {
7
7
  iconLeft?: IconProps;
8
8
  label: ReactElement;
9
9
  value: ListItemValue;
10
+ dataE2eTestId?: string;
10
11
  };
11
12
  export type ListItemsByCategory = {
12
13
  category: string;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CategoryList(){return CategoryList},get getListItemId(){return getListItemId}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Header=require("../Typography/Header"),_Icon=require("../Icon/Icon"),_Text=require("../Typography/Text"),_Columns=require("../Column/Columns"),_Stack=require("../Stack/Stack"),_Container=require("../Container"),_Divider=require("../Divider/Divider");function getListItemId(name,category,index){return`${name}_${category}_ListItem${index}`}const StyledIconLeft=(0,_styled.default)(_Icon.Icon,{target:"e1n1ipl40",label:"StyledIconLeft"})(({theme})=>({marginRight:theme.variables.size.spacing.xs}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE1vdXNlRXZlbnQsIFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVZhbHVlID0gc3RyaW5nIHwgeyB2YWx1ZTogc3RyaW5nIH07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtUHJvcHMgPSB7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICBsYWJlbDogUmVhY3RFbGVtZW50O1xuICB2YWx1ZTogTGlzdEl0ZW1WYWx1ZTtcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgaW5kZXhJbkNhdGVnb3J5OiBudW1iZXI7XG4gIHZhbHVlOiBMaXN0SXRlbVByb3BzW1widmFsdWVcIl07XG4gIGlkOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBDYXRlZ29yeUxpc3RQcm9wcyA9IExpc3RJdGVtc0J5Q2F0ZWdvcnkgJiB7XG4gIG5hbWU6IHN0cmluZztcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBvbkxpc3RJdGVtQ2xpY2s6IChcbiAgICBjYXRlZ29yeTogc3RyaW5nLFxuICAgIGluZGV4SW5DYXRlZ29yeTogbnVtYmVyLFxuICAgIGV2dD86IE1vdXNlRXZlbnQ8SFRNTERpdkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRMaXN0SXRlbUlkKFxuICBuYW1lOiBzdHJpbmcsXG4gIGNhdGVnb3J5OiBzdHJpbmcsXG4gIGluZGV4OiBudW1iZXJcbik6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV8ke2NhdGVnb3J5fV9MaXN0SXRlbSR7aW5kZXh9YDtcbn1cblxuY29uc3QgU3R5bGVkSWNvbkxlZnQgPSBzdHlsZWQoSWNvbikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgbWFyZ2luUmlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG59KSk7XG5cbnR5cGUgU3R5bGVkTGlzdEl0ZW1Qcm9wcyA9IHtcbiAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZExpc3RJdGVtID0gc3R5bGVkLmRpdjxTdHlsZWRMaXN0SXRlbVByb3BzPihcbiAgKHsgdGhlbWUsIGlzU2VsZWN0ZWQgfSkgPT4gKHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG5cbiAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9LFxuXG4gICAgLi4uKGlzU2VsZWN0ZWQgJiYge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9KSxcbiAgfSlcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiBDYXRlZ29yeUxpc3Qoe1xuICBuYW1lLFxuICBjYXRlZ29yeSxcbiAgaWNvbkxlZnQsXG4gIHJpZ2h0Q29udGVudCxcbiAgaXRlbXMsXG4gIHNlbGVjdGVkTGlzdEl0ZW0sXG4gIG9uTGlzdEl0ZW1DbGljayxcbn06IENhdGVnb3J5TGlzdFByb3BzKTogUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgbGlzdEl0ZW1zID0gaXRlbXMubWFwKCh7IGxhYmVsLCBpY29uTGVmdDogaXRlbUljb25MZWZ0IH0sIGluZGV4KSA9PiB7XG4gICAgY29uc3QgbGVmdENvbnRlbnQgPSAoXG4gICAgICA8VGV4dD5cbiAgICAgICAge2ljb25MZWZ0ICYmIChcbiAgICAgICAgICA8U3R5bGVkSWNvbkxlZnRcbiAgICAgICAgICAgIHsuLi4oaXRlbUljb25MZWZ0IHx8IGljb25MZWZ0KX1cbiAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgIGNvbG9yPVwidGVydGlhcnlcIlxuICAgICAgICAgICAgaW5saW5lXG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAge2xhYmVsfVxuICAgICAgPC9UZXh0PlxuICAgICk7XG4gICAgY29uc3QgY29udGVudCA9IHJpZ2h0Q29udGVudCA/IChcbiAgICAgIDxDb2x1bW5zPlxuICAgICAgICA8Q29sdW1uPntsZWZ0Q29udGVudH08L0NvbHVtbj5cbiAgICAgICAgPENvbHVtbiBzaXplPVwibmFycm93XCI+e3JpZ2h0Q29udGVudH08L0NvbHVtbj5cbiAgICAgIDwvQ29sdW1ucz5cbiAgICApIDogKFxuICAgICAgbGVmdENvbnRlbnRcbiAgICApO1xuXG4gICAgY29uc3QgaXNTZWxlY3RlZCA9XG4gICAgICAhIXNlbGVjdGVkTGlzdEl0ZW0gJiZcbiAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICBzZWxlY3RlZExpc3RJdGVtLmluZGV4SW5DYXRlZ29yeSA9PT0gaW5kZXg7XG5cbiAgICAvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9uby1hcnJheS1pbmRleC1rZXkgKi9cbiAgICByZXR1cm4gKFxuICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICA8U3R5bGVkTGlzdEl0ZW1cbiAgICAgICAgICBpZD17Z2V0TGlzdEl0ZW1JZChuYW1lLCBjYXRlZ29yeSwgaW5kZXgpfVxuICAgICAgICAgIHJvbGU9XCJvcHRpb25cIlxuICAgICAgICAgIGlzU2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgYXJpYS1zZWxlY3RlZD17aXNTZWxlY3RlZH1cbiAgICAgICAgICBvblBvaW50ZXJEb3duPXsoZXZ0KSA9PiBldnQucHJldmVudERlZmF1bHQoKX0gLy8gbmVlZGVkIHRvIGF2b2lkIGZvY3VzIGNoYW5nZVxuICAgICAgICAgIG9uQ2xpY2s9eyhldnQpID0+IG9uTGlzdEl0ZW1DbGljayhjYXRlZ29yeSwgaW5kZXgsIGV2dCl9XG4gICAgICAgID5cbiAgICAgICAgICB7Y29udGVudH1cbiAgICAgICAgPC9TdHlsZWRMaXN0SXRlbT5cbiAgICAgICAge2luZGV4ICE9PSBpdGVtcy5sZW5ndGggLSAxICYmIDxEaXZpZGVyIC8+fVxuICAgICAgPC9GcmFnbWVudD5cbiAgICApO1xuICAgIC8qIGVzbGludC1lbmFibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIHNwYWNlPVwic1wiPlxuICAgICAgPEg2IGFzPVwiZGl2XCI+e2NhdGVnb3J5fTwvSDY+XG4gICAgICA8Q29udGFpbmVyIGVsZXZhdGlvbj17MH0gYm9yZGVyUmFkaXVzPVwic1wiPlxuICAgICAgICA8U3RhY2sgc3BhY2U9XCJ6ZXJvXCI+e2xpc3RJdGVtc308L1N0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgPC9TdGFjaz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRHVCIn0= */"),StyledListItem=(0,_styled.default)("div",{target:"e1n1ipl41",label:"StyledListItem"})(({theme,isSelected})=>({padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover},...isSelected&&{backgroundColor:theme.values.color.background.transparent.hover}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE1vdXNlRXZlbnQsIFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVZhbHVlID0gc3RyaW5nIHwgeyB2YWx1ZTogc3RyaW5nIH07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtUHJvcHMgPSB7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICBsYWJlbDogUmVhY3RFbGVtZW50O1xuICB2YWx1ZTogTGlzdEl0ZW1WYWx1ZTtcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgaW5kZXhJbkNhdGVnb3J5OiBudW1iZXI7XG4gIHZhbHVlOiBMaXN0SXRlbVByb3BzW1widmFsdWVcIl07XG4gIGlkOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBDYXRlZ29yeUxpc3RQcm9wcyA9IExpc3RJdGVtc0J5Q2F0ZWdvcnkgJiB7XG4gIG5hbWU6IHN0cmluZztcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBvbkxpc3RJdGVtQ2xpY2s6IChcbiAgICBjYXRlZ29yeTogc3RyaW5nLFxuICAgIGluZGV4SW5DYXRlZ29yeTogbnVtYmVyLFxuICAgIGV2dD86IE1vdXNlRXZlbnQ8SFRNTERpdkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRMaXN0SXRlbUlkKFxuICBuYW1lOiBzdHJpbmcsXG4gIGNhdGVnb3J5OiBzdHJpbmcsXG4gIGluZGV4OiBudW1iZXJcbik6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV8ke2NhdGVnb3J5fV9MaXN0SXRlbSR7aW5kZXh9YDtcbn1cblxuY29uc3QgU3R5bGVkSWNvbkxlZnQgPSBzdHlsZWQoSWNvbikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgbWFyZ2luUmlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG59KSk7XG5cbnR5cGUgU3R5bGVkTGlzdEl0ZW1Qcm9wcyA9IHtcbiAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZExpc3RJdGVtID0gc3R5bGVkLmRpdjxTdHlsZWRMaXN0SXRlbVByb3BzPihcbiAgKHsgdGhlbWUsIGlzU2VsZWN0ZWQgfSkgPT4gKHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG5cbiAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9LFxuXG4gICAgLi4uKGlzU2VsZWN0ZWQgJiYge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9KSxcbiAgfSlcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiBDYXRlZ29yeUxpc3Qoe1xuICBuYW1lLFxuICBjYXRlZ29yeSxcbiAgaWNvbkxlZnQsXG4gIHJpZ2h0Q29udGVudCxcbiAgaXRlbXMsXG4gIHNlbGVjdGVkTGlzdEl0ZW0sXG4gIG9uTGlzdEl0ZW1DbGljayxcbn06IENhdGVnb3J5TGlzdFByb3BzKTogUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgbGlzdEl0ZW1zID0gaXRlbXMubWFwKCh7IGxhYmVsLCBpY29uTGVmdDogaXRlbUljb25MZWZ0IH0sIGluZGV4KSA9PiB7XG4gICAgY29uc3QgbGVmdENvbnRlbnQgPSAoXG4gICAgICA8VGV4dD5cbiAgICAgICAge2ljb25MZWZ0ICYmIChcbiAgICAgICAgICA8U3R5bGVkSWNvbkxlZnRcbiAgICAgICAgICAgIHsuLi4oaXRlbUljb25MZWZ0IHx8IGljb25MZWZ0KX1cbiAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgIGNvbG9yPVwidGVydGlhcnlcIlxuICAgICAgICAgICAgaW5saW5lXG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAge2xhYmVsfVxuICAgICAgPC9UZXh0PlxuICAgICk7XG4gICAgY29uc3QgY29udGVudCA9IHJpZ2h0Q29udGVudCA/IChcbiAgICAgIDxDb2x1bW5zPlxuICAgICAgICA8Q29sdW1uPntsZWZ0Q29udGVudH08L0NvbHVtbj5cbiAgICAgICAgPENvbHVtbiBzaXplPVwibmFycm93XCI+e3JpZ2h0Q29udGVudH08L0NvbHVtbj5cbiAgICAgIDwvQ29sdW1ucz5cbiAgICApIDogKFxuICAgICAgbGVmdENvbnRlbnRcbiAgICApO1xuXG4gICAgY29uc3QgaXNTZWxlY3RlZCA9XG4gICAgICAhIXNlbGVjdGVkTGlzdEl0ZW0gJiZcbiAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICBzZWxlY3RlZExpc3RJdGVtLmluZGV4SW5DYXRlZ29yeSA9PT0gaW5kZXg7XG5cbiAgICAvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9uby1hcnJheS1pbmRleC1rZXkgKi9cbiAgICByZXR1cm4gKFxuICAgICAgPEZyYWdtZW50IGtleT17aW5kZXh9PlxuICAgICAgICA8U3R5bGVkTGlzdEl0ZW1cbiAgICAgICAgICBpZD17Z2V0TGlzdEl0ZW1JZChuYW1lLCBjYXRlZ29yeSwgaW5kZXgpfVxuICAgICAgICAgIHJvbGU9XCJvcHRpb25cIlxuICAgICAgICAgIGlzU2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgYXJpYS1zZWxlY3RlZD17aXNTZWxlY3RlZH1cbiAgICAgICAgICBvblBvaW50ZXJEb3duPXsoZXZ0KSA9PiBldnQucHJldmVudERlZmF1bHQoKX0gLy8gbmVlZGVkIHRvIGF2b2lkIGZvY3VzIGNoYW5nZVxuICAgICAgICAgIG9uQ2xpY2s9eyhldnQpID0+IG9uTGlzdEl0ZW1DbGljayhjYXRlZ29yeSwgaW5kZXgsIGV2dCl9XG4gICAgICAgID5cbiAgICAgICAgICB7Y29udGVudH1cbiAgICAgICAgPC9TdHlsZWRMaXN0SXRlbT5cbiAgICAgICAge2luZGV4ICE9PSBpdGVtcy5sZW5ndGggLSAxICYmIDxEaXZpZGVyIC8+fVxuICAgICAgPC9GcmFnbWVudD5cbiAgICApO1xuICAgIC8qIGVzbGludC1lbmFibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPFN0YWNrIHNwYWNlPVwic1wiPlxuICAgICAgPEg2IGFzPVwiZGl2XCI+e2NhdGVnb3J5fTwvSDY+XG4gICAgICA8Q29udGFpbmVyIGVsZXZhdGlvbj17MH0gYm9yZGVyUmFkaXVzPVwic1wiPlxuICAgICAgICA8U3RhY2sgc3BhY2U9XCJ6ZXJvXCI+e2xpc3RJdGVtc308L1N0YWNrPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgPC9TdGFjaz5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RHVCIn0= */");function CategoryList({name,category,iconLeft,rightContent,items,selectedListItem,onListItemClick}){let listItems=items.map(({label,iconLeft:itemIconLeft},index)=>{let leftContent=_react.default.createElement(_Text.Text,null,iconLeft&&_react.default.createElement(StyledIconLeft,{...itemIconLeft||iconLeft,size:"s",color:"tertiary",inline:!0}),label),content=rightContent?_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,null,leftContent),_react.default.createElement(_Columns.Column,{size:"narrow"},rightContent)):leftContent,isSelected=!!selectedListItem&&selectedListItem.category===category&&selectedListItem.indexInCategory===index;return _react.default.createElement(_react.Fragment,{key:index},_react.default.createElement(StyledListItem,{id:getListItemId(name,category,index),role:"option",isSelected:isSelected,"aria-selected":isSelected,onPointerDown:evt=>evt.preventDefault(),onClick:evt=>onListItemClick(category,index,evt)},content),index!==items.length-1&&_react.default.createElement(_Divider.Divider,null))});return _react.default.createElement(_Stack.Stack,{space:"s"},_react.default.createElement(_Header.H6,{as:"div"},category),_react.default.createElement(_Container.Container,{elevation:0,borderRadius:"s"},_react.default.createElement(_Stack.Stack,{space:"zero"},listItems)))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CategoryList(){return CategoryList},get getListItemId(){return getListItemId}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Header=require("../Typography/Header"),_Icon=require("../Icon/Icon"),_Text=require("../Typography/Text"),_Columns=require("../Column/Columns"),_Stack=require("../Stack/Stack"),_Container=require("../Container"),_Divider=require("../Divider/Divider");function getListItemId(name,category,index){return`${name}_${category}_ListItem${index}`}const StyledIconLeft=(0,_styled.default)(_Icon.Icon,{target:"e1n7h3uo0",label:"StyledIconLeft"})(({theme})=>({marginRight:theme.variables.size.spacing.xs}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE1vdXNlRXZlbnQsIFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVZhbHVlID0gc3RyaW5nIHwgeyB2YWx1ZTogc3RyaW5nIH07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtUHJvcHMgPSB7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICBsYWJlbDogUmVhY3RFbGVtZW50O1xuICB2YWx1ZTogTGlzdEl0ZW1WYWx1ZTtcbiAgZGF0YUUyZVRlc3RJZD86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgaW5kZXhJbkNhdGVnb3J5OiBudW1iZXI7XG4gIHZhbHVlOiBMaXN0SXRlbVByb3BzW1widmFsdWVcIl07XG4gIGlkOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBDYXRlZ29yeUxpc3RQcm9wcyA9IExpc3RJdGVtc0J5Q2F0ZWdvcnkgJiB7XG4gIG5hbWU6IHN0cmluZztcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBvbkxpc3RJdGVtQ2xpY2s6IChcbiAgICBjYXRlZ29yeTogc3RyaW5nLFxuICAgIGluZGV4SW5DYXRlZ29yeTogbnVtYmVyLFxuICAgIGV2dD86IE1vdXNlRXZlbnQ8SFRNTERpdkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRMaXN0SXRlbUlkKFxuICBuYW1lOiBzdHJpbmcsXG4gIGNhdGVnb3J5OiBzdHJpbmcsXG4gIGluZGV4OiBudW1iZXJcbik6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV8ke2NhdGVnb3J5fV9MaXN0SXRlbSR7aW5kZXh9YDtcbn1cblxuY29uc3QgU3R5bGVkSWNvbkxlZnQgPSBzdHlsZWQoSWNvbikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgbWFyZ2luUmlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG59KSk7XG5cbnR5cGUgU3R5bGVkTGlzdEl0ZW1Qcm9wcyA9IHtcbiAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZExpc3RJdGVtID0gc3R5bGVkLmRpdjxTdHlsZWRMaXN0SXRlbVByb3BzPihcbiAgKHsgdGhlbWUsIGlzU2VsZWN0ZWQgfSkgPT4gKHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG5cbiAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9LFxuXG4gICAgLi4uKGlzU2VsZWN0ZWQgJiYge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9KSxcbiAgfSlcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiBDYXRlZ29yeUxpc3Qoe1xuICBuYW1lLFxuICBjYXRlZ29yeSxcbiAgaWNvbkxlZnQsXG4gIHJpZ2h0Q29udGVudCxcbiAgaXRlbXMsXG4gIHNlbGVjdGVkTGlzdEl0ZW0sXG4gIG9uTGlzdEl0ZW1DbGljayxcbn06IENhdGVnb3J5TGlzdFByb3BzKTogUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgbGlzdEl0ZW1zID0gaXRlbXMubWFwKFxuICAgICh7IGxhYmVsLCBpY29uTGVmdDogaXRlbUljb25MZWZ0LCBkYXRhRTJlVGVzdElkIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBsZWZ0Q29udGVudCA9IChcbiAgICAgICAgPFRleHQ+XG4gICAgICAgICAge2ljb25MZWZ0ICYmIChcbiAgICAgICAgICAgIDxTdHlsZWRJY29uTGVmdFxuICAgICAgICAgICAgICB7Li4uKGl0ZW1JY29uTGVmdCB8fCBpY29uTGVmdCl9XG4gICAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIGlubGluZVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9UZXh0PlxuICAgICAgKTtcbiAgICAgIGNvbnN0IGNvbnRlbnQgPSByaWdodENvbnRlbnQgPyAoXG4gICAgICAgIDxDb2x1bW5zPlxuICAgICAgICAgIDxDb2x1bW4+e2xlZnRDb250ZW50fTwvQ29sdW1uPlxuICAgICAgICAgIDxDb2x1bW4gc2l6ZT1cIm5hcnJvd1wiPntyaWdodENvbnRlbnR9PC9Db2x1bW4+XG4gICAgICAgIDwvQ29sdW1ucz5cbiAgICAgICkgOiAoXG4gICAgICAgIGxlZnRDb250ZW50XG4gICAgICApO1xuXG4gICAgICBjb25zdCBpc1NlbGVjdGVkID1cbiAgICAgICAgISFzZWxlY3RlZExpc3RJdGVtICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uaW5kZXhJbkNhdGVnb3J5ID09PSBpbmRleDtcblxuICAgICAgLyogZXNsaW50LWRpc2FibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RnJhZ21lbnQga2V5PXtpbmRleH0+XG4gICAgICAgICAgPFN0eWxlZExpc3RJdGVtXG4gICAgICAgICAgICBpZD17Z2V0TGlzdEl0ZW1JZChuYW1lLCBjYXRlZ29yeSwgaW5kZXgpfVxuICAgICAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgICAgICAgIHJvbGU9XCJvcHRpb25cIlxuICAgICAgICAgICAgaXNTZWxlY3RlZD17aXNTZWxlY3RlZH1cbiAgICAgICAgICAgIGFyaWEtc2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgICBvblBvaW50ZXJEb3duPXsoZXZ0KSA9PiBldnQucHJldmVudERlZmF1bHQoKX0gLy8gbmVlZGVkIHRvIGF2b2lkIGZvY3VzIGNoYW5nZVxuICAgICAgICAgICAgb25DbGljaz17KGV2dCkgPT4gb25MaXN0SXRlbUNsaWNrKGNhdGVnb3J5LCBpbmRleCwgZXZ0KX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7Y29udGVudH1cbiAgICAgICAgICA8L1N0eWxlZExpc3RJdGVtPlxuICAgICAgICAgIHtpbmRleCAhPT0gaXRlbXMubGVuZ3RoIC0gMSAmJiA8RGl2aWRlciAvPn1cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgICAvKiBlc2xpbnQtZW5hYmxlIHJlYWN0L25vLWFycmF5LWluZGV4LWtleSAqL1xuICAgIH1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxTdGFjayBzcGFjZT1cInNcIj5cbiAgICAgIDxINiBhcz1cImRpdlwiPntjYXRlZ29yeX08L0g2PlxuICAgICAgPENvbnRhaW5lciBlbGV2YXRpb249ezB9IGJvcmRlclJhZGl1cz1cInNcIj5cbiAgICAgICAgPFN0YWNrIHNwYWNlPVwiemVyb1wiPntsaXN0SXRlbXN9PC9TdGFjaz5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3RhY2s+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUR1QiJ9 */"),StyledListItem=(0,_styled.default)("div",{target:"e1n7h3uo1",label:"StyledListItem"})(({theme,isSelected})=>({padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,cursor:"pointer","&:hover":{backgroundColor:theme.values.color.background.transparent.hover},...isSelected&&{backgroundColor:theme.values.color.background.transparent.hover}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvQ2F0ZWdvcnlMaXN0LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE1vdXNlRXZlbnQsIFJlYWN0RWxlbWVudCwgUmVhY3ROb2RlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgUmVhY3QsIHsgRnJhZ21lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgSDYgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9IZWFkZXJcIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgeyBDb2x1bW5zLCBDb2x1bW4gfSBmcm9tIFwiLi4vQ29sdW1uL0NvbHVtbnNcIjtcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSBcIi4uL1N0YWNrL1N0YWNrXCI7XG5pbXBvcnQgeyBDb250YWluZXIgfSBmcm9tIFwiLi4vQ29udGFpbmVyXCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuXG5leHBvcnQgdHlwZSBMaXN0SXRlbVZhbHVlID0gc3RyaW5nIHwgeyB2YWx1ZTogc3RyaW5nIH07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtUHJvcHMgPSB7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICBsYWJlbDogUmVhY3RFbGVtZW50O1xuICB2YWx1ZTogTGlzdEl0ZW1WYWx1ZTtcbiAgZGF0YUUyZVRlc3RJZD86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIExpc3RJdGVtc0J5Q2F0ZWdvcnkgPSB7XG4gIGNhdGVnb3J5OiBzdHJpbmc7XG4gIGljb25MZWZ0PzogSWNvblByb3BzO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdE5vZGU7XG4gIGl0ZW1zOiBMaXN0SXRlbVByb3BzW107XG59O1xuXG5leHBvcnQgdHlwZSBGbGF0dGVuZWRMaXN0SXRlbSA9IHtcbiAgY2F0ZWdvcnk6IExpc3RJdGVtc0J5Q2F0ZWdvcnlbXCJjYXRlZ29yeVwiXTtcbiAgaW5kZXhJbkNhdGVnb3J5OiBudW1iZXI7XG4gIHZhbHVlOiBMaXN0SXRlbVByb3BzW1widmFsdWVcIl07XG4gIGlkOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBDYXRlZ29yeUxpc3RQcm9wcyA9IExpc3RJdGVtc0J5Q2F0ZWdvcnkgJiB7XG4gIG5hbWU6IHN0cmluZztcbiAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICBvbkxpc3RJdGVtQ2xpY2s6IChcbiAgICBjYXRlZ29yeTogc3RyaW5nLFxuICAgIGluZGV4SW5DYXRlZ29yeTogbnVtYmVyLFxuICAgIGV2dD86IE1vdXNlRXZlbnQ8SFRNTERpdkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRMaXN0SXRlbUlkKFxuICBuYW1lOiBzdHJpbmcsXG4gIGNhdGVnb3J5OiBzdHJpbmcsXG4gIGluZGV4OiBudW1iZXJcbik6IHN0cmluZyB7XG4gIHJldHVybiBgJHtuYW1lfV8ke2NhdGVnb3J5fV9MaXN0SXRlbSR7aW5kZXh9YDtcbn1cblxuY29uc3QgU3R5bGVkSWNvbkxlZnQgPSBzdHlsZWQoSWNvbikoKHsgdGhlbWUgfSkgPT4gKHtcbiAgbWFyZ2luUmlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG59KSk7XG5cbnR5cGUgU3R5bGVkTGlzdEl0ZW1Qcm9wcyA9IHtcbiAgaXNTZWxlY3RlZDogYm9vbGVhbjtcbn07XG5cbmNvbnN0IFN0eWxlZExpc3RJdGVtID0gc3R5bGVkLmRpdjxTdHlsZWRMaXN0SXRlbVByb3BzPihcbiAgKHsgdGhlbWUsIGlzU2VsZWN0ZWQgfSkgPT4gKHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubX1gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG5cbiAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9LFxuXG4gICAgLi4uKGlzU2VsZWN0ZWQgJiYge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC50cmFuc3BhcmVudC5ob3ZlcixcbiAgICB9KSxcbiAgfSlcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiBDYXRlZ29yeUxpc3Qoe1xuICBuYW1lLFxuICBjYXRlZ29yeSxcbiAgaWNvbkxlZnQsXG4gIHJpZ2h0Q29udGVudCxcbiAgaXRlbXMsXG4gIHNlbGVjdGVkTGlzdEl0ZW0sXG4gIG9uTGlzdEl0ZW1DbGljayxcbn06IENhdGVnb3J5TGlzdFByb3BzKTogUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgbGlzdEl0ZW1zID0gaXRlbXMubWFwKFxuICAgICh7IGxhYmVsLCBpY29uTGVmdDogaXRlbUljb25MZWZ0LCBkYXRhRTJlVGVzdElkIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBsZWZ0Q29udGVudCA9IChcbiAgICAgICAgPFRleHQ+XG4gICAgICAgICAge2ljb25MZWZ0ICYmIChcbiAgICAgICAgICAgIDxTdHlsZWRJY29uTGVmdFxuICAgICAgICAgICAgICB7Li4uKGl0ZW1JY29uTGVmdCB8fCBpY29uTGVmdCl9XG4gICAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgICAgY29sb3I9XCJ0ZXJ0aWFyeVwiXG4gICAgICAgICAgICAgIGlubGluZVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9UZXh0PlxuICAgICAgKTtcbiAgICAgIGNvbnN0IGNvbnRlbnQgPSByaWdodENvbnRlbnQgPyAoXG4gICAgICAgIDxDb2x1bW5zPlxuICAgICAgICAgIDxDb2x1bW4+e2xlZnRDb250ZW50fTwvQ29sdW1uPlxuICAgICAgICAgIDxDb2x1bW4gc2l6ZT1cIm5hcnJvd1wiPntyaWdodENvbnRlbnR9PC9Db2x1bW4+XG4gICAgICAgIDwvQ29sdW1ucz5cbiAgICAgICkgOiAoXG4gICAgICAgIGxlZnRDb250ZW50XG4gICAgICApO1xuXG4gICAgICBjb25zdCBpc1NlbGVjdGVkID1cbiAgICAgICAgISFzZWxlY3RlZExpc3RJdGVtICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uY2F0ZWdvcnkgPT09IGNhdGVnb3J5ICYmXG4gICAgICAgIHNlbGVjdGVkTGlzdEl0ZW0uaW5kZXhJbkNhdGVnb3J5ID09PSBpbmRleDtcblxuICAgICAgLyogZXNsaW50LWRpc2FibGUgcmVhY3Qvbm8tYXJyYXktaW5kZXgta2V5ICovXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RnJhZ21lbnQga2V5PXtpbmRleH0+XG4gICAgICAgICAgPFN0eWxlZExpc3RJdGVtXG4gICAgICAgICAgICBpZD17Z2V0TGlzdEl0ZW1JZChuYW1lLCBjYXRlZ29yeSwgaW5kZXgpfVxuICAgICAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgICAgICAgIHJvbGU9XCJvcHRpb25cIlxuICAgICAgICAgICAgaXNTZWxlY3RlZD17aXNTZWxlY3RlZH1cbiAgICAgICAgICAgIGFyaWEtc2VsZWN0ZWQ9e2lzU2VsZWN0ZWR9XG4gICAgICAgICAgICBvblBvaW50ZXJEb3duPXsoZXZ0KSA9PiBldnQucHJldmVudERlZmF1bHQoKX0gLy8gbmVlZGVkIHRvIGF2b2lkIGZvY3VzIGNoYW5nZVxuICAgICAgICAgICAgb25DbGljaz17KGV2dCkgPT4gb25MaXN0SXRlbUNsaWNrKGNhdGVnb3J5LCBpbmRleCwgZXZ0KX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7Y29udGVudH1cbiAgICAgICAgICA8L1N0eWxlZExpc3RJdGVtPlxuICAgICAgICAgIHtpbmRleCAhPT0gaXRlbXMubGVuZ3RoIC0gMSAmJiA8RGl2aWRlciAvPn1cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgICAvKiBlc2xpbnQtZW5hYmxlIHJlYWN0L25vLWFycmF5LWluZGV4LWtleSAqL1xuICAgIH1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxTdGFjayBzcGFjZT1cInNcIj5cbiAgICAgIDxINiBhcz1cImRpdlwiPntjYXRlZ29yeX08L0g2PlxuICAgICAgPENvbnRhaW5lciBlbGV2YXRpb249ezB9IGJvcmRlclJhZGl1cz1cInNcIj5cbiAgICAgICAgPFN0YWNrIHNwYWNlPVwiemVyb1wiPntsaXN0SXRlbXN9PC9TdGFjaz5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3RhY2s+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkR1QiJ9 */");function CategoryList({name,category,iconLeft,rightContent,items,selectedListItem,onListItemClick}){let listItems=items.map(({label,iconLeft:itemIconLeft,dataE2eTestId},index)=>{let leftContent=_react.default.createElement(_Text.Text,null,iconLeft&&_react.default.createElement(StyledIconLeft,{...itemIconLeft||iconLeft,size:"s",color:"tertiary",inline:!0}),label),content=rightContent?_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,null,leftContent),_react.default.createElement(_Columns.Column,{size:"narrow"},rightContent)):leftContent,isSelected=!!selectedListItem&&selectedListItem.category===category&&selectedListItem.indexInCategory===index;return _react.default.createElement(_react.Fragment,{key:index},_react.default.createElement(StyledListItem,{id:getListItemId(name,category,index),"data-e2e-test-id":dataE2eTestId,role:"option",isSelected:isSelected,"aria-selected":isSelected,onPointerDown:evt=>evt.preventDefault(),onClick:evt=>onListItemClick(category,index,evt)},content),index!==items.length-1&&_react.default.createElement(_Divider.Divider,null))});return _react.default.createElement(_Stack.Stack,{space:"s"},_react.default.createElement(_Header.H6,{as:"div"},category),_react.default.createElement(_Container.Container,{elevation:0,borderRadius:"s"},_react.default.createElement(_Stack.Stack,{space:"zero"},listItems)))}
@@ -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"),_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
+ "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:"e1djr9990",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                    dataE2eTestId={\n                      dataE2eTestId ? `${dataE2eTestId}-input` : undefined\n                    }\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:"e1djr9991",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                    dataE2eTestId={\n                      dataE2eTestId ? `${dataE2eTestId}-input` : undefined\n                    }\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:"e1djr9992",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                    dataE2eTestId={\n                      dataE2eTestId ? `${dataE2eTestId}-input` : undefined\n                    }\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:"e1djr9993",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                    dataE2eTestId={\n                      dataE2eTestId ? `${dataE2eTestId}-input` : undefined\n                    }\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,dataE2eTestId:dataE2eTestId?`${dataE2eTestId}-input`:void 0,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()}}))});
@@ -3,6 +3,7 @@ import React from "react";
3
3
  import type { Property } from "csstype";
4
4
  import type { FlattenedListItem } from "./CategoryList";
5
5
  export type PromptTextAreaProps = TextareaHTMLAttributes<HTMLTextAreaElement> & {
6
+ dataE2eTestId?: string;
6
7
  label: string;
7
8
  name: string;
8
9
  value: string;
@@ -14,6 +15,7 @@ export type PromptTextAreaProps = TextareaHTMLAttributes<HTMLTextAreaElement> &
14
15
  isNavBarVariant?: boolean;
15
16
  };
16
17
  export declare const PromptTextArea: React.ForwardRefExoticComponent<TextareaHTMLAttributes<HTMLTextAreaElement> & {
18
+ dataE2eTestId?: string;
17
19
  label: string;
18
20
  name: string;
19
21
  value: string;