@amboss/design-system 3.13.4 → 3.13.5

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 +1 @@
1
- import React,{useRef,useMemo,useState,useEffect,useCallback,forwardRef}from"react";import styled from"@emotion/styled";import{PromptTextArea}from"./PromptTextArea";import{Container}from"../Container";import{AutocompleteList}from"./AutocompleteList";import{getListItemId}from"./CategoryList";import{Box}from"../Box/Box";import{Text}from"../Typography/Text";import{Column,Columns}from"../Column/Columns";import{Inline}from"../Inline/Inline";import{RoundButton}from"../RoundButton/RoundButton";import{PictogramButton}from"../PictogramButton/PictogramButton";import{Stack}from"../Stack/Stack";let CustomContainer=styled(Container,{target:"ec6cdii0",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} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst 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?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-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":"AAgCwB"} */"),StyledTextAreaContainer=styled("div",{target:"ec6cdii1",label:"StyledTextAreaContainer"})({position:"relative"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst 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?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-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":"AA8CgC"} */"),StyledEmptyStateTopRightContentContainer=styled("div",{target:"ec6cdii2",label:"StyledEmptyStateTopRightContentContainer"})(({theme,isNavBarVariant})=>({position:"absolute",top:isNavBarVariant?theme.variables.size.spacing.xxs:theme.variables.size.spacing.m,right:theme.variables.size.spacing.m,userSelect:"none",pointerEvents:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst 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?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-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":"AAwDE"} */"),StyledClearButton=styled(PictogramButton,{target:"ec6cdii3",label:"StyledClearButton"})(({theme,isNavBarVariant})=>({position:"absolute",right:theme.variables.size.spacing.s,top:isNavBarVariant?0:theme.variables.size.spacing.s}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport { getListItemId, type FlattenedListItem } from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst 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?: (value: string, category?: string) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete(itemValue, category);\n      }\n    };\n\n    const handleListItemClick = (category: string, itemValue: string) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category && listItem.value === itemValue\n      );\n      handleSelectedIndexChange(index);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete(userTypedQuery.current);\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.(userTypedQuery.current);\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-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":"AAuE0B"} */");export const PromptInput=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=useRef(null),textAreaContainerRef=useRef(null),internalRef=useRef(null),[selectedIndex,setSelectedIndex]=useState(-1),[isCollapsed,setIsCollapsed]=useState(isNavBarVariant),userTypedQuery=useRef(""),[isAutocompleteListOpen,setIsAutocompleteListOpen]=useState(!1),textAreaRef=ref||internalRef,closeAutocompleteList=useCallback(()=>{setIsAutocompleteListOpen(!1),setSelectedIndex(-1)},[]),openAutocompleteList=useCallback(()=>{autocompleteListItems.length&&(setIsAutocompleteListOpen(!0),setSelectedIndex(-1))},[autocompleteListItems]),acceptTextSelection=()=>{userTypedQuery.current=value,textAreaRef.current.setSelectionRange(value.length,value.length)};useEffect(()=>{autocompleteListItems.length&&!isCollapsed?openAutocompleteList():closeAutocompleteList()},[autocompleteListItems,openAutocompleteList,closeAutocompleteList,isCollapsed]),useEffect(()=>{value&&value!==userTypedQuery.current&&isAutocompleteListOpen&&textAreaRef.current.setSelectionRange(userTypedQuery.current.length,value.length)},[value,textAreaRef,isAutocompleteListOpen]),useEffect(()=>{let handler,container=containerRef.current;return isNavBarVariant&&container&&(handler=evt=>{containerRef.current.contains(evt.relatedTarget)||setIsCollapsed(!0)},containerRef.current.addEventListener("focusout",handler)),()=>{container&&container.removeEventListener("focusout",handler)}},[isNavBarVariant,containerRef]);let flattenedListItems=useMemo(()=>{let list=[];return autocompleteListItems.forEach(listItem=>{listItem.items.forEach((item,index)=>{list.push({category:listItem.category,value:item.value,id:getListItemId(name,listItem.category,index)})})}),list},[autocompleteListItems,name]),handleSelectedIndexChange=index=>{if(setSelectedIndex(index),-1!==index){let{category,value:itemValue}=flattenedListItems[index];onComplete(itemValue,category)}},selectedListItem=-1!==selectedIndex?flattenedListItems[selectedIndex]:null,emptyStateTopRightContentElm=emptyStateTopRightContent?React.createElement(StyledEmptyStateTopRightContentContainer,{isNavBarVariant:isNavBarVariant},React.createElement(Text,{color:"tertiary"},emptyStateTopRightContent)):null,clearButtonElm=value?React.createElement(StyledClearButton,{size:"s",icon:"x-circle-filled","aria-label":clearButtonAriaLabel,isNavBarVariant:isNavBarVariant,onPointerDown:evt=>evt.preventDefault(),onClick:onClear}):emptyStateTopRightContentElm,hintElm=!!hint&&React.createElement(Inline,{alignItems:"center"},React.createElement(Text,{size:"s",color:"tertiary"},hint)),bottomToolbarElm=!isCollapsed&&React.createElement(Box,{space:"m","data-e2e-test-id":"bottomToolbar"},React.createElement(Columns,{gap:"s",alignItems:"spaceBetween",vAlignItems:"center"},React.createElement(Column,null,bottomToolbar.leftContent),React.createElement(Column,{size:"narrow"},React.createElement(Inline,{space:"xs",vAlignItems:"center"},bottomToolbar.rightContent,React.createElement(RoundButton,{...sendButtonProps,ariaAttributes:{"aria-label":isProcessing?"Processing query":"Submit query"},variant:"primary",disabled:!value,icon:isProcessing?"stop-filled":sendButtonProps.icon})))));return React.createElement(React.Fragment,null,React.createElement("div",{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PromptInput",ref:containerRef},React.createElement(Stack,{space:"s"},React.createElement("div",{ref:textAreaContainerRef},React.createElement(CustomContainer,{elevation:+!isCollapsed,borderRadius:isCollapsed?"s":"m"},React.createElement(StyledTextAreaContainer,null,React.createElement(PromptTextArea,{...rest,name:name,value:value,ref:textAreaRef,isNavBarVariant:isNavBarVariant,selectedListItem:selectedListItem,isAutocompleteListOpen:isAutocompleteListOpen,isCollapsed:isCollapsed,onFocus:evt=>{setIsCollapsed(!1),onFocus?.(evt)},onBlur:evt=>{value!==userTypedQuery.current&&onComplete?.(userTypedQuery.current),onBlur?.(evt)},onChange:evt=>{userTypedQuery.current=evt.target.value,onChange(evt)},onKeyDown:evt=>{if(isAutocompleteListOpen)switch(evt.key){case"Escape":closeAutocompleteList(),onComplete(userTypedQuery.current);break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),closeAutocompleteList(),acceptTextSelection(),value&&onEnterKey?.());break;case" ":acceptTextSelection();break;case"ArrowUp":evt.preventDefault(),selectedIndex>-1&&handleSelectedIndexChange(selectedIndex-1);break;case"ArrowDown":evt.preventDefault(),selectedIndex<flattenedListItems.length-1&&handleSelectedIndexChange(selectedIndex+1)}else switch(evt.key){case"Escape":onClear?.();break;case"Enter":!evt.shiftKey&&(evt.preventDefault(),value&&onEnterKey?.())}onKeyDown?.(evt)}}),clearButtonElm),bottomToolbarElm)),hintElm)),React.createElement(AutocompleteList,{name:name,value:value,autocompleteListItems:autocompleteListItems,triggerRef:textAreaContainerRef,selectedListItem:selectedListItem,isOpen:isAutocompleteListOpen,autocompleteListFooter:autocompleteListFooter,portalContainer:portalContainer,onListItemClick:(category,itemValue)=>{handleSelectedIndexChange(flattenedListItems.findIndex(listItem=>listItem.category===category&&listItem.value===itemValue)),closeAutocompleteList()}}))});
1
+ import React,{useRef,useMemo,useState,useEffect,useCallback,forwardRef}from"react";import styled from"@emotion/styled";import{PromptTextArea}from"./PromptTextArea";import{Container}from"../Container";import{AutocompleteList}from"./AutocompleteList";import{getListItemId}from"./CategoryList";import{Box}from"../Box/Box";import{Text}from"../Typography/Text";import{Column,Columns}from"../Column/Columns";import{Inline}from"../Inline/Inline";import{RoundButton}from"../RoundButton/RoundButton";import{PictogramButton}from"../PictogramButton/PictogramButton";import{Stack}from"../Stack/Stack";let CustomContainer=styled(Container,{target:"e1dwpec10",label:"CustomContainer"})(({theme})=>({"&:has(textarea:focus-visible)":{outlineWidth:1,outlineStyle:"solid",outlineOffset:-1,outlineColor:theme.values.color.border.accent.default,boxShadow:theme.values.shadow.focusRing,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:theme.values.color.border.accent.default}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n  SyntheticEvent,\n  MouseEvent,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\"> & {\n    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            indexInCategory: index,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.({ value: userTypedQuery.current, evt });\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-circle-filled\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <CustomContainer\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </CustomContainer>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsCwB"} */"),StyledTextAreaContainer=styled("div",{target:"e1dwpec11",label:"StyledTextAreaContainer"})({position:"relative"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n  SyntheticEvent,\n  MouseEvent,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\"> & {\n    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            indexInCategory: index,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.({ value: userTypedQuery.current, evt });\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-circle-filled\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <CustomContainer\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </CustomContainer>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AAoDgC"} */"),StyledEmptyStateTopRightContentContainer=styled("div",{target:"e1dwpec12",label:"StyledEmptyStateTopRightContentContainer"})(({theme,isNavBarVariant})=>({position:"absolute",top:isNavBarVariant?theme.variables.size.spacing.xxs:theme.variables.size.spacing.m,right:theme.variables.size.spacing.m,userSelect:"none",pointerEvents:"none"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n  SyntheticEvent,\n  MouseEvent,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\"> & {\n    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            indexInCategory: index,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.({ value: userTypedQuery.current, evt });\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-circle-filled\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <CustomContainer\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </CustomContainer>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AA8DE"} */"),StyledClearButton=styled(PictogramButton,{target:"e1dwpec13",label:"StyledClearButton"})(({theme,isNavBarVariant})=>({position:"absolute",right:theme.variables.size.spacing.s,top:isNavBarVariant?0:theme.variables.size.spacing.s}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/PromptInput/PromptInput.tsx","sources":["src/components/PromptInput/PromptInput.tsx"],"sourcesContent":["import type {\n  ReactElement,\n  ChangeEventHandler,\n  KeyboardEventHandler,\n  RefObject,\n  FocusEventHandler,\n  SyntheticEvent,\n  MouseEvent,\n} from \"react\";\nimport React, {\n  useRef,\n  useMemo,\n  useState,\n  useEffect,\n  useCallback,\n  forwardRef,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { PromptTextAreaProps } from \"./PromptTextArea\";\nimport { PromptTextArea } from \"./PromptTextArea\";\nimport { Container } from \"../Container\";\nimport type { AutocompleteListProps } from \"./AutocompleteList\";\nimport { AutocompleteList } from \"./AutocompleteList\";\nimport {\n  getListItemId,\n  type FlattenedListItem,\n  type ListItemValue,\n} from \"./CategoryList\";\nimport { Box } from \"../Box/Box\";\nimport { Text } from \"../Typography/Text\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport type { RoundButtonProps } from \"../RoundButton/RoundButton\";\nimport { RoundButton } from \"../RoundButton/RoundButton\";\nimport type { PictogramButtonProps } from \"../PictogramButton/PictogramButton\";\nimport { PictogramButton } from \"../PictogramButton/PictogramButton\";\nimport { Stack } from \"../Stack/Stack\";\n\nconst CustomContainer = styled(Container)(({ theme }) => ({\n  [`&:has(textarea:focus-visible)`]: {\n    outlineWidth: 1,\n    outlineStyle: \"solid\",\n    outlineOffset: -1,\n    outlineColor: theme.values.color.border.accent.default,\n    boxShadow: theme.values.shadow.focusRing,\n\n    \"@media (-webkit-min-device-pixel-ratio:0)\": {\n      outlineColor: theme.values.color.border.accent.default,\n    },\n  },\n}));\n\nconst StyledTextAreaContainer = styled.div({\n  position: \"relative\",\n});\n\ntype StyledEmptyStateTopRightContentContainerProps = Pick<\n  PromptInputProps,\n  \"isNavBarVariant\"\n>;\n\nconst StyledEmptyStateTopRightContentContainer =\n  styled.div<StyledEmptyStateTopRightContentContainerProps>(\n    ({ theme, isNavBarVariant }) => ({\n      position: \"absolute\",\n      top: isNavBarVariant\n        ? theme.variables.size.spacing.xxs\n        : theme.variables.size.spacing.m,\n      right: theme.variables.size.spacing.m,\n      userSelect: \"none\",\n      pointerEvents: \"none\",\n    })\n  );\n\ntype StyledClearButtonProps = PictogramButtonProps &\n  Pick<PromptInputProps, \"isNavBarVariant\">;\n\nconst StyledClearButton = styled(PictogramButton)<StyledClearButtonProps>(\n  ({ theme, isNavBarVariant }) => ({\n    position: \"absolute\",\n    right: theme.variables.size.spacing.s,\n    top: isNavBarVariant ? 0 : theme.variables.size.spacing.s,\n  })\n);\n\nexport type PromptInputProps = {\n  \"data-e2e-test-id\"?: string;\n  /** Toolbar elements below text area */\n  bottomToolbar?: {\n    leftContent?: ReactElement;\n    rightContent?: ReactElement;\n  };\n  /** Currently shows send button processing state  */\n  isProcessing?: boolean;\n  sendButtonProps?: Omit<RoundButtonProps, \"icon\" | \"variant\"> & {\n    icon?: \"arrow-up\" | \"search\" | \"arrow-right\";\n  };\n  clearButtonAriaLabel?: string;\n  hint?: ReactElement;\n  /** Shows in the clear button space in empty state */\n  emptyStateTopRightContent?: ReactElement;\n  onClear: () => void;\n  /** Called when user selects (or rejects) a list item from autocomplete list */\n  onComplete?: ({\n    value,\n    category,\n    evt,\n    index,\n  }: {\n    value: ListItemValue;\n    category?: string;\n    evt?: SyntheticEvent;\n    index?: number;\n  }) => void;\n  /** Called on Enter key to submit the form  */\n  onEnterKey: () => void;\n} & Omit<\n  PromptTextAreaProps,\n  \"isCollapsed\" | \"isAutocompleteListOpen\" | \"selectedListItem\"\n> &\n  Pick<\n    AutocompleteListProps,\n    \"autocompleteListItems\" | \"autocompleteListFooter\" | \"portalContainer\"\n  >;\n\nexport const PromptInput = forwardRef(\n  (\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      name,\n      autocompleteListItems = [],\n      value,\n      bottomToolbar = { leftContent: null, rightContent: null },\n      isProcessing,\n      sendButtonProps = {\n        type: \"submit\",\n        icon: \"arrow-up\",\n      },\n      autocompleteListFooter,\n      clearButtonAriaLabel = \"Clear input\",\n      hint,\n      emptyStateTopRightContent,\n      isNavBarVariant,\n      portalContainer,\n      onChange,\n      onComplete,\n      onClear,\n      onEnterKey,\n      onFocus,\n      onBlur,\n      onKeyDown,\n      ...rest\n    }: PromptInputProps,\n    ref: RefObject<HTMLTextAreaElement>\n  ): ReactElement => {\n    const containerRef = useRef<HTMLDivElement>(null);\n    const textAreaContainerRef = useRef<HTMLDivElement>(null);\n    const internalRef = useRef<HTMLTextAreaElement>(null);\n    const [selectedIndex, setSelectedIndex] = useState(-1);\n    const [isCollapsed, setIsCollapsed] = useState(isNavBarVariant);\n    const userTypedQuery = useRef(\"\");\n    const [isAutocompleteListOpen, setIsAutocompleteListOpen] = useState(false);\n    const textAreaRef = ref || internalRef;\n\n    const closeAutocompleteList = useCallback(() => {\n      setIsAutocompleteListOpen(false);\n      setSelectedIndex(-1);\n    }, []);\n\n    const openAutocompleteList = useCallback(() => {\n      if (autocompleteListItems.length) {\n        setIsAutocompleteListOpen(true);\n        setSelectedIndex(-1);\n      }\n    }, [autocompleteListItems]);\n\n    const acceptTextSelection = () => {\n      userTypedQuery.current = value;\n      textAreaRef.current.setSelectionRange(value.length, value.length);\n    };\n\n    useEffect(() => {\n      if (autocompleteListItems.length && !isCollapsed) {\n        openAutocompleteList();\n      } else {\n        closeAutocompleteList();\n      }\n    }, [\n      autocompleteListItems,\n      openAutocompleteList,\n      closeAutocompleteList,\n      isCollapsed,\n    ]);\n\n    useEffect(() => {\n      if (value && value !== userTypedQuery.current && isAutocompleteListOpen) {\n        textAreaRef.current.setSelectionRange(\n          userTypedQuery.current.length,\n          value.length\n        );\n      }\n    }, [value, textAreaRef, isAutocompleteListOpen]);\n\n    // Determine when focus leaves the container to collapse it\n    useEffect(() => {\n      let handler: (evt: FocusEvent) => void;\n      const container = containerRef.current;\n\n      if (isNavBarVariant && container) {\n        handler = (evt: FocusEvent) => {\n          if (!containerRef.current.contains(evt.relatedTarget as Node)) {\n            setIsCollapsed(true);\n          }\n        };\n        containerRef.current.addEventListener(\"focusout\", handler);\n      }\n\n      return () => {\n        if (container) {\n          container.removeEventListener(\"focusout\", handler);\n        }\n      };\n    }, [isNavBarVariant, containerRef]);\n\n    const flattenedListItems = useMemo(() => {\n      const list: FlattenedListItem[] = [];\n\n      autocompleteListItems.forEach((listItem) => {\n        listItem.items.forEach((item, index) => {\n          list.push({\n            category: listItem.category,\n            indexInCategory: index,\n            value: item.value,\n            id: getListItemId(name, listItem.category, index),\n          });\n        });\n      });\n      return list;\n    }, [autocompleteListItems, name]);\n\n    const handleSelectedIndexChange = (index: number, evt?: SyntheticEvent) => {\n      setSelectedIndex(index);\n      if (index !== -1) {\n        const { category, value: itemValue } = flattenedListItems[index];\n\n        onComplete({ value: itemValue, category, evt, index });\n      }\n    };\n\n    const handleListItemClick = (\n      category: string,\n      indexInCategory: number,\n      evt?: MouseEvent\n    ) => {\n      const index = flattenedListItems.findIndex(\n        (listItem) =>\n          listItem.category === category &&\n          listItem.indexInCategory === indexInCategory\n      );\n\n      handleSelectedIndexChange(index, evt);\n      closeAutocompleteList();\n    };\n\n    const handleKeyDown: KeyboardEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (isAutocompleteListOpen) {\n        switch (evt.key) {\n          case \"Escape\":\n            closeAutocompleteList();\n            onComplete({ value: userTypedQuery.current, evt });\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              closeAutocompleteList();\n              acceptTextSelection();\n\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          case \" \":\n            acceptTextSelection();\n            break;\n          case \"ArrowUp\":\n            evt.preventDefault();\n            if (selectedIndex > -1) {\n              handleSelectedIndexChange(selectedIndex - 1, evt);\n            }\n            break;\n          case \"ArrowDown\":\n            evt.preventDefault();\n            if (selectedIndex < flattenedListItems.length - 1) {\n              handleSelectedIndexChange(selectedIndex + 1, evt);\n            }\n            break;\n          default:\n        }\n      } else {\n        switch (evt.key) {\n          case \"Escape\":\n            onClear?.();\n            break;\n          case \"Enter\":\n            if (!evt.shiftKey) {\n              evt.preventDefault();\n              if (value) {\n                onEnterKey?.();\n              }\n            }\n            break;\n          default:\n            break;\n        }\n      }\n\n      onKeyDown?.(evt);\n    };\n\n    const handleChange: ChangeEventHandler<HTMLTextAreaElement> = (evt) => {\n      userTypedQuery.current = evt.target.value;\n      onChange(evt);\n    };\n\n    const handleFocus: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      setIsCollapsed(false);\n      onFocus?.(evt);\n    };\n\n    const handleBlur: FocusEventHandler<HTMLTextAreaElement> = (evt) => {\n      if (value !== userTypedQuery.current) {\n        onComplete?.({ value: userTypedQuery.current, evt });\n      }\n      onBlur?.(evt);\n    };\n\n    const selectedListItem =\n      selectedIndex !== -1 ? flattenedListItems[selectedIndex] : null;\n\n    const emptyStateTopRightContentElm = emptyStateTopRightContent ? (\n      <StyledEmptyStateTopRightContentContainer\n        isNavBarVariant={isNavBarVariant}\n      >\n        <Text color=\"tertiary\">{emptyStateTopRightContent}</Text>\n      </StyledEmptyStateTopRightContentContainer>\n    ) : null;\n\n    const clearButtonElm = value ? (\n      <StyledClearButton\n        size=\"s\"\n        icon=\"x-circle-filled\"\n        aria-label={clearButtonAriaLabel}\n        isNavBarVariant={isNavBarVariant}\n        onPointerDown={(evt: any) => evt.preventDefault()}\n        onClick={onClear}\n      />\n    ) : (\n      emptyStateTopRightContentElm\n    );\n\n    const hintElm = !!hint && (\n      <Inline alignItems=\"center\">\n        <Text size=\"s\" color=\"tertiary\">\n          {hint}\n        </Text>\n      </Inline>\n    );\n\n    const bottomToolbarElm = !isCollapsed && (\n      <Box space=\"m\" data-e2e-test-id=\"bottomToolbar\">\n        <Columns gap=\"s\" alignItems=\"spaceBetween\" vAlignItems=\"center\">\n          <Column>{bottomToolbar.leftContent}</Column>\n          <Column size=\"narrow\">\n            <Inline space=\"xs\" vAlignItems=\"center\">\n              {bottomToolbar.rightContent}\n              <RoundButton\n                {...sendButtonProps}\n                ariaAttributes={{\n                  \"aria-label\": isProcessing\n                    ? \"Processing query\"\n                    : \"Submit query\",\n                }}\n                variant=\"primary\"\n                disabled={!value}\n                icon={isProcessing ? \"stop-filled\" : sendButtonProps.icon}\n              />\n            </Inline>\n          </Column>\n        </Columns>\n      </Box>\n    );\n\n    return (\n      <>\n        <div\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id=\"PromptInput\"\n          ref={containerRef}\n        >\n          <Stack space=\"s\">\n            <div ref={textAreaContainerRef}>\n              <CustomContainer\n                elevation={isCollapsed ? 0 : 1}\n                borderRadius={isCollapsed ? \"s\" : \"m\"}\n              >\n                <StyledTextAreaContainer>\n                  <PromptTextArea\n                    {...rest}\n                    name={name}\n                    value={value}\n                    ref={textAreaRef}\n                    isNavBarVariant={isNavBarVariant}\n                    selectedListItem={selectedListItem}\n                    isAutocompleteListOpen={isAutocompleteListOpen}\n                    isCollapsed={isCollapsed}\n                    onFocus={handleFocus}\n                    onBlur={handleBlur}\n                    onChange={handleChange}\n                    onKeyDown={handleKeyDown}\n                  />\n                  {clearButtonElm}\n                </StyledTextAreaContainer>\n                {bottomToolbarElm}\n              </CustomContainer>\n            </div>\n            {hintElm}\n          </Stack>\n        </div>\n\n        <AutocompleteList\n          name={name}\n          value={value}\n          autocompleteListItems={autocompleteListItems}\n          triggerRef={textAreaContainerRef}\n          selectedListItem={selectedListItem}\n          isOpen={isAutocompleteListOpen}\n          autocompleteListFooter={autocompleteListFooter}\n          portalContainer={portalContainer}\n          onListItemClick={handleListItemClick}\n        />\n      </>\n    );\n  }\n);\n"],"names":[],"mappings":"AA6E0B"} */");export const PromptInput=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=useRef(null),textAreaContainerRef=useRef(null),internalRef=useRef(null),[selectedIndex,setSelectedIndex]=useState(-1),[isCollapsed,setIsCollapsed]=useState(isNavBarVariant),userTypedQuery=useRef(""),[isAutocompleteListOpen,setIsAutocompleteListOpen]=useState(!1),textAreaRef=ref||internalRef,closeAutocompleteList=useCallback(()=>{setIsAutocompleteListOpen(!1),setSelectedIndex(-1)},[]),openAutocompleteList=useCallback(()=>{autocompleteListItems.length&&(setIsAutocompleteListOpen(!0),setSelectedIndex(-1))},[autocompleteListItems]),acceptTextSelection=()=>{userTypedQuery.current=value,textAreaRef.current.setSelectionRange(value.length,value.length)};useEffect(()=>{autocompleteListItems.length&&!isCollapsed?openAutocompleteList():closeAutocompleteList()},[autocompleteListItems,openAutocompleteList,closeAutocompleteList,isCollapsed]),useEffect(()=>{value&&value!==userTypedQuery.current&&isAutocompleteListOpen&&textAreaRef.current.setSelectionRange(userTypedQuery.current.length,value.length)},[value,textAreaRef,isAutocompleteListOpen]),useEffect(()=>{let handler,container=containerRef.current;return isNavBarVariant&&container&&(handler=evt=>{containerRef.current.contains(evt.relatedTarget)||setIsCollapsed(!0)},containerRef.current.addEventListener("focusout",handler)),()=>{container&&container.removeEventListener("focusout",handler)}},[isNavBarVariant,containerRef]);let flattenedListItems=useMemo(()=>{let list=[];return autocompleteListItems.forEach(listItem=>{listItem.items.forEach((item,index)=>{list.push({category:listItem.category,indexInCategory:index,value:item.value,id: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.createElement(StyledEmptyStateTopRightContentContainer,{isNavBarVariant:isNavBarVariant},React.createElement(Text,{color:"tertiary"},emptyStateTopRightContent)):null,clearButtonElm=value?React.createElement(StyledClearButton,{size:"s",icon:"x-circle-filled","aria-label":clearButtonAriaLabel,isNavBarVariant:isNavBarVariant,onPointerDown:evt=>evt.preventDefault(),onClick:onClear}):emptyStateTopRightContentElm,hintElm=!!hint&&React.createElement(Inline,{alignItems:"center"},React.createElement(Text,{size:"s",color:"tertiary"},hint)),bottomToolbarElm=!isCollapsed&&React.createElement(Box,{space:"m","data-e2e-test-id":"bottomToolbar"},React.createElement(Columns,{gap:"s",alignItems:"spaceBetween",vAlignItems:"center"},React.createElement(Column,null,bottomToolbar.leftContent),React.createElement(Column,{size:"narrow"},React.createElement(Inline,{space:"xs",vAlignItems:"center"},bottomToolbar.rightContent,React.createElement(RoundButton,{...sendButtonProps,ariaAttributes:{"aria-label":isProcessing?"Processing query":"Submit query"},variant:"primary",disabled:!value,icon:isProcessing?"stop-filled":sendButtonProps.icon})))));return React.createElement(React.Fragment,null,React.createElement("div",{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"PromptInput",ref:containerRef},React.createElement(Stack,{space:"s"},React.createElement("div",{ref:textAreaContainerRef},React.createElement(CustomContainer,{elevation:+!isCollapsed,borderRadius:isCollapsed?"s":"m"},React.createElement(StyledTextAreaContainer,null,React.createElement(PromptTextArea,{...rest,name:name,value:value,ref:textAreaRef,isNavBarVariant:isNavBarVariant,selectedListItem:selectedListItem,isAutocompleteListOpen:isAutocompleteListOpen,isCollapsed:isCollapsed,onFocus:evt=>{setIsCollapsed(!1),onFocus?.(evt)},onBlur:evt=>{value!==userTypedQuery.current&&onComplete?.({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.createElement(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()}}))});
@@ -45,7 +45,6 @@ export * from "./components/Notification/Notification";
45
45
  export * from "./components/Logo/Logo";
46
46
  export * from "./components/MediaItem";
47
47
  export * from "./components/Callout/Callout";
48
- export * from "./components/ContentBox/ContentBox";
49
48
  export * from "./components/Patterns/Modal/Modal";
50
49
  export * from "./components/Patterns/ButtonGroup/ButtonGroup";
51
50
  export * from "./components/Collapsible/Collapsible";
@@ -1 +1 @@
1
- import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Combobox/Combobox";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/Callout/Callout";export*from"./components/ContentBox/ContentBox";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree";export*from"./components/EntityList";export*from"./components/Form/Select";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Grid/Grid";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Toast";export*from"./components/Form/DateInput/DateInput";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/RadioCard/RadioCard";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/CatalogCard/CatalogCard";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";export*from"./components/PromptInput/PromptInput";export*from"./components/ColorIndicator/ColorIndicator";export*from"./components/ColorPicker/ColorPicker";
1
+ import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/Box/Box";export*from"./components/Inline/Inline";export*from"./components/Stack/Stack";export*from"./components/Typography/Header";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Link/Link";export*from"./components/Icon/Icon";export*from"./components/Button/Button";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Divider/Divider";export*from"./components/Column/Columns";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Tabs/Tabs";export*from"./components/Badge/Badge";export*from"./components/SearchResult/SearchResult";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Combobox/Combobox";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/PictogramButton/PictogramButton";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/ProgressBar/ProgressBar";export*from"./components/Container";export*from"./components/Form/PasswordInput";export*from"./components/RoundButton/RoundButton";export*from"./components/Notification/Notification";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/Callout/Callout";export*from"./components/Patterns/Modal/Modal";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Collapsible/Collapsible";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Pagination/Pagination";export*from"./components/DataTable";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Tooltip/Tooltip";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toggletip/Toggletip";export*from"./components/Popover/Popover";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Sheet/Sheet";export*from"./components/Image/Image";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/QBankRichText/QBankRichText";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/EntityTree";export*from"./components/EntityList";export*from"./components/Form/Select";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Grid/Grid";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Toast";export*from"./components/Form/DateInput/DateInput";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/RadioCard/RadioCard";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/CatalogCard/CatalogCard";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";export*from"./components/PromptInput/PromptInput";export*from"./components/ColorIndicator/ColorIndicator";export*from"./components/ColorPicker/ColorPicker";
@@ -46,8 +46,6 @@ export declare const IconSizesRuntype: Union<[Literal<"s">, Literal<"m">, Litera
46
46
  export type IconSizes = Static<typeof IconSizesRuntype>;
47
47
  declare const CalloutVariationsRuntype: Union<[Literal<"info">, Literal<"success">, Literal<"error">, Literal<"warning">, Literal<"neutral">]>;
48
48
  export type CalloutVariations = Static<typeof CalloutVariationsRuntype>;
49
- declare const ContentBoxVariationsRuntype: Union<[Literal<"info">, Literal<"error">, Literal<"success">, Literal<"warning">, Literal<"neutral">]>;
50
- export type ContentBoxVariations = Static<typeof ContentBoxVariationsRuntype>;
51
49
  declare const LinkVariationsRuntype: Union<[Union<[Literal<"primary">, Literal<"secondary">, Literal<"tertiary">]>]>;
52
50
  export type LinkVariations = Static<typeof LinkVariationsRuntype>;
53
51
  declare const LinkColorsRuntype: Union<[Union<[Union<[Literal<"primary">, Literal<"secondary">, Literal<"tertiary">]>, Literal<"accent">]>]>;
@@ -1 +1 @@
1
- import{Literal,Union}from"runtypes";export const LinkTextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"));export const TextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"));export const InputTextSizeRuntype=Union(Literal("s"),Literal("m"));export const BorderRadiusRuntype=Union(Literal("none"),Literal("xs"),Literal("s"),Literal("m"));export const TextAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"));export const HorizontalAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"),Literal("spaceBetween"));export const VerticalAlignmentRuntype=Union(Literal("top"),Literal("bottom"),Literal("center"),Literal("stretch"));export const StackVerticalAlignmentRuntype=Union(Literal("top"),Literal("bottom"),Literal("center"),Literal("spaceBetween"));export const StackHorizontalAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"),Literal("stretch"));export const SpaceSizesRuntype=Union(Literal("zero"),Literal("xxxs"),Literal("xxs"),Literal("xs"),Literal("s"),Literal("m"),Literal("l"),Literal("xl"),Literal("xxl"));export const ColumsSizesRuntype=Union(Literal(1),Literal(2),Literal(3),Literal(4),Literal(5),Literal(6),Literal(7),Literal(8),Literal(9),Literal(10),Literal(11),Literal(12),Literal("auto"),Literal("narrow"),Literal("fill"));export const ColumnAlignmentRunType=Union(Literal("auto"),Literal("start"),Literal("center"),Literal("end"));export const OrderRuntype=Union(Literal("first"),Literal("last"),Literal("unset"));export const BaseVariationsRuntype=Union(Literal("primary"),Literal("secondary"),Literal("tertiary"));export const BaseColorsRuntype=Union(BaseVariationsRuntype,Literal("accent"));Union(Literal("secondary"),Literal("tertiary"),Literal("quaternary")),Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(Literal("normal"),Literal("bold"),Literal("black"),Literal("inherit")),Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand"),Literal("quaternary")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand"));export const IconSizesRuntype=Union(Literal("s"),Literal("m"),Literal("l"));Union(Literal("info"),Literal("success"),Literal("error"),Literal("warning"),Literal("neutral")),Union(Literal("info"),Literal("error"),Literal("success"),Literal("warning"),Literal("neutral")),Union(BaseVariationsRuntype),Union(BaseColorsRuntype);export const ButtonSizeRuntype=Union(Literal("s"),Literal("m"),Literal("l"));export const HyphensRuntype=Union(Literal("auto"),Literal("none"),Literal("manual"));Union(Literal("normal"),Literal("break-word"));export const ToggleSizeRuntype=Union(Literal("s"),Literal("m"));export const ListSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"));export const MediaItemSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"),Literal("xl"));
1
+ import{Literal,Union}from"runtypes";export const LinkTextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"));export const TextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"));export const InputTextSizeRuntype=Union(Literal("s"),Literal("m"));export const BorderRadiusRuntype=Union(Literal("none"),Literal("xs"),Literal("s"),Literal("m"));export const TextAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"));export const HorizontalAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"),Literal("spaceBetween"));export const VerticalAlignmentRuntype=Union(Literal("top"),Literal("bottom"),Literal("center"),Literal("stretch"));export const StackVerticalAlignmentRuntype=Union(Literal("top"),Literal("bottom"),Literal("center"),Literal("spaceBetween"));export const StackHorizontalAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"),Literal("stretch"));export const SpaceSizesRuntype=Union(Literal("zero"),Literal("xxxs"),Literal("xxs"),Literal("xs"),Literal("s"),Literal("m"),Literal("l"),Literal("xl"),Literal("xxl"));export const ColumsSizesRuntype=Union(Literal(1),Literal(2),Literal(3),Literal(4),Literal(5),Literal(6),Literal(7),Literal(8),Literal(9),Literal(10),Literal(11),Literal(12),Literal("auto"),Literal("narrow"),Literal("fill"));export const ColumnAlignmentRunType=Union(Literal("auto"),Literal("start"),Literal("center"),Literal("end"));export const OrderRuntype=Union(Literal("first"),Literal("last"),Literal("unset"));export const BaseVariationsRuntype=Union(Literal("primary"),Literal("secondary"),Literal("tertiary"));export const BaseColorsRuntype=Union(BaseVariationsRuntype,Literal("accent"));Union(Literal("secondary"),Literal("tertiary"),Literal("quaternary")),Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(Literal("normal"),Literal("bold"),Literal("black"),Literal("inherit")),Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand"),Literal("quaternary")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand"));export const IconSizesRuntype=Union(Literal("s"),Literal("m"),Literal("l"));Union(Literal("info"),Literal("success"),Literal("error"),Literal("warning"),Literal("neutral")),Union(BaseVariationsRuntype),Union(BaseColorsRuntype);export const ButtonSizeRuntype=Union(Literal("s"),Literal("m"),Literal("l"));export const HyphensRuntype=Union(Literal("auto"),Literal("none"),Literal("manual"));Union(Literal("normal"),Literal("break-word"));export const ToggleSizeRuntype=Union(Literal("s"),Literal("m"));export const ListSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"));export const MediaItemSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"),Literal("xl"));
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "3.13.4",
3
+ "version": "3.13.5",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",
@@ -1,13 +0,0 @@
1
- import type { ReactElement } from "react";
2
- import React from "react";
3
- declare const CONTENT_BOX_TYPES: readonly ["merke", "merkspruch", "cave", "clinic-box", "case-link", "dgim-negative", "dgim-positive", "guideline-recommendations"];
4
- type ContentBoxType = (typeof CONTENT_BOX_TYPES)[number];
5
- export type ContentBoxProps = {
6
- type: ContentBoxType;
7
- content: string | ReactElement;
8
- market: "US" | "DE";
9
- "data-e2e-test-id"?: string;
10
- renderTopRightElement?: () => React.ReactNode;
11
- };
12
- export declare function ContentBox({ type, content, market, renderTopRightElement, "data-e2e-test-id": dataE2eTestId, }: ContentBoxProps): React.ReactElement;
13
- export {};
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ContentBox",{enumerable:!0,get:function(){return ContentBox}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../Icon/Icon"),_Box=require("../Box/Box"),_Container=require("../Container"),_Inline=require("../Inline/Inline"),_Text=require("../Typography/Text/Text"),CONTENT_BOX_TYPE_TO_VARIANT={merke:"success",merkspruch:"info",cave:"error","clinic-box":"neutral","case-link":"success","dgim-negative":"error","dgim-positive":"success","guideline-recommendations":"neutral"},TITLE_COLOR_BY_VARIANT={info:"info",warning:"primary",error:"error",success:"success",neutral:"primary"},ICON_COLOR_BY_VARIANT={info:"info",warning:"warning",error:"error",success:"success",neutral:"primary"},CONTENT_BOX_TYPE_TO_ICON={merke:"stethoscope",merkspruch:"bulb",cave:"alert-triangle","clinic-box":"stethoscope","case-link":"link","dgim-negative":"dgim","dgim-positive":"dgim","guideline-recommendations":"compass"},CONTENT_BOX_TYPE_TO_TITLE_US={merke:"Clinical Pearl",merkspruch:"Student Pearl",cave:"Caution","clinic-box":null,"case-link":null,"dgim-negative":null,"dgim-positive":null,"guideline-recommendations":null},CONTENT_BOX_TYPE_TO_TITLE_DE={merke:"Merke",merkspruch:"Merkspruch",cave:"Cave","clinic-box":"Klinik Kasten","case-link":"Fall","dgim-negative":"DGIM Negative Empfehlung","dgim-positive":"DGIM Positive Empfehlung","guideline-recommendations":"Empfehlung"},StyledContainer=(0,_styled.default)("div",{target:"e16mnxib0",label:"StyledContainer"})(({theme,variant})=>{let borderColor="neutral"===variant?theme.values.color.border.primary.default:`${theme.values.color.contentBox.border[`${variant}`]}`;return{overflow:"hidden",border:`1px solid ${borderColor}`,borderRadius:theme.variables.size.borderRadius.xs,lineHeight:theme.variables.size.lineHeight.xs}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgQ29udGFpbmVyIH0gZnJvbSBcIi4uL0NvbnRhaW5lclwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHtcbiAgQ29udGVudEJveFZhcmlhdGlvbnMsXG4gIEljb25zQ29sb3JzLFxuICBUZXh0Q29sb3JzLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRVMgPSBbXG4gIFwibWVya2VcIixcbiAgXCJtZXJrc3BydWNoXCIsXG4gIFwiY2F2ZVwiLFxuICBcImNsaW5pYy1ib3hcIixcbiAgXCJjYXNlLWxpbmtcIixcbiAgXCJkZ2ltLW5lZ2F0aXZlXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIixcbl0gYXMgY29uc3Q7XG5cbnR5cGUgQ29udGVudEJveFR5cGUgPSAodHlwZW9mIENPTlRFTlRfQk9YX1RZUEVTKVtudW1iZXJdO1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1ZBUklBTlQ6IFJlY29yZDxcbiAgQ29udGVudEJveFR5cGUsXG4gIENvbnRlbnRCb3hWYXJpYXRpb25zXG4+ID0ge1xuICBtZXJrZTogXCJzdWNjZXNzXCIsXG4gIG1lcmtzcHJ1Y2g6IFwiaW5mb1wiLFxuICBjYXZlOiBcImVycm9yXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIm5ldXRyYWxcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJzdWNjZXNzXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImVycm9yXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiOiBcInN1Y2Nlc3NcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwibmV1dHJhbFwiLFxufSBhcyBjb25zdDtcblxuY29uc3QgVElUTEVfQ09MT1JfQllfVkFSSUFOVDogUmVjb3JkPENvbnRlbnRCb3hWYXJpYXRpb25zLCBUZXh0Q29sb3JzPiA9IHtcbiAgaW5mbzogXCJpbmZvXCIsXG4gIHdhcm5pbmc6IFwicHJpbWFyeVwiLFxuICBlcnJvcjogXCJlcnJvclwiLFxuICBzdWNjZXNzOiBcInN1Y2Nlc3NcIixcbiAgbmV1dHJhbDogXCJwcmltYXJ5XCIsXG59O1xuXG5jb25zdCBJQ09OX0NPTE9SX0JZX1ZBUklBTlQ6IFJlY29yZDxDb250ZW50Qm94VmFyaWF0aW9ucywgSWNvbnNDb2xvcnM+ID0ge1xuICBpbmZvOiBcImluZm9cIixcbiAgd2FybmluZzogXCJ3YXJuaW5nXCIsXG4gIGVycm9yOiBcImVycm9yXCIsXG4gIHN1Y2Nlc3M6IFwic3VjY2Vzc1wiLFxuICBuZXV0cmFsOiBcInByaW1hcnlcIixcbn07XG5cbmNvbnN0IENPTlRFTlRfQk9YX1RZUEVfVE9fSUNPTjogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBJY29uUHJvcHNbXCJuYW1lXCJdPiA9IHtcbiAgbWVya2U6IFwic3RldGhvc2NvcGVcIixcbiAgbWVya3NwcnVjaDogXCJidWxiXCIsXG4gIGNhdmU6IFwiYWxlcnQtdHJpYW5nbGVcIixcbiAgXCJjbGluaWMtYm94XCI6IFwic3RldGhvc2NvcGVcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJsaW5rXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImRnaW1cIixcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IFwiZGdpbVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIjogXCJjb21wYXNzXCIsXG59IGFzIGNvbnN0O1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1RJVExFX1VTOiBSZWNvcmQ8Q29udGVudEJveFR5cGUsIHN0cmluZyB8IG51bGw+ID0ge1xuICBtZXJrZTogXCJDbGluaWNhbCBQZWFybFwiLFxuICBtZXJrc3BydWNoOiBcIlN0dWRlbnQgUGVhcmxcIixcbiAgY2F2ZTogXCJDYXV0aW9uXCIsXG4gIFwiY2xpbmljLWJveFwiOiBudWxsLFxuICBcImNhc2UtbGlua1wiOiBudWxsLFxuICBcImRnaW0tbmVnYXRpdmVcIjogbnVsbCxcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IG51bGwsXG4gIFwiZ3VpZGVsaW5lLXJlY29tbWVuZGF0aW9uc1wiOiBudWxsLFxufTtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9ERTogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBzdHJpbmc+ID0ge1xuICBtZXJrZTogXCJNZXJrZVwiLFxuICBtZXJrc3BydWNoOiBcIk1lcmtzcHJ1Y2hcIixcbiAgY2F2ZTogXCJDYXZlXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIktsaW5payBLYXN0ZW5cIixcbiAgXCJjYXNlLWxpbmtcIjogXCJGYWxsXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcIkRHSU0gTmVnYXRpdmUgRW1wZmVobHVuZ1wiLFxuICBcImRnaW0tcG9zaXRpdmVcIjogXCJER0lNIFBvc2l0aXZlIEVtcGZlaGx1bmdcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwiRW1wZmVobHVuZ1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29udGVudEJveFByb3BzID0ge1xuICB0eXBlOiBDb250ZW50Qm94VHlwZTtcbiAgY29udGVudDogc3RyaW5nIHwgUmVhY3RFbGVtZW50O1xuICBtYXJrZXQ6IFwiVVNcIiB8IFwiREVcIjtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIHJlbmRlclRvcFJpZ2h0RWxlbWVudD86ICgpID0+IFJlYWN0LlJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB2YXJpYW50OiBDb250ZW50Qm94VmFyaWF0aW9ucyB9PihcbiAgKHsgdGhlbWUsIHZhcmlhbnQgfSkgPT4ge1xuICAgIGNvbnN0IGJvcmRlckNvbG9yID1cbiAgICAgIHZhcmlhbnQgPT09IFwibmV1dHJhbFwiXG4gICAgICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRlZmF1bHRcbiAgICAgICAgOiBgJHt0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudEJveC5ib3JkZXJbYCR7dmFyaWFudH1gXX1gO1xuICAgIHJldHVybiB7XG4gICAgICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgICAgIGJvcmRlcjogYDFweCBzb2xpZCAke2JvcmRlckNvbG9yfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsIC8vIFRPRE86IGNvdWxkIGJlIGRlbGV0ZWQgb25jZSBsaW5lLWhlaWdodCBmcm9tIHVpLWFtYm9zcyBiYXNlIHN0eWxlcyBpcyByZW1vdmVkXG4gICAgfTtcbiAgfVxuKTtcblxuY29uc3QgU3R5bGVkSGVhZGVyID0gc3R5bGVkLmRpdjx7IHZhcmlhbnQ6IENvbnRlbnRCb3hWYXJpYXRpb25zIH0+KFxuICAoeyB0aGVtZSwgdmFyaWFudCB9KSA9PiAoe1xuICAgIHBhZGRpbmc6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgYmFja2dyb3VuZENvbG9yOlxuICAgICAgdmFyaWFudCA9PT0gXCJuZXV0cmFsXCJcbiAgICAgICAgPyB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuZGVmYXVsdFxuICAgICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kW2Ake3ZhcmlhbnR9U3VidGxlYF0uZGVmYXVsdCxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBoZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbn0pKTtcblxuY29uc3QgU3R5bGVkRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICBtYXJnaW5Ub3A6IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfWAsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBDb250ZW50Qm94KHtcbiAgdHlwZSxcbiAgY29udGVudCxcbiAgbWFya2V0LFxuICByZW5kZXJUb3BSaWdodEVsZW1lbnQsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogQ29udGVudEJveFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdmFyaWFudCA9IENPTlRFTlRfQk9YX1RZUEVfVE9fVkFSSUFOVFt0eXBlXTtcbiAgY29uc3QgaWNvbk5hbWUgPSBDT05URU5UX0JPWF9UWVBFX1RPX0lDT05bdHlwZV07XG4gIGNvbnN0IGljb25Db2xvciA9IElDT05fQ09MT1JfQllfVkFSSUFOVFt2YXJpYW50XTtcbiAgY29uc3QgdGl0bGUgPVxuICAgIG1hcmtldCA9PT0gXCJERVwiXG4gICAgICA/IENPTlRFTlRfQk9YX1RZUEVfVE9fVElUTEVfREVbdHlwZV1cbiAgICAgIDogQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9VU1t0eXBlXTtcbiAgY29uc3QgdGl0bGVDb2xvciA9IFRJVExFX0NPTE9SX0JZX1ZBUklBTlRbdmFyaWFudF07XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD1cIkNvbnRlbnRCb3hcIlxuICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgIHJvbGU9XCJhbGVydFwiXG4gICAgPlxuICAgICAgPFN0eWxlZEhlYWRlciB2YXJpYW50PXt2YXJpYW50fT5cbiAgICAgICAgPElubGluZSBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgdkFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgc3BhY2U9XCJ4c1wiIG5vV3JhcD5cbiAgICAgICAgICAgIDxTdHlsZWRJY29uV3JhcHBlcj5cbiAgICAgICAgICAgICAgPEljb25cbiAgICAgICAgICAgICAgICBuYW1lPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgICBjb2xvcj17aWNvbkNvbG9yfVxuICAgICAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgICAgICByb2xlPVwiaW1nXCJcbiAgICAgICAgICAgICAgICBhcmlhLWxhYmVsPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvU3R5bGVkSWNvbldyYXBwZXI+XG4gICAgICAgICAgICA8VGV4dCB3ZWlnaHQ9XCJib2xkXCIgc2l6ZT1cIm1cIiBjb2xvcj17dGl0bGVDb2xvcn0+XG4gICAgICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICA8U3R5bGVkRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgICB7cmVuZGVyVG9wUmlnaHRFbGVtZW50Py4oKX1cbiAgICAgICAgICA8L1N0eWxlZEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICA8L0lubGluZT5cbiAgICAgIDwvU3R5bGVkSGVhZGVyPlxuICAgICAgPENvbnRhaW5lciBlbGV2YXRpb249ezB9IHNxdWFyZUNvcm5lcnM+XG4gICAgICAgIDxCb3ggc3BhY2U9XCJzXCIgdlNwYWNlPVwieHNcIj5cbiAgICAgICAgICA8VGV4dCBhcz1cInNwYW5cIiBzaXplPVwic1wiPlxuICAgICAgICAgICAge2NvbnRlbnR9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Hd0IifQ== */"),StyledHeader=(0,_styled.default)("div",{target:"e16mnxib1",label:"StyledHeader"})(({theme,variant})=>({padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,backgroundColor:"neutral"===variant?theme.values.color.background.secondary.default:theme.values.color.background[`${variant}Subtle`].default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgQ29udGFpbmVyIH0gZnJvbSBcIi4uL0NvbnRhaW5lclwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHtcbiAgQ29udGVudEJveFZhcmlhdGlvbnMsXG4gIEljb25zQ29sb3JzLFxuICBUZXh0Q29sb3JzLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRVMgPSBbXG4gIFwibWVya2VcIixcbiAgXCJtZXJrc3BydWNoXCIsXG4gIFwiY2F2ZVwiLFxuICBcImNsaW5pYy1ib3hcIixcbiAgXCJjYXNlLWxpbmtcIixcbiAgXCJkZ2ltLW5lZ2F0aXZlXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIixcbl0gYXMgY29uc3Q7XG5cbnR5cGUgQ29udGVudEJveFR5cGUgPSAodHlwZW9mIENPTlRFTlRfQk9YX1RZUEVTKVtudW1iZXJdO1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1ZBUklBTlQ6IFJlY29yZDxcbiAgQ29udGVudEJveFR5cGUsXG4gIENvbnRlbnRCb3hWYXJpYXRpb25zXG4+ID0ge1xuICBtZXJrZTogXCJzdWNjZXNzXCIsXG4gIG1lcmtzcHJ1Y2g6IFwiaW5mb1wiLFxuICBjYXZlOiBcImVycm9yXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIm5ldXRyYWxcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJzdWNjZXNzXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImVycm9yXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiOiBcInN1Y2Nlc3NcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwibmV1dHJhbFwiLFxufSBhcyBjb25zdDtcblxuY29uc3QgVElUTEVfQ09MT1JfQllfVkFSSUFOVDogUmVjb3JkPENvbnRlbnRCb3hWYXJpYXRpb25zLCBUZXh0Q29sb3JzPiA9IHtcbiAgaW5mbzogXCJpbmZvXCIsXG4gIHdhcm5pbmc6IFwicHJpbWFyeVwiLFxuICBlcnJvcjogXCJlcnJvclwiLFxuICBzdWNjZXNzOiBcInN1Y2Nlc3NcIixcbiAgbmV1dHJhbDogXCJwcmltYXJ5XCIsXG59O1xuXG5jb25zdCBJQ09OX0NPTE9SX0JZX1ZBUklBTlQ6IFJlY29yZDxDb250ZW50Qm94VmFyaWF0aW9ucywgSWNvbnNDb2xvcnM+ID0ge1xuICBpbmZvOiBcImluZm9cIixcbiAgd2FybmluZzogXCJ3YXJuaW5nXCIsXG4gIGVycm9yOiBcImVycm9yXCIsXG4gIHN1Y2Nlc3M6IFwic3VjY2Vzc1wiLFxuICBuZXV0cmFsOiBcInByaW1hcnlcIixcbn07XG5cbmNvbnN0IENPTlRFTlRfQk9YX1RZUEVfVE9fSUNPTjogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBJY29uUHJvcHNbXCJuYW1lXCJdPiA9IHtcbiAgbWVya2U6IFwic3RldGhvc2NvcGVcIixcbiAgbWVya3NwcnVjaDogXCJidWxiXCIsXG4gIGNhdmU6IFwiYWxlcnQtdHJpYW5nbGVcIixcbiAgXCJjbGluaWMtYm94XCI6IFwic3RldGhvc2NvcGVcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJsaW5rXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImRnaW1cIixcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IFwiZGdpbVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIjogXCJjb21wYXNzXCIsXG59IGFzIGNvbnN0O1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1RJVExFX1VTOiBSZWNvcmQ8Q29udGVudEJveFR5cGUsIHN0cmluZyB8IG51bGw+ID0ge1xuICBtZXJrZTogXCJDbGluaWNhbCBQZWFybFwiLFxuICBtZXJrc3BydWNoOiBcIlN0dWRlbnQgUGVhcmxcIixcbiAgY2F2ZTogXCJDYXV0aW9uXCIsXG4gIFwiY2xpbmljLWJveFwiOiBudWxsLFxuICBcImNhc2UtbGlua1wiOiBudWxsLFxuICBcImRnaW0tbmVnYXRpdmVcIjogbnVsbCxcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IG51bGwsXG4gIFwiZ3VpZGVsaW5lLXJlY29tbWVuZGF0aW9uc1wiOiBudWxsLFxufTtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9ERTogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBzdHJpbmc+ID0ge1xuICBtZXJrZTogXCJNZXJrZVwiLFxuICBtZXJrc3BydWNoOiBcIk1lcmtzcHJ1Y2hcIixcbiAgY2F2ZTogXCJDYXZlXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIktsaW5payBLYXN0ZW5cIixcbiAgXCJjYXNlLWxpbmtcIjogXCJGYWxsXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcIkRHSU0gTmVnYXRpdmUgRW1wZmVobHVuZ1wiLFxuICBcImRnaW0tcG9zaXRpdmVcIjogXCJER0lNIFBvc2l0aXZlIEVtcGZlaGx1bmdcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwiRW1wZmVobHVuZ1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29udGVudEJveFByb3BzID0ge1xuICB0eXBlOiBDb250ZW50Qm94VHlwZTtcbiAgY29udGVudDogc3RyaW5nIHwgUmVhY3RFbGVtZW50O1xuICBtYXJrZXQ6IFwiVVNcIiB8IFwiREVcIjtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIHJlbmRlclRvcFJpZ2h0RWxlbWVudD86ICgpID0+IFJlYWN0LlJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB2YXJpYW50OiBDb250ZW50Qm94VmFyaWF0aW9ucyB9PihcbiAgKHsgdGhlbWUsIHZhcmlhbnQgfSkgPT4ge1xuICAgIGNvbnN0IGJvcmRlckNvbG9yID1cbiAgICAgIHZhcmlhbnQgPT09IFwibmV1dHJhbFwiXG4gICAgICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRlZmF1bHRcbiAgICAgICAgOiBgJHt0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudEJveC5ib3JkZXJbYCR7dmFyaWFudH1gXX1gO1xuICAgIHJldHVybiB7XG4gICAgICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgICAgIGJvcmRlcjogYDFweCBzb2xpZCAke2JvcmRlckNvbG9yfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsIC8vIFRPRE86IGNvdWxkIGJlIGRlbGV0ZWQgb25jZSBsaW5lLWhlaWdodCBmcm9tIHVpLWFtYm9zcyBiYXNlIHN0eWxlcyBpcyByZW1vdmVkXG4gICAgfTtcbiAgfVxuKTtcblxuY29uc3QgU3R5bGVkSGVhZGVyID0gc3R5bGVkLmRpdjx7IHZhcmlhbnQ6IENvbnRlbnRCb3hWYXJpYXRpb25zIH0+KFxuICAoeyB0aGVtZSwgdmFyaWFudCB9KSA9PiAoe1xuICAgIHBhZGRpbmc6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgYmFja2dyb3VuZENvbG9yOlxuICAgICAgdmFyaWFudCA9PT0gXCJuZXV0cmFsXCJcbiAgICAgICAgPyB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuZGVmYXVsdFxuICAgICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kW2Ake3ZhcmlhbnR9U3VidGxlYF0uZGVmYXVsdCxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBoZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbn0pKTtcblxuY29uc3QgU3R5bGVkRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICBtYXJnaW5Ub3A6IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfWAsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBDb250ZW50Qm94KHtcbiAgdHlwZSxcbiAgY29udGVudCxcbiAgbWFya2V0LFxuICByZW5kZXJUb3BSaWdodEVsZW1lbnQsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogQ29udGVudEJveFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdmFyaWFudCA9IENPTlRFTlRfQk9YX1RZUEVfVE9fVkFSSUFOVFt0eXBlXTtcbiAgY29uc3QgaWNvbk5hbWUgPSBDT05URU5UX0JPWF9UWVBFX1RPX0lDT05bdHlwZV07XG4gIGNvbnN0IGljb25Db2xvciA9IElDT05fQ09MT1JfQllfVkFSSUFOVFt2YXJpYW50XTtcbiAgY29uc3QgdGl0bGUgPVxuICAgIG1hcmtldCA9PT0gXCJERVwiXG4gICAgICA/IENPTlRFTlRfQk9YX1RZUEVfVE9fVElUTEVfREVbdHlwZV1cbiAgICAgIDogQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9VU1t0eXBlXTtcbiAgY29uc3QgdGl0bGVDb2xvciA9IFRJVExFX0NPTE9SX0JZX1ZBUklBTlRbdmFyaWFudF07XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD1cIkNvbnRlbnRCb3hcIlxuICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgIHJvbGU9XCJhbGVydFwiXG4gICAgPlxuICAgICAgPFN0eWxlZEhlYWRlciB2YXJpYW50PXt2YXJpYW50fT5cbiAgICAgICAgPElubGluZSBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgdkFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgc3BhY2U9XCJ4c1wiIG5vV3JhcD5cbiAgICAgICAgICAgIDxTdHlsZWRJY29uV3JhcHBlcj5cbiAgICAgICAgICAgICAgPEljb25cbiAgICAgICAgICAgICAgICBuYW1lPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgICBjb2xvcj17aWNvbkNvbG9yfVxuICAgICAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgICAgICByb2xlPVwiaW1nXCJcbiAgICAgICAgICAgICAgICBhcmlhLWxhYmVsPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvU3R5bGVkSWNvbldyYXBwZXI+XG4gICAgICAgICAgICA8VGV4dCB3ZWlnaHQ9XCJib2xkXCIgc2l6ZT1cIm1cIiBjb2xvcj17dGl0bGVDb2xvcn0+XG4gICAgICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICA8U3R5bGVkRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgICB7cmVuZGVyVG9wUmlnaHRFbGVtZW50Py4oKX1cbiAgICAgICAgICA8L1N0eWxlZEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICA8L0lubGluZT5cbiAgICAgIDwvU3R5bGVkSGVhZGVyPlxuICAgICAgPENvbnRhaW5lciBlbGV2YXRpb249ezB9IHNxdWFyZUNvcm5lcnM+XG4gICAgICAgIDxCb3ggc3BhY2U9XCJzXCIgdlNwYWNlPVwieHNcIj5cbiAgICAgICAgICA8VGV4dCBhcz1cInNwYW5cIiBzaXplPVwic1wiPlxuICAgICAgICAgICAge2NvbnRlbnR9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtIcUIifQ== */"),StyledIconWrapper=(0,_styled.default)("div",{target:"e16mnxib2",label:"StyledIconWrapper"})(({theme})=>({height:theme.variables.size.spacing.m}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgQ29udGFpbmVyIH0gZnJvbSBcIi4uL0NvbnRhaW5lclwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHtcbiAgQ29udGVudEJveFZhcmlhdGlvbnMsXG4gIEljb25zQ29sb3JzLFxuICBUZXh0Q29sb3JzLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRVMgPSBbXG4gIFwibWVya2VcIixcbiAgXCJtZXJrc3BydWNoXCIsXG4gIFwiY2F2ZVwiLFxuICBcImNsaW5pYy1ib3hcIixcbiAgXCJjYXNlLWxpbmtcIixcbiAgXCJkZ2ltLW5lZ2F0aXZlXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIixcbl0gYXMgY29uc3Q7XG5cbnR5cGUgQ29udGVudEJveFR5cGUgPSAodHlwZW9mIENPTlRFTlRfQk9YX1RZUEVTKVtudW1iZXJdO1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1ZBUklBTlQ6IFJlY29yZDxcbiAgQ29udGVudEJveFR5cGUsXG4gIENvbnRlbnRCb3hWYXJpYXRpb25zXG4+ID0ge1xuICBtZXJrZTogXCJzdWNjZXNzXCIsXG4gIG1lcmtzcHJ1Y2g6IFwiaW5mb1wiLFxuICBjYXZlOiBcImVycm9yXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIm5ldXRyYWxcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJzdWNjZXNzXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImVycm9yXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiOiBcInN1Y2Nlc3NcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwibmV1dHJhbFwiLFxufSBhcyBjb25zdDtcblxuY29uc3QgVElUTEVfQ09MT1JfQllfVkFSSUFOVDogUmVjb3JkPENvbnRlbnRCb3hWYXJpYXRpb25zLCBUZXh0Q29sb3JzPiA9IHtcbiAgaW5mbzogXCJpbmZvXCIsXG4gIHdhcm5pbmc6IFwicHJpbWFyeVwiLFxuICBlcnJvcjogXCJlcnJvclwiLFxuICBzdWNjZXNzOiBcInN1Y2Nlc3NcIixcbiAgbmV1dHJhbDogXCJwcmltYXJ5XCIsXG59O1xuXG5jb25zdCBJQ09OX0NPTE9SX0JZX1ZBUklBTlQ6IFJlY29yZDxDb250ZW50Qm94VmFyaWF0aW9ucywgSWNvbnNDb2xvcnM+ID0ge1xuICBpbmZvOiBcImluZm9cIixcbiAgd2FybmluZzogXCJ3YXJuaW5nXCIsXG4gIGVycm9yOiBcImVycm9yXCIsXG4gIHN1Y2Nlc3M6IFwic3VjY2Vzc1wiLFxuICBuZXV0cmFsOiBcInByaW1hcnlcIixcbn07XG5cbmNvbnN0IENPTlRFTlRfQk9YX1RZUEVfVE9fSUNPTjogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBJY29uUHJvcHNbXCJuYW1lXCJdPiA9IHtcbiAgbWVya2U6IFwic3RldGhvc2NvcGVcIixcbiAgbWVya3NwcnVjaDogXCJidWxiXCIsXG4gIGNhdmU6IFwiYWxlcnQtdHJpYW5nbGVcIixcbiAgXCJjbGluaWMtYm94XCI6IFwic3RldGhvc2NvcGVcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJsaW5rXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImRnaW1cIixcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IFwiZGdpbVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIjogXCJjb21wYXNzXCIsXG59IGFzIGNvbnN0O1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1RJVExFX1VTOiBSZWNvcmQ8Q29udGVudEJveFR5cGUsIHN0cmluZyB8IG51bGw+ID0ge1xuICBtZXJrZTogXCJDbGluaWNhbCBQZWFybFwiLFxuICBtZXJrc3BydWNoOiBcIlN0dWRlbnQgUGVhcmxcIixcbiAgY2F2ZTogXCJDYXV0aW9uXCIsXG4gIFwiY2xpbmljLWJveFwiOiBudWxsLFxuICBcImNhc2UtbGlua1wiOiBudWxsLFxuICBcImRnaW0tbmVnYXRpdmVcIjogbnVsbCxcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IG51bGwsXG4gIFwiZ3VpZGVsaW5lLXJlY29tbWVuZGF0aW9uc1wiOiBudWxsLFxufTtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9ERTogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBzdHJpbmc+ID0ge1xuICBtZXJrZTogXCJNZXJrZVwiLFxuICBtZXJrc3BydWNoOiBcIk1lcmtzcHJ1Y2hcIixcbiAgY2F2ZTogXCJDYXZlXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIktsaW5payBLYXN0ZW5cIixcbiAgXCJjYXNlLWxpbmtcIjogXCJGYWxsXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcIkRHSU0gTmVnYXRpdmUgRW1wZmVobHVuZ1wiLFxuICBcImRnaW0tcG9zaXRpdmVcIjogXCJER0lNIFBvc2l0aXZlIEVtcGZlaGx1bmdcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwiRW1wZmVobHVuZ1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29udGVudEJveFByb3BzID0ge1xuICB0eXBlOiBDb250ZW50Qm94VHlwZTtcbiAgY29udGVudDogc3RyaW5nIHwgUmVhY3RFbGVtZW50O1xuICBtYXJrZXQ6IFwiVVNcIiB8IFwiREVcIjtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIHJlbmRlclRvcFJpZ2h0RWxlbWVudD86ICgpID0+IFJlYWN0LlJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB2YXJpYW50OiBDb250ZW50Qm94VmFyaWF0aW9ucyB9PihcbiAgKHsgdGhlbWUsIHZhcmlhbnQgfSkgPT4ge1xuICAgIGNvbnN0IGJvcmRlckNvbG9yID1cbiAgICAgIHZhcmlhbnQgPT09IFwibmV1dHJhbFwiXG4gICAgICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRlZmF1bHRcbiAgICAgICAgOiBgJHt0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudEJveC5ib3JkZXJbYCR7dmFyaWFudH1gXX1gO1xuICAgIHJldHVybiB7XG4gICAgICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgICAgIGJvcmRlcjogYDFweCBzb2xpZCAke2JvcmRlckNvbG9yfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsIC8vIFRPRE86IGNvdWxkIGJlIGRlbGV0ZWQgb25jZSBsaW5lLWhlaWdodCBmcm9tIHVpLWFtYm9zcyBiYXNlIHN0eWxlcyBpcyByZW1vdmVkXG4gICAgfTtcbiAgfVxuKTtcblxuY29uc3QgU3R5bGVkSGVhZGVyID0gc3R5bGVkLmRpdjx7IHZhcmlhbnQ6IENvbnRlbnRCb3hWYXJpYXRpb25zIH0+KFxuICAoeyB0aGVtZSwgdmFyaWFudCB9KSA9PiAoe1xuICAgIHBhZGRpbmc6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgYmFja2dyb3VuZENvbG9yOlxuICAgICAgdmFyaWFudCA9PT0gXCJuZXV0cmFsXCJcbiAgICAgICAgPyB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuZGVmYXVsdFxuICAgICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kW2Ake3ZhcmlhbnR9U3VidGxlYF0uZGVmYXVsdCxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBoZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbn0pKTtcblxuY29uc3QgU3R5bGVkRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICBtYXJnaW5Ub3A6IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfWAsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBDb250ZW50Qm94KHtcbiAgdHlwZSxcbiAgY29udGVudCxcbiAgbWFya2V0LFxuICByZW5kZXJUb3BSaWdodEVsZW1lbnQsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogQ29udGVudEJveFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdmFyaWFudCA9IENPTlRFTlRfQk9YX1RZUEVfVE9fVkFSSUFOVFt0eXBlXTtcbiAgY29uc3QgaWNvbk5hbWUgPSBDT05URU5UX0JPWF9UWVBFX1RPX0lDT05bdHlwZV07XG4gIGNvbnN0IGljb25Db2xvciA9IElDT05fQ09MT1JfQllfVkFSSUFOVFt2YXJpYW50XTtcbiAgY29uc3QgdGl0bGUgPVxuICAgIG1hcmtldCA9PT0gXCJERVwiXG4gICAgICA/IENPTlRFTlRfQk9YX1RZUEVfVE9fVElUTEVfREVbdHlwZV1cbiAgICAgIDogQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9VU1t0eXBlXTtcbiAgY29uc3QgdGl0bGVDb2xvciA9IFRJVExFX0NPTE9SX0JZX1ZBUklBTlRbdmFyaWFudF07XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD1cIkNvbnRlbnRCb3hcIlxuICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgIHJvbGU9XCJhbGVydFwiXG4gICAgPlxuICAgICAgPFN0eWxlZEhlYWRlciB2YXJpYW50PXt2YXJpYW50fT5cbiAgICAgICAgPElubGluZSBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgdkFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgc3BhY2U9XCJ4c1wiIG5vV3JhcD5cbiAgICAgICAgICAgIDxTdHlsZWRJY29uV3JhcHBlcj5cbiAgICAgICAgICAgICAgPEljb25cbiAgICAgICAgICAgICAgICBuYW1lPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgICBjb2xvcj17aWNvbkNvbG9yfVxuICAgICAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgICAgICByb2xlPVwiaW1nXCJcbiAgICAgICAgICAgICAgICBhcmlhLWxhYmVsPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvU3R5bGVkSWNvbldyYXBwZXI+XG4gICAgICAgICAgICA8VGV4dCB3ZWlnaHQ9XCJib2xkXCIgc2l6ZT1cIm1cIiBjb2xvcj17dGl0bGVDb2xvcn0+XG4gICAgICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICA8U3R5bGVkRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgICB7cmVuZGVyVG9wUmlnaHRFbGVtZW50Py4oKX1cbiAgICAgICAgICA8L1N0eWxlZEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICA8L0lubGluZT5cbiAgICAgIDwvU3R5bGVkSGVhZGVyPlxuICAgICAgPENvbnRhaW5lciBlbGV2YXRpb249ezB9IHNxdWFyZUNvcm5lcnM+XG4gICAgICAgIDxCb3ggc3BhY2U9XCJzXCIgdlNwYWNlPVwieHNcIj5cbiAgICAgICAgICA8VGV4dCBhcz1cInNwYW5cIiBzaXplPVwic1wiPlxuICAgICAgICAgICAge2NvbnRlbnR9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRIMEIifQ== */"),StyledElementWrapper=(0,_styled.default)("div",{target:"e16mnxib3",label:"StyledElementWrapper"})(({theme})=>({height:theme.variables.size.spacing.m,marginTop:`-${theme.variables.size.spacing.xs}`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudEJveC9Db250ZW50Qm94LnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IEljb25Qcm9wcyB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBCb3ggfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHsgQ29udGFpbmVyIH0gZnJvbSBcIi4uL0NvbnRhaW5lclwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0L1RleHRcIjtcbmltcG9ydCB0eXBlIHtcbiAgQ29udGVudEJveFZhcmlhdGlvbnMsXG4gIEljb25zQ29sb3JzLFxuICBUZXh0Q29sb3JzLFxufSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRVMgPSBbXG4gIFwibWVya2VcIixcbiAgXCJtZXJrc3BydWNoXCIsXG4gIFwiY2F2ZVwiLFxuICBcImNsaW5pYy1ib3hcIixcbiAgXCJjYXNlLWxpbmtcIixcbiAgXCJkZ2ltLW5lZ2F0aXZlXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIixcbl0gYXMgY29uc3Q7XG5cbnR5cGUgQ29udGVudEJveFR5cGUgPSAodHlwZW9mIENPTlRFTlRfQk9YX1RZUEVTKVtudW1iZXJdO1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1ZBUklBTlQ6IFJlY29yZDxcbiAgQ29udGVudEJveFR5cGUsXG4gIENvbnRlbnRCb3hWYXJpYXRpb25zXG4+ID0ge1xuICBtZXJrZTogXCJzdWNjZXNzXCIsXG4gIG1lcmtzcHJ1Y2g6IFwiaW5mb1wiLFxuICBjYXZlOiBcImVycm9yXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIm5ldXRyYWxcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJzdWNjZXNzXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImVycm9yXCIsXG4gIFwiZGdpbS1wb3NpdGl2ZVwiOiBcInN1Y2Nlc3NcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwibmV1dHJhbFwiLFxufSBhcyBjb25zdDtcblxuY29uc3QgVElUTEVfQ09MT1JfQllfVkFSSUFOVDogUmVjb3JkPENvbnRlbnRCb3hWYXJpYXRpb25zLCBUZXh0Q29sb3JzPiA9IHtcbiAgaW5mbzogXCJpbmZvXCIsXG4gIHdhcm5pbmc6IFwicHJpbWFyeVwiLFxuICBlcnJvcjogXCJlcnJvclwiLFxuICBzdWNjZXNzOiBcInN1Y2Nlc3NcIixcbiAgbmV1dHJhbDogXCJwcmltYXJ5XCIsXG59O1xuXG5jb25zdCBJQ09OX0NPTE9SX0JZX1ZBUklBTlQ6IFJlY29yZDxDb250ZW50Qm94VmFyaWF0aW9ucywgSWNvbnNDb2xvcnM+ID0ge1xuICBpbmZvOiBcImluZm9cIixcbiAgd2FybmluZzogXCJ3YXJuaW5nXCIsXG4gIGVycm9yOiBcImVycm9yXCIsXG4gIHN1Y2Nlc3M6IFwic3VjY2Vzc1wiLFxuICBuZXV0cmFsOiBcInByaW1hcnlcIixcbn07XG5cbmNvbnN0IENPTlRFTlRfQk9YX1RZUEVfVE9fSUNPTjogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBJY29uUHJvcHNbXCJuYW1lXCJdPiA9IHtcbiAgbWVya2U6IFwic3RldGhvc2NvcGVcIixcbiAgbWVya3NwcnVjaDogXCJidWxiXCIsXG4gIGNhdmU6IFwiYWxlcnQtdHJpYW5nbGVcIixcbiAgXCJjbGluaWMtYm94XCI6IFwic3RldGhvc2NvcGVcIixcbiAgXCJjYXNlLWxpbmtcIjogXCJsaW5rXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcImRnaW1cIixcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IFwiZGdpbVwiLFxuICBcImd1aWRlbGluZS1yZWNvbW1lbmRhdGlvbnNcIjogXCJjb21wYXNzXCIsXG59IGFzIGNvbnN0O1xuXG5jb25zdCBDT05URU5UX0JPWF9UWVBFX1RPX1RJVExFX1VTOiBSZWNvcmQ8Q29udGVudEJveFR5cGUsIHN0cmluZyB8IG51bGw+ID0ge1xuICBtZXJrZTogXCJDbGluaWNhbCBQZWFybFwiLFxuICBtZXJrc3BydWNoOiBcIlN0dWRlbnQgUGVhcmxcIixcbiAgY2F2ZTogXCJDYXV0aW9uXCIsXG4gIFwiY2xpbmljLWJveFwiOiBudWxsLFxuICBcImNhc2UtbGlua1wiOiBudWxsLFxuICBcImRnaW0tbmVnYXRpdmVcIjogbnVsbCxcbiAgXCJkZ2ltLXBvc2l0aXZlXCI6IG51bGwsXG4gIFwiZ3VpZGVsaW5lLXJlY29tbWVuZGF0aW9uc1wiOiBudWxsLFxufTtcblxuY29uc3QgQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9ERTogUmVjb3JkPENvbnRlbnRCb3hUeXBlLCBzdHJpbmc+ID0ge1xuICBtZXJrZTogXCJNZXJrZVwiLFxuICBtZXJrc3BydWNoOiBcIk1lcmtzcHJ1Y2hcIixcbiAgY2F2ZTogXCJDYXZlXCIsXG4gIFwiY2xpbmljLWJveFwiOiBcIktsaW5payBLYXN0ZW5cIixcbiAgXCJjYXNlLWxpbmtcIjogXCJGYWxsXCIsXG4gIFwiZGdpbS1uZWdhdGl2ZVwiOiBcIkRHSU0gTmVnYXRpdmUgRW1wZmVobHVuZ1wiLFxuICBcImRnaW0tcG9zaXRpdmVcIjogXCJER0lNIFBvc2l0aXZlIEVtcGZlaGx1bmdcIixcbiAgXCJndWlkZWxpbmUtcmVjb21tZW5kYXRpb25zXCI6IFwiRW1wZmVobHVuZ1wiLFxufTtcblxuZXhwb3J0IHR5cGUgQ29udGVudEJveFByb3BzID0ge1xuICB0eXBlOiBDb250ZW50Qm94VHlwZTtcbiAgY29udGVudDogc3RyaW5nIHwgUmVhY3RFbGVtZW50O1xuICBtYXJrZXQ6IFwiVVNcIiB8IFwiREVcIjtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIHJlbmRlclRvcFJpZ2h0RWxlbWVudD86ICgpID0+IFJlYWN0LlJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyB2YXJpYW50OiBDb250ZW50Qm94VmFyaWF0aW9ucyB9PihcbiAgKHsgdGhlbWUsIHZhcmlhbnQgfSkgPT4ge1xuICAgIGNvbnN0IGJvcmRlckNvbG9yID1cbiAgICAgIHZhcmlhbnQgPT09IFwibmV1dHJhbFwiXG4gICAgICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5wcmltYXJ5LmRlZmF1bHRcbiAgICAgICAgOiBgJHt0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudEJveC5ib3JkZXJbYCR7dmFyaWFudH1gXX1gO1xuICAgIHJldHVybiB7XG4gICAgICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgICAgIGJvcmRlcjogYDFweCBzb2xpZCAke2JvcmRlckNvbG9yfWAsXG4gICAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54cyxcbiAgICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsIC8vIFRPRE86IGNvdWxkIGJlIGRlbGV0ZWQgb25jZSBsaW5lLWhlaWdodCBmcm9tIHVpLWFtYm9zcyBiYXNlIHN0eWxlcyBpcyByZW1vdmVkXG4gICAgfTtcbiAgfVxuKTtcblxuY29uc3QgU3R5bGVkSGVhZGVyID0gc3R5bGVkLmRpdjx7IHZhcmlhbnQ6IENvbnRlbnRCb3hWYXJpYXRpb25zIH0+KFxuICAoeyB0aGVtZSwgdmFyaWFudCB9KSA9PiAoe1xuICAgIHBhZGRpbmc6IGAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHN9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgYmFja2dyb3VuZENvbG9yOlxuICAgICAgdmFyaWFudCA9PT0gXCJuZXV0cmFsXCJcbiAgICAgICAgPyB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuZGVmYXVsdFxuICAgICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kW2Ake3ZhcmlhbnR9U3VidGxlYF0uZGVmYXVsdCxcbiAgfSlcbik7XG5cbmNvbnN0IFN0eWxlZEljb25XcmFwcGVyID0gc3R5bGVkLmRpdigoeyB0aGVtZSB9KSA9PiAoe1xuICBoZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcubSxcbn0pKTtcblxuY29uc3QgU3R5bGVkRWxlbWVudFdyYXBwZXIgPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICBtYXJnaW5Ub3A6IGAtJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfWAsXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBDb250ZW50Qm94KHtcbiAgdHlwZSxcbiAgY29udGVudCxcbiAgbWFya2V0LFxuICByZW5kZXJUb3BSaWdodEVsZW1lbnQsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogQ29udGVudEJveFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdmFyaWFudCA9IENPTlRFTlRfQk9YX1RZUEVfVE9fVkFSSUFOVFt0eXBlXTtcbiAgY29uc3QgaWNvbk5hbWUgPSBDT05URU5UX0JPWF9UWVBFX1RPX0lDT05bdHlwZV07XG4gIGNvbnN0IGljb25Db2xvciA9IElDT05fQ09MT1JfQllfVkFSSUFOVFt2YXJpYW50XTtcbiAgY29uc3QgdGl0bGUgPVxuICAgIG1hcmtldCA9PT0gXCJERVwiXG4gICAgICA/IENPTlRFTlRfQk9YX1RZUEVfVE9fVElUTEVfREVbdHlwZV1cbiAgICAgIDogQ09OVEVOVF9CT1hfVFlQRV9UT19USVRMRV9VU1t0eXBlXTtcbiAgY29uc3QgdGl0bGVDb2xvciA9IFRJVExFX0NPTE9SX0JZX1ZBUklBTlRbdmFyaWFudF07XG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD1cIkNvbnRlbnRCb3hcIlxuICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgIHJvbGU9XCJhbGVydFwiXG4gICAgPlxuICAgICAgPFN0eWxlZEhlYWRlciB2YXJpYW50PXt2YXJpYW50fT5cbiAgICAgICAgPElubGluZSBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgdkFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgc3BhY2U9XCJ4c1wiIG5vV3JhcD5cbiAgICAgICAgICAgIDxTdHlsZWRJY29uV3JhcHBlcj5cbiAgICAgICAgICAgICAgPEljb25cbiAgICAgICAgICAgICAgICBuYW1lPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgICBjb2xvcj17aWNvbkNvbG9yfVxuICAgICAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgICAgICByb2xlPVwiaW1nXCJcbiAgICAgICAgICAgICAgICBhcmlhLWxhYmVsPXtpY29uTmFtZX1cbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDwvU3R5bGVkSWNvbldyYXBwZXI+XG4gICAgICAgICAgICA8VGV4dCB3ZWlnaHQ9XCJib2xkXCIgc2l6ZT1cIm1cIiBjb2xvcj17dGl0bGVDb2xvcn0+XG4gICAgICAgICAgICAgIHt0aXRsZX1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgICA8U3R5bGVkRWxlbWVudFdyYXBwZXI+XG4gICAgICAgICAgICB7cmVuZGVyVG9wUmlnaHRFbGVtZW50Py4oKX1cbiAgICAgICAgICA8L1N0eWxlZEVsZW1lbnRXcmFwcGVyPlxuICAgICAgICA8L0lubGluZT5cbiAgICAgIDwvU3R5bGVkSGVhZGVyPlxuICAgICAgPENvbnRhaW5lciBlbGV2YXRpb249ezB9IHNxdWFyZUNvcm5lcnM+XG4gICAgICAgIDxCb3ggc3BhY2U9XCJzXCIgdlNwYWNlPVwieHNcIj5cbiAgICAgICAgICA8VGV4dCBhcz1cInNwYW5cIiBzaXplPVwic1wiPlxuICAgICAgICAgICAge2NvbnRlbnR9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0JveD5cbiAgICAgIDwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdJNkIifQ== */");function ContentBox({type,content,market,renderTopRightElement,"data-e2e-test-id":dataE2eTestId}){let variant=CONTENT_BOX_TYPE_TO_VARIANT[type],iconName=CONTENT_BOX_TYPE_TO_ICON[type],iconColor=ICON_COLOR_BY_VARIANT[variant],title="DE"===market?CONTENT_BOX_TYPE_TO_TITLE_DE[type]:CONTENT_BOX_TYPE_TO_TITLE_US[type],titleColor=TITLE_COLOR_BY_VARIANT[variant];return _react.default.createElement(StyledContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ContentBox",variant:variant,role:"alert"},_react.default.createElement(StyledHeader,{variant:variant},_react.default.createElement(_Inline.Inline,{alignItems:"spaceBetween",vAlignItems:"center"},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",space:"xs",noWrap:!0},_react.default.createElement(StyledIconWrapper,null,_react.default.createElement(_Icon.Icon,{name:iconName,color:iconColor,size:"s",role:"img","aria-label":iconName})),_react.default.createElement(_Text.Text,{weight:"bold",size:"m",color:titleColor},title)),_react.default.createElement(StyledElementWrapper,null,renderTopRightElement?.()))),_react.default.createElement(_Container.Container,{elevation:0,squareCorners:!0},_react.default.createElement(_Box.Box,{space:"s",vSpace:"xs"},_react.default.createElement(_Text.Text,{as:"span",size:"s"},content))))}
@@ -1,13 +0,0 @@
1
- import type { ReactElement } from "react";
2
- import React from "react";
3
- declare const CONTENT_BOX_TYPES: readonly ["merke", "merkspruch", "cave", "clinic-box", "case-link", "dgim-negative", "dgim-positive", "guideline-recommendations"];
4
- type ContentBoxType = (typeof CONTENT_BOX_TYPES)[number];
5
- export type ContentBoxProps = {
6
- type: ContentBoxType;
7
- content: string | ReactElement;
8
- market: "US" | "DE";
9
- "data-e2e-test-id"?: string;
10
- renderTopRightElement?: () => React.ReactNode;
11
- };
12
- export declare function ContentBox({ type, content, market, renderTopRightElement, "data-e2e-test-id": dataE2eTestId, }: ContentBoxProps): React.ReactElement;
13
- export {};