@ultraviolet/ui 2.0.3 → 2.0.4

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.
@@ -11,6 +11,7 @@ import { useMenu, DisclosureContext } from "./MenuProvider.js";
11
11
  function _EMOTION_STRINGIFIED_CSS_ERROR__() {
12
12
  return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
13
13
  }
14
+ const SPACE_DISCLOSURE_POPUP = 24;
14
15
  const StyledPopup = /* @__PURE__ */ _styled(Popup, process.env.NODE_ENV === "production" ? {
15
16
  shouldForwardProp: (prop) => !["searchable"].includes(prop),
16
17
  target: "exosi9s4"
@@ -28,7 +29,7 @@ const StyledPopup = /* @__PURE__ */ _styled(Popup, process.env.NODE_ENV === "pro
28
29
  searchable
29
30
  }) => searchable ? `min-width: 20rem` : null, ";padding:", ({
30
31
  theme
31
- }) => `${theme.space["0.25"]} 0`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AAgC2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) =>\n    theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            onKeyDown={handleKeyDown}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
32
+ }) => `${theme.space["0.25"]} 0`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AAkC2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst SPACE_DISCLOSURE_POPUP = 24 // in px\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height', 'heightAvailableSpace'].includes(prop),\n})<{ height: string; heightAvailableSpace: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: ${({ theme, height, heightAvailableSpace }) =>\n    `calc(min(${height}, ${heightAvailableSpace}) - ${theme.space['0.5']})`};\n\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n      noShrink = false,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const [popupMaxHeight, setPopupMaxHeight] = useState<string>(\n      maxHeight ?? '30rem',\n    )\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (disclosureRef.current && placement === 'bottom' && !noShrink) {\n        const disclosureRect = disclosureRef.current.getBoundingClientRect()\n        const disclosureBottom = disclosureRect.bottom\n        const targetSize = portalTarget.getBoundingClientRect().bottom\n        const availableSpace =\n          targetSize - disclosureBottom - SPACE_DISCLOSURE_POPUP\n        setPopupMaxHeight(`${availableSpace}px`)\n      }\n    }, [isVisible, portalTarget, disclosureRef, placement, noShrink])\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            heightAvailableSpace={popupMaxHeight}\n            onKeyDown={handleKeyDown}\n            onMouseEnter={() => setShouldBeVisible(true)}\n            onMouseLeave={() => setShouldBeVisible(false)}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
32
33
  const Content = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
33
34
  target: "exosi9s3"
34
35
  } : {
@@ -39,7 +40,7 @@ const Content = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "product
39
40
  styles: "overflow:auto"
40
41
  } : {
41
42
  name: "1qmr6ab",
42
- styles: "overflow:auto/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AAuD6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) =>\n    theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            onKeyDown={handleKeyDown}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */",
43
+ styles: "overflow:auto/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AAyD6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst SPACE_DISCLOSURE_POPUP = 24 // in px\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height', 'heightAvailableSpace'].includes(prop),\n})<{ height: string; heightAvailableSpace: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: ${({ theme, height, heightAvailableSpace }) =>\n    `calc(min(${height}, ${heightAvailableSpace}) - ${theme.space['0.5']})`};\n\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n      noShrink = false,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const [popupMaxHeight, setPopupMaxHeight] = useState<string>(\n      maxHeight ?? '30rem',\n    )\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (disclosureRef.current && placement === 'bottom' && !noShrink) {\n        const disclosureRect = disclosureRef.current.getBoundingClientRect()\n        const disclosureBottom = disclosureRect.bottom\n        const targetSize = portalTarget.getBoundingClientRect().bottom\n        const availableSpace =\n          targetSize - disclosureBottom - SPACE_DISCLOSURE_POPUP\n        setPopupMaxHeight(`${availableSpace}px`)\n      }\n    }, [isVisible, portalTarget, disclosureRef, placement, noShrink])\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            heightAvailableSpace={popupMaxHeight}\n            onKeyDown={handleKeyDown}\n            onMouseEnter={() => setShouldBeVisible(true)}\n            onMouseLeave={() => setShouldBeVisible(false)}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */",
43
44
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
44
45
  });
45
46
  const Footer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
@@ -49,25 +50,25 @@ const Footer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "producti
49
50
  label: "Footer"
50
51
  })("padding:", ({
51
52
  theme
52
- }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AA2D4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) =>\n    theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            onKeyDown={handleKeyDown}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
53
+ }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AA6D4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst SPACE_DISCLOSURE_POPUP = 24 // in px\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height', 'heightAvailableSpace'].includes(prop),\n})<{ height: string; heightAvailableSpace: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: ${({ theme, height, heightAvailableSpace }) =>\n    `calc(min(${height}, ${heightAvailableSpace}) - ${theme.space['0.5']})`};\n\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n      noShrink = false,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const [popupMaxHeight, setPopupMaxHeight] = useState<string>(\n      maxHeight ?? '30rem',\n    )\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (disclosureRef.current && placement === 'bottom' && !noShrink) {\n        const disclosureRect = disclosureRef.current.getBoundingClientRect()\n        const disclosureBottom = disclosureRect.bottom\n        const targetSize = portalTarget.getBoundingClientRect().bottom\n        const availableSpace =\n          targetSize - disclosureBottom - SPACE_DISCLOSURE_POPUP\n        setPopupMaxHeight(`${availableSpace}px`)\n      }\n    }, [isVisible, portalTarget, disclosureRef, placement, noShrink])\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            heightAvailableSpace={popupMaxHeight}\n            onKeyDown={handleKeyDown}\n            onMouseEnter={() => setShouldBeVisible(true)}\n            onMouseLeave={() => setShouldBeVisible(false)}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
53
54
  const MenuList = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
54
- shouldForwardProp: (prop) => !["height"].includes(prop),
55
+ shouldForwardProp: (prop) => !["height", "heightAvailableSpace"].includes(prop),
55
56
  target: "exosi9s1"
56
57
  } : {
57
- shouldForwardProp: (prop) => !["height"].includes(prop),
58
+ shouldForwardProp: (prop) => !["height", "heightAvailableSpace"].includes(prop),
58
59
  target: "exosi9s1",
59
60
  label: "MenuList"
60
- })("overflow-y:auto;overflow-x:hidden;max-height:calc(", ({
61
- height
62
- }) => height, " - ", ({
63
- theme
64
- }) => theme.space["0.5"], ");&:after,&:before{border:solid transparent;border-width:9px;content:' ';height:0;width:0;position:absolute;pointer-events:none;}&:after{border-color:transparent;}&:before{border-color:transparent;}background-color:", ({
61
+ })("overflow-y:auto;overflow-x:hidden;max-height:", ({
62
+ theme,
63
+ height,
64
+ heightAvailableSpace
65
+ }) => `calc(min(${height}, ${heightAvailableSpace}) - ${theme.space["0.5"]})`, ";&:after,&:before{border:solid transparent;border-width:9px;content:' ';height:0;width:0;position:absolute;pointer-events:none;}&:after{border-color:transparent;}&:before{border-color:transparent;}background-color:", ({
65
66
  theme
66
67
  }) => theme.colors.other.elevation.background.raised, ";color:", ({
67
68
  theme
68
69
  }) => theme.colors.neutral.text, ";border-radius:", ({
69
70
  theme
70
- }) => theme.radii.default, ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AAiEsB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) =>\n    theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            onKeyDown={handleKeyDown}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
71
+ }) => theme.radii.default, ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AAmEoD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst SPACE_DISCLOSURE_POPUP = 24 // in px\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height', 'heightAvailableSpace'].includes(prop),\n})<{ height: string; heightAvailableSpace: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: ${({ theme, height, heightAvailableSpace }) =>\n    `calc(min(${height}, ${heightAvailableSpace}) - ${theme.space['0.5']})`};\n\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n      noShrink = false,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const [popupMaxHeight, setPopupMaxHeight] = useState<string>(\n      maxHeight ?? '30rem',\n    )\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (disclosureRef.current && placement === 'bottom' && !noShrink) {\n        const disclosureRect = disclosureRef.current.getBoundingClientRect()\n        const disclosureBottom = disclosureRect.bottom\n        const targetSize = portalTarget.getBoundingClientRect().bottom\n        const availableSpace =\n          targetSize - disclosureBottom - SPACE_DISCLOSURE_POPUP\n        setPopupMaxHeight(`${availableSpace}px`)\n      }\n    }, [isVisible, portalTarget, disclosureRef, placement, noShrink])\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            heightAvailableSpace={popupMaxHeight}\n            onKeyDown={handleKeyDown}\n            onMouseEnter={() => setShouldBeVisible(true)}\n            onMouseLeave={() => setShouldBeVisible(false)}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
71
72
  const StyledSearchInput = /* @__PURE__ */ _styled(SearchInput, process.env.NODE_ENV === "production" ? {
72
73
  target: "exosi9s0"
73
74
  } : {
@@ -75,7 +76,7 @@ const StyledSearchInput = /* @__PURE__ */ _styled(SearchInput, process.env.NODE_
75
76
  label: "StyledSearchInput"
76
77
  })("padding:", ({
77
78
  theme
78
- }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AA8F6C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) =>\n    theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            onKeyDown={handleKeyDown}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
79
+ }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx"],"names":[],"mappings":"AAiG6C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ButtonHTMLAttributes,\n  KeyboardEvent,\n  MouseEvent,\n  ReactNode,\n  Ref,\n} from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { SIZES } from './constants'\nimport { getListItem, searchChildren } from './helpers'\nimport { DisclosureContext, useMenu } from './MenuProvider'\nimport type { MenuProps } from './types'\n\nconst SPACE_DISCLOSURE_POPUP = 24 // in px\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['searchable'].includes(prop),\n})<{ searchable: boolean }>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) =>\n    `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) =>\n        theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height', 'heightAvailableSpace'].includes(prop),\n})<{ height: string; heightAvailableSpace: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: ${({ theme, height, heightAvailableSpace }) =>\n    `calc(min(${height}, ${heightAvailableSpace}) - ${theme.space['0.5']})`};\n\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      portalTarget = document.body,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n      noShrink = false,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const {\n      isVisible,\n      setIsVisible,\n      isNested,\n      disclosureRef,\n      menuRef,\n      setShouldBeVisible,\n      shouldBeVisible,\n    } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const [popupMaxHeight, setPopupMaxHeight] = useState<string>(\n      maxHeight ?? '30rem',\n    )\n    const contentRef = useRef<HTMLDivElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      'aria-expanded': isVisible,\n      'aria-haspopup': 'dialog',\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    useEffect(() => {\n      if (disclosureRef.current && triggerMethod === 'hover') {\n        const handler = (value: boolean | undefined) => {\n          setShouldBeVisible(value)\n        }\n\n        disclosureRef.current.addEventListener('focus', () => handler(true))\n        disclosureRef.current.addEventListener('mouseenter', () =>\n          handler(true),\n        )\n        disclosureRef.current.addEventListener('mouseleave', () =>\n          handler(false),\n        )\n        disclosureRef.current.addEventListener('keydown', event => {\n          if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n            handler(false) // force close menu when navigating with arrow keys\n          }\n        })\n\n        return () => {\n          window.removeEventListener('focus', () => handler(undefined))\n          window.removeEventListener('mouseenter', () => handler(undefined))\n          window.removeEventListener('mouseleave', () => handler(undefined))\n          window.removeEventListener('keydown', () => handler(undefined))\n        }\n      }\n\n      return undefined\n    }, [setShouldBeVisible, disclosureRef, triggerMethod])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    const handleTabOpen = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem && isVisible && ['Tab', 'ArrowDown'].includes(event.key)) {\n          event?.preventDefault()\n          listItem[0]?.focus()\n        }\n      }\n    }\n\n    const handleKeyDown = (event: KeyboardEvent) => {\n      if (contentRef.current) {\n        const listItem = getListItem([...contentRef.current.children])\n        if (listItem) {\n          const currentElement = listItem.find(\n            item => item === document.activeElement,\n          )\n          if (currentElement) {\n            if (event.key === 'ArrowDown') {\n              event.preventDefault()\n              const indexOfCurrent = listItem.indexOf(currentElement)\n\n              if (indexOfCurrent < listItem.length - 1) {\n                listItem[indexOfCurrent + 1].focus()\n              } else {\n                listItem[0].focus()\n              }\n            } else if (event.key === 'ArrowUp') {\n              event.preventDefault()\n\n              const indexOfCurrent = listItem.indexOf(currentElement)\n              if (indexOfCurrent > 0) {\n                listItem[indexOfCurrent - 1].focus()\n              } else {\n                listItem[listItem.length - 1].focus()\n              }\n            } else if (event.key === 'ArrowLeft' && triggerMethod === 'hover') {\n              disclosureRef.current?.focus()\n              setShouldBeVisible(undefined)\n            }\n          }\n        }\n      }\n    }\n\n    useEffect(() => {\n      if (disclosureRef.current && placement === 'bottom' && !noShrink) {\n        const disclosureRect = disclosureRef.current.getBoundingClientRect()\n        const disclosureBottom = disclosureRect.bottom\n        const targetSize = portalTarget.getBoundingClientRect().bottom\n        const availableSpace =\n          targetSize - disclosureBottom - SPACE_DISCLOSURE_POPUP\n        setPopupMaxHeight(`${availableSpace}px`)\n      }\n    }, [isVisible, portalTarget, disclosureRef, placement, noShrink])\n\n    return (\n      <StyledPopup\n        align={align}\n        aria-label={ariaLabel}\n        className={className}\n        data-has-arrow={hasArrow}\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        dynamicDomRendering={dynamicDomRendering}\n        hasArrow={hasArrow}\n        hideOnClickOutside\n        id={finalId}\n        maxHeight={maxHeight ?? '30rem'}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n          if (triggerMethod === 'click') {\n            disclosureRef.current?.focus()\n          }\n          setShouldBeVisible(undefined)\n        }}\n        onKeyDown={handleTabOpen}\n        placement={isNested ? 'nested-menu' : placement}\n        portalTarget={portalTarget}\n        ref={menuRef}\n        role=\"dialog\"\n        searchable={searchable}\n        tabIndex={-1}\n        text={\n          <MenuList\n            className={className}\n            data-testid={dataTestId}\n            height={maxHeight ?? '30rem'}\n            heightAvailableSpace={popupMaxHeight}\n            onKeyDown={handleKeyDown}\n            onMouseEnter={() => setShouldBeVisible(true)}\n            onMouseLeave={() => setShouldBeVisible(false)}\n            role=\"menu\"\n          >\n            <Content ref={contentRef}>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                  size=\"small\"\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        visible={triggerMethod === 'click' ? isVisible : shouldBeVisible}\n      >\n        <DisclosureContext.Provider value>\n          {finalDisclosure}\n        </DisclosureContext.Provider>\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
79
80
  const Menu = forwardRef(({
80
81
  id,
81
82
  ariaLabel = "Menu",
@@ -91,7 +92,8 @@ const Menu = forwardRef(({
91
92
  dynamicDomRendering,
92
93
  align,
93
94
  searchable = false,
94
- footer
95
+ footer,
96
+ noShrink = false
95
97
  }, ref) => {
96
98
  const {
97
99
  isVisible,
@@ -104,6 +106,7 @@ const Menu = forwardRef(({
104
106
  } = useMenu();
105
107
  const searchInputRef = useRef(null);
106
108
  const [localChild, setLocalChild] = useState(null);
109
+ const [popupMaxHeight, setPopupMaxHeight] = useState(maxHeight ?? "30rem");
107
110
  const contentRef = useRef(null);
108
111
  const tempId = useId();
109
112
  const finalId = `menu-${id ?? tempId}`;
@@ -206,6 +209,15 @@ const Menu = forwardRef(({
206
209
  }
207
210
  }
208
211
  };
212
+ useEffect(() => {
213
+ if (disclosureRef.current && placement === "bottom" && !noShrink) {
214
+ const disclosureRect = disclosureRef.current.getBoundingClientRect();
215
+ const disclosureBottom = disclosureRect.bottom;
216
+ const targetSize = portalTarget.getBoundingClientRect().bottom;
217
+ const availableSpace = targetSize - disclosureBottom - SPACE_DISCLOSURE_POPUP;
218
+ setPopupMaxHeight(`${availableSpace}px`);
219
+ }
220
+ }, [isVisible, portalTarget, disclosureRef, placement, noShrink]);
209
221
  return /* @__PURE__ */ jsx(StyledPopup, { align, "aria-label": ariaLabel, className, "data-has-arrow": hasArrow, debounceDelay: triggerMethod === "hover" ? 250 : 0, dynamicDomRendering, hasArrow, hideOnClickOutside: true, id: finalId, maxHeight: maxHeight ?? "30rem", onClose: () => {
210
222
  setIsVisible(false);
211
223
  setLocalChild(null);
@@ -213,7 +225,7 @@ const Menu = forwardRef(({
213
225
  disclosureRef.current?.focus();
214
226
  }
215
227
  setShouldBeVisible(void 0);
216
- }, onKeyDown: handleTabOpen, placement: isNested ? "nested-menu" : placement, portalTarget, ref: menuRef, role: "dialog", searchable, tabIndex: -1, text: /* @__PURE__ */ jsxs(MenuList, { className, "data-testid": dataTestId, height: maxHeight ?? "30rem", onKeyDown: handleKeyDown, role: "menu", children: [
228
+ }, onKeyDown: handleTabOpen, placement: isNested ? "nested-menu" : placement, portalTarget, ref: menuRef, role: "dialog", searchable, tabIndex: -1, text: /* @__PURE__ */ jsxs(MenuList, { className, "data-testid": dataTestId, height: maxHeight ?? "30rem", heightAvailableSpace: popupMaxHeight, onKeyDown: handleKeyDown, onMouseEnter: () => setShouldBeVisible(true), onMouseLeave: () => setShouldBeVisible(false), role: "menu", children: [
217
229
  /* @__PURE__ */ jsxs(Content, { ref: contentRef, children: [
218
230
  searchable && typeof children !== "function" ? /* @__PURE__ */ jsx(StyledSearchInput, { onSearch, ref: searchInputRef, size: "small" }) : null,
219
231
  finalChild
@@ -19,6 +19,7 @@ export declare const Menu: import("react").ForwardRefExoticComponent<{
19
19
  hideOnClickItem?: boolean;
20
20
  footer?: import("react").ReactNode;
21
21
  placement?: Exclude<import("react").ComponentProps<typeof import("..").Popup>["placement"], "nested-menu">;
22
+ noShrink?: boolean;
22
23
  } & Pick<{
23
24
  id?: string;
24
25
  children: import("react").ReactNode | ((renderProps: {
@@ -40,5 +40,9 @@ export type MenuProps = {
40
40
  hideOnClickItem?: boolean;
41
41
  footer?: ReactNode;
42
42
  placement?: Exclude<ComponentProps<typeof Popup>['placement'], 'nested-menu'>;
43
+ /**
44
+ * When set to true, the menu does not shrink (height) to avoid overflow on the page
45
+ */
46
+ noShrink?: boolean;
43
47
  } & Pick<ComponentProps<typeof Popup>, 'dynamicDomRendering' | 'align'>;
44
48
  export {};
@@ -17,7 +17,7 @@ const StyledSortIcon = /* @__PURE__ */ _styled__default.default(Icon.SouthShortI
17
17
  label: "StyledSortIcon"
18
18
  })("transform:", ({
19
19
  order
20
- }) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWN5QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJsZS9IZWFkZXJDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7XG4gIEluZm9ybWF0aW9uT3V0bGluZUljb24sXG4gIFNvcnRJY29uIGFzIFNvcnRJY29uVVYsXG4gIFNvdXRoU2hvcnRJY29uLFxufSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcblxuY29uc3QgU3R5bGVkU29ydEljb24gPSBzdHlsZWQoU291dGhTaG9ydEljb24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnb3JkZXInXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgb3JkZXI6ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnIH0+YFxuICAgIHRyYW5zZm9ybTogJHsoeyBvcmRlciB9KSA9PlxuICAgICAgb3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ3JvdGF0ZSgtMTgwZGVnKScgOiAnbm9uZSd9O1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjJzO1xuYFxuXG5jb25zdCBTb3J0SWNvbiA9ICh7IG9yZGVyIH06IHsgb3JkZXI/OiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9KSA9PlxuICBvcmRlciA/IChcbiAgICA8U3R5bGVkU29ydEljb24gb3JkZXI9e29yZGVyfSBzZW50aW1lbnQ9XCJwcmltYXJ5XCIgLz5cbiAgKSA6IChcbiAgICA8U29ydEljb25VViBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgLz5cbiAgKVxuXG50eXBlIFN0eWxlZEhlYWRlckNlbGxQcm9wcyA9IFBpY2s8XG4gIEhlYWRlckNlbGxQcm9wcyxcbiAgJ3dpZHRoJyB8ICdtYXhXaWR0aCcgfCAnbWluV2lkdGgnXG4+ICYge1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xufVxuXG5jb25zdCBTdHlsZWRIZWFkZXJDZWxsID0gc3R5bGVkKCd0aCcsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhWydhbGlnbicsICd3aWR0aCcsICdtYXhXaWR0aCcsICdtaW5XaWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSGVhZGVyQ2VsbFByb3BzPmBcbiR7KHsgd2lkdGgsIG1heFdpZHRoLCBtaW5XaWR0aCB9KSA9PiBgXG4gICAgJHt3aWR0aCA/IGB3aWR0aDogJHt3aWR0aH07YCA6ICcnfVxuICAgICR7bWF4V2lkdGggPyBgbWF4LXdpZHRoOiAke21heFdpZHRofTtgIDogJyd9XG4gICAgJHttaW5XaWR0aCA/IGBtaW4td2lkdGg6ICR7bWluV2lkdGh9O2AgOiAnJ31cbiAgYH1cbiAgZGlzcGxheTogdGFibGUtY2VsbDtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgdGV4dC1hbGlnbjogJHsoeyBhbGlnbiB9KSA9PiBhbGlnbn07XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJltyb2xlKj0nYnV0dG9uJ10ge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICB1c2VyLXNlbGVjdDogbm9uZTtcbiAgfVxuXG4gICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiByb3c7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxudHlwZSBIZWFkZXJDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGlzT3JkZXJlZD86IGJvb2xlYW5cbiAgb3JkZXJEaXJlY3Rpb24/OiAnYXNjJyB8ICdkZXNjJyB8ICdub25lJ1xuICBvbk9yZGVyPzogKG5ld09yZGVyOiAnYXNjJyB8ICdkZXNjJykgPT4gdm9pZFxuICBpbmZvPzogc3RyaW5nXG4gIGFsaWduPzogJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnXG4gIHdpZHRoPzogc3RyaW5nXG4gIG1heFdpZHRoPzogc3RyaW5nXG4gIG1pbldpZHRoPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBIZWFkZXJDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgaXNPcmRlcmVkLFxuICBvbk9yZGVyLFxuICBvcmRlckRpcmVjdGlvbixcbiAgaW5mbyxcbiAgYWxpZ24sXG4gIHdpZHRoLFxuICBtYXhXaWR0aCxcbiAgbWluV2lkdGgsXG59OiBIZWFkZXJDZWxsUHJvcHMpID0+IHtcbiAgbGV0IG9yZGVyOiB1bmRlZmluZWQgfCAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJ1xuICBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnYXNjJykge1xuICAgIG9yZGVyID0gJ2FzY2VuZGluZydcbiAgfSBlbHNlIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdkZXNjJykge1xuICAgIG9yZGVyID0gJ2Rlc2NlbmRpbmcnXG4gIH1cblxuICBjb25zdCBoYW5kbGVPcmRlciA9IG9uT3JkZXJcbiAgICA/ICgpID0+IG9uT3JkZXIob3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ2Rlc2MnIDogJ2FzYycpXG4gICAgOiB1bmRlZmluZWRcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRIZWFkZXJDZWxsXG4gICAgICBhbGlnbj17YWxpZ259XG4gICAgICBhcmlhLXNvcnQ9e29yZGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2lkdGh9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICA+XG4gICAgICA8U3R5bGVkVGV4dFxuICAgICAgICBhcz1cImRpdlwiXG4gICAgICAgIHNlbnRpbWVudD17b3JkZXIgIT09IHVuZGVmaW5lZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFwiXG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gYXJpYS1kaXNhYmxlZD17IW9uT3JkZXJ9IG9yZGVyPXtvcmRlcn0gLz5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0eWxlZFRleHQ+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
20
+ }) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWN5QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJsZS9IZWFkZXJDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7XG4gIEluZm9ybWF0aW9uT3V0bGluZUljb24sXG4gIFNvcnRJY29uIGFzIFNvcnRJY29uVVYsXG4gIFNvdXRoU2hvcnRJY29uLFxufSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcblxuY29uc3QgU3R5bGVkU29ydEljb24gPSBzdHlsZWQoU291dGhTaG9ydEljb24sIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnb3JkZXInXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHsgb3JkZXI6ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnIH0+YFxuICAgIHRyYW5zZm9ybTogJHsoeyBvcmRlciB9KSA9PlxuICAgICAgb3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ3JvdGF0ZSgtMTgwZGVnKScgOiAnbm9uZSd9O1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjJzO1xuYFxuXG5jb25zdCBTb3J0SWNvbiA9ICh7IG9yZGVyIH06IHsgb3JkZXI/OiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9KSA9PlxuICBvcmRlciA/IChcbiAgICA8U3R5bGVkU29ydEljb24gb3JkZXI9e29yZGVyfSBzZW50aW1lbnQ9XCJwcmltYXJ5XCIgLz5cbiAgKSA6IChcbiAgICA8U29ydEljb25VViBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgLz5cbiAgKVxuXG50eXBlIFN0eWxlZEhlYWRlckNlbGxQcm9wcyA9IFBpY2s8XG4gIEhlYWRlckNlbGxQcm9wcyxcbiAgJ3dpZHRoJyB8ICdtYXhXaWR0aCcgfCAnbWluV2lkdGgnXG4+ICYge1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xufVxuXG5jb25zdCBTdHlsZWRIZWFkZXJDZWxsID0gc3R5bGVkKCd0aCcsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhWydhbGlnbicsICd3aWR0aCcsICdtYXhXaWR0aCcsICdtaW5XaWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSGVhZGVyQ2VsbFByb3BzPmBcbiR7KHsgd2lkdGgsIG1heFdpZHRoLCBtaW5XaWR0aCB9KSA9PiBgXG4gICAgJHt3aWR0aCA/IGB3aWR0aDogJHt3aWR0aH07YCA6ICcnfVxuICAgICR7bWF4V2lkdGggPyBgbWF4LXdpZHRoOiAke21heFdpZHRofTtgIDogJyd9XG4gICAgJHttaW5XaWR0aCA/IGBtaW4td2lkdGg6ICR7bWluV2lkdGh9O2AgOiAnJ31cbiAgYH1cbiAgZGlzcGxheTogdGFibGUtY2VsbDtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbiAgdGV4dC1hbGlnbjogJHsoeyBhbGlnbiB9KSA9PiBhbGlnbn07XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5cbiAgJltyb2xlKj0nYnV0dG9uJ10ge1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICB1c2VyLXNlbGVjdDogbm9uZTtcbiAgfVxuXG4gICY6Zmlyc3Qtb2YtdHlwZSB7XG4gICAgJltkYXRhLWNoZWNrYm94PVwidHJ1ZVwiXSB7XG4gICAgICBwYWRkaW5nLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG4gICAgfSBcbiAgfVxuYFxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xuICB3aWR0aD86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtaW5XaWR0aD86IHN0cmluZ1xuICBpc0NoZWNrYm94PzogYm9vbGVhblxufVxuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7XG4gIGNoaWxkcmVuLFxuICBjbGFzc05hbWUsXG4gIGlzT3JkZXJlZCxcbiAgb25PcmRlcixcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIGluZm8sXG4gIGFsaWduLFxuICB3aWR0aCxcbiAgbWF4V2lkdGgsXG4gIG1pbldpZHRoLFxuICBpc0NoZWNrYm94LFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgYWxpZ249e2FsaWdufVxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS1jaGVja2JveD17aXNDaGVja2JveH1cbiAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgIG1pbldpZHRoPXttaW5XaWR0aH1cbiAgICAgIG9uQ2xpY2s9e2hhbmRsZU9yZGVyfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaGFuZGxlT3JkZXJcbiAgICAgICAgICA/IGV2ZW50ID0+IHtcbiAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnIHx8IGV2ZW50LmtleSA9PT0gJ0VudGVyJykge1xuICAgICAgICAgICAgICAgIGhhbmRsZU9yZGVyKClcbiAgICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICAgIC8vIEBub3RlOiBpdCBhdm9pZCBzY3JvbGwgd2hlbiBwcmVzc2luZyBTcGFjZVxuICAgICAgICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIDogdW5kZWZpbmVkXG4gICAgICB9XG4gICAgICByb2xlPXtvbk9yZGVyID8gJ2J1dHRvbiBjb2x1bW5oZWFkZXInIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2hhbmRsZU9yZGVyID8gMCA6IC0xfVxuICAgICAgd2lkdGg9e3dpZHRofVxuICAgID5cbiAgICAgIDxTdHlsZWRUZXh0XG4gICAgICAgIGFzPVwiZGl2XCJcbiAgICAgICAgc2VudGltZW50PXtvcmRlciAhPT0gdW5kZWZpbmVkID8gJ3ByaW1hcnknIDogJ25ldXRyYWwnfVxuICAgICAgICB2YXJpYW50PVwiYm9keVNtYWxsXCJcbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7aW5mbyA/IChcbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXtpbmZvfT5cbiAgICAgICAgICAgIDxJbmZvcm1hdGlvbk91dGxpbmVJY29uXG4gICAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIHNpemU9XCJzbWFsbFwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICAgIHtvcmRlckRpcmVjdGlvbiAhPT0gdW5kZWZpbmVkICYmIGlzT3JkZXJlZCAhPT0gdW5kZWZpbmVkID8gKFxuICAgICAgICAgIDxTb3J0SWNvbiBhcmlhLWRpc2FibGVkPXshb25PcmRlcn0gb3JkZXI9e29yZGVyfSAvPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICA8L1N0eWxlZEhlYWRlckNlbGw+XG4gIClcbn1cbiJdfQ== */"));
21
21
  const SortIcon = ({
22
22
  order
23
23
  }) => order ? /* @__PURE__ */ jsxRuntime.jsx(StyledSortIcon, { order, sentiment: "primary" }) : /* @__PURE__ */ jsxRuntime.jsx(Icon.SortIcon, { sentiment: "neutral" });
@@ -40,9 +40,9 @@ const StyledHeaderCell = /* @__PURE__ */ _styled__default.default("th", process.
40
40
  align
41
41
  }) => align, ";padding:", ({
42
42
  theme
43
- }) => theme.space["1"], ";&[role*='button']{cursor:pointer;user-select:none;}&:first-of-type{padding-left:", ({
43
+ }) => theme.space["1"], `;&[role*='button']{cursor:pointer;user-select:none;}&:first-of-type{&[data-checkbox="true"]{padding-left:`, ({
44
44
  theme
45
- }) => theme.space["2"], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDeUIiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgfVxuYFxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xuICB3aWR0aD86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtaW5XaWR0aD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7XG4gIGNoaWxkcmVuLFxuICBjbGFzc05hbWUsXG4gIGlzT3JkZXJlZCxcbiAgb25PcmRlcixcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIGluZm8sXG4gIGFsaWduLFxuICB3aWR0aCxcbiAgbWF4V2lkdGgsXG4gIG1pbldpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgYWxpZ249e2FsaWdufVxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgbWF4V2lkdGg9e21heFdpZHRofVxuICAgICAgbWluV2lkdGg9e21pbldpZHRofVxuICAgICAgb25DbGljaz17aGFuZGxlT3JkZXJ9XG4gICAgICBvbktleURvd249e1xuICAgICAgICBoYW5kbGVPcmRlclxuICAgICAgICAgID8gZXZlbnQgPT4ge1xuICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcgfHwgZXZlbnQua2V5ID09PSAnRW50ZXInKSB7XG4gICAgICAgICAgICAgICAgaGFuZGxlT3JkZXIoKVxuICAgICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJykge1xuICAgICAgICAgICAgICAgICAgLy8gQG5vdGU6IGl0IGF2b2lkIHNjcm9sbCB3aGVuIHByZXNzaW5nIFNwYWNlXG4gICAgICAgICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB1bmRlZmluZWRcbiAgICAgIH1cbiAgICAgIHJvbGU9e29uT3JkZXIgPyAnYnV0dG9uIGNvbHVtbmhlYWRlcicgOiB1bmRlZmluZWR9XG4gICAgICB0YWJJbmRleD17aGFuZGxlT3JkZXIgPyAwIDogLTF9XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgPlxuICAgICAgPFN0eWxlZFRleHRcbiAgICAgICAgYXM9XCJkaXZcIlxuICAgICAgICBzZW50aW1lbnQ9e29yZGVyICE9PSB1bmRlZmluZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIHtpbmZvID8gKFxuICAgICAgICAgIDxUb29sdGlwIHRleHQ9e2luZm99PlxuICAgICAgICAgICAgPEluZm9ybWF0aW9uT3V0bGluZUljb25cbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cIndlYWtcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge29yZGVyRGlyZWN0aW9uICE9PSB1bmRlZmluZWQgJiYgaXNPcmRlcmVkICE9PSB1bmRlZmluZWQgPyAoXG4gICAgICAgICAgPFNvcnRJY29uIGFyaWEtZGlzYWJsZWQ9eyFvbk9yZGVyfSBvcmRlcj17b3JkZXJ9IC8+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdHlsZWRUZXh0PlxuICAgIDwvU3R5bGVkSGVhZGVyQ2VsbD5cbiAgKVxufVxuIl19 */"));
45
+ }) => theme.space["2"], ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDeUIiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgICZbZGF0YS1jaGVja2JveD1cInRydWVcIl0ge1xuICAgICAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICAgIH0gXG4gIH1cbmBcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuYFxuXG50eXBlIEhlYWRlckNlbGxQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgaXNPcmRlcmVkPzogYm9vbGVhblxuICBvcmRlckRpcmVjdGlvbj86ICdhc2MnIHwgJ2Rlc2MnIHwgJ25vbmUnXG4gIG9uT3JkZXI/OiAobmV3T3JkZXI6ICdhc2MnIHwgJ2Rlc2MnKSA9PiB2b2lkXG4gIGluZm8/OiBzdHJpbmdcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbiAgd2lkdGg/OiBzdHJpbmdcbiAgbWF4V2lkdGg/OiBzdHJpbmdcbiAgbWluV2lkdGg/OiBzdHJpbmdcbiAgaXNDaGVja2JveD86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEhlYWRlckNlbGwgPSAoe1xuICBjaGlsZHJlbixcbiAgY2xhc3NOYW1lLFxuICBpc09yZGVyZWQsXG4gIG9uT3JkZXIsXG4gIG9yZGVyRGlyZWN0aW9uLFxuICBpbmZvLFxuICBhbGlnbixcbiAgd2lkdGgsXG4gIG1heFdpZHRoLFxuICBtaW5XaWR0aCxcbiAgaXNDaGVja2JveCxcbn06IEhlYWRlckNlbGxQcm9wcykgPT4ge1xuICBsZXQgb3JkZXI6IHVuZGVmaW5lZCB8ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnXG4gIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdhc2MnKSB7XG4gICAgb3JkZXIgPSAnYXNjZW5kaW5nJ1xuICB9IGVsc2UgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2Rlc2MnKSB7XG4gICAgb3JkZXIgPSAnZGVzY2VuZGluZydcbiAgfVxuXG4gIGNvbnN0IGhhbmRsZU9yZGVyID0gb25PcmRlclxuICAgID8gKCkgPT4gb25PcmRlcihvcmRlciA9PT0gJ2FzY2VuZGluZycgPyAnZGVzYycgOiAnYXNjJylcbiAgICA6IHVuZGVmaW5lZFxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEhlYWRlckNlbGxcbiAgICAgIGFsaWduPXthbGlnbn1cbiAgICAgIGFyaWEtc29ydD17b3JkZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtY2hlY2tib3g9e2lzQ2hlY2tib3h9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2lkdGh9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICA+XG4gICAgICA8U3R5bGVkVGV4dFxuICAgICAgICBhcz1cImRpdlwiXG4gICAgICAgIHNlbnRpbWVudD17b3JkZXIgIT09IHVuZGVmaW5lZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFwiXG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gYXJpYS1kaXNhYmxlZD17IW9uT3JkZXJ9IG9yZGVyPXtvcmRlcn0gLz5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0eWxlZFRleHQ+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
46
46
  const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
47
47
  target: "ev6jkq80"
48
48
  } : {
@@ -50,7 +50,7 @@ const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, proces
50
50
  label: "StyledText"
51
51
  })("display:flex;flex-direction:row;align-items:center;gap:", ({
52
52
  theme
53
- }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBEK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgIHBhZGRpbmctbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgfVxuYFxuXG5jb25zdCBTdHlsZWRUZXh0ID0gc3R5bGVkKFRleHQpYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzEnXX07XG5gXG5cbnR5cGUgSGVhZGVyQ2VsbFByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBpc09yZGVyZWQ/OiBib29sZWFuXG4gIG9yZGVyRGlyZWN0aW9uPzogJ2FzYycgfCAnZGVzYycgfCAnbm9uZSdcbiAgb25PcmRlcj86IChuZXdPcmRlcjogJ2FzYycgfCAnZGVzYycpID0+IHZvaWRcbiAgaW5mbz86IHN0cmluZ1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xuICB3aWR0aD86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtaW5XaWR0aD86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgSGVhZGVyQ2VsbCA9ICh7XG4gIGNoaWxkcmVuLFxuICBjbGFzc05hbWUsXG4gIGlzT3JkZXJlZCxcbiAgb25PcmRlcixcbiAgb3JkZXJEaXJlY3Rpb24sXG4gIGluZm8sXG4gIGFsaWduLFxuICB3aWR0aCxcbiAgbWF4V2lkdGgsXG4gIG1pbldpZHRoLFxufTogSGVhZGVyQ2VsbFByb3BzKSA9PiB7XG4gIGxldCBvcmRlcjogdW5kZWZpbmVkIHwgJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZydcbiAgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICBvcmRlciA9ICdhc2NlbmRpbmcnXG4gIH0gZWxzZSBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnZGVzYycpIHtcbiAgICBvcmRlciA9ICdkZXNjZW5kaW5nJ1xuICB9XG5cbiAgY29uc3QgaGFuZGxlT3JkZXIgPSBvbk9yZGVyXG4gICAgPyAoKSA9PiBvbk9yZGVyKG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdkZXNjJyA6ICdhc2MnKVxuICAgIDogdW5kZWZpbmVkXG5cbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkSGVhZGVyQ2VsbFxuICAgICAgYWxpZ249e2FsaWdufVxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgbWF4V2lkdGg9e21heFdpZHRofVxuICAgICAgbWluV2lkdGg9e21pbldpZHRofVxuICAgICAgb25DbGljaz17aGFuZGxlT3JkZXJ9XG4gICAgICBvbktleURvd249e1xuICAgICAgICBoYW5kbGVPcmRlclxuICAgICAgICAgID8gZXZlbnQgPT4ge1xuICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcgfHwgZXZlbnQua2V5ID09PSAnRW50ZXInKSB7XG4gICAgICAgICAgICAgICAgaGFuZGxlT3JkZXIoKVxuICAgICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJykge1xuICAgICAgICAgICAgICAgICAgLy8gQG5vdGU6IGl0IGF2b2lkIHNjcm9sbCB3aGVuIHByZXNzaW5nIFNwYWNlXG4gICAgICAgICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgOiB1bmRlZmluZWRcbiAgICAgIH1cbiAgICAgIHJvbGU9e29uT3JkZXIgPyAnYnV0dG9uIGNvbHVtbmhlYWRlcicgOiB1bmRlZmluZWR9XG4gICAgICB0YWJJbmRleD17aGFuZGxlT3JkZXIgPyAwIDogLTF9XG4gICAgICB3aWR0aD17d2lkdGh9XG4gICAgPlxuICAgICAgPFN0eWxlZFRleHRcbiAgICAgICAgYXM9XCJkaXZcIlxuICAgICAgICBzZW50aW1lbnQ9e29yZGVyICE9PSB1bmRlZmluZWQgPyAncHJpbWFyeScgOiAnbmV1dHJhbCd9XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIHtpbmZvID8gKFxuICAgICAgICAgIDxUb29sdGlwIHRleHQ9e2luZm99PlxuICAgICAgICAgICAgPEluZm9ybWF0aW9uT3V0bGluZUljb25cbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cIndlYWtcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge29yZGVyRGlyZWN0aW9uICE9PSB1bmRlZmluZWQgJiYgaXNPcmRlcmVkICE9PSB1bmRlZmluZWQgPyAoXG4gICAgICAgICAgPFNvcnRJY29uIGFyaWEtZGlzYWJsZWQ9eyFvbk9yZGVyfSBvcmRlcj17b3JkZXJ9IC8+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdHlsZWRUZXh0PlxuICAgIDwvU3R5bGVkSGVhZGVyQ2VsbD5cbiAgKVxufVxuIl19 */"));
53
+ }) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyQ2VsbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQge1xuICBJbmZvcm1hdGlvbk91dGxpbmVJY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5cbmNvbnN0IFN0eWxlZFNvcnRJY29uID0gc3R5bGVkKFNvdXRoU2hvcnRJY29uLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ29yZGVyJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IG9yZGVyOiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9PmBcbiAgICB0cmFuc2Zvcm06ICR7KHsgb3JkZXIgfSkgPT5cbiAgICAgIG9yZGVyID09PSAnYXNjZW5kaW5nJyA/ICdyb3RhdGUoLTE4MGRlZyknIDogJ25vbmUnfTtcbiAgICB0cmFuc2l0aW9uOiB0cmFuc2Zvcm0gMC4ycztcbmBcblxuY29uc3QgU29ydEljb24gPSAoeyBvcmRlciB9OiB7IG9yZGVyPzogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfSkgPT5cbiAgb3JkZXIgPyAoXG4gICAgPFN0eWxlZFNvcnRJY29uIG9yZGVyPXtvcmRlcn0gc2VudGltZW50PVwicHJpbWFyeVwiIC8+XG4gICkgOiAoXG4gICAgPFNvcnRJY29uVVYgc2VudGltZW50PVwibmV1dHJhbFwiIC8+XG4gIClcblxudHlwZSBTdHlsZWRIZWFkZXJDZWxsUHJvcHMgPSBQaWNrPFxuICBIZWFkZXJDZWxsUHJvcHMsXG4gICd3aWR0aCcgfCAnbWF4V2lkdGgnIHwgJ21pbldpZHRoJ1xuPiAmIHtcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbn1cblxuY29uc3QgU3R5bGVkSGVhZGVyQ2VsbCA9IHN0eWxlZCgndGgnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsnYWxpZ24nLCAnd2lkdGgnLCAnbWF4V2lkdGgnLCAnbWluV2lkdGgnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPFN0eWxlZEhlYWRlckNlbGxQcm9wcz5gXG4keyh7IHdpZHRoLCBtYXhXaWR0aCwgbWluV2lkdGggfSkgPT4gYFxuICAgICR7d2lkdGggPyBgd2lkdGg6ICR7d2lkdGh9O2AgOiAnJ31cbiAgICAke21heFdpZHRoID8gYG1heC13aWR0aDogJHttYXhXaWR0aH07YCA6ICcnfVxuICAgICR7bWluV2lkdGggPyBgbWluLXdpZHRoOiAke21pbldpZHRofTtgIDogJyd9XG4gIGB9XG4gIGRpc3BsYXk6IHRhYmxlLWNlbGw7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG4gIHRleHQtYWxpZ246ICR7KHsgYWxpZ24gfSkgPT4gYWxpZ259O1xuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuXG4gICZbcm9sZSo9J2J1dHRvbiddIHtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIH1cblxuICAmOmZpcnN0LW9mLXR5cGUge1xuICAgICZbZGF0YS1jaGVja2JveD1cInRydWVcIl0ge1xuICAgICAgcGFkZGluZy1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICAgIH0gXG4gIH1cbmBcblxuY29uc3QgU3R5bGVkVGV4dCA9IHN0eWxlZChUZXh0KWBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycxJ119O1xuYFxuXG50eXBlIEhlYWRlckNlbGxQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgaXNPcmRlcmVkPzogYm9vbGVhblxuICBvcmRlckRpcmVjdGlvbj86ICdhc2MnIHwgJ2Rlc2MnIHwgJ25vbmUnXG4gIG9uT3JkZXI/OiAobmV3T3JkZXI6ICdhc2MnIHwgJ2Rlc2MnKSA9PiB2b2lkXG4gIGluZm8/OiBzdHJpbmdcbiAgYWxpZ24/OiAnbGVmdCcgfCAnY2VudGVyJyB8ICdyaWdodCdcbiAgd2lkdGg/OiBzdHJpbmdcbiAgbWF4V2lkdGg/OiBzdHJpbmdcbiAgbWluV2lkdGg/OiBzdHJpbmdcbiAgaXNDaGVja2JveD86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IEhlYWRlckNlbGwgPSAoe1xuICBjaGlsZHJlbixcbiAgY2xhc3NOYW1lLFxuICBpc09yZGVyZWQsXG4gIG9uT3JkZXIsXG4gIG9yZGVyRGlyZWN0aW9uLFxuICBpbmZvLFxuICBhbGlnbixcbiAgd2lkdGgsXG4gIG1heFdpZHRoLFxuICBtaW5XaWR0aCxcbiAgaXNDaGVja2JveCxcbn06IEhlYWRlckNlbGxQcm9wcykgPT4ge1xuICBsZXQgb3JkZXI6IHVuZGVmaW5lZCB8ICdhc2NlbmRpbmcnIHwgJ2Rlc2NlbmRpbmcnXG4gIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdhc2MnKSB7XG4gICAgb3JkZXIgPSAnYXNjZW5kaW5nJ1xuICB9IGVsc2UgaWYgKGlzT3JkZXJlZCAmJiBvcmRlckRpcmVjdGlvbiA9PT0gJ2Rlc2MnKSB7XG4gICAgb3JkZXIgPSAnZGVzY2VuZGluZydcbiAgfVxuXG4gIGNvbnN0IGhhbmRsZU9yZGVyID0gb25PcmRlclxuICAgID8gKCkgPT4gb25PcmRlcihvcmRlciA9PT0gJ2FzY2VuZGluZycgPyAnZGVzYycgOiAnYXNjJylcbiAgICA6IHVuZGVmaW5lZFxuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEhlYWRlckNlbGxcbiAgICAgIGFsaWduPXthbGlnbn1cbiAgICAgIGFyaWEtc29ydD17b3JkZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtY2hlY2tib3g9e2lzQ2hlY2tib3h9XG4gICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICBtaW5XaWR0aD17bWluV2lkdGh9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVPcmRlcn1cbiAgICAgIG9uS2V5RG93bj17XG4gICAgICAgIGhhbmRsZU9yZGVyXG4gICAgICAgICAgPyBldmVudCA9PiB7XG4gICAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICcgJyB8fCBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBoYW5kbGVPcmRlcigpXG4gICAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnKSB7XG4gICAgICAgICAgICAgICAgICAvLyBAbm90ZTogaXQgYXZvaWQgc2Nyb2xsIHdoZW4gcHJlc3NpbmcgU3BhY2VcbiAgICAgICAgICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA6IHVuZGVmaW5lZFxuICAgICAgfVxuICAgICAgcm9sZT17b25PcmRlciA/ICdidXR0b24gY29sdW1uaGVhZGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgIHRhYkluZGV4PXtoYW5kbGVPcmRlciA/IDAgOiAtMX1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICA+XG4gICAgICA8U3R5bGVkVGV4dFxuICAgICAgICBhcz1cImRpdlwiXG4gICAgICAgIHNlbnRpbWVudD17b3JkZXIgIT09IHVuZGVmaW5lZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFwiXG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAge2luZm8gPyAoXG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17aW5mb30+XG4gICAgICAgICAgICA8SW5mb3JtYXRpb25PdXRsaW5lSWNvblxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7b3JkZXJEaXJlY3Rpb24gIT09IHVuZGVmaW5lZCAmJiBpc09yZGVyZWQgIT09IHVuZGVmaW5lZCA/IChcbiAgICAgICAgICA8U29ydEljb24gYXJpYS1kaXNhYmxlZD17IW9uT3JkZXJ9IG9yZGVyPXtvcmRlcn0gLz5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0eWxlZFRleHQ+XG4gICAgPC9TdHlsZWRIZWFkZXJDZWxsPlxuICApXG59XG4iXX0= */"));
54
54
  const HeaderCell = ({
55
55
  children,
56
56
  className,
@@ -61,7 +61,8 @@ const HeaderCell = ({
61
61
  align,
62
62
  width,
63
63
  maxWidth,
64
- minWidth
64
+ minWidth,
65
+ isCheckbox
65
66
  }) => {
66
67
  let order;
67
68
  if (isOrdered && orderDirection === "asc") {
@@ -70,7 +71,7 @@ const HeaderCell = ({
70
71
  order = "descending";
71
72
  }
72
73
  const handleOrder = onOrder ? () => onOrder(order === "ascending" ? "desc" : "asc") : void 0;
73
- return /* @__PURE__ */ jsxRuntime.jsx(StyledHeaderCell, { align, "aria-sort": order, className, maxWidth, minWidth, onClick: handleOrder, onKeyDown: handleOrder ? (event) => {
74
+ return /* @__PURE__ */ jsxRuntime.jsx(StyledHeaderCell, { align, "aria-sort": order, className, "data-checkbox": isCheckbox, maxWidth, minWidth, onClick: handleOrder, onKeyDown: handleOrder ? (event) => {
74
75
  if (event.key === " " || event.key === "Enter") {
75
76
  handleOrder();
76
77
  if (event.key === " ") {
@@ -10,6 +10,7 @@ type HeaderCellProps = {
10
10
  width?: string;
11
11
  maxWidth?: string;
12
12
  minWidth?: string;
13
+ isCheckbox?: boolean;
13
14
  };
14
- export declare const HeaderCell: ({ children, className, isOrdered, onOrder, orderDirection, info, align, width, maxWidth, minWidth, }: HeaderCellProps) => import("@emotion/react/jsx-runtime").JSX.Element;
15
+ export declare const HeaderCell: ({ children, className, isOrdered, onOrder, orderDirection, info, align, width, maxWidth, minWidth, isCheckbox, }: HeaderCellProps) => import("@emotion/react/jsx-runtime").JSX.Element;
15
16
  export {};