@ultraviolet/ui 2.0.0-beta.2 → 2.0.0-beta.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.
Files changed (47) hide show
  1. package/dist/components/ActionBar/index.cjs +13 -4
  2. package/dist/components/ActionBar/index.js +13 -4
  3. package/dist/components/BarChart/index.cjs +2 -35
  4. package/dist/components/BarChart/index.js +2 -35
  5. package/dist/components/CheckboxGroup/index.cjs +11 -13
  6. package/dist/components/CheckboxGroup/index.d.ts +3 -2
  7. package/dist/components/CheckboxGroup/index.js +5 -7
  8. package/dist/components/Chip/index.d.ts +1 -1
  9. package/dist/components/LineChart/index.cjs +2 -35
  10. package/dist/components/LineChart/index.js +2 -35
  11. package/dist/components/List/SelectBar.cjs +2 -28
  12. package/dist/components/List/SelectBar.js +2 -26
  13. package/dist/components/MenuV2/MenuContent.cjs +48 -14
  14. package/dist/components/MenuV2/MenuContent.d.ts +1 -0
  15. package/dist/components/MenuV2/MenuContent.js +44 -10
  16. package/dist/components/MenuV2/index.d.ts +1 -0
  17. package/dist/components/MenuV2/types.d.ts +1 -0
  18. package/dist/components/Modal/components/Dialog.cjs +5 -5
  19. package/dist/components/Modal/components/Dialog.js +5 -5
  20. package/dist/components/PieChart/index.cjs +5 -4
  21. package/dist/components/PieChart/index.js +5 -4
  22. package/dist/components/RadioGroup/index.cjs +10 -12
  23. package/dist/components/RadioGroup/index.d.ts +3 -2
  24. package/dist/components/RadioGroup/index.js +4 -6
  25. package/dist/components/SelectableCardGroup/index.cjs +9 -13
  26. package/dist/components/SelectableCardGroup/index.d.ts +3 -2
  27. package/dist/components/SelectableCardGroup/index.js +5 -9
  28. package/dist/components/Separator/index.cjs +7 -9
  29. package/dist/components/Separator/index.js +7 -9
  30. package/dist/components/Slider/components/DoubleSlider.cjs +24 -23
  31. package/dist/components/Slider/components/DoubleSlider.js +24 -23
  32. package/dist/components/Slider/components/SingleSlider.cjs +23 -12
  33. package/dist/components/Slider/components/SingleSlider.js +23 -12
  34. package/dist/components/Table/SelectBar.cjs +2 -28
  35. package/dist/components/Table/SelectBar.js +2 -26
  36. package/dist/components/ToggleGroup/index.cjs +10 -12
  37. package/dist/components/ToggleGroup/index.d.ts +3 -2
  38. package/dist/components/ToggleGroup/index.js +4 -6
  39. package/dist/helpers/nivoTheme.cjs +22 -0
  40. package/dist/helpers/nivoTheme.d.ts +20 -0
  41. package/dist/helpers/nivoTheme.js +22 -0
  42. package/dist/theme/index.cjs +2 -2
  43. package/dist/theme/index.d.ts +9 -155
  44. package/dist/theme/index.js +2 -2
  45. package/dist/utils/responsive/utilities.cjs +1 -1
  46. package/dist/utils/responsive/utilities.js +5 -5
  47. package/package.json +5 -5
@@ -17,7 +17,7 @@ const StyledDiv = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "produ
17
17
  label: "StyledDiv"
18
18
  })("width:100%;height:15rem;background-color:", ({
19
19
  theme
20
- }) => theme.colors.primary.background, ";overflow:hidden;" + (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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AAiB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n  &[data-animation='true'] {\n    overflow: hidden;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
20
+ }) => theme.colors.primary.background, ";overflow:hidden;" + (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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AAiB+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n  \n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
21
21
  const StyledImg = /* @__PURE__ */ _styled("img", process.env.NODE_ENV === "production" ? {
22
22
  target: "e1fims043"
23
23
  } : {
@@ -28,7 +28,7 @@ const StyledImg = /* @__PURE__ */ _styled("img", process.env.NODE_ENV === "produ
28
28
  styles: "margin-inline:auto;object-fit:cover;height:100%;width:100%"
29
29
  } : {
30
30
  name: "1dpiy6s",
31
- styles: "margin-inline:auto;object-fit:cover;height:100%;width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx"],"names":[],"mappings":"AAwB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n  &[data-animation='true'] {\n    overflow: hidden;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */",
31
+ styles: "margin-inline:auto;object-fit:cover;height:100%;width:100%/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx"],"names":[],"mappings":"AAwB4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n  \n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */",
32
32
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
33
33
  });
34
34
  const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
@@ -38,7 +38,7 @@ const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pro
38
38
  label: "StyledStack"
39
39
  })("padding:", ({
40
40
  theme
41
- }) => theme.space["3"], ";" + (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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AA+BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n  &[data-animation='true'] {\n    overflow: hidden;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
41
+ }) => theme.space["3"], ";" + (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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AA+BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n  \n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
42
42
  const StyledBackdrop = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
43
43
  target: "e1fims041"
44
44
  } : {
@@ -48,7 +48,7 @@ const StyledBackdrop = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "
48
48
  theme
49
49
  }) => theme.colors.overlay, ";z-index:1;opacity:0;&[data-open='true']{padding:", ({
50
50
  theme
51
- }) => theme.space["2"], ";overflow:auto;display:flex;bottom:0;left:0;height:100%;width:100%;}&[data-visible='true']{opacity:1;}&[data-animation='true']{overflow:hidden;}" + (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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AAmC2D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n  &[data-animation='true'] {\n    overflow: hidden;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
51
+ }) => theme.space["2"], ";overflow:auto;display:flex;bottom:0;left:0;height:100%;width:100%;}&[data-visible='true']{opacity: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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AAmC2D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n  \n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
52
52
  const StyledDialog = /* @__PURE__ */ _styled("dialog", process.env.NODE_ENV === "production" ? {
53
53
  shouldForwardProp: (prop) => !["position", "size", "openedModals", "top"].includes(prop),
54
54
  target: "e1fims040"
@@ -79,7 +79,7 @@ const StyledDialog = /* @__PURE__ */ _styled("dialog", process.env.NODE_ENV ===
79
79
  }) => position > 0 ? `
80
80
  width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;
81
81
  transform: translate3d(0, -${top}px, 0);
82
- ` : void 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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AA6EqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n  &[data-animation='true'] {\n    overflow: hidden;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
82
+ ` : void 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/Modal/components/Dialog.tsx"],"names":[],"mappings":"AAyEqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Modal/components/Dialog.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  FocusEventHandler,\n  KeyboardEventHandler,\n  MouseEventHandler,\n  ReactEventHandler,\n} from 'react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\nimport { createPortal } from 'react-dom'\nimport { slideFromBottom } from '../../../utils/animations'\nimport { Stack } from '../../Stack'\nimport { useModal } from '../ModalProvider'\nimport { MODAL_PLACEMENT, MODAL_WIDTH } from '../constants'\nimport type { DialogProps, ModalPlacement, ModalSize } from '../types'\n\nconst StyledDiv = styled(Stack)`\n  width: 100%;\n  height: 15rem;\n  background-color: ${({ theme }) => theme.colors.primary.background};\n  overflow: hidden;\n`\n\nconst StyledImg = styled.img`\n  margin-inline: auto;\n  object-fit: cover;\n  height: 100%;\n  width: 100%;\n`\n\nconst StyledStack = styled(Stack)`\n  padding: ${({ theme }) => theme.space['3']};\n `\n\nconst StyledBackdrop = styled.div<{ 'data-open': boolean }>`\n  position: fixed;\n  top: 0;\n  right: 0;\n  height: 0;\n  width: 0;\n  overflow: hidden;\n  background-color: ${({ theme }) => theme.colors.overlay};\n  z-index: 1;\n  opacity: 0;\n\n  &[data-open='true'] {\n    padding: ${({ theme }) => theme.space['2']};\n    overflow: auto;\n    display: flex;\n    bottom: 0;\n    left: 0;\n    height: 100%;\n    width: 100%;\n  }\n\n  &[data-visible='true'] {\n    opacity: 1;\n  }\n\n`\n\ntype StyledDialogProps = {\n  'data-size': ModalSize\n  'data-placement': ModalPlacement\n  position: number\n  size: ModalSize\n  top?: number\n}\n\nexport const StyledDialog = styled('dialog', {\n  shouldForwardProp: prop =>\n    !['position', 'size', 'openedModals', 'top'].includes(prop),\n})<StyledDialogProps>`\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.overlay};\n  position: relative;\n  border-radius: ${({ theme }) => theme.radii.default};\n  border: 0;\n  padding: ${({ theme }) => theme.space['3']};\n  width: ${MODAL_WIDTH.medium}rem;\n  box-shadow: ${({ theme }) => `${theme.shadows.overlay[0]}, ${theme.shadows.overlay[1]}`};\n  \n\n\n  ${Object.entries(MODAL_WIDTH).map(\n    ([size, value]) => `\n      &[data-size=\"${size}\"] {\n        width: ${value}rem;\n      }\n      `,\n  )}\n\n  ${Object.entries(MODAL_PLACEMENT).map(\n    ([placement, value]) => `\n        &[data-placement=\"${placement}\"] {\n          ${value}\n        }\n        `,\n  )}\n\n  &[data-has-image='true'] {\n    padding: 0;\n  }\n\n  &[data-animation='true'] {\n    animation: ${slideFromBottom} 0.3s ease-in-out forwards;\n  }\n\n  transition: width 0.3s ease-in-out, transform 0.3s ease-in-out;\n\n  ${({ position, size, top }) =>\n    position > 0\n      ? `\n    width: calc(${MODAL_WIDTH[size]}rem - ${position * 50}px) !important;\n    transform: translate3d(0, -${top}px, 0);\n  `\n      : undefined}\n`\n\n// Prevent default behaviour on Escape\nconst stopCancel: ReactEventHandler = event => {\n  event.preventDefault()\n  event.stopPropagation()\n}\n\nexport const Dialog = ({\n  children,\n  placement,\n  onClose,\n  hideOnClickOutside,\n  size,\n  id,\n  ariaLabel,\n  className,\n  'data-testid': dataTestId,\n  preventBodyScroll,\n  hideOnEsc,\n  backdropClassName,\n  dialogCss,\n  backdropCss,\n  image,\n}: DialogProps) => {\n  const [isVisible, setIsVisible] = useState(false)\n\n  const containerRef = useRef(document.createElement('div'))\n  const dialogRef = useRef<HTMLDialogElement>(null)\n  const onCloseRef = useRef(onClose)\n  const {\n    registerModal,\n    unregisterModal,\n    openedModals,\n    previsousOpenedModales,\n  } = useModal()\n\n  useEffect(() => {\n    setIsVisible(true)\n  }, [])\n\n  // register/unregister the modal to handle nested modals\n  useEffect(() => {\n    registerModal({ id, ref: dialogRef })\n\n    return () => {\n      unregisterModal(id)\n    }\n  }, [id, registerModal, unregisterModal])\n\n  // Portal to put the modal in\n  useEffect(() => {\n    const element = containerRef.current\n    document.body.appendChild(element)\n\n    return () => {\n      if (document.body.contains(element)) {\n        document.body.removeChild(element)\n      }\n    }\n  }, [])\n\n  // Save the reassignment of eventHandler in the useEffect below\n  useEffect(() => {\n    onCloseRef.current = onClose\n  }, [onClose])\n\n  // On open focus the modal\n  useEffect(() => {\n    dialogRef.current?.focus()\n  }, [])\n\n  // Handle body scroll\n  useEffect(() => {\n    const previousOverflow = document.body.style.overflow\n\n    if (preventBodyScroll) {\n      document.body.style.overflow = 'hidden'\n    }\n\n    return () => {\n      document.body.style.overflow = previousOverflow\n    }\n  }, [preventBodyScroll])\n\n  // Stop focus to prevent unexpected body loose focus\n  const stopFocus: FocusEventHandler = useCallback(event => {\n    event.stopPropagation()\n  }, [])\n\n  // We need to reverse the array as the last opened modal should be the first to be with normal size\n  // while the first opened modal should shrink\n  const realPosition = [...openedModals].findIndex(object => object.id === id)\n  const position = [...openedModals]\n    .reverse()\n    .findIndex(object => object.id === id) // reverse method mutate array so we need to create a new array\n  const modalAbove = openedModals[realPosition + 1]\n  const currentModalHeight = dialogRef.current?.offsetHeight\n  let top = 0\n\n  // handle key up : used when having inputs in modals - useful for hideOnEsc\n  const handleKeyUp: KeyboardEventHandler = useCallback(\n    event => {\n      event.stopPropagation()\n      if (event.key === 'Escape' && hideOnEsc) {\n        event.preventDefault()\n        onCloseRef.current()\n      }\n    },\n    [hideOnEsc],\n  )\n\n  const handleClose: MouseEventHandler = useCallback(\n    event => {\n      // if the user actually click outside of modal\n      if (\n        hideOnClickOutside &&\n        dialogRef.current &&\n        !dialogRef.current.contains(event.target as Node) &&\n        position === 0\n      ) {\n        onCloseRef.current()\n      }\n    },\n    [hideOnClickOutside, position],\n  )\n\n  // Enable focus trap inside the modal\n  const handleFocusTrap: KeyboardEventHandler = useCallback(event => {\n    event.stopPropagation()\n    if (event.key === 'Escape') {\n      event.preventDefault()\n\n      return\n    }\n    const isTabPressed = event.key === 'Tab'\n\n    if (!isTabPressed) {\n      return\n    }\n\n    const focusableEls =\n      dialogRef.current?.querySelectorAll(\n        'a[href]:not([disabled]), button:not([disabled]), textarea:not([disabled]), input:not([disabled]), select:not([disabled])',\n      ) ?? []\n\n    // Handle case when no interactive element are within the modal (including close icon)\n    if (focusableEls.length === 0) {\n      event.preventDefault()\n    }\n\n    const firstFocusableEl = focusableEls[0] as HTMLElement\n    const lastFocusableEl = focusableEls[focusableEls.length - 1] as HTMLElement\n\n    if (event.shiftKey) {\n      if (\n        document.activeElement === firstFocusableEl ||\n        document.activeElement === dialogRef.current\n      ) {\n        lastFocusableEl.focus()\n        event.preventDefault()\n      }\n    } else if (\n      document.activeElement === lastFocusableEl ||\n      document.activeElement === dialogRef.current\n    ) {\n      firstFocusableEl.focus()\n      event.preventDefault()\n    }\n  }, [])\n\n  if (\n    modalAbove?.ref &&\n    typeof modalAbove.ref === 'object' &&\n    'current' in modalAbove.ref &&\n    currentModalHeight\n  ) {\n    top =\n      (modalAbove?.ref?.current?.offsetHeight ?? 0) / 2 -\n      currentModalHeight / 2 +\n      20\n  }\n\n  const animation =\n    openedModals.length > 1 &&\n    position === 0 &&\n    previsousOpenedModales.length < openedModals.length\n\n  return createPortal(\n    <StyledBackdrop\n      data-open\n      onClick={handleClose}\n      className={backdropClassName}\n      css={backdropCss}\n      data-testid={dataTestId ? `${dataTestId}-backdrop` : undefined}\n      onFocus={stopFocus}\n      data-animation={animation}\n      data-visible={isVisible}\n      id=\"backdrop-modal\"\n    >\n      <StyledDialog\n        css={dialogCss}\n        onKeyUp={handleKeyUp}\n        onKeyDown={handleFocusTrap}\n        className={className}\n        id={id}\n        data-testid={dataTestId}\n        aria-label={ariaLabel}\n        data-placement={placement}\n        data-size={size}\n        open\n        onCancel={stopCancel}\n        onClose={stopCancel}\n        aria-modal\n        ref={dialogRef}\n        tabIndex={0}\n        position={position}\n        top={Math.max(top, 0)}\n        data-animation={animation}\n        size={size}\n        data-has-image={!!image}\n      >\n        {image ? (\n          <>\n            <StyledDiv alignItems=\"end\" justifyContent=\"center\">\n              <StyledImg src={image} alt=\"illustration\" />\n            </StyledDiv>\n            <StyledStack gap={5}>{children}</StyledStack>\n          </>\n        ) : (\n          children\n        )}\n      </StyledDialog>\n    </StyledBackdrop>,\n    containerRef.current,\n  )\n}\n"]} */"));
83
83
  const stopCancel = (event) => {
84
84
  event.preventDefault();
85
85
  event.stopPropagation();
@@ -7,6 +7,7 @@ const react = require("@emotion/react");
7
7
  const pie = require("@nivo/pie");
8
8
  const React = require("react");
9
9
  const legend = require("../../helpers/legend.cjs");
10
+ const nivoTheme = require("../../helpers/nivoTheme.cjs");
10
11
  const index = require("../Text/index.cjs");
11
12
  const Legends = require("./Legends.cjs");
12
13
  const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
@@ -18,7 +19,7 @@ const Container = /* @__PURE__ */ _styled__default.default("div", process.env.NO
18
19
  label: "Container"
19
20
  })("display:flex;align-items:center;height:", ({
20
21
  height
21
- }) => `${height}px`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhZ0QiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUGllQ2hhcnQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQm94IH0gZnJvbSAnQG5pdm8vY29yZSdcbmltcG9ydCB7IFBpZSB9IGZyb20gJ0BuaXZvL3BpZSdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGdldExlZ2VuZENvbG9yIH0gZnJvbSAnLi4vLi4vaGVscGVycy9sZWdlbmQnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnNSddfTtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuaGVhZGluZ1N0cm9uZ307XG4gIGxpbmUtaGVpZ2h0OiAxMDBweDtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgd2lkdGg6IDEwMHB4O1xuICBtYXJnaW46IGF1dG87XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbmBcblxudHlwZSBQaWVDaGFydFByb3BzID0ge1xuICBjaGFydFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZGF0YT86IERhdGFbXVxuICBoZWlnaHQ/OiBudW1iZXJcbiAgd2lkdGg/OiBudW1iZXJcbiAgZW1wdHlMZWdlbmQ/OiBzdHJpbmdcbiAgY29udGVudD86IFJlYWN0Tm9kZVxuICB3aXRoTGVnZW5kPzogYm9vbGVhblxuICBtYXJnaW4/OiBCb3hcbn1cblxuY29uc3QgREVGQVVMVF9DSEFSVFBST1BTID0ge31cbmNvbnN0IERFRkFVTFRfTUFSR0lOID0geyBib3R0b206IDEwLCBsZWZ0OiAxMCwgcmlnaHQ6IDEwLCB0b3A6IDEwIH1cblxuLyoqXG4gKiBQaWVDaGFydCBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgTml2byBQaWUgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBwaWUgY2hhcnQuXG4gKiBTZWUgaHR0cHM6Ly9uaXZvLnJvY2tzL3BpZS8gZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgY29tcG9uZW50IGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIHN1YmplY3QgdG8gYnJlYWtpbmcgY2hhbmdlcyBpbiB0aGUgZnV0dXJlLlxuICovXG5leHBvcnQgY29uc3QgUGllQ2hhcnQgPSAoe1xuICBoZWlnaHQgPSAyMDYsXG4gIHdpZHRoID0gMjA2LFxuICBkYXRhID0gdW5kZWZpbmVkLFxuICBlbXB0eUxlZ2VuZCxcbiAgY29udGVudCxcbiAgd2l0aExlZ2VuZCA9IGZhbHNlLFxuICBtYXJnaW4gPSBERUZBVUxUX01BUkdJTixcbiAgY2hhcnRQcm9wcyA9IERFRkFVTFRfQ0hBUlRQUk9QUyxcbn06IFBpZUNoYXJ0UHJvcHMpID0+IHtcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gIGNvbnN0IFtjdXJyZW50Rm9jdXNJbmRleCwgc2V0Q3VycmVudEZvY3VzSW5kZXhdID0gdXNlU3RhdGU8c3RyaW5nPigpXG4gIGNvbnN0IGVtcHR5VG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IDxzcGFuIC8+LCBbXSlcbiAgY29uc3QgaXNFbXB0eSA9ICFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwXG5cbiAgY29uc3QgRW1wdHlMZWdlbmREaXNwbGF5ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgZW1wdHlMZWdlbmQgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZD5cbiAgICAgICAgICA8VGV4dCB2YXJpYW50PVwiYm9keVwiIGFzPVwicFwiPlxuICAgICAgICAgICAge2VtcHR5TGVnZW5kfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9FbXB0eUxlZ2VuZD5cbiAgICAgICkgOiBudWxsLFxuICAgIFtlbXB0eUxlZ2VuZF0sXG4gIClcblxuICBjb25zdCBsb2NhbENvbG9ycyA9IGdldExlZ2VuZENvbG9yKHRoZW1lKVxuXG4gIGNvbnN0IExlZ2VuZERpc3BsYXllciA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBpc0VtcHR5ID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmREaXNwbGF5ZWQgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxMZWdlbmRzXG4gICAgICAgICAgZm9jdXNlZD17Y3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgZGF0YT17ZGF0YX1cbiAgICAgICAgICBvbkZvY3VzQ2hhbmdlPXtzZXRDdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbaXNFbXB0eSwgY3VycmVudEZvY3VzSW5kZXgsIGRhdGEsIEVtcHR5TGVnZW5kRGlzcGxheWVkLCBsb2NhbENvbG9yc10sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXIgaGVpZ2h0PXtoZWlnaHR9PlxuICAgICAgPGRpdiBzdHlsZT17eyBwb3NpdGlvbjogJ3JlbGF0aXZlJyB9fT5cbiAgICAgICAgPFBpZVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgIHZhbHVlPVwicGVyY2VudFwiXG4gICAgICAgICAgZW5hYmxlQXJjTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBlbmFibGVBcmNMaW5rTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBkYXRhPXtcbiAgICAgICAgICAgICFpc0VtcHR5XG4gICAgICAgICAgICAgID8gZGF0YVxuICAgICAgICAgICAgICA6IFtcbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgaWQ6ICdlbXB0eScsXG4gICAgICAgICAgICAgICAgICAgIHBlcmNlbnQ6IDEwMCxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXVxuICAgICAgICAgIH1cbiAgICAgICAgICBkZWZzPXtbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICdpbmhlcml0JyxcbiAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmcsXG4gICAgICAgICAgICAgIGlkOiAnbGluZXMnLFxuICAgICAgICAgICAgICBsaW5lV2lkdGg6IDIsXG4gICAgICAgICAgICAgIHJvdGF0aW9uOiAwLFxuICAgICAgICAgICAgICBzcGFjaW5nOiA1LFxuICAgICAgICAgICAgICB0eXBlOiAncGF0dGVybkxpbmVzJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXX1cbiAgICAgICAgICBtYXJnaW49e21hcmdpbn1cbiAgICAgICAgICBpbm5lclJhZGl1cz17MC44fVxuICAgICAgICAgIGNvcm5lclJhZGl1cz17MH1cbiAgICAgICAgICBwYWRBbmdsZT17MX1cbiAgICAgICAgICBhY3RpdmVPdXRlclJhZGl1c09mZnNldD17IWlzRW1wdHkgPyA0IDogMH1cbiAgICAgICAgICB0b29sdGlwPXtlbXB0eVRvb2x0aXB9XG4gICAgICAgICAgb25Nb3VzZUVudGVyPXsoZGF0dW0sIGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoIWlzRW1wdHkpIHtcbiAgICAgICAgICAgICAgY29uc3QgcGllID0gZXZlbnQuY3VycmVudFRhcmdldFxuICAgICAgICAgICAgICBwaWUuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInXG4gICAgICAgICAgICAgIHNldEN1cnJlbnRGb2N1c0luZGV4KGRhdHVtLmlkLnRvU3RyaW5nKCkpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHNldEN1cnJlbnRGb2N1c0luZGV4KHVuZGVmaW5lZCl9XG4gICAgICAgICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgICAgIC8+XG4gICAgICAgIHtjb250ZW50ID8gPFN0eWxlZENvbnRlbnQ+e2NvbnRlbnR9PC9TdHlsZWRDb250ZW50PiA6IG51bGx9XG4gICAgICA8L2Rpdj5cbiAgICAgIHt3aXRoTGVnZW5kID8gPExlZ2VuZERpc3BsYXllciAvPiA6IG51bGx9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cbiJdfQ== */"));
22
+ }) => `${height}px`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjZ0QiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUGllQ2hhcnQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQm94IH0gZnJvbSAnQG5pdm8vY29yZSdcbmltcG9ydCB7IFBpZSB9IGZyb20gJ0BuaXZvL3BpZSdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGdldExlZ2VuZENvbG9yIH0gZnJvbSAnLi4vLi4vaGVscGVycy9sZWdlbmQnXG5pbXBvcnQgeyBnZXROaXZvVGhlbWUgfSBmcm9tICcuLi8uLi9oZWxwZXJzL25pdm9UaGVtZSdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IExlZ2VuZHMgZnJvbSAnLi9MZWdlbmRzJ1xuaW1wb3J0IHR5cGUgeyBEYXRhIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdjx7IGhlaWdodDogbnVtYmVyIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBoZWlnaHQ6ICR7KHsgaGVpZ2h0IH0pID0+IGAke2hlaWdodH1weGB9O1xuYFxuXG5jb25zdCBFbXB0eUxlZ2VuZCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyc1J119O1xuYFxuXG5jb25zdCBTdHlsZWRDb250ZW50ID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGJvdHRvbTogMDtcbiAgbGVmdDogMDtcbiAgcmlnaHQ6IDA7XG4gIHRvcDogMDtcblxuICBmb250LXNpemU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5oZWFkaW5nU3Ryb25nfTtcbiAgbGluZS1oZWlnaHQ6IDEwMHB4O1xuICBoZWlnaHQ6IDEwMHB4O1xuICB3aWR0aDogMTAwcHg7XG4gIG1hcmdpbjogYXV0bztcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB2ZXJ0aWNhbC1hbGlnbjogbWlkZGxlO1xuYFxuXG50eXBlIFBpZUNoYXJ0UHJvcHMgPSB7XG4gIGNoYXJ0UHJvcHM/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPlxuICBkYXRhPzogRGF0YVtdXG4gIGhlaWdodD86IG51bWJlclxuICB3aWR0aD86IG51bWJlclxuICBlbXB0eUxlZ2VuZD86IHN0cmluZ1xuICBjb250ZW50PzogUmVhY3ROb2RlXG4gIHdpdGhMZWdlbmQ/OiBib29sZWFuXG4gIG1hcmdpbj86IEJveFxufVxuXG5jb25zdCBERUZBVUxUX0NIQVJUUFJPUFMgPSB7fVxuY29uc3QgREVGQVVMVF9NQVJHSU4gPSB7IGJvdHRvbTogMTAsIGxlZnQ6IDEwLCByaWdodDogMTAsIHRvcDogMTAgfVxuXG4vKipcbiAqIFBpZUNoYXJ0IGNvbXBvbmVudCBpcyBhIHdyYXBwZXIgYXJvdW5kIHRoZSBOaXZvIFBpZSBjb21wb25lbnQgdG8gZGlzcGxheSBhIHBpZSBjaGFydC5cbiAqIFNlZSBodHRwczovL25pdm8ucm9ja3MvcGllLyBmb3IgbW9yZSBpbmZvcm1hdGlvbi5cbiAqIEBleHBlcmltZW50YWwgVGhpcyBjb21wb25lbnQgaXMgZXhwZXJpbWVudGFsIGFuZCBtYXkgYmUgc3ViamVjdCB0byBicmVha2luZyBjaGFuZ2VzIGluIHRoZSBmdXR1cmUuXG4gKi9cbmV4cG9ydCBjb25zdCBQaWVDaGFydCA9ICh7XG4gIGhlaWdodCA9IDIwNixcbiAgd2lkdGggPSAyMDYsXG4gIGRhdGEgPSB1bmRlZmluZWQsXG4gIGVtcHR5TGVnZW5kLFxuICBjb250ZW50LFxuICB3aXRoTGVnZW5kID0gZmFsc2UsXG4gIG1hcmdpbiA9IERFRkFVTFRfTUFSR0lOLFxuICBjaGFydFByb3BzID0gREVGQVVMVF9DSEFSVFBST1BTLFxufTogUGllQ2hhcnRQcm9wcykgPT4ge1xuICBjb25zdCB0aGVtZSA9IHVzZVRoZW1lKClcbiAgY29uc3QgW2N1cnJlbnRGb2N1c0luZGV4LCBzZXRDdXJyZW50Rm9jdXNJbmRleF0gPSB1c2VTdGF0ZTxzdHJpbmc+KClcbiAgY29uc3QgZW1wdHlUb29sdGlwID0gdXNlQ2FsbGJhY2soKCkgPT4gPHNwYW4gLz4sIFtdKVxuICBjb25zdCBpc0VtcHR5ID0gIWRhdGEgfHwgZGF0YS5sZW5ndGggPT09IDBcblxuICBjb25zdCBFbXB0eUxlZ2VuZERpc3BsYXllZCA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBlbXB0eUxlZ2VuZCA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kPlxuICAgICAgICAgIDxUZXh0IHZhcmlhbnQ9XCJib2R5XCIgYXM9XCJwXCI+XG4gICAgICAgICAgICB7ZW1wdHlMZWdlbmR9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0VtcHR5TGVnZW5kPlxuICAgICAgKSA6IG51bGwsXG4gICAgW2VtcHR5TGVnZW5kXSxcbiAgKVxuXG4gIGNvbnN0IGxvY2FsQ29sb3JzID0gZ2V0TGVnZW5kQ29sb3IodGhlbWUpXG5cbiAgY29uc3QgTGVnZW5kRGlzcGxheWVyID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGlzRW1wdHkgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZERpc3BsYXllZCAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPExlZ2VuZHNcbiAgICAgICAgICBmb2N1c2VkPXtjdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBkYXRhPXtkYXRhfVxuICAgICAgICAgIG9uRm9jdXNDaGFuZ2U9e3NldEN1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgIC8+XG4gICAgICApLFxuICAgIFtpc0VtcHR5LCBjdXJyZW50Rm9jdXNJbmRleCwgZGF0YSwgRW1wdHlMZWdlbmREaXNwbGF5ZWQsIGxvY2FsQ29sb3JzXSxcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lciBoZWlnaHQ9e2hlaWdodH0+XG4gICAgICA8ZGl2IHN0eWxlPXt7IHBvc2l0aW9uOiAncmVsYXRpdmUnIH19PlxuICAgICAgICA8UGllXG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgICBoZWlnaHQ9e2hlaWdodH1cbiAgICAgICAgICB3aWR0aD17d2lkdGh9XG4gICAgICAgICAgdmFsdWU9XCJwZXJjZW50XCJcbiAgICAgICAgICBlbmFibGVBcmNMYWJlbHM9e2ZhbHNlfVxuICAgICAgICAgIGVuYWJsZUFyY0xpbmtMYWJlbHM9e2ZhbHNlfVxuICAgICAgICAgIGRhdGE9e1xuICAgICAgICAgICAgIWlzRW1wdHlcbiAgICAgICAgICAgICAgPyBkYXRhXG4gICAgICAgICAgICAgIDogW1xuICAgICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICBpZDogJ2VtcHR5JyxcbiAgICAgICAgICAgICAgICAgICAgcGVyY2VudDogMTAwLFxuICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBdXG4gICAgICAgICAgfVxuICAgICAgICAgIGRlZnM9e1tcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgYmFja2dyb3VuZDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgICBjb2xvcjogdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFN0cm9uZyxcbiAgICAgICAgICAgICAgaWQ6ICdsaW5lcycsXG4gICAgICAgICAgICAgIGxpbmVXaWR0aDogMixcbiAgICAgICAgICAgICAgcm90YXRpb246IDAsXG4gICAgICAgICAgICAgIHNwYWNpbmc6IDUsXG4gICAgICAgICAgICAgIHR5cGU6ICdwYXR0ZXJuTGluZXMnLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICBdfVxuICAgICAgICAgIG1hcmdpbj17bWFyZ2lufVxuICAgICAgICAgIGlubmVyUmFkaXVzPXswLjh9XG4gICAgICAgICAgY29ybmVyUmFkaXVzPXswfVxuICAgICAgICAgIHBhZEFuZ2xlPXsxfVxuICAgICAgICAgIGFjdGl2ZU91dGVyUmFkaXVzT2Zmc2V0PXshaXNFbXB0eSA/IDQgOiAwfVxuICAgICAgICAgIHRvb2x0aXA9e2VtcHR5VG9vbHRpcH1cbiAgICAgICAgICBvbk1vdXNlRW50ZXI9eyhkYXR1bSwgZXZlbnQpID0+IHtcbiAgICAgICAgICAgIGlmICghaXNFbXB0eSkge1xuICAgICAgICAgICAgICBjb25zdCBwaWUgPSBldmVudC5jdXJyZW50VGFyZ2V0XG4gICAgICAgICAgICAgIHBpZS5zdHlsZS5jdXJzb3IgPSAncG9pbnRlcidcbiAgICAgICAgICAgICAgc2V0Q3VycmVudEZvY3VzSW5kZXgoZGF0dW0uaWQudG9TdHJpbmcoKSlcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIG9uTW91c2VMZWF2ZT17KCkgPT4gc2V0Q3VycmVudEZvY3VzSW5kZXgodW5kZWZpbmVkKX1cbiAgICAgICAgICB0aGVtZT17Z2V0Tml2b1RoZW1lKHRoZW1lKX1cbiAgICAgICAgICB7Li4uY2hhcnRQcm9wc31cbiAgICAgICAgLz5cbiAgICAgICAge2NvbnRlbnQgPyA8U3R5bGVkQ29udGVudD57Y29udGVudH08L1N0eWxlZENvbnRlbnQ+IDogbnVsbH1cbiAgICAgIDwvZGl2PlxuICAgICAge3dpdGhMZWdlbmQgPyA8TGVnZW5kRGlzcGxheWVyIC8+IDogbnVsbH1cbiAgICA8L0NvbnRhaW5lcj5cbiAgKVxufVxuIl19 */"));
22
23
  const EmptyLegend = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
23
24
  target: "epjfe5p1"
24
25
  } : {
@@ -26,7 +27,7 @@ const EmptyLegend = /* @__PURE__ */ _styled__default.default("div", process.env.
26
27
  label: "EmptyLegend"
27
28
  })("display:flex;align-items:center;margin-left:", ({
28
29
  theme
29
- }) => theme.space["5"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgTGVnZW5kcyBmcm9tICcuL0xlZ2VuZHMnXG5pbXBvcnQgdHlwZSB7IERhdGEgfSBmcm9tICcuL3R5cGVzJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2PHsgaGVpZ2h0OiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGhlaWdodDogJHsoeyBoZWlnaHQgfSkgPT4gYCR7aGVpZ2h0fXB4YH07XG5gXG5cbmNvbnN0IEVtcHR5TGVnZW5kID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG5gXG5cbmNvbnN0IFN0eWxlZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgYm90dG9tOiAwO1xuICBsZWZ0OiAwO1xuICByaWdodDogMDtcbiAgdG9wOiAwO1xuXG4gIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmhlYWRpbmdTdHJvbmd9O1xuICBsaW5lLWhlaWdodDogMTAwcHg7XG4gIGhlaWdodDogMTAwcHg7XG4gIHdpZHRoOiAxMDBweDtcbiAgbWFyZ2luOiBhdXRvO1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG5gXG5cbnR5cGUgUGllQ2hhcnRQcm9wcyA9IHtcbiAgY2hhcnRQcm9wcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gIGRhdGE/OiBEYXRhW11cbiAgaGVpZ2h0PzogbnVtYmVyXG4gIHdpZHRoPzogbnVtYmVyXG4gIGVtcHR5TGVnZW5kPzogc3RyaW5nXG4gIGNvbnRlbnQ/OiBSZWFjdE5vZGVcbiAgd2l0aExlZ2VuZD86IGJvb2xlYW5cbiAgbWFyZ2luPzogQm94XG59XG5cbmNvbnN0IERFRkFVTFRfQ0hBUlRQUk9QUyA9IHt9XG5jb25zdCBERUZBVUxUX01BUkdJTiA9IHsgYm90dG9tOiAxMCwgbGVmdDogMTAsIHJpZ2h0OiAxMCwgdG9wOiAxMCB9XG5cbi8qKlxuICogUGllQ2hhcnQgY29tcG9uZW50IGlzIGEgd3JhcHBlciBhcm91bmQgdGhlIE5pdm8gUGllIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgcGllIGNoYXJ0LlxuICogU2VlIGh0dHBzOi8vbml2by5yb2Nrcy9waWUvIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGNvbXBvbmVudCBpcyBleHBlcmltZW50YWwgYW5kIG1heSBiZSBzdWJqZWN0IHRvIGJyZWFraW5nIGNoYW5nZXMgaW4gdGhlIGZ1dHVyZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBpZUNoYXJ0ID0gKHtcbiAgaGVpZ2h0ID0gMjA2LFxuICB3aWR0aCA9IDIwNixcbiAgZGF0YSA9IHVuZGVmaW5lZCxcbiAgZW1wdHlMZWdlbmQsXG4gIGNvbnRlbnQsXG4gIHdpdGhMZWdlbmQgPSBmYWxzZSxcbiAgbWFyZ2luID0gREVGQVVMVF9NQVJHSU4sXG4gIGNoYXJ0UHJvcHMgPSBERUZBVUxUX0NIQVJUUFJPUFMsXG59OiBQaWVDaGFydFByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICBjb25zdCBbY3VycmVudEZvY3VzSW5kZXgsIHNldEN1cnJlbnRGb2N1c0luZGV4XSA9IHVzZVN0YXRlPHN0cmluZz4oKVxuICBjb25zdCBlbXB0eVRvb2x0aXAgPSB1c2VDYWxsYmFjaygoKSA9PiA8c3BhbiAvPiwgW10pXG4gIGNvbnN0IGlzRW1wdHkgPSAhZGF0YSB8fCBkYXRhLmxlbmd0aCA9PT0gMFxuXG4gIGNvbnN0IEVtcHR5TGVnZW5kRGlzcGxheWVkID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGVtcHR5TGVnZW5kID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmQ+XG4gICAgICAgICAgPFRleHQgdmFyaWFudD1cImJvZHlcIiBhcz1cInBcIj5cbiAgICAgICAgICAgIHtlbXB0eUxlZ2VuZH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRW1wdHlMZWdlbmQ+XG4gICAgICApIDogbnVsbCxcbiAgICBbZW1wdHlMZWdlbmRdLFxuICApXG5cbiAgY29uc3QgbG9jYWxDb2xvcnMgPSBnZXRMZWdlbmRDb2xvcih0aGVtZSlcblxuICBjb25zdCBMZWdlbmREaXNwbGF5ZXIgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgaXNFbXB0eSA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kRGlzcGxheWVkIC8+XG4gICAgICApIDogKFxuICAgICAgICA8TGVnZW5kc1xuICAgICAgICAgIGZvY3VzZWQ9e2N1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGRhdGE9e2RhdGF9XG4gICAgICAgICAgb25Gb2N1c0NoYW5nZT17c2V0Q3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgLz5cbiAgICAgICksXG4gICAgW2lzRW1wdHksIGN1cnJlbnRGb2N1c0luZGV4LCBkYXRhLCBFbXB0eUxlZ2VuZERpc3BsYXllZCwgbG9jYWxDb2xvcnNdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyIGhlaWdodD17aGVpZ2h0fT5cbiAgICAgIDxkaXYgc3R5bGU9e3sgcG9zaXRpb246ICdyZWxhdGl2ZScgfX0+XG4gICAgICAgIDxQaWVcbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICB2YWx1ZT1cInBlcmNlbnRcIlxuICAgICAgICAgIGVuYWJsZUFyY0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZW5hYmxlQXJjTGlua0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZGF0YT17XG4gICAgICAgICAgICAhaXNFbXB0eVxuICAgICAgICAgICAgICA/IGRhdGFcbiAgICAgICAgICAgICAgOiBbXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGlkOiAnZW1wdHknLFxuICAgICAgICAgICAgICAgICAgICBwZXJjZW50OiAxMDAsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICB9XG4gICAgICAgICAgZGVmcz17W1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBiYWNrZ3JvdW5kOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICAgIGNvbG9yOiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0U3Ryb25nLFxuICAgICAgICAgICAgICBpZDogJ2xpbmVzJyxcbiAgICAgICAgICAgICAgbGluZVdpZHRoOiAyLFxuICAgICAgICAgICAgICByb3RhdGlvbjogMCxcbiAgICAgICAgICAgICAgc3BhY2luZzogNSxcbiAgICAgICAgICAgICAgdHlwZTogJ3BhdHRlcm5MaW5lcycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF19XG4gICAgICAgICAgbWFyZ2luPXttYXJnaW59XG4gICAgICAgICAgaW5uZXJSYWRpdXM9ezAuOH1cbiAgICAgICAgICBjb3JuZXJSYWRpdXM9ezB9XG4gICAgICAgICAgcGFkQW5nbGU9ezF9XG4gICAgICAgICAgYWN0aXZlT3V0ZXJSYWRpdXNPZmZzZXQ9eyFpc0VtcHR5ID8gNCA6IDB9XG4gICAgICAgICAgdG9vbHRpcD17ZW1wdHlUb29sdGlwfVxuICAgICAgICAgIG9uTW91c2VFbnRlcj17KGRhdHVtLCBldmVudCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFpc0VtcHR5KSB7XG4gICAgICAgICAgICAgIGNvbnN0IHBpZSA9IGV2ZW50LmN1cnJlbnRUYXJnZXRcbiAgICAgICAgICAgICAgcGllLnN0eWxlLmN1cnNvciA9ICdwb2ludGVyJ1xuICAgICAgICAgICAgICBzZXRDdXJyZW50Rm9jdXNJbmRleChkYXR1bS5pZC50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiBzZXRDdXJyZW50Rm9jdXNJbmRleCh1bmRlZmluZWQpfVxuICAgICAgICAgIHsuLi5jaGFydFByb3BzfVxuICAgICAgICAvPlxuICAgICAgICB7Y29udGVudCA/IDxTdHlsZWRDb250ZW50Pntjb250ZW50fTwvU3R5bGVkQ29udGVudD4gOiBudWxsfVxuICAgICAgPC9kaXY+XG4gICAgICB7d2l0aExlZ2VuZCA/IDxMZWdlbmREaXNwbGF5ZXIgLz4gOiBudWxsfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG4iXX0= */"));
30
+ }) => theme.space["5"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgZ2V0Tml2b1RoZW1lIH0gZnJvbSAnLi4vLi4vaGVscGVycy9uaXZvVGhlbWUnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnNSddfTtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuaGVhZGluZ1N0cm9uZ307XG4gIGxpbmUtaGVpZ2h0OiAxMDBweDtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgd2lkdGg6IDEwMHB4O1xuICBtYXJnaW46IGF1dG87XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbmBcblxudHlwZSBQaWVDaGFydFByb3BzID0ge1xuICBjaGFydFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZGF0YT86IERhdGFbXVxuICBoZWlnaHQ/OiBudW1iZXJcbiAgd2lkdGg/OiBudW1iZXJcbiAgZW1wdHlMZWdlbmQ/OiBzdHJpbmdcbiAgY29udGVudD86IFJlYWN0Tm9kZVxuICB3aXRoTGVnZW5kPzogYm9vbGVhblxuICBtYXJnaW4/OiBCb3hcbn1cblxuY29uc3QgREVGQVVMVF9DSEFSVFBST1BTID0ge31cbmNvbnN0IERFRkFVTFRfTUFSR0lOID0geyBib3R0b206IDEwLCBsZWZ0OiAxMCwgcmlnaHQ6IDEwLCB0b3A6IDEwIH1cblxuLyoqXG4gKiBQaWVDaGFydCBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgTml2byBQaWUgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBwaWUgY2hhcnQuXG4gKiBTZWUgaHR0cHM6Ly9uaXZvLnJvY2tzL3BpZS8gZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgY29tcG9uZW50IGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIHN1YmplY3QgdG8gYnJlYWtpbmcgY2hhbmdlcyBpbiB0aGUgZnV0dXJlLlxuICovXG5leHBvcnQgY29uc3QgUGllQ2hhcnQgPSAoe1xuICBoZWlnaHQgPSAyMDYsXG4gIHdpZHRoID0gMjA2LFxuICBkYXRhID0gdW5kZWZpbmVkLFxuICBlbXB0eUxlZ2VuZCxcbiAgY29udGVudCxcbiAgd2l0aExlZ2VuZCA9IGZhbHNlLFxuICBtYXJnaW4gPSBERUZBVUxUX01BUkdJTixcbiAgY2hhcnRQcm9wcyA9IERFRkFVTFRfQ0hBUlRQUk9QUyxcbn06IFBpZUNoYXJ0UHJvcHMpID0+IHtcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gIGNvbnN0IFtjdXJyZW50Rm9jdXNJbmRleCwgc2V0Q3VycmVudEZvY3VzSW5kZXhdID0gdXNlU3RhdGU8c3RyaW5nPigpXG4gIGNvbnN0IGVtcHR5VG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IDxzcGFuIC8+LCBbXSlcbiAgY29uc3QgaXNFbXB0eSA9ICFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwXG5cbiAgY29uc3QgRW1wdHlMZWdlbmREaXNwbGF5ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgZW1wdHlMZWdlbmQgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZD5cbiAgICAgICAgICA8VGV4dCB2YXJpYW50PVwiYm9keVwiIGFzPVwicFwiPlxuICAgICAgICAgICAge2VtcHR5TGVnZW5kfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9FbXB0eUxlZ2VuZD5cbiAgICAgICkgOiBudWxsLFxuICAgIFtlbXB0eUxlZ2VuZF0sXG4gIClcblxuICBjb25zdCBsb2NhbENvbG9ycyA9IGdldExlZ2VuZENvbG9yKHRoZW1lKVxuXG4gIGNvbnN0IExlZ2VuZERpc3BsYXllciA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBpc0VtcHR5ID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmREaXNwbGF5ZWQgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxMZWdlbmRzXG4gICAgICAgICAgZm9jdXNlZD17Y3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgZGF0YT17ZGF0YX1cbiAgICAgICAgICBvbkZvY3VzQ2hhbmdlPXtzZXRDdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbaXNFbXB0eSwgY3VycmVudEZvY3VzSW5kZXgsIGRhdGEsIEVtcHR5TGVnZW5kRGlzcGxheWVkLCBsb2NhbENvbG9yc10sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXIgaGVpZ2h0PXtoZWlnaHR9PlxuICAgICAgPGRpdiBzdHlsZT17eyBwb3NpdGlvbjogJ3JlbGF0aXZlJyB9fT5cbiAgICAgICAgPFBpZVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgIHZhbHVlPVwicGVyY2VudFwiXG4gICAgICAgICAgZW5hYmxlQXJjTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBlbmFibGVBcmNMaW5rTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBkYXRhPXtcbiAgICAgICAgICAgICFpc0VtcHR5XG4gICAgICAgICAgICAgID8gZGF0YVxuICAgICAgICAgICAgICA6IFtcbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgaWQ6ICdlbXB0eScsXG4gICAgICAgICAgICAgICAgICAgIHBlcmNlbnQ6IDEwMCxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXVxuICAgICAgICAgIH1cbiAgICAgICAgICBkZWZzPXtbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICdpbmhlcml0JyxcbiAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmcsXG4gICAgICAgICAgICAgIGlkOiAnbGluZXMnLFxuICAgICAgICAgICAgICBsaW5lV2lkdGg6IDIsXG4gICAgICAgICAgICAgIHJvdGF0aW9uOiAwLFxuICAgICAgICAgICAgICBzcGFjaW5nOiA1LFxuICAgICAgICAgICAgICB0eXBlOiAncGF0dGVybkxpbmVzJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXX1cbiAgICAgICAgICBtYXJnaW49e21hcmdpbn1cbiAgICAgICAgICBpbm5lclJhZGl1cz17MC44fVxuICAgICAgICAgIGNvcm5lclJhZGl1cz17MH1cbiAgICAgICAgICBwYWRBbmdsZT17MX1cbiAgICAgICAgICBhY3RpdmVPdXRlclJhZGl1c09mZnNldD17IWlzRW1wdHkgPyA0IDogMH1cbiAgICAgICAgICB0b29sdGlwPXtlbXB0eVRvb2x0aXB9XG4gICAgICAgICAgb25Nb3VzZUVudGVyPXsoZGF0dW0sIGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoIWlzRW1wdHkpIHtcbiAgICAgICAgICAgICAgY29uc3QgcGllID0gZXZlbnQuY3VycmVudFRhcmdldFxuICAgICAgICAgICAgICBwaWUuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInXG4gICAgICAgICAgICAgIHNldEN1cnJlbnRGb2N1c0luZGV4KGRhdHVtLmlkLnRvU3RyaW5nKCkpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHNldEN1cnJlbnRGb2N1c0luZGV4KHVuZGVmaW5lZCl9XG4gICAgICAgICAgdGhlbWU9e2dldE5pdm9UaGVtZSh0aGVtZSl9XG4gICAgICAgICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgICAgIC8+XG4gICAgICAgIHtjb250ZW50ID8gPFN0eWxlZENvbnRlbnQ+e2NvbnRlbnR9PC9TdHlsZWRDb250ZW50PiA6IG51bGx9XG4gICAgICA8L2Rpdj5cbiAgICAgIHt3aXRoTGVnZW5kID8gPExlZ2VuZERpc3BsYXllciAvPiA6IG51bGx9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cbiJdfQ== */"));
30
31
  const StyledContent = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
31
32
  target: "epjfe5p0"
32
33
  } : {
@@ -34,7 +35,7 @@ const StyledContent = /* @__PURE__ */ _styled__default.default("div", process.en
34
35
  label: "StyledContent"
35
36
  })("display:inline-block;position:absolute;bottom:0;left:0;right:0;top:0;font-size:", ({
36
37
  theme
37
- }) => theme.typography.headingStrong, ";line-height:100px;height:100px;width:100px;margin:auto;text-align:center;vertical-align:middle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QmdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgTGVnZW5kcyBmcm9tICcuL0xlZ2VuZHMnXG5pbXBvcnQgdHlwZSB7IERhdGEgfSBmcm9tICcuL3R5cGVzJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2PHsgaGVpZ2h0OiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGhlaWdodDogJHsoeyBoZWlnaHQgfSkgPT4gYCR7aGVpZ2h0fXB4YH07XG5gXG5cbmNvbnN0IEVtcHR5TGVnZW5kID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG5gXG5cbmNvbnN0IFN0eWxlZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgYm90dG9tOiAwO1xuICBsZWZ0OiAwO1xuICByaWdodDogMDtcbiAgdG9wOiAwO1xuXG4gIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmhlYWRpbmdTdHJvbmd9O1xuICBsaW5lLWhlaWdodDogMTAwcHg7XG4gIGhlaWdodDogMTAwcHg7XG4gIHdpZHRoOiAxMDBweDtcbiAgbWFyZ2luOiBhdXRvO1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG5gXG5cbnR5cGUgUGllQ2hhcnRQcm9wcyA9IHtcbiAgY2hhcnRQcm9wcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gIGRhdGE/OiBEYXRhW11cbiAgaGVpZ2h0PzogbnVtYmVyXG4gIHdpZHRoPzogbnVtYmVyXG4gIGVtcHR5TGVnZW5kPzogc3RyaW5nXG4gIGNvbnRlbnQ/OiBSZWFjdE5vZGVcbiAgd2l0aExlZ2VuZD86IGJvb2xlYW5cbiAgbWFyZ2luPzogQm94XG59XG5cbmNvbnN0IERFRkFVTFRfQ0hBUlRQUk9QUyA9IHt9XG5jb25zdCBERUZBVUxUX01BUkdJTiA9IHsgYm90dG9tOiAxMCwgbGVmdDogMTAsIHJpZ2h0OiAxMCwgdG9wOiAxMCB9XG5cbi8qKlxuICogUGllQ2hhcnQgY29tcG9uZW50IGlzIGEgd3JhcHBlciBhcm91bmQgdGhlIE5pdm8gUGllIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgcGllIGNoYXJ0LlxuICogU2VlIGh0dHBzOi8vbml2by5yb2Nrcy9waWUvIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGNvbXBvbmVudCBpcyBleHBlcmltZW50YWwgYW5kIG1heSBiZSBzdWJqZWN0IHRvIGJyZWFraW5nIGNoYW5nZXMgaW4gdGhlIGZ1dHVyZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBpZUNoYXJ0ID0gKHtcbiAgaGVpZ2h0ID0gMjA2LFxuICB3aWR0aCA9IDIwNixcbiAgZGF0YSA9IHVuZGVmaW5lZCxcbiAgZW1wdHlMZWdlbmQsXG4gIGNvbnRlbnQsXG4gIHdpdGhMZWdlbmQgPSBmYWxzZSxcbiAgbWFyZ2luID0gREVGQVVMVF9NQVJHSU4sXG4gIGNoYXJ0UHJvcHMgPSBERUZBVUxUX0NIQVJUUFJPUFMsXG59OiBQaWVDaGFydFByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICBjb25zdCBbY3VycmVudEZvY3VzSW5kZXgsIHNldEN1cnJlbnRGb2N1c0luZGV4XSA9IHVzZVN0YXRlPHN0cmluZz4oKVxuICBjb25zdCBlbXB0eVRvb2x0aXAgPSB1c2VDYWxsYmFjaygoKSA9PiA8c3BhbiAvPiwgW10pXG4gIGNvbnN0IGlzRW1wdHkgPSAhZGF0YSB8fCBkYXRhLmxlbmd0aCA9PT0gMFxuXG4gIGNvbnN0IEVtcHR5TGVnZW5kRGlzcGxheWVkID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGVtcHR5TGVnZW5kID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmQ+XG4gICAgICAgICAgPFRleHQgdmFyaWFudD1cImJvZHlcIiBhcz1cInBcIj5cbiAgICAgICAgICAgIHtlbXB0eUxlZ2VuZH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRW1wdHlMZWdlbmQ+XG4gICAgICApIDogbnVsbCxcbiAgICBbZW1wdHlMZWdlbmRdLFxuICApXG5cbiAgY29uc3QgbG9jYWxDb2xvcnMgPSBnZXRMZWdlbmRDb2xvcih0aGVtZSlcblxuICBjb25zdCBMZWdlbmREaXNwbGF5ZXIgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgaXNFbXB0eSA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kRGlzcGxheWVkIC8+XG4gICAgICApIDogKFxuICAgICAgICA8TGVnZW5kc1xuICAgICAgICAgIGZvY3VzZWQ9e2N1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGRhdGE9e2RhdGF9XG4gICAgICAgICAgb25Gb2N1c0NoYW5nZT17c2V0Q3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgLz5cbiAgICAgICksXG4gICAgW2lzRW1wdHksIGN1cnJlbnRGb2N1c0luZGV4LCBkYXRhLCBFbXB0eUxlZ2VuZERpc3BsYXllZCwgbG9jYWxDb2xvcnNdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyIGhlaWdodD17aGVpZ2h0fT5cbiAgICAgIDxkaXYgc3R5bGU9e3sgcG9zaXRpb246ICdyZWxhdGl2ZScgfX0+XG4gICAgICAgIDxQaWVcbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICB2YWx1ZT1cInBlcmNlbnRcIlxuICAgICAgICAgIGVuYWJsZUFyY0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZW5hYmxlQXJjTGlua0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZGF0YT17XG4gICAgICAgICAgICAhaXNFbXB0eVxuICAgICAgICAgICAgICA/IGRhdGFcbiAgICAgICAgICAgICAgOiBbXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGlkOiAnZW1wdHknLFxuICAgICAgICAgICAgICAgICAgICBwZXJjZW50OiAxMDAsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICB9XG4gICAgICAgICAgZGVmcz17W1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBiYWNrZ3JvdW5kOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICAgIGNvbG9yOiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0U3Ryb25nLFxuICAgICAgICAgICAgICBpZDogJ2xpbmVzJyxcbiAgICAgICAgICAgICAgbGluZVdpZHRoOiAyLFxuICAgICAgICAgICAgICByb3RhdGlvbjogMCxcbiAgICAgICAgICAgICAgc3BhY2luZzogNSxcbiAgICAgICAgICAgICAgdHlwZTogJ3BhdHRlcm5MaW5lcycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF19XG4gICAgICAgICAgbWFyZ2luPXttYXJnaW59XG4gICAgICAgICAgaW5uZXJSYWRpdXM9ezAuOH1cbiAgICAgICAgICBjb3JuZXJSYWRpdXM9ezB9XG4gICAgICAgICAgcGFkQW5nbGU9ezF9XG4gICAgICAgICAgYWN0aXZlT3V0ZXJSYWRpdXNPZmZzZXQ9eyFpc0VtcHR5ID8gNCA6IDB9XG4gICAgICAgICAgdG9vbHRpcD17ZW1wdHlUb29sdGlwfVxuICAgICAgICAgIG9uTW91c2VFbnRlcj17KGRhdHVtLCBldmVudCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFpc0VtcHR5KSB7XG4gICAgICAgICAgICAgIGNvbnN0IHBpZSA9IGV2ZW50LmN1cnJlbnRUYXJnZXRcbiAgICAgICAgICAgICAgcGllLnN0eWxlLmN1cnNvciA9ICdwb2ludGVyJ1xuICAgICAgICAgICAgICBzZXRDdXJyZW50Rm9jdXNJbmRleChkYXR1bS5pZC50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiBzZXRDdXJyZW50Rm9jdXNJbmRleCh1bmRlZmluZWQpfVxuICAgICAgICAgIHsuLi5jaGFydFByb3BzfVxuICAgICAgICAvPlxuICAgICAgICB7Y29udGVudCA/IDxTdHlsZWRDb250ZW50Pntjb250ZW50fTwvU3R5bGVkQ29udGVudD4gOiBudWxsfVxuICAgICAgPC9kaXY+XG4gICAgICB7d2l0aExlZ2VuZCA/IDxMZWdlbmREaXNwbGF5ZXIgLz4gOiBudWxsfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG4iXX0= */"));
38
+ }) => theme.typography.headingStrong, ";line-height:100px;height:100px;width:100px;margin:auto;text-align:center;vertical-align:middle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQmdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgZ2V0Tml2b1RoZW1lIH0gZnJvbSAnLi4vLi4vaGVscGVycy9uaXZvVGhlbWUnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnNSddfTtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuaGVhZGluZ1N0cm9uZ307XG4gIGxpbmUtaGVpZ2h0OiAxMDBweDtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgd2lkdGg6IDEwMHB4O1xuICBtYXJnaW46IGF1dG87XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbmBcblxudHlwZSBQaWVDaGFydFByb3BzID0ge1xuICBjaGFydFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZGF0YT86IERhdGFbXVxuICBoZWlnaHQ/OiBudW1iZXJcbiAgd2lkdGg/OiBudW1iZXJcbiAgZW1wdHlMZWdlbmQ/OiBzdHJpbmdcbiAgY29udGVudD86IFJlYWN0Tm9kZVxuICB3aXRoTGVnZW5kPzogYm9vbGVhblxuICBtYXJnaW4/OiBCb3hcbn1cblxuY29uc3QgREVGQVVMVF9DSEFSVFBST1BTID0ge31cbmNvbnN0IERFRkFVTFRfTUFSR0lOID0geyBib3R0b206IDEwLCBsZWZ0OiAxMCwgcmlnaHQ6IDEwLCB0b3A6IDEwIH1cblxuLyoqXG4gKiBQaWVDaGFydCBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgTml2byBQaWUgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBwaWUgY2hhcnQuXG4gKiBTZWUgaHR0cHM6Ly9uaXZvLnJvY2tzL3BpZS8gZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgY29tcG9uZW50IGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIHN1YmplY3QgdG8gYnJlYWtpbmcgY2hhbmdlcyBpbiB0aGUgZnV0dXJlLlxuICovXG5leHBvcnQgY29uc3QgUGllQ2hhcnQgPSAoe1xuICBoZWlnaHQgPSAyMDYsXG4gIHdpZHRoID0gMjA2LFxuICBkYXRhID0gdW5kZWZpbmVkLFxuICBlbXB0eUxlZ2VuZCxcbiAgY29udGVudCxcbiAgd2l0aExlZ2VuZCA9IGZhbHNlLFxuICBtYXJnaW4gPSBERUZBVUxUX01BUkdJTixcbiAgY2hhcnRQcm9wcyA9IERFRkFVTFRfQ0hBUlRQUk9QUyxcbn06IFBpZUNoYXJ0UHJvcHMpID0+IHtcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gIGNvbnN0IFtjdXJyZW50Rm9jdXNJbmRleCwgc2V0Q3VycmVudEZvY3VzSW5kZXhdID0gdXNlU3RhdGU8c3RyaW5nPigpXG4gIGNvbnN0IGVtcHR5VG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IDxzcGFuIC8+LCBbXSlcbiAgY29uc3QgaXNFbXB0eSA9ICFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwXG5cbiAgY29uc3QgRW1wdHlMZWdlbmREaXNwbGF5ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgZW1wdHlMZWdlbmQgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZD5cbiAgICAgICAgICA8VGV4dCB2YXJpYW50PVwiYm9keVwiIGFzPVwicFwiPlxuICAgICAgICAgICAge2VtcHR5TGVnZW5kfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9FbXB0eUxlZ2VuZD5cbiAgICAgICkgOiBudWxsLFxuICAgIFtlbXB0eUxlZ2VuZF0sXG4gIClcblxuICBjb25zdCBsb2NhbENvbG9ycyA9IGdldExlZ2VuZENvbG9yKHRoZW1lKVxuXG4gIGNvbnN0IExlZ2VuZERpc3BsYXllciA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBpc0VtcHR5ID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmREaXNwbGF5ZWQgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxMZWdlbmRzXG4gICAgICAgICAgZm9jdXNlZD17Y3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgZGF0YT17ZGF0YX1cbiAgICAgICAgICBvbkZvY3VzQ2hhbmdlPXtzZXRDdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbaXNFbXB0eSwgY3VycmVudEZvY3VzSW5kZXgsIGRhdGEsIEVtcHR5TGVnZW5kRGlzcGxheWVkLCBsb2NhbENvbG9yc10sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXIgaGVpZ2h0PXtoZWlnaHR9PlxuICAgICAgPGRpdiBzdHlsZT17eyBwb3NpdGlvbjogJ3JlbGF0aXZlJyB9fT5cbiAgICAgICAgPFBpZVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgIHZhbHVlPVwicGVyY2VudFwiXG4gICAgICAgICAgZW5hYmxlQXJjTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBlbmFibGVBcmNMaW5rTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBkYXRhPXtcbiAgICAgICAgICAgICFpc0VtcHR5XG4gICAgICAgICAgICAgID8gZGF0YVxuICAgICAgICAgICAgICA6IFtcbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgaWQ6ICdlbXB0eScsXG4gICAgICAgICAgICAgICAgICAgIHBlcmNlbnQ6IDEwMCxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXVxuICAgICAgICAgIH1cbiAgICAgICAgICBkZWZzPXtbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICdpbmhlcml0JyxcbiAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmcsXG4gICAgICAgICAgICAgIGlkOiAnbGluZXMnLFxuICAgICAgICAgICAgICBsaW5lV2lkdGg6IDIsXG4gICAgICAgICAgICAgIHJvdGF0aW9uOiAwLFxuICAgICAgICAgICAgICBzcGFjaW5nOiA1LFxuICAgICAgICAgICAgICB0eXBlOiAncGF0dGVybkxpbmVzJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXX1cbiAgICAgICAgICBtYXJnaW49e21hcmdpbn1cbiAgICAgICAgICBpbm5lclJhZGl1cz17MC44fVxuICAgICAgICAgIGNvcm5lclJhZGl1cz17MH1cbiAgICAgICAgICBwYWRBbmdsZT17MX1cbiAgICAgICAgICBhY3RpdmVPdXRlclJhZGl1c09mZnNldD17IWlzRW1wdHkgPyA0IDogMH1cbiAgICAgICAgICB0b29sdGlwPXtlbXB0eVRvb2x0aXB9XG4gICAgICAgICAgb25Nb3VzZUVudGVyPXsoZGF0dW0sIGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoIWlzRW1wdHkpIHtcbiAgICAgICAgICAgICAgY29uc3QgcGllID0gZXZlbnQuY3VycmVudFRhcmdldFxuICAgICAgICAgICAgICBwaWUuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInXG4gICAgICAgICAgICAgIHNldEN1cnJlbnRGb2N1c0luZGV4KGRhdHVtLmlkLnRvU3RyaW5nKCkpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHNldEN1cnJlbnRGb2N1c0luZGV4KHVuZGVmaW5lZCl9XG4gICAgICAgICAgdGhlbWU9e2dldE5pdm9UaGVtZSh0aGVtZSl9XG4gICAgICAgICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgICAgIC8+XG4gICAgICAgIHtjb250ZW50ID8gPFN0eWxlZENvbnRlbnQ+e2NvbnRlbnR9PC9TdHlsZWRDb250ZW50PiA6IG51bGx9XG4gICAgICA8L2Rpdj5cbiAgICAgIHt3aXRoTGVnZW5kID8gPExlZ2VuZERpc3BsYXllciAvPiA6IG51bGx9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cbiJdfQ== */"));
38
39
  const DEFAULT_CHARTPROPS = {};
39
40
  const DEFAULT_MARGIN = {
40
41
  bottom: 10,
@@ -80,7 +81,7 @@ const PieChart = ({
80
81
  pie2.style.cursor = "pointer";
81
82
  setCurrentFocusIndex(datum.id.toString());
82
83
  }
83
- }, onMouseLeave: () => setCurrentFocusIndex(void 0), ...chartProps }),
84
+ }, onMouseLeave: () => setCurrentFocusIndex(void 0), theme: nivoTheme.getNivoTheme(theme), ...chartProps }),
84
85
  content ? /* @__PURE__ */ jsxRuntime.jsx(StyledContent, { children: content }) : null
85
86
  ] }),
86
87
  withLegend ? /* @__PURE__ */ jsxRuntime.jsx(LegendDisplayer, {}) : null
@@ -5,6 +5,7 @@ import { useTheme } from "@emotion/react";
5
5
  import { Pie } from "@nivo/pie";
6
6
  import { useState, useCallback } from "react";
7
7
  import { getLegendColor } from "../../helpers/legend.js";
8
+ import { getNivoTheme } from "../../helpers/nivoTheme.js";
8
9
  import { Text } from "../Text/index.js";
9
10
  import Legends from "./Legends.js";
10
11
  const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
@@ -14,7 +15,7 @@ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
14
15
  label: "Container"
15
16
  })("display:flex;align-items:center;height:", ({
16
17
  height
17
- }) => `${height}px`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhZ0QiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUGllQ2hhcnQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQm94IH0gZnJvbSAnQG5pdm8vY29yZSdcbmltcG9ydCB7IFBpZSB9IGZyb20gJ0BuaXZvL3BpZSdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGdldExlZ2VuZENvbG9yIH0gZnJvbSAnLi4vLi4vaGVscGVycy9sZWdlbmQnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnNSddfTtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuaGVhZGluZ1N0cm9uZ307XG4gIGxpbmUtaGVpZ2h0OiAxMDBweDtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgd2lkdGg6IDEwMHB4O1xuICBtYXJnaW46IGF1dG87XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbmBcblxudHlwZSBQaWVDaGFydFByb3BzID0ge1xuICBjaGFydFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZGF0YT86IERhdGFbXVxuICBoZWlnaHQ/OiBudW1iZXJcbiAgd2lkdGg/OiBudW1iZXJcbiAgZW1wdHlMZWdlbmQ/OiBzdHJpbmdcbiAgY29udGVudD86IFJlYWN0Tm9kZVxuICB3aXRoTGVnZW5kPzogYm9vbGVhblxuICBtYXJnaW4/OiBCb3hcbn1cblxuY29uc3QgREVGQVVMVF9DSEFSVFBST1BTID0ge31cbmNvbnN0IERFRkFVTFRfTUFSR0lOID0geyBib3R0b206IDEwLCBsZWZ0OiAxMCwgcmlnaHQ6IDEwLCB0b3A6IDEwIH1cblxuLyoqXG4gKiBQaWVDaGFydCBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgTml2byBQaWUgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBwaWUgY2hhcnQuXG4gKiBTZWUgaHR0cHM6Ly9uaXZvLnJvY2tzL3BpZS8gZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgY29tcG9uZW50IGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIHN1YmplY3QgdG8gYnJlYWtpbmcgY2hhbmdlcyBpbiB0aGUgZnV0dXJlLlxuICovXG5leHBvcnQgY29uc3QgUGllQ2hhcnQgPSAoe1xuICBoZWlnaHQgPSAyMDYsXG4gIHdpZHRoID0gMjA2LFxuICBkYXRhID0gdW5kZWZpbmVkLFxuICBlbXB0eUxlZ2VuZCxcbiAgY29udGVudCxcbiAgd2l0aExlZ2VuZCA9IGZhbHNlLFxuICBtYXJnaW4gPSBERUZBVUxUX01BUkdJTixcbiAgY2hhcnRQcm9wcyA9IERFRkFVTFRfQ0hBUlRQUk9QUyxcbn06IFBpZUNoYXJ0UHJvcHMpID0+IHtcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gIGNvbnN0IFtjdXJyZW50Rm9jdXNJbmRleCwgc2V0Q3VycmVudEZvY3VzSW5kZXhdID0gdXNlU3RhdGU8c3RyaW5nPigpXG4gIGNvbnN0IGVtcHR5VG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IDxzcGFuIC8+LCBbXSlcbiAgY29uc3QgaXNFbXB0eSA9ICFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwXG5cbiAgY29uc3QgRW1wdHlMZWdlbmREaXNwbGF5ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgZW1wdHlMZWdlbmQgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZD5cbiAgICAgICAgICA8VGV4dCB2YXJpYW50PVwiYm9keVwiIGFzPVwicFwiPlxuICAgICAgICAgICAge2VtcHR5TGVnZW5kfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9FbXB0eUxlZ2VuZD5cbiAgICAgICkgOiBudWxsLFxuICAgIFtlbXB0eUxlZ2VuZF0sXG4gIClcblxuICBjb25zdCBsb2NhbENvbG9ycyA9IGdldExlZ2VuZENvbG9yKHRoZW1lKVxuXG4gIGNvbnN0IExlZ2VuZERpc3BsYXllciA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBpc0VtcHR5ID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmREaXNwbGF5ZWQgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxMZWdlbmRzXG4gICAgICAgICAgZm9jdXNlZD17Y3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgZGF0YT17ZGF0YX1cbiAgICAgICAgICBvbkZvY3VzQ2hhbmdlPXtzZXRDdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbaXNFbXB0eSwgY3VycmVudEZvY3VzSW5kZXgsIGRhdGEsIEVtcHR5TGVnZW5kRGlzcGxheWVkLCBsb2NhbENvbG9yc10sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXIgaGVpZ2h0PXtoZWlnaHR9PlxuICAgICAgPGRpdiBzdHlsZT17eyBwb3NpdGlvbjogJ3JlbGF0aXZlJyB9fT5cbiAgICAgICAgPFBpZVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgIHZhbHVlPVwicGVyY2VudFwiXG4gICAgICAgICAgZW5hYmxlQXJjTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBlbmFibGVBcmNMaW5rTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBkYXRhPXtcbiAgICAgICAgICAgICFpc0VtcHR5XG4gICAgICAgICAgICAgID8gZGF0YVxuICAgICAgICAgICAgICA6IFtcbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgaWQ6ICdlbXB0eScsXG4gICAgICAgICAgICAgICAgICAgIHBlcmNlbnQ6IDEwMCxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXVxuICAgICAgICAgIH1cbiAgICAgICAgICBkZWZzPXtbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICdpbmhlcml0JyxcbiAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmcsXG4gICAgICAgICAgICAgIGlkOiAnbGluZXMnLFxuICAgICAgICAgICAgICBsaW5lV2lkdGg6IDIsXG4gICAgICAgICAgICAgIHJvdGF0aW9uOiAwLFxuICAgICAgICAgICAgICBzcGFjaW5nOiA1LFxuICAgICAgICAgICAgICB0eXBlOiAncGF0dGVybkxpbmVzJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXX1cbiAgICAgICAgICBtYXJnaW49e21hcmdpbn1cbiAgICAgICAgICBpbm5lclJhZGl1cz17MC44fVxuICAgICAgICAgIGNvcm5lclJhZGl1cz17MH1cbiAgICAgICAgICBwYWRBbmdsZT17MX1cbiAgICAgICAgICBhY3RpdmVPdXRlclJhZGl1c09mZnNldD17IWlzRW1wdHkgPyA0IDogMH1cbiAgICAgICAgICB0b29sdGlwPXtlbXB0eVRvb2x0aXB9XG4gICAgICAgICAgb25Nb3VzZUVudGVyPXsoZGF0dW0sIGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoIWlzRW1wdHkpIHtcbiAgICAgICAgICAgICAgY29uc3QgcGllID0gZXZlbnQuY3VycmVudFRhcmdldFxuICAgICAgICAgICAgICBwaWUuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInXG4gICAgICAgICAgICAgIHNldEN1cnJlbnRGb2N1c0luZGV4KGRhdHVtLmlkLnRvU3RyaW5nKCkpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHNldEN1cnJlbnRGb2N1c0luZGV4KHVuZGVmaW5lZCl9XG4gICAgICAgICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgICAgIC8+XG4gICAgICAgIHtjb250ZW50ID8gPFN0eWxlZENvbnRlbnQ+e2NvbnRlbnR9PC9TdHlsZWRDb250ZW50PiA6IG51bGx9XG4gICAgICA8L2Rpdj5cbiAgICAgIHt3aXRoTGVnZW5kID8gPExlZ2VuZERpc3BsYXllciAvPiA6IG51bGx9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cbiJdfQ== */"));
18
+ }) => `${height}px`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjZ0QiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUGllQ2hhcnQvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB7IHVzZVRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQm94IH0gZnJvbSAnQG5pdm8vY29yZSdcbmltcG9ydCB7IFBpZSB9IGZyb20gJ0BuaXZvL3BpZSdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGdldExlZ2VuZENvbG9yIH0gZnJvbSAnLi4vLi4vaGVscGVycy9sZWdlbmQnXG5pbXBvcnQgeyBnZXROaXZvVGhlbWUgfSBmcm9tICcuLi8uLi9oZWxwZXJzL25pdm9UaGVtZSdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IExlZ2VuZHMgZnJvbSAnLi9MZWdlbmRzJ1xuaW1wb3J0IHR5cGUgeyBEYXRhIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkLmRpdjx7IGhlaWdodDogbnVtYmVyIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBoZWlnaHQ6ICR7KHsgaGVpZ2h0IH0pID0+IGAke2hlaWdodH1weGB9O1xuYFxuXG5jb25zdCBFbXB0eUxlZ2VuZCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1hcmdpbi1sZWZ0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWyc1J119O1xuYFxuXG5jb25zdCBTdHlsZWRDb250ZW50ID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGJvdHRvbTogMDtcbiAgbGVmdDogMDtcbiAgcmlnaHQ6IDA7XG4gIHRvcDogMDtcblxuICBmb250LXNpemU6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUudHlwb2dyYXBoeS5oZWFkaW5nU3Ryb25nfTtcbiAgbGluZS1oZWlnaHQ6IDEwMHB4O1xuICBoZWlnaHQ6IDEwMHB4O1xuICB3aWR0aDogMTAwcHg7XG4gIG1hcmdpbjogYXV0bztcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICB2ZXJ0aWNhbC1hbGlnbjogbWlkZGxlO1xuYFxuXG50eXBlIFBpZUNoYXJ0UHJvcHMgPSB7XG4gIGNoYXJ0UHJvcHM/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPlxuICBkYXRhPzogRGF0YVtdXG4gIGhlaWdodD86IG51bWJlclxuICB3aWR0aD86IG51bWJlclxuICBlbXB0eUxlZ2VuZD86IHN0cmluZ1xuICBjb250ZW50PzogUmVhY3ROb2RlXG4gIHdpdGhMZWdlbmQ/OiBib29sZWFuXG4gIG1hcmdpbj86IEJveFxufVxuXG5jb25zdCBERUZBVUxUX0NIQVJUUFJPUFMgPSB7fVxuY29uc3QgREVGQVVMVF9NQVJHSU4gPSB7IGJvdHRvbTogMTAsIGxlZnQ6IDEwLCByaWdodDogMTAsIHRvcDogMTAgfVxuXG4vKipcbiAqIFBpZUNoYXJ0IGNvbXBvbmVudCBpcyBhIHdyYXBwZXIgYXJvdW5kIHRoZSBOaXZvIFBpZSBjb21wb25lbnQgdG8gZGlzcGxheSBhIHBpZSBjaGFydC5cbiAqIFNlZSBodHRwczovL25pdm8ucm9ja3MvcGllLyBmb3IgbW9yZSBpbmZvcm1hdGlvbi5cbiAqIEBleHBlcmltZW50YWwgVGhpcyBjb21wb25lbnQgaXMgZXhwZXJpbWVudGFsIGFuZCBtYXkgYmUgc3ViamVjdCB0byBicmVha2luZyBjaGFuZ2VzIGluIHRoZSBmdXR1cmUuXG4gKi9cbmV4cG9ydCBjb25zdCBQaWVDaGFydCA9ICh7XG4gIGhlaWdodCA9IDIwNixcbiAgd2lkdGggPSAyMDYsXG4gIGRhdGEgPSB1bmRlZmluZWQsXG4gIGVtcHR5TGVnZW5kLFxuICBjb250ZW50LFxuICB3aXRoTGVnZW5kID0gZmFsc2UsXG4gIG1hcmdpbiA9IERFRkFVTFRfTUFSR0lOLFxuICBjaGFydFByb3BzID0gREVGQVVMVF9DSEFSVFBST1BTLFxufTogUGllQ2hhcnRQcm9wcykgPT4ge1xuICBjb25zdCB0aGVtZSA9IHVzZVRoZW1lKClcbiAgY29uc3QgW2N1cnJlbnRGb2N1c0luZGV4LCBzZXRDdXJyZW50Rm9jdXNJbmRleF0gPSB1c2VTdGF0ZTxzdHJpbmc+KClcbiAgY29uc3QgZW1wdHlUb29sdGlwID0gdXNlQ2FsbGJhY2soKCkgPT4gPHNwYW4gLz4sIFtdKVxuICBjb25zdCBpc0VtcHR5ID0gIWRhdGEgfHwgZGF0YS5sZW5ndGggPT09IDBcblxuICBjb25zdCBFbXB0eUxlZ2VuZERpc3BsYXllZCA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBlbXB0eUxlZ2VuZCA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kPlxuICAgICAgICAgIDxUZXh0IHZhcmlhbnQ9XCJib2R5XCIgYXM9XCJwXCI+XG4gICAgICAgICAgICB7ZW1wdHlMZWdlbmR9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0VtcHR5TGVnZW5kPlxuICAgICAgKSA6IG51bGwsXG4gICAgW2VtcHR5TGVnZW5kXSxcbiAgKVxuXG4gIGNvbnN0IGxvY2FsQ29sb3JzID0gZ2V0TGVnZW5kQ29sb3IodGhlbWUpXG5cbiAgY29uc3QgTGVnZW5kRGlzcGxheWVyID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGlzRW1wdHkgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZERpc3BsYXllZCAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPExlZ2VuZHNcbiAgICAgICAgICBmb2N1c2VkPXtjdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBkYXRhPXtkYXRhfVxuICAgICAgICAgIG9uRm9jdXNDaGFuZ2U9e3NldEN1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgIC8+XG4gICAgICApLFxuICAgIFtpc0VtcHR5LCBjdXJyZW50Rm9jdXNJbmRleCwgZGF0YSwgRW1wdHlMZWdlbmREaXNwbGF5ZWQsIGxvY2FsQ29sb3JzXSxcbiAgKVxuXG4gIHJldHVybiAoXG4gICAgPENvbnRhaW5lciBoZWlnaHQ9e2hlaWdodH0+XG4gICAgICA8ZGl2IHN0eWxlPXt7IHBvc2l0aW9uOiAncmVsYXRpdmUnIH19PlxuICAgICAgICA8UGllXG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgICBoZWlnaHQ9e2hlaWdodH1cbiAgICAgICAgICB3aWR0aD17d2lkdGh9XG4gICAgICAgICAgdmFsdWU9XCJwZXJjZW50XCJcbiAgICAgICAgICBlbmFibGVBcmNMYWJlbHM9e2ZhbHNlfVxuICAgICAgICAgIGVuYWJsZUFyY0xpbmtMYWJlbHM9e2ZhbHNlfVxuICAgICAgICAgIGRhdGE9e1xuICAgICAgICAgICAgIWlzRW1wdHlcbiAgICAgICAgICAgICAgPyBkYXRhXG4gICAgICAgICAgICAgIDogW1xuICAgICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICBpZDogJ2VtcHR5JyxcbiAgICAgICAgICAgICAgICAgICAgcGVyY2VudDogMTAwLFxuICAgICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgICBdXG4gICAgICAgICAgfVxuICAgICAgICAgIGRlZnM9e1tcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgYmFja2dyb3VuZDogJ2luaGVyaXQnLFxuICAgICAgICAgICAgICBjb2xvcjogdGhlbWUuY29sb3JzLm5ldXRyYWwudGV4dFN0cm9uZyxcbiAgICAgICAgICAgICAgaWQ6ICdsaW5lcycsXG4gICAgICAgICAgICAgIGxpbmVXaWR0aDogMixcbiAgICAgICAgICAgICAgcm90YXRpb246IDAsXG4gICAgICAgICAgICAgIHNwYWNpbmc6IDUsXG4gICAgICAgICAgICAgIHR5cGU6ICdwYXR0ZXJuTGluZXMnLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICBdfVxuICAgICAgICAgIG1hcmdpbj17bWFyZ2lufVxuICAgICAgICAgIGlubmVyUmFkaXVzPXswLjh9XG4gICAgICAgICAgY29ybmVyUmFkaXVzPXswfVxuICAgICAgICAgIHBhZEFuZ2xlPXsxfVxuICAgICAgICAgIGFjdGl2ZU91dGVyUmFkaXVzT2Zmc2V0PXshaXNFbXB0eSA/IDQgOiAwfVxuICAgICAgICAgIHRvb2x0aXA9e2VtcHR5VG9vbHRpcH1cbiAgICAgICAgICBvbk1vdXNlRW50ZXI9eyhkYXR1bSwgZXZlbnQpID0+IHtcbiAgICAgICAgICAgIGlmICghaXNFbXB0eSkge1xuICAgICAgICAgICAgICBjb25zdCBwaWUgPSBldmVudC5jdXJyZW50VGFyZ2V0XG4gICAgICAgICAgICAgIHBpZS5zdHlsZS5jdXJzb3IgPSAncG9pbnRlcidcbiAgICAgICAgICAgICAgc2V0Q3VycmVudEZvY3VzSW5kZXgoZGF0dW0uaWQudG9TdHJpbmcoKSlcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9fVxuICAgICAgICAgIG9uTW91c2VMZWF2ZT17KCkgPT4gc2V0Q3VycmVudEZvY3VzSW5kZXgodW5kZWZpbmVkKX1cbiAgICAgICAgICB0aGVtZT17Z2V0Tml2b1RoZW1lKHRoZW1lKX1cbiAgICAgICAgICB7Li4uY2hhcnRQcm9wc31cbiAgICAgICAgLz5cbiAgICAgICAge2NvbnRlbnQgPyA8U3R5bGVkQ29udGVudD57Y29udGVudH08L1N0eWxlZENvbnRlbnQ+IDogbnVsbH1cbiAgICAgIDwvZGl2PlxuICAgICAge3dpdGhMZWdlbmQgPyA8TGVnZW5kRGlzcGxheWVyIC8+IDogbnVsbH1cbiAgICA8L0NvbnRhaW5lcj5cbiAgKVxufVxuIl19 */"));
18
19
  const EmptyLegend = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
19
20
  target: "epjfe5p1"
20
21
  } : {
@@ -22,7 +23,7 @@ const EmptyLegend = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pro
22
23
  label: "EmptyLegend"
23
24
  })("display:flex;align-items:center;margin-left:", ({
24
25
  theme
25
- }) => theme.space["5"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgTGVnZW5kcyBmcm9tICcuL0xlZ2VuZHMnXG5pbXBvcnQgdHlwZSB7IERhdGEgfSBmcm9tICcuL3R5cGVzJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2PHsgaGVpZ2h0OiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGhlaWdodDogJHsoeyBoZWlnaHQgfSkgPT4gYCR7aGVpZ2h0fXB4YH07XG5gXG5cbmNvbnN0IEVtcHR5TGVnZW5kID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG5gXG5cbmNvbnN0IFN0eWxlZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgYm90dG9tOiAwO1xuICBsZWZ0OiAwO1xuICByaWdodDogMDtcbiAgdG9wOiAwO1xuXG4gIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmhlYWRpbmdTdHJvbmd9O1xuICBsaW5lLWhlaWdodDogMTAwcHg7XG4gIGhlaWdodDogMTAwcHg7XG4gIHdpZHRoOiAxMDBweDtcbiAgbWFyZ2luOiBhdXRvO1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG5gXG5cbnR5cGUgUGllQ2hhcnRQcm9wcyA9IHtcbiAgY2hhcnRQcm9wcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gIGRhdGE/OiBEYXRhW11cbiAgaGVpZ2h0PzogbnVtYmVyXG4gIHdpZHRoPzogbnVtYmVyXG4gIGVtcHR5TGVnZW5kPzogc3RyaW5nXG4gIGNvbnRlbnQ/OiBSZWFjdE5vZGVcbiAgd2l0aExlZ2VuZD86IGJvb2xlYW5cbiAgbWFyZ2luPzogQm94XG59XG5cbmNvbnN0IERFRkFVTFRfQ0hBUlRQUk9QUyA9IHt9XG5jb25zdCBERUZBVUxUX01BUkdJTiA9IHsgYm90dG9tOiAxMCwgbGVmdDogMTAsIHJpZ2h0OiAxMCwgdG9wOiAxMCB9XG5cbi8qKlxuICogUGllQ2hhcnQgY29tcG9uZW50IGlzIGEgd3JhcHBlciBhcm91bmQgdGhlIE5pdm8gUGllIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgcGllIGNoYXJ0LlxuICogU2VlIGh0dHBzOi8vbml2by5yb2Nrcy9waWUvIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGNvbXBvbmVudCBpcyBleHBlcmltZW50YWwgYW5kIG1heSBiZSBzdWJqZWN0IHRvIGJyZWFraW5nIGNoYW5nZXMgaW4gdGhlIGZ1dHVyZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBpZUNoYXJ0ID0gKHtcbiAgaGVpZ2h0ID0gMjA2LFxuICB3aWR0aCA9IDIwNixcbiAgZGF0YSA9IHVuZGVmaW5lZCxcbiAgZW1wdHlMZWdlbmQsXG4gIGNvbnRlbnQsXG4gIHdpdGhMZWdlbmQgPSBmYWxzZSxcbiAgbWFyZ2luID0gREVGQVVMVF9NQVJHSU4sXG4gIGNoYXJ0UHJvcHMgPSBERUZBVUxUX0NIQVJUUFJPUFMsXG59OiBQaWVDaGFydFByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICBjb25zdCBbY3VycmVudEZvY3VzSW5kZXgsIHNldEN1cnJlbnRGb2N1c0luZGV4XSA9IHVzZVN0YXRlPHN0cmluZz4oKVxuICBjb25zdCBlbXB0eVRvb2x0aXAgPSB1c2VDYWxsYmFjaygoKSA9PiA8c3BhbiAvPiwgW10pXG4gIGNvbnN0IGlzRW1wdHkgPSAhZGF0YSB8fCBkYXRhLmxlbmd0aCA9PT0gMFxuXG4gIGNvbnN0IEVtcHR5TGVnZW5kRGlzcGxheWVkID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGVtcHR5TGVnZW5kID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmQ+XG4gICAgICAgICAgPFRleHQgdmFyaWFudD1cImJvZHlcIiBhcz1cInBcIj5cbiAgICAgICAgICAgIHtlbXB0eUxlZ2VuZH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRW1wdHlMZWdlbmQ+XG4gICAgICApIDogbnVsbCxcbiAgICBbZW1wdHlMZWdlbmRdLFxuICApXG5cbiAgY29uc3QgbG9jYWxDb2xvcnMgPSBnZXRMZWdlbmRDb2xvcih0aGVtZSlcblxuICBjb25zdCBMZWdlbmREaXNwbGF5ZXIgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgaXNFbXB0eSA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kRGlzcGxheWVkIC8+XG4gICAgICApIDogKFxuICAgICAgICA8TGVnZW5kc1xuICAgICAgICAgIGZvY3VzZWQ9e2N1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGRhdGE9e2RhdGF9XG4gICAgICAgICAgb25Gb2N1c0NoYW5nZT17c2V0Q3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgLz5cbiAgICAgICksXG4gICAgW2lzRW1wdHksIGN1cnJlbnRGb2N1c0luZGV4LCBkYXRhLCBFbXB0eUxlZ2VuZERpc3BsYXllZCwgbG9jYWxDb2xvcnNdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyIGhlaWdodD17aGVpZ2h0fT5cbiAgICAgIDxkaXYgc3R5bGU9e3sgcG9zaXRpb246ICdyZWxhdGl2ZScgfX0+XG4gICAgICAgIDxQaWVcbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICB2YWx1ZT1cInBlcmNlbnRcIlxuICAgICAgICAgIGVuYWJsZUFyY0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZW5hYmxlQXJjTGlua0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZGF0YT17XG4gICAgICAgICAgICAhaXNFbXB0eVxuICAgICAgICAgICAgICA/IGRhdGFcbiAgICAgICAgICAgICAgOiBbXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGlkOiAnZW1wdHknLFxuICAgICAgICAgICAgICAgICAgICBwZXJjZW50OiAxMDAsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICB9XG4gICAgICAgICAgZGVmcz17W1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBiYWNrZ3JvdW5kOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICAgIGNvbG9yOiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0U3Ryb25nLFxuICAgICAgICAgICAgICBpZDogJ2xpbmVzJyxcbiAgICAgICAgICAgICAgbGluZVdpZHRoOiAyLFxuICAgICAgICAgICAgICByb3RhdGlvbjogMCxcbiAgICAgICAgICAgICAgc3BhY2luZzogNSxcbiAgICAgICAgICAgICAgdHlwZTogJ3BhdHRlcm5MaW5lcycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF19XG4gICAgICAgICAgbWFyZ2luPXttYXJnaW59XG4gICAgICAgICAgaW5uZXJSYWRpdXM9ezAuOH1cbiAgICAgICAgICBjb3JuZXJSYWRpdXM9ezB9XG4gICAgICAgICAgcGFkQW5nbGU9ezF9XG4gICAgICAgICAgYWN0aXZlT3V0ZXJSYWRpdXNPZmZzZXQ9eyFpc0VtcHR5ID8gNCA6IDB9XG4gICAgICAgICAgdG9vbHRpcD17ZW1wdHlUb29sdGlwfVxuICAgICAgICAgIG9uTW91c2VFbnRlcj17KGRhdHVtLCBldmVudCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFpc0VtcHR5KSB7XG4gICAgICAgICAgICAgIGNvbnN0IHBpZSA9IGV2ZW50LmN1cnJlbnRUYXJnZXRcbiAgICAgICAgICAgICAgcGllLnN0eWxlLmN1cnNvciA9ICdwb2ludGVyJ1xuICAgICAgICAgICAgICBzZXRDdXJyZW50Rm9jdXNJbmRleChkYXR1bS5pZC50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiBzZXRDdXJyZW50Rm9jdXNJbmRleCh1bmRlZmluZWQpfVxuICAgICAgICAgIHsuLi5jaGFydFByb3BzfVxuICAgICAgICAvPlxuICAgICAgICB7Y29udGVudCA/IDxTdHlsZWRDb250ZW50Pntjb250ZW50fTwvU3R5bGVkQ29udGVudD4gOiBudWxsfVxuICAgICAgPC9kaXY+XG4gICAgICB7d2l0aExlZ2VuZCA/IDxMZWdlbmREaXNwbGF5ZXIgLz4gOiBudWxsfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG4iXX0= */"));
26
+ }) => theme.space["5"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvQjhCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgZ2V0Tml2b1RoZW1lIH0gZnJvbSAnLi4vLi4vaGVscGVycy9uaXZvVGhlbWUnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnNSddfTtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuaGVhZGluZ1N0cm9uZ307XG4gIGxpbmUtaGVpZ2h0OiAxMDBweDtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgd2lkdGg6IDEwMHB4O1xuICBtYXJnaW46IGF1dG87XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbmBcblxudHlwZSBQaWVDaGFydFByb3BzID0ge1xuICBjaGFydFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZGF0YT86IERhdGFbXVxuICBoZWlnaHQ/OiBudW1iZXJcbiAgd2lkdGg/OiBudW1iZXJcbiAgZW1wdHlMZWdlbmQ/OiBzdHJpbmdcbiAgY29udGVudD86IFJlYWN0Tm9kZVxuICB3aXRoTGVnZW5kPzogYm9vbGVhblxuICBtYXJnaW4/OiBCb3hcbn1cblxuY29uc3QgREVGQVVMVF9DSEFSVFBST1BTID0ge31cbmNvbnN0IERFRkFVTFRfTUFSR0lOID0geyBib3R0b206IDEwLCBsZWZ0OiAxMCwgcmlnaHQ6IDEwLCB0b3A6IDEwIH1cblxuLyoqXG4gKiBQaWVDaGFydCBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgTml2byBQaWUgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBwaWUgY2hhcnQuXG4gKiBTZWUgaHR0cHM6Ly9uaXZvLnJvY2tzL3BpZS8gZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgY29tcG9uZW50IGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIHN1YmplY3QgdG8gYnJlYWtpbmcgY2hhbmdlcyBpbiB0aGUgZnV0dXJlLlxuICovXG5leHBvcnQgY29uc3QgUGllQ2hhcnQgPSAoe1xuICBoZWlnaHQgPSAyMDYsXG4gIHdpZHRoID0gMjA2LFxuICBkYXRhID0gdW5kZWZpbmVkLFxuICBlbXB0eUxlZ2VuZCxcbiAgY29udGVudCxcbiAgd2l0aExlZ2VuZCA9IGZhbHNlLFxuICBtYXJnaW4gPSBERUZBVUxUX01BUkdJTixcbiAgY2hhcnRQcm9wcyA9IERFRkFVTFRfQ0hBUlRQUk9QUyxcbn06IFBpZUNoYXJ0UHJvcHMpID0+IHtcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gIGNvbnN0IFtjdXJyZW50Rm9jdXNJbmRleCwgc2V0Q3VycmVudEZvY3VzSW5kZXhdID0gdXNlU3RhdGU8c3RyaW5nPigpXG4gIGNvbnN0IGVtcHR5VG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IDxzcGFuIC8+LCBbXSlcbiAgY29uc3QgaXNFbXB0eSA9ICFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwXG5cbiAgY29uc3QgRW1wdHlMZWdlbmREaXNwbGF5ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgZW1wdHlMZWdlbmQgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZD5cbiAgICAgICAgICA8VGV4dCB2YXJpYW50PVwiYm9keVwiIGFzPVwicFwiPlxuICAgICAgICAgICAge2VtcHR5TGVnZW5kfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9FbXB0eUxlZ2VuZD5cbiAgICAgICkgOiBudWxsLFxuICAgIFtlbXB0eUxlZ2VuZF0sXG4gIClcblxuICBjb25zdCBsb2NhbENvbG9ycyA9IGdldExlZ2VuZENvbG9yKHRoZW1lKVxuXG4gIGNvbnN0IExlZ2VuZERpc3BsYXllciA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBpc0VtcHR5ID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmREaXNwbGF5ZWQgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxMZWdlbmRzXG4gICAgICAgICAgZm9jdXNlZD17Y3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgZGF0YT17ZGF0YX1cbiAgICAgICAgICBvbkZvY3VzQ2hhbmdlPXtzZXRDdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbaXNFbXB0eSwgY3VycmVudEZvY3VzSW5kZXgsIGRhdGEsIEVtcHR5TGVnZW5kRGlzcGxheWVkLCBsb2NhbENvbG9yc10sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXIgaGVpZ2h0PXtoZWlnaHR9PlxuICAgICAgPGRpdiBzdHlsZT17eyBwb3NpdGlvbjogJ3JlbGF0aXZlJyB9fT5cbiAgICAgICAgPFBpZVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgIHZhbHVlPVwicGVyY2VudFwiXG4gICAgICAgICAgZW5hYmxlQXJjTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBlbmFibGVBcmNMaW5rTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBkYXRhPXtcbiAgICAgICAgICAgICFpc0VtcHR5XG4gICAgICAgICAgICAgID8gZGF0YVxuICAgICAgICAgICAgICA6IFtcbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgaWQ6ICdlbXB0eScsXG4gICAgICAgICAgICAgICAgICAgIHBlcmNlbnQ6IDEwMCxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXVxuICAgICAgICAgIH1cbiAgICAgICAgICBkZWZzPXtbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICdpbmhlcml0JyxcbiAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmcsXG4gICAgICAgICAgICAgIGlkOiAnbGluZXMnLFxuICAgICAgICAgICAgICBsaW5lV2lkdGg6IDIsXG4gICAgICAgICAgICAgIHJvdGF0aW9uOiAwLFxuICAgICAgICAgICAgICBzcGFjaW5nOiA1LFxuICAgICAgICAgICAgICB0eXBlOiAncGF0dGVybkxpbmVzJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXX1cbiAgICAgICAgICBtYXJnaW49e21hcmdpbn1cbiAgICAgICAgICBpbm5lclJhZGl1cz17MC44fVxuICAgICAgICAgIGNvcm5lclJhZGl1cz17MH1cbiAgICAgICAgICBwYWRBbmdsZT17MX1cbiAgICAgICAgICBhY3RpdmVPdXRlclJhZGl1c09mZnNldD17IWlzRW1wdHkgPyA0IDogMH1cbiAgICAgICAgICB0b29sdGlwPXtlbXB0eVRvb2x0aXB9XG4gICAgICAgICAgb25Nb3VzZUVudGVyPXsoZGF0dW0sIGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoIWlzRW1wdHkpIHtcbiAgICAgICAgICAgICAgY29uc3QgcGllID0gZXZlbnQuY3VycmVudFRhcmdldFxuICAgICAgICAgICAgICBwaWUuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInXG4gICAgICAgICAgICAgIHNldEN1cnJlbnRGb2N1c0luZGV4KGRhdHVtLmlkLnRvU3RyaW5nKCkpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHNldEN1cnJlbnRGb2N1c0luZGV4KHVuZGVmaW5lZCl9XG4gICAgICAgICAgdGhlbWU9e2dldE5pdm9UaGVtZSh0aGVtZSl9XG4gICAgICAgICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgICAgIC8+XG4gICAgICAgIHtjb250ZW50ID8gPFN0eWxlZENvbnRlbnQ+e2NvbnRlbnR9PC9TdHlsZWRDb250ZW50PiA6IG51bGx9XG4gICAgICA8L2Rpdj5cbiAgICAgIHt3aXRoTGVnZW5kID8gPExlZ2VuZERpc3BsYXllciAvPiA6IG51bGx9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cbiJdfQ== */"));
26
27
  const StyledContent = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
27
28
  target: "epjfe5p0"
28
29
  } : {
@@ -30,7 +31,7 @@ const StyledContent = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "p
30
31
  label: "StyledContent"
31
32
  })("display:inline-block;position:absolute;bottom:0;left:0;right:0;top:0;font-size:", ({
32
33
  theme
33
- }) => theme.typography.headingStrong, ";line-height:100px;height:100px;width:100px;margin:auto;text-align:center;vertical-align:middle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QmdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgTGVnZW5kcyBmcm9tICcuL0xlZ2VuZHMnXG5pbXBvcnQgdHlwZSB7IERhdGEgfSBmcm9tICcuL3R5cGVzJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQuZGl2PHsgaGVpZ2h0OiBudW1iZXIgfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGhlaWdodDogJHsoeyBoZWlnaHQgfSkgPT4gYCR7aGVpZ2h0fXB4YH07XG5gXG5cbmNvbnN0IEVtcHR5TGVnZW5kID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWFyZ2luLWxlZnQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzUnXX07XG5gXG5cbmNvbnN0IFN0eWxlZENvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgYm90dG9tOiAwO1xuICBsZWZ0OiAwO1xuICByaWdodDogMDtcbiAgdG9wOiAwO1xuXG4gIGZvbnQtc2l6ZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS50eXBvZ3JhcGh5LmhlYWRpbmdTdHJvbmd9O1xuICBsaW5lLWhlaWdodDogMTAwcHg7XG4gIGhlaWdodDogMTAwcHg7XG4gIHdpZHRoOiAxMDBweDtcbiAgbWFyZ2luOiBhdXRvO1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHZlcnRpY2FsLWFsaWduOiBtaWRkbGU7XG5gXG5cbnR5cGUgUGllQ2hhcnRQcm9wcyA9IHtcbiAgY2hhcnRQcm9wcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gIGRhdGE/OiBEYXRhW11cbiAgaGVpZ2h0PzogbnVtYmVyXG4gIHdpZHRoPzogbnVtYmVyXG4gIGVtcHR5TGVnZW5kPzogc3RyaW5nXG4gIGNvbnRlbnQ/OiBSZWFjdE5vZGVcbiAgd2l0aExlZ2VuZD86IGJvb2xlYW5cbiAgbWFyZ2luPzogQm94XG59XG5cbmNvbnN0IERFRkFVTFRfQ0hBUlRQUk9QUyA9IHt9XG5jb25zdCBERUZBVUxUX01BUkdJTiA9IHsgYm90dG9tOiAxMCwgbGVmdDogMTAsIHJpZ2h0OiAxMCwgdG9wOiAxMCB9XG5cbi8qKlxuICogUGllQ2hhcnQgY29tcG9uZW50IGlzIGEgd3JhcHBlciBhcm91bmQgdGhlIE5pdm8gUGllIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgcGllIGNoYXJ0LlxuICogU2VlIGh0dHBzOi8vbml2by5yb2Nrcy9waWUvIGZvciBtb3JlIGluZm9ybWF0aW9uLlxuICogQGV4cGVyaW1lbnRhbCBUaGlzIGNvbXBvbmVudCBpcyBleHBlcmltZW50YWwgYW5kIG1heSBiZSBzdWJqZWN0IHRvIGJyZWFraW5nIGNoYW5nZXMgaW4gdGhlIGZ1dHVyZS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBpZUNoYXJ0ID0gKHtcbiAgaGVpZ2h0ID0gMjA2LFxuICB3aWR0aCA9IDIwNixcbiAgZGF0YSA9IHVuZGVmaW5lZCxcbiAgZW1wdHlMZWdlbmQsXG4gIGNvbnRlbnQsXG4gIHdpdGhMZWdlbmQgPSBmYWxzZSxcbiAgbWFyZ2luID0gREVGQVVMVF9NQVJHSU4sXG4gIGNoYXJ0UHJvcHMgPSBERUZBVUxUX0NIQVJUUFJPUFMsXG59OiBQaWVDaGFydFByb3BzKSA9PiB7XG4gIGNvbnN0IHRoZW1lID0gdXNlVGhlbWUoKVxuICBjb25zdCBbY3VycmVudEZvY3VzSW5kZXgsIHNldEN1cnJlbnRGb2N1c0luZGV4XSA9IHVzZVN0YXRlPHN0cmluZz4oKVxuICBjb25zdCBlbXB0eVRvb2x0aXAgPSB1c2VDYWxsYmFjaygoKSA9PiA8c3BhbiAvPiwgW10pXG4gIGNvbnN0IGlzRW1wdHkgPSAhZGF0YSB8fCBkYXRhLmxlbmd0aCA9PT0gMFxuXG4gIGNvbnN0IEVtcHR5TGVnZW5kRGlzcGxheWVkID0gdXNlQ2FsbGJhY2soXG4gICAgKCkgPT5cbiAgICAgIGVtcHR5TGVnZW5kID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmQ+XG4gICAgICAgICAgPFRleHQgdmFyaWFudD1cImJvZHlcIiBhcz1cInBcIj5cbiAgICAgICAgICAgIHtlbXB0eUxlZ2VuZH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRW1wdHlMZWdlbmQ+XG4gICAgICApIDogbnVsbCxcbiAgICBbZW1wdHlMZWdlbmRdLFxuICApXG5cbiAgY29uc3QgbG9jYWxDb2xvcnMgPSBnZXRMZWdlbmRDb2xvcih0aGVtZSlcblxuICBjb25zdCBMZWdlbmREaXNwbGF5ZXIgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgaXNFbXB0eSA/IChcbiAgICAgICAgPEVtcHR5TGVnZW5kRGlzcGxheWVkIC8+XG4gICAgICApIDogKFxuICAgICAgICA8TGVnZW5kc1xuICAgICAgICAgIGZvY3VzZWQ9e2N1cnJlbnRGb2N1c0luZGV4fVxuICAgICAgICAgIGRhdGE9e2RhdGF9XG4gICAgICAgICAgb25Gb2N1c0NoYW5nZT17c2V0Q3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgY29sb3JzPXtsb2NhbENvbG9yc31cbiAgICAgICAgLz5cbiAgICAgICksXG4gICAgW2lzRW1wdHksIGN1cnJlbnRGb2N1c0luZGV4LCBkYXRhLCBFbXB0eUxlZ2VuZERpc3BsYXllZCwgbG9jYWxDb2xvcnNdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8Q29udGFpbmVyIGhlaWdodD17aGVpZ2h0fT5cbiAgICAgIDxkaXYgc3R5bGU9e3sgcG9zaXRpb246ICdyZWxhdGl2ZScgfX0+XG4gICAgICAgIDxQaWVcbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICB2YWx1ZT1cInBlcmNlbnRcIlxuICAgICAgICAgIGVuYWJsZUFyY0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZW5hYmxlQXJjTGlua0xhYmVscz17ZmFsc2V9XG4gICAgICAgICAgZGF0YT17XG4gICAgICAgICAgICAhaXNFbXB0eVxuICAgICAgICAgICAgICA/IGRhdGFcbiAgICAgICAgICAgICAgOiBbXG4gICAgICAgICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgICAgIGlkOiAnZW1wdHknLFxuICAgICAgICAgICAgICAgICAgICBwZXJjZW50OiAxMDAsXG4gICAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIF1cbiAgICAgICAgICB9XG4gICAgICAgICAgZGVmcz17W1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBiYWNrZ3JvdW5kOiAnaW5oZXJpdCcsXG4gICAgICAgICAgICAgIGNvbG9yOiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0U3Ryb25nLFxuICAgICAgICAgICAgICBpZDogJ2xpbmVzJyxcbiAgICAgICAgICAgICAgbGluZVdpZHRoOiAyLFxuICAgICAgICAgICAgICByb3RhdGlvbjogMCxcbiAgICAgICAgICAgICAgc3BhY2luZzogNSxcbiAgICAgICAgICAgICAgdHlwZTogJ3BhdHRlcm5MaW5lcycsXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIF19XG4gICAgICAgICAgbWFyZ2luPXttYXJnaW59XG4gICAgICAgICAgaW5uZXJSYWRpdXM9ezAuOH1cbiAgICAgICAgICBjb3JuZXJSYWRpdXM9ezB9XG4gICAgICAgICAgcGFkQW5nbGU9ezF9XG4gICAgICAgICAgYWN0aXZlT3V0ZXJSYWRpdXNPZmZzZXQ9eyFpc0VtcHR5ID8gNCA6IDB9XG4gICAgICAgICAgdG9vbHRpcD17ZW1wdHlUb29sdGlwfVxuICAgICAgICAgIG9uTW91c2VFbnRlcj17KGRhdHVtLCBldmVudCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFpc0VtcHR5KSB7XG4gICAgICAgICAgICAgIGNvbnN0IHBpZSA9IGV2ZW50LmN1cnJlbnRUYXJnZXRcbiAgICAgICAgICAgICAgcGllLnN0eWxlLmN1cnNvciA9ICdwb2ludGVyJ1xuICAgICAgICAgICAgICBzZXRDdXJyZW50Rm9jdXNJbmRleChkYXR1bS5pZC50b1N0cmluZygpKVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH19XG4gICAgICAgICAgb25Nb3VzZUxlYXZlPXsoKSA9PiBzZXRDdXJyZW50Rm9jdXNJbmRleCh1bmRlZmluZWQpfVxuICAgICAgICAgIHsuLi5jaGFydFByb3BzfVxuICAgICAgICAvPlxuICAgICAgICB7Y29udGVudCA/IDxTdHlsZWRDb250ZW50Pntjb250ZW50fTwvU3R5bGVkQ29udGVudD4gOiBudWxsfVxuICAgICAgPC9kaXY+XG4gICAgICB7d2l0aExlZ2VuZCA/IDxMZWdlbmREaXNwbGF5ZXIgLz4gOiBudWxsfVxuICAgIDwvQ29udGFpbmVyPlxuICApXG59XG4iXX0= */"));
34
+ }) => theme.typography.headingStrong, ";line-height:100px;height:100px;width:100px;margin:auto;text-align:center;vertical-align:middle;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQmdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BpZUNoYXJ0L2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VUaGVtZSB9IGZyb20gJ0BlbW90aW9uL3JlYWN0J1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IEJveCB9IGZyb20gJ0BuaXZvL2NvcmUnXG5pbXBvcnQgeyBQaWUgfSBmcm9tICdAbml2by9waWUnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlQ2FsbGJhY2ssIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBnZXRMZWdlbmRDb2xvciB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbGVnZW5kJ1xuaW1wb3J0IHsgZ2V0Tml2b1RoZW1lIH0gZnJvbSAnLi4vLi4vaGVscGVycy9uaXZvVGhlbWUnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCBMZWdlbmRzIGZyb20gJy4vTGVnZW5kcydcbmltcG9ydCB0eXBlIHsgRGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8eyBoZWlnaHQ6IG51bWJlciB9PmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiAkeyh7IGhlaWdodCB9KSA9PiBgJHtoZWlnaHR9cHhgfTtcbmBcblxuY29uc3QgRW1wdHlMZWdlbmQgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtYXJnaW4tbGVmdDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnNSddfTtcbmBcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IDA7XG4gIGxlZnQ6IDA7XG4gIHJpZ2h0OiAwO1xuICB0b3A6IDA7XG5cbiAgZm9udC1zaXplOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnR5cG9ncmFwaHkuaGVhZGluZ1N0cm9uZ307XG4gIGxpbmUtaGVpZ2h0OiAxMDBweDtcbiAgaGVpZ2h0OiAxMDBweDtcbiAgd2lkdGg6IDEwMHB4O1xuICBtYXJnaW46IGF1dG87XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdmVydGljYWwtYWxpZ246IG1pZGRsZTtcbmBcblxudHlwZSBQaWVDaGFydFByb3BzID0ge1xuICBjaGFydFByb3BzPzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgZGF0YT86IERhdGFbXVxuICBoZWlnaHQ/OiBudW1iZXJcbiAgd2lkdGg/OiBudW1iZXJcbiAgZW1wdHlMZWdlbmQ/OiBzdHJpbmdcbiAgY29udGVudD86IFJlYWN0Tm9kZVxuICB3aXRoTGVnZW5kPzogYm9vbGVhblxuICBtYXJnaW4/OiBCb3hcbn1cblxuY29uc3QgREVGQVVMVF9DSEFSVFBST1BTID0ge31cbmNvbnN0IERFRkFVTFRfTUFSR0lOID0geyBib3R0b206IDEwLCBsZWZ0OiAxMCwgcmlnaHQ6IDEwLCB0b3A6IDEwIH1cblxuLyoqXG4gKiBQaWVDaGFydCBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGFyb3VuZCB0aGUgTml2byBQaWUgY29tcG9uZW50IHRvIGRpc3BsYXkgYSBwaWUgY2hhcnQuXG4gKiBTZWUgaHR0cHM6Ly9uaXZvLnJvY2tzL3BpZS8gZm9yIG1vcmUgaW5mb3JtYXRpb24uXG4gKiBAZXhwZXJpbWVudGFsIFRoaXMgY29tcG9uZW50IGlzIGV4cGVyaW1lbnRhbCBhbmQgbWF5IGJlIHN1YmplY3QgdG8gYnJlYWtpbmcgY2hhbmdlcyBpbiB0aGUgZnV0dXJlLlxuICovXG5leHBvcnQgY29uc3QgUGllQ2hhcnQgPSAoe1xuICBoZWlnaHQgPSAyMDYsXG4gIHdpZHRoID0gMjA2LFxuICBkYXRhID0gdW5kZWZpbmVkLFxuICBlbXB0eUxlZ2VuZCxcbiAgY29udGVudCxcbiAgd2l0aExlZ2VuZCA9IGZhbHNlLFxuICBtYXJnaW4gPSBERUZBVUxUX01BUkdJTixcbiAgY2hhcnRQcm9wcyA9IERFRkFVTFRfQ0hBUlRQUk9QUyxcbn06IFBpZUNoYXJ0UHJvcHMpID0+IHtcbiAgY29uc3QgdGhlbWUgPSB1c2VUaGVtZSgpXG4gIGNvbnN0IFtjdXJyZW50Rm9jdXNJbmRleCwgc2V0Q3VycmVudEZvY3VzSW5kZXhdID0gdXNlU3RhdGU8c3RyaW5nPigpXG4gIGNvbnN0IGVtcHR5VG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IDxzcGFuIC8+LCBbXSlcbiAgY29uc3QgaXNFbXB0eSA9ICFkYXRhIHx8IGRhdGEubGVuZ3RoID09PSAwXG5cbiAgY29uc3QgRW1wdHlMZWdlbmREaXNwbGF5ZWQgPSB1c2VDYWxsYmFjayhcbiAgICAoKSA9PlxuICAgICAgZW1wdHlMZWdlbmQgPyAoXG4gICAgICAgIDxFbXB0eUxlZ2VuZD5cbiAgICAgICAgICA8VGV4dCB2YXJpYW50PVwiYm9keVwiIGFzPVwicFwiPlxuICAgICAgICAgICAge2VtcHR5TGVnZW5kfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgPC9FbXB0eUxlZ2VuZD5cbiAgICAgICkgOiBudWxsLFxuICAgIFtlbXB0eUxlZ2VuZF0sXG4gIClcblxuICBjb25zdCBsb2NhbENvbG9ycyA9IGdldExlZ2VuZENvbG9yKHRoZW1lKVxuXG4gIGNvbnN0IExlZ2VuZERpc3BsYXllciA9IHVzZUNhbGxiYWNrKFxuICAgICgpID0+XG4gICAgICBpc0VtcHR5ID8gKFxuICAgICAgICA8RW1wdHlMZWdlbmREaXNwbGF5ZWQgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDxMZWdlbmRzXG4gICAgICAgICAgZm9jdXNlZD17Y3VycmVudEZvY3VzSW5kZXh9XG4gICAgICAgICAgZGF0YT17ZGF0YX1cbiAgICAgICAgICBvbkZvY3VzQ2hhbmdlPXtzZXRDdXJyZW50Rm9jdXNJbmRleH1cbiAgICAgICAgICBjb2xvcnM9e2xvY2FsQ29sb3JzfVxuICAgICAgICAvPlxuICAgICAgKSxcbiAgICBbaXNFbXB0eSwgY3VycmVudEZvY3VzSW5kZXgsIGRhdGEsIEVtcHR5TGVnZW5kRGlzcGxheWVkLCBsb2NhbENvbG9yc10sXG4gIClcblxuICByZXR1cm4gKFxuICAgIDxDb250YWluZXIgaGVpZ2h0PXtoZWlnaHR9PlxuICAgICAgPGRpdiBzdHlsZT17eyBwb3NpdGlvbjogJ3JlbGF0aXZlJyB9fT5cbiAgICAgICAgPFBpZVxuICAgICAgICAgIGNvbG9ycz17bG9jYWxDb2xvcnN9XG4gICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgIHZhbHVlPVwicGVyY2VudFwiXG4gICAgICAgICAgZW5hYmxlQXJjTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBlbmFibGVBcmNMaW5rTGFiZWxzPXtmYWxzZX1cbiAgICAgICAgICBkYXRhPXtcbiAgICAgICAgICAgICFpc0VtcHR5XG4gICAgICAgICAgICAgID8gZGF0YVxuICAgICAgICAgICAgICA6IFtcbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgaWQ6ICdlbXB0eScsXG4gICAgICAgICAgICAgICAgICAgIHBlcmNlbnQ6IDEwMCxcbiAgICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgXVxuICAgICAgICAgIH1cbiAgICAgICAgICBkZWZzPXtbXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgIGJhY2tncm91bmQ6ICdpbmhlcml0JyxcbiAgICAgICAgICAgICAgY29sb3I6IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHRTdHJvbmcsXG4gICAgICAgICAgICAgIGlkOiAnbGluZXMnLFxuICAgICAgICAgICAgICBsaW5lV2lkdGg6IDIsXG4gICAgICAgICAgICAgIHJvdGF0aW9uOiAwLFxuICAgICAgICAgICAgICBzcGFjaW5nOiA1LFxuICAgICAgICAgICAgICB0eXBlOiAncGF0dGVybkxpbmVzJyxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgXX1cbiAgICAgICAgICBtYXJnaW49e21hcmdpbn1cbiAgICAgICAgICBpbm5lclJhZGl1cz17MC44fVxuICAgICAgICAgIGNvcm5lclJhZGl1cz17MH1cbiAgICAgICAgICBwYWRBbmdsZT17MX1cbiAgICAgICAgICBhY3RpdmVPdXRlclJhZGl1c09mZnNldD17IWlzRW1wdHkgPyA0IDogMH1cbiAgICAgICAgICB0b29sdGlwPXtlbXB0eVRvb2x0aXB9XG4gICAgICAgICAgb25Nb3VzZUVudGVyPXsoZGF0dW0sIGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoIWlzRW1wdHkpIHtcbiAgICAgICAgICAgICAgY29uc3QgcGllID0gZXZlbnQuY3VycmVudFRhcmdldFxuICAgICAgICAgICAgICBwaWUuc3R5bGUuY3Vyc29yID0gJ3BvaW50ZXInXG4gICAgICAgICAgICAgIHNldEN1cnJlbnRGb2N1c0luZGV4KGRhdHVtLmlkLnRvU3RyaW5nKCkpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfX1cbiAgICAgICAgICBvbk1vdXNlTGVhdmU9eygpID0+IHNldEN1cnJlbnRGb2N1c0luZGV4KHVuZGVmaW5lZCl9XG4gICAgICAgICAgdGhlbWU9e2dldE5pdm9UaGVtZSh0aGVtZSl9XG4gICAgICAgICAgey4uLmNoYXJ0UHJvcHN9XG4gICAgICAgIC8+XG4gICAgICAgIHtjb250ZW50ID8gPFN0eWxlZENvbnRlbnQ+e2NvbnRlbnR9PC9TdHlsZWRDb250ZW50PiA6IG51bGx9XG4gICAgICA8L2Rpdj5cbiAgICAgIHt3aXRoTGVnZW5kID8gPExlZ2VuZERpc3BsYXllciAvPiA6IG51bGx9XG4gICAgPC9Db250YWluZXI+XG4gIClcbn1cbiJdfQ== */"));
34
35
  const DEFAULT_CHARTPROPS = {};
35
36
  const DEFAULT_MARGIN = {
36
37
  bottom: 10,
@@ -76,7 +77,7 @@ const PieChart = ({
76
77
  pie.style.cursor = "pointer";
77
78
  setCurrentFocusIndex(datum.id.toString());
78
79
  }
79
- }, onMouseLeave: () => setCurrentFocusIndex(void 0), ...chartProps }),
80
+ }, onMouseLeave: () => setCurrentFocusIndex(void 0), theme: getNivoTheme(theme), ...chartProps }),
80
81
  content ? /* @__PURE__ */ jsx(StyledContent, { children: content }) : null
81
82
  ] }),
82
83
  withLegend ? /* @__PURE__ */ jsx(LegendDisplayer, {}) : null