@ultraviolet/ui 1.84.0 → 1.84.2

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.
@@ -52,40 +52,41 @@ const coreStyle = ({
52
52
  } else if (iconOnly) {
53
53
  width = `${theme.sizing[SIZE_HEIGHT[size]]}`;
54
54
  }
55
- return `display: inline-flex;
56
- height: ${theme.sizing[SIZE_HEIGHT[size]]};
57
- padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};
58
- flex-direction: ${iconPosition === "right" ? "row-reverse" : "row"};
59
- gap: ${theme.space[SIZE_GAP_KEY[size]]};
60
- border-radius: ${theme.radii.default};
61
- box-sizing: border-box;
62
- width: ${width};
63
- align-items: center;
64
- cursor: ${disabled ? "not-allowed" : "pointer"};
65
- justify-content: center;
66
- outline-offset: 2px;
67
- white-space: nowrap;
68
- text-decoration: none;
69
- &:hover {
55
+ return `
56
+ display: inline-flex;
57
+ height: ${theme.sizing[SIZE_HEIGHT[size]]};
58
+ padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};
59
+ flex-direction: ${iconPosition === "right" ? "row-reverse" : "row"};
60
+ gap: ${theme.space[SIZE_GAP_KEY[size]]};
61
+ border-radius: ${theme.radii.default};
62
+ box-sizing: border-box;
63
+ width: ${width};
64
+ align-items: center;
65
+ cursor: ${disabled ? "not-allowed" : "pointer"};
66
+ justify-content: center;
67
+ outline-offset: 2px;
68
+ white-space: nowrap;
70
69
  text-decoration: none;
71
- }
70
+ &:hover {
71
+ text-decoration: none;
72
+ }
72
73
 
73
74
 
74
- ${disabled ? "" : `
75
- &:active {
76
- box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};
77
- }
78
- `}
75
+ ${disabled ? "" : `
76
+ &:active {
77
+ box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};
78
+ }
79
+ `}
79
80
 
80
- /* We can't use Text component because of button hover effect, so we need to duplicate */
81
- font-size: ${font.fontSize};
82
- font-family: ${font.fontFamily};
83
- font-weight: ${font.weight};
84
- letter-spacing: ${font.letterSpacing};
85
- line-height: ${font.lineHeight};
86
- paragraph-spacing: ${font.paragraphSpacing};
87
- text-case: ${font.textCase};
88
- `;
81
+ /* We can't use Text component because of button hover effect, so we need to duplicate */
82
+ font-size: ${font.fontSize};
83
+ font-family: ${font.fontFamily};
84
+ font-weight: ${font.weight};
85
+ letter-spacing: ${font.letterSpacing};
86
+ line-height: ${font.lineHeight};
87
+ paragraph-spacing: ${font.paragraphSpacing};
88
+ text-case: ${font.textCase};
89
+ `;
89
90
  };
90
91
  const StyledFilledButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
91
92
  shouldForwardProp: (prop) => !["size", "sentiment", "iconPosition", "fullWidth", "iconOnly"].includes(prop),
@@ -115,7 +116,7 @@ const StyledFilledButton = /* @__PURE__ */ _styled("button", process.env.NODE_EN
115
116
  color:
116
117
  ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === "white" ? "black" : "white"].textHover};
117
118
  }
118
- `, ";" + (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/Button/index.tsx"],"names":[],"mappings":"AAgIqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  ComponentProps,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader } from '../Loader'\nimport { Tooltip } from '../Tooltip'\n\n// SIZE\nexport const SIZE_HEIGHT = {\n  large: '600', // sizing key value from tokens\n  medium: '500',\n  small: '400',\n  xsmall: '300',\n} as const\ntype ButtonSize = keyof typeof SIZE_HEIGHT\nconst SIZE_PADDING_KEY = {\n  large: 2,\n  medium: 1.5,\n  small: 1,\n  xsmall: 0.5,\n} as const\nconst SIZE_GAP_KEY = {\n  large: 1,\n  medium: 1,\n  small: 1,\n  xsmall: 0.5,\n} as const\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n  black: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<\n    FinalProps,\n    'size' | 'sentiment' | 'disabled' | 'iconPosition' | 'fullWidth'\n  >\n> & { iconOnly: boolean }\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  iconPosition,\n  fullWidth,\n  disabled,\n  iconOnly,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  } else if (iconOnly) {\n    width = `${theme.sizing[SIZE_HEIGHT[size]]}`\n  }\n\n  return `display: inline-flex;\n  height: ${theme.sizing[SIZE_HEIGHT[size]]};\n  padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n  flex-direction: ${iconPosition === 'right' ? 'row-reverse' : 'row'};\n  gap: ${theme.space[SIZE_GAP_KEY[size]]};\n  border-radius: ${theme.radii.default};\n  box-sizing: border-box;\n  width: ${width};\n  align-items: center;\n  cursor: ${disabled ? 'not-allowed' : 'pointer'};\n  justify-content: center;\n  outline-offset: 2px;\n  white-space: nowrap;\n  text-decoration: none;\n  &:hover {\n    text-decoration: none;\n  }\n\n\n  ${\n    disabled\n      ? ''\n      : `\n          &:active {\n            box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n          }\n        `\n  }\n\n  /* We can't use Text component because of button hover effect, so we need to duplicate */\n  font-size: ${font.fontSize};\n  font-family: ${font.fontFamily};\n  font-weight: ${font.weight};\n  letter-spacing: ${font.letterSpacing};\n  line-height: ${font.lineHeight};\n  paragraph-spacing: ${font.paragraphSpacing};\n  text-case: ${font.textCase};\n`\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n}\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  iconPosition?: 'left' | 'right'\n  iconVariant?: ComponentProps<typeof Icon>['variant']\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n}\n\n// @note: using XOR utility was generating some lint erros\ntype FinalProps = CommonProps &\n  (\n    | {\n        // Button : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Button : Icon only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Anchor : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n    | {\n        // Anchor : Children + Icon Only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n  )\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      icon,\n      iconPosition = 'left',\n      iconVariant,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const content = (\n      <>\n        {!isLoading && icon ? (\n          <Icon name={icon} size=\"small\" variant={iconVariant} />\n        ) : null}\n        {isLoading ? (\n          <Loader\n            active\n            trailColor=\"transparent\"\n            size=\"1em\"\n            color=\"currentColor\"\n          />\n        ) : null}\n        {children && typeof children !== 'string' ? (\n          <div>{children}</div>\n        ) : (\n          children\n        )}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n          <Component\n            role={role}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            fullWidth={fullWidth}\n            iconPosition={iconPosition}\n            sentiment={sentiment}\n            size={size}\n            type={type}\n            onClick={onClick}\n            aria-label={ariaLabel}\n            aria-current={ariaCurrent}\n            aria-controls={ariaControls}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            href={href}\n            target={target}\n            download={download}\n            ref={ref as Ref<HTMLAnchorElement>}\n            iconOnly={!!icon && !children}\n            tabIndex={tabIndex}\n            autoFocus={autoFocus}\n            onMouseDown={onMouseDown}\n            onMouseUp={onMouseUp}\n            onMouseOut={onMouseOut}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n        <Component\n          role={role}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          iconPosition={iconPosition}\n          sentiment={sentiment}\n          size={size}\n          type={type}\n          onClick={onClick}\n          ref={ref as Ref<HTMLButtonElement>}\n          name={name}\n          aria-label={ariaLabel}\n          aria-current={ariaCurrent}\n          aria-controls={ariaControls}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          iconOnly={!!icon && !children}\n          tabIndex={tabIndex}\n          autoFocus={autoFocus}\n          onMouseDown={onMouseDown}\n          onMouseUp={onMouseUp}\n          onMouseOut={onMouseOut}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
119
+ `, ";" + (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/Button/index.tsx"],"names":[],"mappings":"AAkIqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  ComponentProps,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader } from '../Loader'\nimport { Tooltip } from '../Tooltip'\n\n// SIZE\nexport const SIZE_HEIGHT = {\n  large: '600', // sizing key value from tokens\n  medium: '500',\n  small: '400',\n  xsmall: '300',\n} as const\ntype ButtonSize = keyof typeof SIZE_HEIGHT\nconst SIZE_PADDING_KEY = {\n  large: 2,\n  medium: 1.5,\n  small: 1,\n  xsmall: 0.5,\n} as const\nconst SIZE_GAP_KEY = {\n  large: 1,\n  medium: 1,\n  small: 1,\n  xsmall: 0.5,\n} as const\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n  black: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<\n    FinalProps,\n    'size' | 'sentiment' | 'disabled' | 'iconPosition' | 'fullWidth'\n  >\n> & { iconOnly: boolean }\n\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  iconPosition,\n  fullWidth,\n  disabled,\n  iconOnly,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  } else if (iconOnly) {\n    width = `${theme.sizing[SIZE_HEIGHT[size]]}`\n  }\n\n  return `\n    display: inline-flex;\n    height: ${theme.sizing[SIZE_HEIGHT[size]]};\n    padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n    flex-direction: ${iconPosition === 'right' ? 'row-reverse' : 'row'};\n    gap: ${theme.space[SIZE_GAP_KEY[size]]};\n    border-radius: ${theme.radii.default};\n    box-sizing: border-box;\n    width: ${width};\n    align-items: center;\n    cursor: ${disabled ? 'not-allowed' : 'pointer'};\n    justify-content: center;\n    outline-offset: 2px;\n    white-space: nowrap;\n    text-decoration: none;\n    &:hover {\n      text-decoration: none;\n    }\n\n\n    ${\n      disabled\n        ? ''\n        : `\n            &:active {\n              box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n            }\n          `\n    }\n\n    /* We can't use Text component because of button hover effect, so we need to duplicate */\n    font-size: ${font.fontSize};\n    font-family: ${font.fontFamily};\n    font-weight: ${font.weight};\n    letter-spacing: ${font.letterSpacing};\n    line-height: ${font.lineHeight};\n    paragraph-spacing: ${font.paragraphSpacing};\n    text-case: ${font.textCase};\n  `\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n}\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  iconPosition?: 'left' | 'right'\n  iconVariant?: ComponentProps<typeof Icon>['variant']\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n}\n\n// @note: using XOR utility was generating some lint erros\ntype FinalProps = CommonProps &\n  (\n    | {\n        // Button : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Button : Icon only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Anchor : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n    | {\n        // Anchor : Children + Icon Only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n  )\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      icon,\n      iconPosition = 'left',\n      iconVariant,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const content = (\n      <>\n        {!isLoading && icon ? (\n          <Icon name={icon} size=\"small\" variant={iconVariant} />\n        ) : null}\n        {isLoading ? (\n          <Loader\n            active\n            trailColor=\"transparent\"\n            size=\"1em\"\n            color=\"currentColor\"\n          />\n        ) : null}\n        {children}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n          <Component\n            role={role}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            fullWidth={fullWidth}\n            iconPosition={iconPosition}\n            sentiment={sentiment}\n            size={size}\n            type={type}\n            onClick={onClick}\n            aria-label={ariaLabel}\n            aria-current={ariaCurrent}\n            aria-controls={ariaControls}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            href={href}\n            target={target}\n            download={download}\n            ref={ref as Ref<HTMLAnchorElement>}\n            iconOnly={!!icon && !children}\n            tabIndex={tabIndex}\n            autoFocus={autoFocus}\n            onMouseDown={onMouseDown}\n            onMouseUp={onMouseUp}\n            onMouseOut={onMouseOut}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n        <Component\n          role={role}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          iconPosition={iconPosition}\n          sentiment={sentiment}\n          size={size}\n          type={type}\n          onClick={onClick}\n          ref={ref as Ref<HTMLButtonElement>}\n          name={name}\n          aria-label={ariaLabel}\n          aria-current={ariaCurrent}\n          aria-controls={ariaControls}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          iconOnly={!!icon && !children}\n          tabIndex={tabIndex}\n          autoFocus={autoFocus}\n          onMouseDown={onMouseDown}\n          onMouseUp={onMouseUp}\n          onMouseOut={onMouseOut}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
119
120
  const StyledOutlinedButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
120
121
  shouldForwardProp: (prop) => !["size", "sentiment", "iconPosition", "fullWidth", "iconOnly"].includes(prop),
121
122
  target: "e112qvla1"
@@ -147,7 +148,7 @@ const StyledOutlinedButton = /* @__PURE__ */ _styled("button", process.env.NODE_
147
148
  border: 1px solid ${!isMonochrome(sentiment) ? theme.colors[sentiment][sentiment === "neutral" ? "borderStrongHover" : "borderHover"] : theme.colors.other.monochrome[sentiment].borderHover};
148
149
 
149
150
  }
150
- `, ";" + (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/Button/index.tsx"],"names":[],"mappings":"AAgKqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  ComponentProps,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader } from '../Loader'\nimport { Tooltip } from '../Tooltip'\n\n// SIZE\nexport const SIZE_HEIGHT = {\n  large: '600', // sizing key value from tokens\n  medium: '500',\n  small: '400',\n  xsmall: '300',\n} as const\ntype ButtonSize = keyof typeof SIZE_HEIGHT\nconst SIZE_PADDING_KEY = {\n  large: 2,\n  medium: 1.5,\n  small: 1,\n  xsmall: 0.5,\n} as const\nconst SIZE_GAP_KEY = {\n  large: 1,\n  medium: 1,\n  small: 1,\n  xsmall: 0.5,\n} as const\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n  black: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<\n    FinalProps,\n    'size' | 'sentiment' | 'disabled' | 'iconPosition' | 'fullWidth'\n  >\n> & { iconOnly: boolean }\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  iconPosition,\n  fullWidth,\n  disabled,\n  iconOnly,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  } else if (iconOnly) {\n    width = `${theme.sizing[SIZE_HEIGHT[size]]}`\n  }\n\n  return `display: inline-flex;\n  height: ${theme.sizing[SIZE_HEIGHT[size]]};\n  padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n  flex-direction: ${iconPosition === 'right' ? 'row-reverse' : 'row'};\n  gap: ${theme.space[SIZE_GAP_KEY[size]]};\n  border-radius: ${theme.radii.default};\n  box-sizing: border-box;\n  width: ${width};\n  align-items: center;\n  cursor: ${disabled ? 'not-allowed' : 'pointer'};\n  justify-content: center;\n  outline-offset: 2px;\n  white-space: nowrap;\n  text-decoration: none;\n  &:hover {\n    text-decoration: none;\n  }\n\n\n  ${\n    disabled\n      ? ''\n      : `\n          &:active {\n            box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n          }\n        `\n  }\n\n  /* We can't use Text component because of button hover effect, so we need to duplicate */\n  font-size: ${font.fontSize};\n  font-family: ${font.fontFamily};\n  font-weight: ${font.weight};\n  letter-spacing: ${font.letterSpacing};\n  line-height: ${font.lineHeight};\n  paragraph-spacing: ${font.paragraphSpacing};\n  text-case: ${font.textCase};\n`\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n}\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  iconPosition?: 'left' | 'right'\n  iconVariant?: ComponentProps<typeof Icon>['variant']\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n}\n\n// @note: using XOR utility was generating some lint erros\ntype FinalProps = CommonProps &\n  (\n    | {\n        // Button : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Button : Icon only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Anchor : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n    | {\n        // Anchor : Children + Icon Only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n  )\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      icon,\n      iconPosition = 'left',\n      iconVariant,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const content = (\n      <>\n        {!isLoading && icon ? (\n          <Icon name={icon} size=\"small\" variant={iconVariant} />\n        ) : null}\n        {isLoading ? (\n          <Loader\n            active\n            trailColor=\"transparent\"\n            size=\"1em\"\n            color=\"currentColor\"\n          />\n        ) : null}\n        {children && typeof children !== 'string' ? (\n          <div>{children}</div>\n        ) : (\n          children\n        )}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n          <Component\n            role={role}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            fullWidth={fullWidth}\n            iconPosition={iconPosition}\n            sentiment={sentiment}\n            size={size}\n            type={type}\n            onClick={onClick}\n            aria-label={ariaLabel}\n            aria-current={ariaCurrent}\n            aria-controls={ariaControls}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            href={href}\n            target={target}\n            download={download}\n            ref={ref as Ref<HTMLAnchorElement>}\n            iconOnly={!!icon && !children}\n            tabIndex={tabIndex}\n            autoFocus={autoFocus}\n            onMouseDown={onMouseDown}\n            onMouseUp={onMouseUp}\n            onMouseOut={onMouseOut}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n        <Component\n          role={role}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          iconPosition={iconPosition}\n          sentiment={sentiment}\n          size={size}\n          type={type}\n          onClick={onClick}\n          ref={ref as Ref<HTMLButtonElement>}\n          name={name}\n          aria-label={ariaLabel}\n          aria-current={ariaCurrent}\n          aria-controls={ariaControls}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          iconOnly={!!icon && !children}\n          tabIndex={tabIndex}\n          autoFocus={autoFocus}\n          onMouseDown={onMouseDown}\n          onMouseUp={onMouseUp}\n          onMouseOut={onMouseOut}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
151
+ `, ";" + (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/Button/index.tsx"],"names":[],"mappings":"AAkKqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  ComponentProps,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader } from '../Loader'\nimport { Tooltip } from '../Tooltip'\n\n// SIZE\nexport const SIZE_HEIGHT = {\n  large: '600', // sizing key value from tokens\n  medium: '500',\n  small: '400',\n  xsmall: '300',\n} as const\ntype ButtonSize = keyof typeof SIZE_HEIGHT\nconst SIZE_PADDING_KEY = {\n  large: 2,\n  medium: 1.5,\n  small: 1,\n  xsmall: 0.5,\n} as const\nconst SIZE_GAP_KEY = {\n  large: 1,\n  medium: 1,\n  small: 1,\n  xsmall: 0.5,\n} as const\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n  black: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<\n    FinalProps,\n    'size' | 'sentiment' | 'disabled' | 'iconPosition' | 'fullWidth'\n  >\n> & { iconOnly: boolean }\n\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  iconPosition,\n  fullWidth,\n  disabled,\n  iconOnly,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  } else if (iconOnly) {\n    width = `${theme.sizing[SIZE_HEIGHT[size]]}`\n  }\n\n  return `\n    display: inline-flex;\n    height: ${theme.sizing[SIZE_HEIGHT[size]]};\n    padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n    flex-direction: ${iconPosition === 'right' ? 'row-reverse' : 'row'};\n    gap: ${theme.space[SIZE_GAP_KEY[size]]};\n    border-radius: ${theme.radii.default};\n    box-sizing: border-box;\n    width: ${width};\n    align-items: center;\n    cursor: ${disabled ? 'not-allowed' : 'pointer'};\n    justify-content: center;\n    outline-offset: 2px;\n    white-space: nowrap;\n    text-decoration: none;\n    &:hover {\n      text-decoration: none;\n    }\n\n\n    ${\n      disabled\n        ? ''\n        : `\n            &:active {\n              box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n            }\n          `\n    }\n\n    /* We can't use Text component because of button hover effect, so we need to duplicate */\n    font-size: ${font.fontSize};\n    font-family: ${font.fontFamily};\n    font-weight: ${font.weight};\n    letter-spacing: ${font.letterSpacing};\n    line-height: ${font.lineHeight};\n    paragraph-spacing: ${font.paragraphSpacing};\n    text-case: ${font.textCase};\n  `\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n}\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  iconPosition?: 'left' | 'right'\n  iconVariant?: ComponentProps<typeof Icon>['variant']\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n}\n\n// @note: using XOR utility was generating some lint erros\ntype FinalProps = CommonProps &\n  (\n    | {\n        // Button : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Button : Icon only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Anchor : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n    | {\n        // Anchor : Children + Icon Only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n  )\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      icon,\n      iconPosition = 'left',\n      iconVariant,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const content = (\n      <>\n        {!isLoading && icon ? (\n          <Icon name={icon} size=\"small\" variant={iconVariant} />\n        ) : null}\n        {isLoading ? (\n          <Loader\n            active\n            trailColor=\"transparent\"\n            size=\"1em\"\n            color=\"currentColor\"\n          />\n        ) : null}\n        {children}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n          <Component\n            role={role}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            fullWidth={fullWidth}\n            iconPosition={iconPosition}\n            sentiment={sentiment}\n            size={size}\n            type={type}\n            onClick={onClick}\n            aria-label={ariaLabel}\n            aria-current={ariaCurrent}\n            aria-controls={ariaControls}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            href={href}\n            target={target}\n            download={download}\n            ref={ref as Ref<HTMLAnchorElement>}\n            iconOnly={!!icon && !children}\n            tabIndex={tabIndex}\n            autoFocus={autoFocus}\n            onMouseDown={onMouseDown}\n            onMouseUp={onMouseUp}\n            onMouseOut={onMouseOut}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n        <Component\n          role={role}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          iconPosition={iconPosition}\n          sentiment={sentiment}\n          size={size}\n          type={type}\n          onClick={onClick}\n          ref={ref as Ref<HTMLButtonElement>}\n          name={name}\n          aria-label={ariaLabel}\n          aria-current={ariaCurrent}\n          aria-controls={ariaControls}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          iconOnly={!!icon && !children}\n          tabIndex={tabIndex}\n          autoFocus={autoFocus}\n          onMouseDown={onMouseDown}\n          onMouseUp={onMouseUp}\n          onMouseOut={onMouseOut}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
151
152
  const StyledGhostButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
152
153
  shouldForwardProp: (prop) => !["size", "sentiment", "iconPosition", "fullWidth", "iconOnly"].includes(prop),
153
154
  target: "e112qvla0"
@@ -172,7 +173,7 @@ const StyledGhostButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV
172
173
  color:
173
174
  ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === "white" ? "black" : "white"].textHover};
174
175
  }
175
- `, ";" + (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/Button/index.tsx"],"names":[],"mappings":"AAsNqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  ComponentProps,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader } from '../Loader'\nimport { Tooltip } from '../Tooltip'\n\n// SIZE\nexport const SIZE_HEIGHT = {\n  large: '600', // sizing key value from tokens\n  medium: '500',\n  small: '400',\n  xsmall: '300',\n} as const\ntype ButtonSize = keyof typeof SIZE_HEIGHT\nconst SIZE_PADDING_KEY = {\n  large: 2,\n  medium: 1.5,\n  small: 1,\n  xsmall: 0.5,\n} as const\nconst SIZE_GAP_KEY = {\n  large: 1,\n  medium: 1,\n  small: 1,\n  xsmall: 0.5,\n} as const\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n  black: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<\n    FinalProps,\n    'size' | 'sentiment' | 'disabled' | 'iconPosition' | 'fullWidth'\n  >\n> & { iconOnly: boolean }\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  iconPosition,\n  fullWidth,\n  disabled,\n  iconOnly,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  } else if (iconOnly) {\n    width = `${theme.sizing[SIZE_HEIGHT[size]]}`\n  }\n\n  return `display: inline-flex;\n  height: ${theme.sizing[SIZE_HEIGHT[size]]};\n  padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n  flex-direction: ${iconPosition === 'right' ? 'row-reverse' : 'row'};\n  gap: ${theme.space[SIZE_GAP_KEY[size]]};\n  border-radius: ${theme.radii.default};\n  box-sizing: border-box;\n  width: ${width};\n  align-items: center;\n  cursor: ${disabled ? 'not-allowed' : 'pointer'};\n  justify-content: center;\n  outline-offset: 2px;\n  white-space: nowrap;\n  text-decoration: none;\n  &:hover {\n    text-decoration: none;\n  }\n\n\n  ${\n    disabled\n      ? ''\n      : `\n          &:active {\n            box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n          }\n        `\n  }\n\n  /* We can't use Text component because of button hover effect, so we need to duplicate */\n  font-size: ${font.fontSize};\n  font-family: ${font.fontFamily};\n  font-weight: ${font.weight};\n  letter-spacing: ${font.letterSpacing};\n  line-height: ${font.lineHeight};\n  paragraph-spacing: ${font.paragraphSpacing};\n  text-case: ${font.textCase};\n`\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n}\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  iconPosition?: 'left' | 'right'\n  iconVariant?: ComponentProps<typeof Icon>['variant']\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n}\n\n// @note: using XOR utility was generating some lint erros\ntype FinalProps = CommonProps &\n  (\n    | {\n        // Button : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Button : Icon only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Anchor : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n    | {\n        // Anchor : Children + Icon Only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n  )\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      icon,\n      iconPosition = 'left',\n      iconVariant,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const content = (\n      <>\n        {!isLoading && icon ? (\n          <Icon name={icon} size=\"small\" variant={iconVariant} />\n        ) : null}\n        {isLoading ? (\n          <Loader\n            active\n            trailColor=\"transparent\"\n            size=\"1em\"\n            color=\"currentColor\"\n          />\n        ) : null}\n        {children && typeof children !== 'string' ? (\n          <div>{children}</div>\n        ) : (\n          children\n        )}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n          <Component\n            role={role}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            fullWidth={fullWidth}\n            iconPosition={iconPosition}\n            sentiment={sentiment}\n            size={size}\n            type={type}\n            onClick={onClick}\n            aria-label={ariaLabel}\n            aria-current={ariaCurrent}\n            aria-controls={ariaControls}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            href={href}\n            target={target}\n            download={download}\n            ref={ref as Ref<HTMLAnchorElement>}\n            iconOnly={!!icon && !children}\n            tabIndex={tabIndex}\n            autoFocus={autoFocus}\n            onMouseDown={onMouseDown}\n            onMouseUp={onMouseUp}\n            onMouseOut={onMouseOut}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n        <Component\n          role={role}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          iconPosition={iconPosition}\n          sentiment={sentiment}\n          size={size}\n          type={type}\n          onClick={onClick}\n          ref={ref as Ref<HTMLButtonElement>}\n          name={name}\n          aria-label={ariaLabel}\n          aria-current={ariaCurrent}\n          aria-controls={ariaControls}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          iconOnly={!!icon && !children}\n          tabIndex={tabIndex}\n          autoFocus={autoFocus}\n          onMouseDown={onMouseDown}\n          onMouseUp={onMouseUp}\n          onMouseOut={onMouseOut}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
176
+ `, ";" + (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/Button/index.tsx"],"names":[],"mappings":"AAwNqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["import type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  ComponentProps,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader } from '../Loader'\nimport { Tooltip } from '../Tooltip'\n\n// SIZE\nexport const SIZE_HEIGHT = {\n  large: '600', // sizing key value from tokens\n  medium: '500',\n  small: '400',\n  xsmall: '300',\n} as const\ntype ButtonSize = keyof typeof SIZE_HEIGHT\nconst SIZE_PADDING_KEY = {\n  large: 2,\n  medium: 1.5,\n  small: 1,\n  xsmall: 0.5,\n} as const\nconst SIZE_GAP_KEY = {\n  large: 1,\n  medium: 1,\n  small: 1,\n  xsmall: 0.5,\n} as const\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n  black: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<\n    FinalProps,\n    'size' | 'sentiment' | 'disabled' | 'iconPosition' | 'fullWidth'\n  >\n> & { iconOnly: boolean }\n\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  iconPosition,\n  fullWidth,\n  disabled,\n  iconOnly,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  } else if (iconOnly) {\n    width = `${theme.sizing[SIZE_HEIGHT[size]]}`\n  }\n\n  return `\n    display: inline-flex;\n    height: ${theme.sizing[SIZE_HEIGHT[size]]};\n    padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n    flex-direction: ${iconPosition === 'right' ? 'row-reverse' : 'row'};\n    gap: ${theme.space[SIZE_GAP_KEY[size]]};\n    border-radius: ${theme.radii.default};\n    box-sizing: border-box;\n    width: ${width};\n    align-items: center;\n    cursor: ${disabled ? 'not-allowed' : 'pointer'};\n    justify-content: center;\n    outline-offset: 2px;\n    white-space: nowrap;\n    text-decoration: none;\n    &:hover {\n      text-decoration: none;\n    }\n\n\n    ${\n      disabled\n        ? ''\n        : `\n            &:active {\n              box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n            }\n          `\n    }\n\n    /* We can't use Text component because of button hover effect, so we need to duplicate */\n    font-size: ${font.fontSize};\n    font-family: ${font.fontFamily};\n    font-weight: ${font.weight};\n    letter-spacing: ${font.letterSpacing};\n    line-height: ${font.lineHeight};\n    paragraph-spacing: ${font.paragraphSpacing};\n    text-case: ${font.textCase};\n  `\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop =>\n    !['size', 'sentiment', 'iconPosition', 'fullWidth', 'iconOnly'].includes(\n      prop,\n    ),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n}\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  iconPosition?: 'left' | 'right'\n  iconVariant?: ComponentProps<typeof Icon>['variant']\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n}\n\n// @note: using XOR utility was generating some lint erros\ntype FinalProps = CommonProps &\n  (\n    | {\n        // Button : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Button : Icon only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: string\n        href?: never\n        target?: never\n        download?: never\n      }\n    | {\n        // Anchor : Children + optional Icon\n        children: ReactNode\n        icon?: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n    | {\n        // Anchor : Children + Icon Only\n        children?: never\n        icon: ComponentProps<typeof Icon>['name']\n        name?: never\n        href: string\n        target?: string\n        download?: string\n      }\n  )\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      icon,\n      iconPosition = 'left',\n      iconVariant,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const content = (\n      <>\n        {!isLoading && icon ? (\n          <Icon name={icon} size=\"small\" variant={iconVariant} />\n        ) : null}\n        {isLoading ? (\n          <Loader\n            active\n            trailColor=\"transparent\"\n            size=\"1em\"\n            color=\"currentColor\"\n          />\n        ) : null}\n        {children}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n          <Component\n            role={role}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            fullWidth={fullWidth}\n            iconPosition={iconPosition}\n            sentiment={sentiment}\n            size={size}\n            type={type}\n            onClick={onClick}\n            aria-label={ariaLabel}\n            aria-current={ariaCurrent}\n            aria-controls={ariaControls}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            href={href}\n            target={target}\n            download={download}\n            ref={ref as Ref<HTMLAnchorElement>}\n            iconOnly={!!icon && !children}\n            tabIndex={tabIndex}\n            autoFocus={autoFocus}\n            onMouseDown={onMouseDown}\n            onMouseUp={onMouseUp}\n            onMouseOut={onMouseOut}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip text={tooltip} containerFullWidth={fullWidth}>\n        <Component\n          role={role}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          iconPosition={iconPosition}\n          sentiment={sentiment}\n          size={size}\n          type={type}\n          onClick={onClick}\n          ref={ref as Ref<HTMLButtonElement>}\n          name={name}\n          aria-label={ariaLabel}\n          aria-current={ariaCurrent}\n          aria-controls={ariaControls}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          iconOnly={!!icon && !children}\n          tabIndex={tabIndex}\n          autoFocus={autoFocus}\n          onMouseDown={onMouseDown}\n          onMouseUp={onMouseUp}\n          onMouseOut={onMouseOut}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
176
177
  const VARIANTS_COMPONENTS = {
177
178
  filled: {
178
179
  button: StyledFilledButton,
@@ -240,7 +241,7 @@ const Button = forwardRef(({
240
241
  const content = /* @__PURE__ */ jsxs(Fragment, { children: [
241
242
  !isLoading && icon ? /* @__PURE__ */ jsx(Icon, { name: icon, size: "small", variant: iconVariant }) : null,
242
243
  isLoading ? /* @__PURE__ */ jsx(Loader, { active: true, trailColor: "transparent", size: "1em", color: "currentColor" }) : null,
243
- children && typeof children !== "string" ? /* @__PURE__ */ jsx("div", { children }) : children
244
+ children
244
245
  ] });
245
246
  if (href && !computeIsDisabled) {
246
247
  const Component2 = VARIANTS_COMPONENTS[variant].link;
@@ -14,7 +14,7 @@ type ChipType = {
14
14
  export declare const Chip: {
15
15
  ({ children, size, disabled, active, className, "data-testid": dataTestId, onClick, }: ChipType): import("@emotion/react/jsx-runtime").JSX.Element;
16
16
  Icon: ({ name, onClick, "data-testid": dataTestId, }: {
17
- name: "address" | "search" | "filter" | "stop" | "view" | "id" | "sort" | "anchor" | "arrowLeft" | "cancel" | "close" | "drag" | "play" | "download" | "asterisk" | "attach" | "burger" | "check" | "detach" | "east" | "equal" | "escape" | "expand" | "github" | "instagram" | "logout" | "minus" | "north" | "organization" | "plus" | "reboot" | "restore" | "revoke" | "rss" | "send" | "slack" | "south" | "upload" | "west" | "youtube" | "bullhorn" | "calculator" | "chat" | "console" | "database" | "delete" | "doc" | "earth" | "eye" | "folder" | "lock" | "members" | "moon" | "mosaic" | "pen" | "pencil" | "phone" | "privacy" | "profile" | "rocket" | "settings" | "sun" | "support" | "unlock" | "pin" | "unpin" | "sparkles" | "email" | "arrowDown" | "arrowLeftBottom" | "arrowLeftDouble" | "arrowRightBottom" | "arrowRightDouble" | "arrowRight" | "arrowUp" | "closeCircleOutline" | "copyContent" | "dotsHorizontal" | "dotsVertical" | "dragVariant" | "eastShort" | "expandMore" | "linkedin" | "northShort" | "openInNew" | "progressCheck" | "rayEndArrow" | "rayStartArrow" | "rayStartEnd" | "rayTopArrow" | "southShort" | "switchOrga" | "twitter" | "westShort" | "addressOutline" | "adjustmentsHorizontalOutline" | "alertCircleOutline" | "autoFixOutline" | "bookOpenOutlineOutline" | "bullhornOutline" | "calculatorOutline" | "calendarRangeOutline" | "chatOutline" | "checkCircleOutline" | "clockOutlineOutline" | "consoleOutline" | "credentialOutline" | "creditCardOutline" | "databaseOutline" | "deleteOutline" | "docOutline" | "earthOutline" | "emailRemoveOutline" | "emailOutline" | "eyeOffOutline" | "eyeOutline" | "filterOutline" | "folderOutline" | "helpCircleOutline" | "idOutline" | "informationOutline" | "leafOutline" | "lightBulbOutline" | "lockOutline" | "membersOutline" | "moonOutline" | "mosaicOutline" | "penOutline" | "pencilOutline" | "phoneOutline" | "pinOutline" | "playOutline" | "privacyOutline" | "profileOutline" | "rocketOutline" | "sendOutline" | "settingsOutline" | "sparklesOutline" | "stopOutline" | "sunOutline" | "supportOutline" | "thumbsDownOutline" | "thumbsUpOutline" | "unlockOutline" | "unpinOutline" | "weatherNightOutline" | "adjustmentsHorizontal" | "alertCircle" | "autoFix" | "bookOpenOutline" | "calendarRange" | "checkCircle" | "clockOutline" | "credential" | "creditCard" | "emailRemove" | "eyeOff" | "helpCircle" | "information" | "leaf" | "lightBulb" | "thumbsDown" | "thumbsUp" | "weatherNight";
17
+ name: "address" | "search" | "filter" | "stop" | "view" | "id" | "sort" | "anchor" | "arrowLeft" | "cancel" | "close" | "drag" | "play" | "download" | "asterisk" | "attach" | "burger" | "check" | "detach" | "east" | "equal" | "escape" | "expand" | "github" | "instagram" | "logout" | "minus" | "north" | "organization" | "plus" | "reboot" | "restore" | "revoke" | "rss" | "send" | "slack" | "south" | "upload" | "west" | "youtube" | "bullhorn" | "calculator" | "chat" | "console" | "database" | "delete" | "doc" | "earth" | "eye" | "folder" | "lock" | "members" | "moon" | "mosaic" | "pen" | "pencil" | "phone" | "privacy" | "profile" | "rocket" | "settings" | "sun" | "support" | "unlock" | "pin" | "unpin" | "sparkles" | "email" | "arrowDown" | "arrowLeftBottom" | "arrowLeftDouble" | "arrowRightBottom" | "arrowRightDouble" | "arrowRight" | "arrowUp" | "closeCircleOutline" | "copyContent" | "dotsHorizontal" | "dotsVertical" | "dragVariant" | "eastShort" | "expandMore" | "linkedin" | "northShort" | "openInNew" | "progressCheck" | "rayEndArrow" | "rayStartArrow" | "rayStartEnd" | "rayTopArrow" | "southShort" | "switchOrga" | "twitter" | "westShort" | "addressOutline" | "adjustmentsHorizontalOutline" | "alertCircleOutline" | "autoFixOutline" | "bookOpenOutlineOutline" | "bullhornOutline" | "calculatorOutline" | "calendarRangeOutline" | "chatOutline" | "checkCircleOutline" | "clockOutlineOutline" | "consoleOutline" | "credentialOutline" | "creditCardOutline" | "databaseOutline" | "deleteOutline" | "docOutline" | "earthOutline" | "emailRemoveOutline" | "emailOutline" | "eyeOffOutline" | "eyeOutline" | "filterOutline" | "folderOutline" | "helpCircleOutline" | "idOutline" | "informationOutline" | "leafOutline" | "lightBulbOutline" | "lockOutline" | "membersOutline" | "moonOutline" | "mosaicOutline" | "notificationOutline" | "penOutline" | "pencilOutline" | "phoneOutline" | "pinOutline" | "playOutline" | "privacyOutline" | "profileOutline" | "rocketOutline" | "sendOutline" | "settingsOutline" | "sidebarOutline" | "sparklesOutline" | "stopOutline" | "sunOutline" | "supportOutline" | "thumbsDownOutline" | "thumbsUpOutline" | "unlockOutline" | "unpinOutline" | "weatherNightOutline" | "adjustmentsHorizontal" | "alertCircle" | "autoFix" | "bookOpenOutline" | "calendarRange" | "checkCircle" | "clockOutline" | "credential" | "creditCard" | "emailRemove" | "eyeOff" | "helpCircle" | "information" | "leaf" | "lightBulb" | "notification" | "sidebar" | "thumbsDown" | "thumbsUp" | "weatherNight";
18
18
  onClick?: () => void;
19
19
  'data-testid'?: string;
20
20
  }) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -4,6 +4,7 @@ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const _styled = require("@emotion/styled/base");
5
5
  const React = require("react");
6
6
  const index$3 = require("../Button/index.cjs");
7
+ const ModalProvider = require("../Modal/ModalProvider.cjs");
7
8
  const index = require("../Popup/index.cjs");
8
9
  const index$1 = require("../Stack/index.cjs");
9
10
  const index$2 = require("../Text/index.cjs");
@@ -52,7 +53,7 @@ const StyledPopup = /* @__PURE__ */ _styled__default.default(index.Popup, proces
52
53
  }
53
54
  }
54
55
  `;
55
- }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BvcG92ZXIvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCRSIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Qb3BvdmVyL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcywgUmVhY3ROb2RlLCBSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYsIHVzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uL0J1dHRvbidcbmltcG9ydCB7IFBvcHVwIH0gZnJvbSAnLi4vUG9wdXAnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgU2VudGltZW50VHlwZSA9ICduZXV0cmFsJyB8ICdwcmltYXJ5J1xuXG5jb25zdCBTSVpFU19XSURUSCA9IHtcbiAgc21hbGw6IDIwLCAvLyBpbiByZW1cbiAgbWVkaXVtOiAyNi4yNSxcbiAgbGFyZ2U6IDMyLjUsXG59XG5cbmNvbnN0IFN0eWxlZFBvcHVwID0gc3R5bGVkKFBvcHVwLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NlbnRpbWVudCcsICdzaXplJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNlbnRpbWVudDogU2VudGltZW50VHlwZVxuICBzaXplOiBrZXlvZiB0eXBlb2YgU0laRVNfV0lEVEhcbn0+YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICB3aWR0aDogJHsoeyBzaXplIH0pID0+IFNJWkVTX1dJRFRIW3NpemVdfXJlbTtcbiAgbWF4LXdpZHRoOiAkeyh7IHNpemUgfSkgPT4gU0laRVNfV0lEVEhbc2l6ZV19cmVtO1xuICB0ZXh0LWFsaWduOiBpbml0aWFsO1xuXG4gICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PiB7XG4gICAgaWYgKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnKSB7XG4gICAgICByZXR1cm4gYFxuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kfTtcbiAgICAgIGJveC1zaGFkb3c6ICR7dGhlbWUuc2hhZG93cy5wb3BvdmVyfTtcbiAgICAgICZbZGF0YS1oYXMtYXJyb3c9J3RydWUnXSB7XG4gICAgICAgICY6OmFmdGVyIHtcbiAgICAgICAgICBib3JkZXItY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH0gdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGBcbiAgICB9XG5cbiAgICByZXR1cm4gYFxuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMucHJpbWFyeS5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAgIGJveC1zaGFkb3c6ICR7dGhlbWUuc2hhZG93cy5wb3BvdmVyfTtcbiAgICAgICZbZGF0YS1oYXMtYXJyb3c9J3RydWUnXSB7XG4gICAgICAgICY6OmFmdGVyIHtcbiAgICAgICAgICBib3JkZXItY29sb3I6ICR7dGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ30gdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGBcbiAgfX1cbmBcblxuLy8gVGhpcyBpcyB0byBhdm9pZCBoYXZpbmcgdGV4dCBpbmhlcml0IGNvbG9yIGZyb20gcG9wdXAgKHdoaWNoIGlzIHdoaXRlIG9uIHdoaXRlIGJhY2tncm91bmQpXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHR9O1xuYFxuXG50eXBlIENvbnRlbnRXcmFwcGVyUHJvcHMgPSBQaWNrPFxuICBQb3BvdmVyUHJvcHMsXG4gICd0aXRsZScgfCAnb25DbG9zZScgfCAnc2VudGltZW50JyB8ICdjaGlsZHJlbidcbj5cblxuY29uc3QgQ29udGVudFdyYXBwZXIgPSAoe1xuICB0aXRsZSxcbiAgb25DbG9zZSxcbiAgY2hpbGRyZW4sXG4gIHNlbnRpbWVudCxcbn06IENvbnRlbnRXcmFwcGVyUHJvcHMpID0+IChcbiAgPFN0eWxlZFN0YWNrIGdhcD17MX0+XG4gICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFRleHRcbiAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICBhcz1cImgzXCJcbiAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgIHByb21pbmVuY2U9e3NlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gJ3N0cm9uZycgOiAnc3Ryb25nZXInfVxuICAgICAgPlxuICAgICAgICB7dGl0bGV9XG4gICAgICA8L1RleHQ+XG4gICAgICA8QnV0dG9uXG4gICAgICAgIHZhcmlhbnQ9e3NlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gJ2dob3N0JyA6ICdmaWxsZWQnfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gJ25ldXRyYWwnIDogJ3ByaW1hcnknfVxuICAgICAgICBvbkNsaWNrPXtvbkNsb3NlfVxuICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICBpY29uPVwiY2xvc2VcIlxuICAgICAgICBhcmlhLWxhYmVsPVwiY2xvc2VcIlxuICAgICAgLz5cbiAgICA8L1N0YWNrPlxuICAgIHt0eXBlb2YgY2hpbGRyZW4gPT09ICdzdHJpbmcnID8gKFxuICAgICAgPFRleHRcbiAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFwiXG4gICAgICAgIGFzPVwicFwiXG4gICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICBwcm9taW5lbmNlPXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdzdHJvbmcnIDogJ3N0cm9uZ2VyJ31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9UZXh0PlxuICAgICkgOiAoXG4gICAgICBjaGlsZHJlblxuICAgICl9XG4gIDwvU3R5bGVkU3RhY2s+XG4pXG5cbnR5cGUgUG9wb3ZlclByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNvbnRlbnQ6IFJlYWN0Tm9kZVxuICB0aXRsZTogc3RyaW5nXG4gIHNlbnRpbWVudD86IFNlbnRpbWVudFR5cGVcbiAgdmlzaWJsZT86IGJvb2xlYW5cbiAgc2l6ZT86IGtleW9mIHR5cGVvZiBTSVpFU19XSURUSFxuICBvbkNsb3NlPzogKCkgPT4gdm9pZFxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtYXhIZWlnaHQ/OiBzdHJpbmdcbiAgLyoqXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBwb3J0YWwgdGFyZ2V0IGlzIGNoaWxkcmVuIGNvbnRhaW5lciBvciBkb2N1bWVudC5ib2R5IGlmIGNoaWxkcmVuIGlzIGEgZnVuY3Rpb24uIFlvdSBjYW4gb3ZlcnJpZGUgdGhpc1xuICAgKiBiZWhhdmlvciBieSBzZXR0aW5nIGEgcG9ydGFsVGFyZ2V0IHByb3AuXG4gICAqL1xuICBwb3J0YWxUYXJnZXQ/OiBIVE1MRWxlbWVudFxufSAmIFBpY2s8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBQb3B1cD4sXG4gICdwbGFjZW1lbnQnIHwgJ2R5bmFtaWNEb21SZW5kZXJpbmcnIHwgJ2FsaWduJ1xuPlxuXG4vKipcbiAqIFBvcG92ZXIgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIG9yIGFjdGlvbnMgb24gdG9wIG9mIHRoZSBtYWluIGNvbnRlbnQgb2YgdGhlIHBhZ2UuXG4gKiBJdCBpcyB1c3VhbGx5IHRyaWdnZXJlZCBieSBjbGlja2luZyBvbiBhIGJ1dHRvbi4gSXQgaW5jbHVkZXMgYSB0aXRsZSwgYSBjbG9zZSBidXR0b24gYW5kIGEgY29udGVudCBhcmVhLlxuICovXG5leHBvcnQgY29uc3QgUG9wb3ZlciA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICB2aXNpYmxlID0gZmFsc2UsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIHBsYWNlbWVudCxcbiAgICAgIGNvbnRlbnQsXG4gICAgICB0aXRsZSxcbiAgICAgIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgICAgIHNpemUgPSAnbWVkaXVtJyxcbiAgICAgIG9uQ2xvc2UsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICBtYXhXaWR0aCxcbiAgICAgIG1heEhlaWdodCxcbiAgICAgICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gICAgICBwb3J0YWxUYXJnZXQsXG4gICAgICBkeW5hbWljRG9tUmVuZGVyaW5nLFxuICAgICAgYWxpZ24sXG4gICAgfTogUG9wb3ZlclByb3BzLFxuICAgIHJlZjogUmVmPEhUTUxEaXZFbGVtZW50PixcbiAgKSA9PiB7XG4gICAgY29uc3QgaW5uZXJSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpXG4gICAgY29uc3QgW2xvY2FsVmlzaWJsZSwgc2V0TG9jYWxWaXNpYmxlXSA9IHVzZVN0YXRlKHZpc2libGUpXG5cbiAgICAvLyBXZSBjaGFuZ2UgbG9jYWwgdmFsdWUgaWYgdmlzaWJsZSBwcm9wIGNoYW5nZXNcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgc2V0TG9jYWxWaXNpYmxlKHZpc2libGUpXG4gICAgfSwgW3Zpc2libGVdKVxuXG4gICAgY29uc3QgbG9jYWxPbkNsb3NlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgICAgc2V0TG9jYWxWaXNpYmxlKGZhbHNlKVxuICAgICAgb25DbG9zZT8uKClcbiAgICB9LCBbb25DbG9zZV0pXG5cbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZFBvcHVwXG4gICAgICAgIGhpZGVPbkNsaWNrT3V0c2lkZVxuICAgICAgICBkZWJvdW5jZURlbGF5PXswfVxuICAgICAgICB2aXNpYmxlPXtsb2NhbFZpc2libGV9XG4gICAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgICB0ZXh0PXtcbiAgICAgICAgICA8Q29udGVudFdyYXBwZXJcbiAgICAgICAgICAgIHRpdGxlPXt0aXRsZX1cbiAgICAgICAgICAgIG9uQ2xvc2U9e2xvY2FsT25DbG9zZX1cbiAgICAgICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvQ29udGVudFdyYXBwZXI+XG4gICAgICAgIH1cbiAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICB0YWJJbmRleD17LTF9XG4gICAgICAgIGlubmVyUmVmPXtpbm5lclJlZn1cbiAgICAgICAgb25DbG9zZT17bG9jYWxPbkNsb3NlfVxuICAgICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICAgIG1heEhlaWdodD17bWF4SGVpZ2h0fVxuICAgICAgICBwb3J0YWxUYXJnZXQ9e3BvcnRhbFRhcmdldH1cbiAgICAgICAgZHluYW1pY0RvbVJlbmRlcmluZz17ZHluYW1pY0RvbVJlbmRlcmluZ31cbiAgICAgICAgYWxpZ249e2FsaWdufVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZFBvcHVwPlxuICAgIClcbiAgfSxcbilcbiJdfQ== */"));
56
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BvcG92ZXIvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCRSIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9Qb3BvdmVyL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcywgUmVhY3ROb2RlLCBSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7XG4gIGZvcndhcmRSZWYsXG4gIHVzZUNhbGxiYWNrLFxuICB1c2VDb250ZXh0LFxuICB1c2VFZmZlY3QsXG4gIHVzZU1lbW8sXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vQnV0dG9uJ1xuaW1wb3J0IHsgTW9kYWxDb250ZXh0IH0gZnJvbSAnLi4vTW9kYWwvTW9kYWxQcm92aWRlcidcbmltcG9ydCB7IFBvcHVwIH0gZnJvbSAnLi4vUG9wdXAnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgU2VudGltZW50VHlwZSA9ICduZXV0cmFsJyB8ICdwcmltYXJ5J1xuXG5jb25zdCBTSVpFU19XSURUSCA9IHtcbiAgc21hbGw6IDIwLCAvLyBpbiByZW1cbiAgbWVkaXVtOiAyNi4yNSxcbiAgbGFyZ2U6IDMyLjUsXG59XG5cbmNvbnN0IFN0eWxlZFBvcHVwID0gc3R5bGVkKFBvcHVwLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ3NlbnRpbWVudCcsICdzaXplJ10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIHNlbnRpbWVudDogU2VudGltZW50VHlwZVxuICBzaXplOiBrZXlvZiB0eXBlb2YgU0laRVNfV0lEVEhcbn0+YFxuICBwYWRkaW5nOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICB3aWR0aDogJHsoeyBzaXplIH0pID0+IFNJWkVTX1dJRFRIW3NpemVdfXJlbTtcbiAgbWF4LXdpZHRoOiAkeyh7IHNpemUgfSkgPT4gU0laRVNfV0lEVEhbc2l6ZV19cmVtO1xuICB0ZXh0LWFsaWduOiBpbml0aWFsO1xuXG4gICR7KHsgdGhlbWUsIHNlbnRpbWVudCB9KSA9PiB7XG4gICAgaWYgKHNlbnRpbWVudCA9PT0gJ25ldXRyYWwnKSB7XG4gICAgICByZXR1cm4gYFxuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5iYWNrZ3JvdW5kfTtcbiAgICAgIGJveC1zaGFkb3c6ICR7dGhlbWUuc2hhZG93cy5wb3BvdmVyfTtcbiAgICAgICZbZGF0YS1oYXMtYXJyb3c9J3RydWUnXSB7XG4gICAgICAgICY6OmFmdGVyIHtcbiAgICAgICAgICBib3JkZXItY29sb3I6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH0gdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGBcbiAgICB9XG5cbiAgICByZXR1cm4gYFxuICAgICAgYmFja2dyb3VuZDogJHt0aGVtZS5jb2xvcnMucHJpbWFyeS5iYWNrZ3JvdW5kU3Ryb25nfTtcbiAgICAgIGJveC1zaGFkb3c6ICR7dGhlbWUuc2hhZG93cy5wb3BvdmVyfTtcbiAgICAgICZbZGF0YS1oYXMtYXJyb3c9J3RydWUnXSB7XG4gICAgICAgICY6OmFmdGVyIHtcbiAgICAgICAgICBib3JkZXItY29sb3I6ICR7dGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ30gdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQgdHJhbnNwYXJlbnQ7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIGBcbiAgfX1cbmBcblxuLy8gVGhpcyBpcyB0byBhdm9pZCBoYXZpbmcgdGV4dCBpbmhlcml0IGNvbG9yIGZyb20gcG9wdXAgKHdoaWNoIGlzIHdoaXRlIG9uIHdoaXRlIGJhY2tncm91bmQpXG5jb25zdCBTdHlsZWRTdGFjayA9IHN0eWxlZChTdGFjaylgXG4gIGNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5uZXV0cmFsLnRleHR9O1xuYFxuXG50eXBlIENvbnRlbnRXcmFwcGVyUHJvcHMgPSBQaWNrPFxuICBQb3BvdmVyUHJvcHMsXG4gICd0aXRsZScgfCAnb25DbG9zZScgfCAnc2VudGltZW50JyB8ICdjaGlsZHJlbidcbj5cblxuY29uc3QgQ29udGVudFdyYXBwZXIgPSAoe1xuICB0aXRsZSxcbiAgb25DbG9zZSxcbiAgY2hpbGRyZW4sXG4gIHNlbnRpbWVudCxcbn06IENvbnRlbnRXcmFwcGVyUHJvcHMpID0+IChcbiAgPFN0eWxlZFN0YWNrIGdhcD17MX0+XG4gICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiPlxuICAgICAgPFRleHRcbiAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICBhcz1cImgzXCJcbiAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgIHByb21pbmVuY2U9e3NlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gJ3N0cm9uZycgOiAnc3Ryb25nZXInfVxuICAgICAgPlxuICAgICAgICB7dGl0bGV9XG4gICAgICA8L1RleHQ+XG4gICAgICA8QnV0dG9uXG4gICAgICAgIHZhcmlhbnQ9e3NlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gJ2dob3N0JyA6ICdmaWxsZWQnfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudCA9PT0gJ25ldXRyYWwnID8gJ25ldXRyYWwnIDogJ3ByaW1hcnknfVxuICAgICAgICBvbkNsaWNrPXtvbkNsb3NlfVxuICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICBpY29uPVwiY2xvc2VcIlxuICAgICAgICBhcmlhLWxhYmVsPVwiY2xvc2VcIlxuICAgICAgLz5cbiAgICA8L1N0YWNrPlxuICAgIHt0eXBlb2YgY2hpbGRyZW4gPT09ICdzdHJpbmcnID8gKFxuICAgICAgPFRleHRcbiAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFwiXG4gICAgICAgIGFzPVwicFwiXG4gICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICBwcm9taW5lbmNlPXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdzdHJvbmcnIDogJ3N0cm9uZ2VyJ31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9UZXh0PlxuICAgICkgOiAoXG4gICAgICBjaGlsZHJlblxuICAgICl9XG4gIDwvU3R5bGVkU3RhY2s+XG4pXG5cbnR5cGUgUG9wb3ZlclByb3BzID0ge1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIGNvbnRlbnQ6IFJlYWN0Tm9kZVxuICB0aXRsZTogc3RyaW5nXG4gIHNlbnRpbWVudD86IFNlbnRpbWVudFR5cGVcbiAgdmlzaWJsZT86IGJvb2xlYW5cbiAgc2l6ZT86IGtleW9mIHR5cGVvZiBTSVpFU19XSURUSFxuICBvbkNsb3NlPzogKCkgPT4gdm9pZFxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBtYXhXaWR0aD86IHN0cmluZ1xuICBtYXhIZWlnaHQ/OiBzdHJpbmdcbiAgLyoqXG4gICAqIEJ5IGRlZmF1bHQsIHRoZSBwb3J0YWwgdGFyZ2V0IGlzIGNoaWxkcmVuIGNvbnRhaW5lciBvciBkb2N1bWVudC5ib2R5IGlmIGNoaWxkcmVuIGlzIGEgZnVuY3Rpb24uIFlvdSBjYW4gb3ZlcnJpZGUgdGhpc1xuICAgKiBiZWhhdmlvciBieSBzZXR0aW5nIGEgcG9ydGFsVGFyZ2V0IHByb3AuXG4gICAqL1xuICBwb3J0YWxUYXJnZXQ/OiBIVE1MRWxlbWVudFxufSAmIFBpY2s8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBQb3B1cD4sXG4gICdwbGFjZW1lbnQnIHwgJ2R5bmFtaWNEb21SZW5kZXJpbmcnIHwgJ2FsaWduJ1xuPlxuXG4vKipcbiAqIFBvcG92ZXIgY29tcG9uZW50IGlzIHVzZWQgdG8gZGlzcGxheSBhZGRpdGlvbmFsIGluZm9ybWF0aW9uIG9yIGFjdGlvbnMgb24gdG9wIG9mIHRoZSBtYWluIGNvbnRlbnQgb2YgdGhlIHBhZ2UuXG4gKiBJdCBpcyB1c3VhbGx5IHRyaWdnZXJlZCBieSBjbGlja2luZyBvbiBhIGJ1dHRvbi4gSXQgaW5jbHVkZXMgYSB0aXRsZSwgYSBjbG9zZSBidXR0b24gYW5kIGEgY29udGVudCBhcmVhLlxuICovXG5leHBvcnQgY29uc3QgUG9wb3ZlciA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICB2aXNpYmxlID0gZmFsc2UsXG4gICAgICBjaGlsZHJlbixcbiAgICAgIHBsYWNlbWVudCxcbiAgICAgIGNvbnRlbnQsXG4gICAgICB0aXRsZSxcbiAgICAgIHNlbnRpbWVudCA9ICduZXV0cmFsJyxcbiAgICAgIHNpemUgPSAnbWVkaXVtJyxcbiAgICAgIG9uQ2xvc2UsXG4gICAgICBjbGFzc05hbWUsXG4gICAgICBtYXhXaWR0aCxcbiAgICAgIG1heEhlaWdodCxcbiAgICAgICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gICAgICBwb3J0YWxUYXJnZXQsXG4gICAgICBkeW5hbWljRG9tUmVuZGVyaW5nLFxuICAgICAgYWxpZ24sXG4gICAgfTogUG9wb3ZlclByb3BzLFxuICAgIHJlZjogUmVmPEhUTUxEaXZFbGVtZW50PixcbiAgKSA9PiB7XG4gICAgY29uc3QgaW5uZXJSZWYgPSB1c2VSZWY8SFRNTERpdkVsZW1lbnQ+KG51bGwpXG4gICAgY29uc3QgaXNJbnNpZGVNb2RhbCA9IHVzZUNvbnRleHQoTW9kYWxDb250ZXh0KVxuICAgIGNvbnN0IFtsb2NhbFZpc2libGUsIHNldExvY2FsVmlzaWJsZV0gPSB1c2VTdGF0ZSh2aXNpYmxlKVxuXG4gICAgLy8gV2UgY2hhbmdlIGxvY2FsIHZhbHVlIGlmIHZpc2libGUgcHJvcCBjaGFuZ2VzXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAgIHNldExvY2FsVmlzaWJsZSh2aXNpYmxlKVxuICAgIH0sIFt2aXNpYmxlXSlcblxuICAgIGNvbnN0IGxvY2FsT25DbG9zZSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICAgIHNldExvY2FsVmlzaWJsZShmYWxzZSlcbiAgICAgIG9uQ2xvc2U/LigpXG4gICAgfSwgW29uQ2xvc2VdKVxuXG4gICAgY29uc3Qgc21hcnRQb3J0YWxUYXJnZXQgPSB1c2VNZW1vKCgpID0+IHtcbiAgICAgIGlmICghcG9ydGFsVGFyZ2V0ICYmIGlzSW5zaWRlTW9kYWwpIHtcbiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZFxuICAgICAgfVxuXG4gICAgICBpZiAoIXBvcnRhbFRhcmdldCAmJiAhaXNJbnNpZGVNb2RhbCkge1xuICAgICAgICByZXR1cm4gZG9jdW1lbnQuYm9keVxuICAgICAgfVxuXG4gICAgICByZXR1cm4gcG9ydGFsVGFyZ2V0XG4gICAgfSwgW2lzSW5zaWRlTW9kYWwsIHBvcnRhbFRhcmdldF0pXG5cbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZFBvcHVwXG4gICAgICAgIGhpZGVPbkNsaWNrT3V0c2lkZVxuICAgICAgICBkZWJvdW5jZURlbGF5PXswfVxuICAgICAgICB2aXNpYmxlPXtsb2NhbFZpc2libGV9XG4gICAgICAgIHBsYWNlbWVudD17cGxhY2VtZW50fVxuICAgICAgICB0ZXh0PXtcbiAgICAgICAgICA8Q29udGVudFdyYXBwZXJcbiAgICAgICAgICAgIHRpdGxlPXt0aXRsZX1cbiAgICAgICAgICAgIG9uQ2xvc2U9e2xvY2FsT25DbG9zZX1cbiAgICAgICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtjb250ZW50fVxuICAgICAgICAgIDwvQ29udGVudFdyYXBwZXI+XG4gICAgICAgIH1cbiAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgcm9sZT1cImRpYWxvZ1wiXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICB0YWJJbmRleD17LTF9XG4gICAgICAgIGlubmVyUmVmPXtpbm5lclJlZn1cbiAgICAgICAgb25DbG9zZT17bG9jYWxPbkNsb3NlfVxuICAgICAgICBtYXhXaWR0aD17bWF4V2lkdGh9XG4gICAgICAgIG1heEhlaWdodD17bWF4SGVpZ2h0fVxuICAgICAgICBwb3J0YWxUYXJnZXQ9e3NtYXJ0UG9ydGFsVGFyZ2V0fVxuICAgICAgICBkeW5hbWljRG9tUmVuZGVyaW5nPXtkeW5hbWljRG9tUmVuZGVyaW5nfVxuICAgICAgICBhbGlnbj17YWxpZ259XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvU3R5bGVkUG9wdXA+XG4gICAgKVxuICB9LFxuKVxuIl19 */"));
56
57
  const StyledStack = /* @__PURE__ */ _styled__default.default(index$1.Stack, process.env.NODE_ENV === "production" ? {
57
58
  target: "ejpxv5a0"
58
59
  } : {
@@ -60,7 +61,7 @@ const StyledStack = /* @__PURE__ */ _styled__default.default(index$1.Stack, proc
60
61
  label: "StyledStack"
61
62
  })("color:", ({
62
63
  theme
63
- }) => theme.colors.neutral.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BvcG92ZXIvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFEaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUG9wb3Zlci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMsIFJlYWN0Tm9kZSwgUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmLCB1c2VDYWxsYmFjaywgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uL1BvcHVwJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFNlbnRpbWVudFR5cGUgPSAnbmV1dHJhbCcgfCAncHJpbWFyeSdcblxuY29uc3QgU0laRVNfV0lEVEggPSB7XG4gIHNtYWxsOiAyMCwgLy8gaW4gcmVtXG4gIG1lZGl1bTogMjYuMjUsXG4gIGxhcmdlOiAzMi41LFxufVxuXG5jb25zdCBTdHlsZWRQb3B1cCA9IHN0eWxlZChQb3B1cCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydzZW50aW1lbnQnLCAnc2l6ZSddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBzZW50aW1lbnQ6IFNlbnRpbWVudFR5cGVcbiAgc2l6ZToga2V5b2YgdHlwZW9mIFNJWkVTX1dJRFRIXG59PmBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiBTSVpFU19XSURUSFtzaXplXX1yZW07XG4gIG1heC13aWR0aDogJHsoeyBzaXplIH0pID0+IFNJWkVTX1dJRFRIW3NpemVdfXJlbTtcbiAgdGV4dC1hbGlnbjogaW5pdGlhbDtcblxuICAkeyh7IHRoZW1lLCBzZW50aW1lbnQgfSkgPT4ge1xuICAgIGlmIChzZW50aW1lbnQgPT09ICduZXV0cmFsJykge1xuICAgICAgcmV0dXJuIGBcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH07XG4gICAgICBib3gtc2hhZG93OiAke3RoZW1lLnNoYWRvd3MucG9wb3Zlcn07XG4gICAgICAmW2RhdGEtaGFzLWFycm93PSd0cnVlJ10ge1xuICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgYm9yZGVyLWNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBgXG4gICAgfVxuXG4gICAgcmV0dXJuIGBcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgICBib3gtc2hhZG93OiAke3RoZW1lLnNoYWRvd3MucG9wb3Zlcn07XG4gICAgICAmW2RhdGEtaGFzLWFycm93PSd0cnVlJ10ge1xuICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgYm9yZGVyLWNvbG9yOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBgXG4gIH19XG5gXG5cbi8vIFRoaXMgaXMgdG8gYXZvaWQgaGF2aW5nIHRleHQgaW5oZXJpdCBjb2xvciBmcm9tIHBvcHVwICh3aGljaCBpcyB3aGl0ZSBvbiB3aGl0ZSBiYWNrZ3JvdW5kKVxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbmBcblxudHlwZSBDb250ZW50V3JhcHBlclByb3BzID0gUGljazxcbiAgUG9wb3ZlclByb3BzLFxuICAndGl0bGUnIHwgJ29uQ2xvc2UnIHwgJ3NlbnRpbWVudCcgfCAnY2hpbGRyZW4nXG4+XG5cbmNvbnN0IENvbnRlbnRXcmFwcGVyID0gKHtcbiAgdGl0bGUsXG4gIG9uQ2xvc2UsXG4gIGNoaWxkcmVuLFxuICBzZW50aW1lbnQsXG59OiBDb250ZW50V3JhcHBlclByb3BzKSA9PiAoXG4gIDxTdHlsZWRTdGFjayBnYXA9ezF9PlxuICAgIDxTdGFjayBkaXJlY3Rpb249XCJyb3dcIiBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgIDxUZXh0XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgYXM9XCJoM1wiXG4gICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICBwcm9taW5lbmNlPXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdzdHJvbmcnIDogJ3N0cm9uZ2VyJ31cbiAgICAgID5cbiAgICAgICAge3RpdGxlfVxuICAgICAgPC9UZXh0PlxuICAgICAgPEJ1dHRvblxuICAgICAgICB2YXJpYW50PXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdnaG9zdCcgOiAnZmlsbGVkJ31cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICduZXV0cmFsJyA6ICdwcmltYXJ5J31cbiAgICAgICAgb25DbGljaz17b25DbG9zZX1cbiAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgaWNvbj1cImNsb3NlXCJcbiAgICAgICAgYXJpYS1sYWJlbD1cImNsb3NlXCJcbiAgICAgIC8+XG4gICAgPC9TdGFjaz5cbiAgICB7dHlwZW9mIGNoaWxkcmVuID09PSAnc3RyaW5nJyA/IChcbiAgICAgIDxUZXh0XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICBhcz1cInBcIlxuICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgcHJvbWluZW5jZT17c2VudGltZW50ID09PSAnbmV1dHJhbCcgPyAnc3Ryb25nJyA6ICdzdHJvbmdlcid9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvVGV4dD5cbiAgICApIDogKFxuICAgICAgY2hpbGRyZW5cbiAgICApfVxuICA8L1N0eWxlZFN0YWNrPlxuKVxuXG50eXBlIFBvcG92ZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBjb250ZW50OiBSZWFjdE5vZGVcbiAgdGl0bGU6IHN0cmluZ1xuICBzZW50aW1lbnQ/OiBTZW50aW1lbnRUeXBlXG4gIHZpc2libGU/OiBib29sZWFuXG4gIHNpemU/OiBrZXlvZiB0eXBlb2YgU0laRVNfV0lEVEhcbiAgb25DbG9zZT86ICgpID0+IHZvaWRcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgbWF4V2lkdGg/OiBzdHJpbmdcbiAgbWF4SGVpZ2h0Pzogc3RyaW5nXG4gIC8qKlxuICAgKiBCeSBkZWZhdWx0LCB0aGUgcG9ydGFsIHRhcmdldCBpcyBjaGlsZHJlbiBjb250YWluZXIgb3IgZG9jdW1lbnQuYm9keSBpZiBjaGlsZHJlbiBpcyBhIGZ1bmN0aW9uLiBZb3UgY2FuIG92ZXJyaWRlIHRoaXNcbiAgICogYmVoYXZpb3IgYnkgc2V0dGluZyBhIHBvcnRhbFRhcmdldCBwcm9wLlxuICAgKi9cbiAgcG9ydGFsVGFyZ2V0PzogSFRNTEVsZW1lbnRcbn0gJiBQaWNrPFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgUG9wdXA+LFxuICAncGxhY2VtZW50JyB8ICdkeW5hbWljRG9tUmVuZGVyaW5nJyB8ICdhbGlnbidcbj5cblxuLyoqXG4gKiBQb3BvdmVyIGNvbXBvbmVudCBpcyB1c2VkIHRvIGRpc3BsYXkgYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBvciBhY3Rpb25zIG9uIHRvcCBvZiB0aGUgbWFpbiBjb250ZW50IG9mIHRoZSBwYWdlLlxuICogSXQgaXMgdXN1YWxseSB0cmlnZ2VyZWQgYnkgY2xpY2tpbmcgb24gYSBidXR0b24uIEl0IGluY2x1ZGVzIGEgdGl0bGUsIGEgY2xvc2UgYnV0dG9uIGFuZCBhIGNvbnRlbnQgYXJlYS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBvcG92ZXIgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgdmlzaWJsZSA9IGZhbHNlLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICBwbGFjZW1lbnQsXG4gICAgICBjb250ZW50LFxuICAgICAgdGl0bGUsXG4gICAgICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gICAgICBzaXplID0gJ21lZGl1bScsXG4gICAgICBvbkNsb3NlLFxuICAgICAgY2xhc3NOYW1lLFxuICAgICAgbWF4V2lkdGgsXG4gICAgICBtYXhIZWlnaHQsXG4gICAgICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICAgICAgcG9ydGFsVGFyZ2V0LFxuICAgICAgZHluYW1pY0RvbVJlbmRlcmluZyxcbiAgICAgIGFsaWduLFxuICAgIH06IFBvcG92ZXJQcm9wcyxcbiAgICByZWY6IFJlZjxIVE1MRGl2RWxlbWVudD4sXG4gICkgPT4ge1xuICAgIGNvbnN0IGlubmVyUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuICAgIGNvbnN0IFtsb2NhbFZpc2libGUsIHNldExvY2FsVmlzaWJsZV0gPSB1c2VTdGF0ZSh2aXNpYmxlKVxuXG4gICAgLy8gV2UgY2hhbmdlIGxvY2FsIHZhbHVlIGlmIHZpc2libGUgcHJvcCBjaGFuZ2VzXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAgIHNldExvY2FsVmlzaWJsZSh2aXNpYmxlKVxuICAgIH0sIFt2aXNpYmxlXSlcblxuICAgIGNvbnN0IGxvY2FsT25DbG9zZSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICAgIHNldExvY2FsVmlzaWJsZShmYWxzZSlcbiAgICAgIG9uQ2xvc2U/LigpXG4gICAgfSwgW29uQ2xvc2VdKVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRQb3B1cFxuICAgICAgICBoaWRlT25DbGlja091dHNpZGVcbiAgICAgICAgZGVib3VuY2VEZWxheT17MH1cbiAgICAgICAgdmlzaWJsZT17bG9jYWxWaXNpYmxlfVxuICAgICAgICBwbGFjZW1lbnQ9e3BsYWNlbWVudH1cbiAgICAgICAgdGV4dD17XG4gICAgICAgICAgPENvbnRlbnRXcmFwcGVyXG4gICAgICAgICAgICB0aXRsZT17dGl0bGV9XG4gICAgICAgICAgICBvbkNsb3NlPXtsb2NhbE9uQ2xvc2V9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7Y29udGVudH1cbiAgICAgICAgICA8L0NvbnRlbnRXcmFwcGVyPlxuICAgICAgICB9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgIHJvbGU9XCJkaWFsb2dcIlxuICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgdGFiSW5kZXg9ey0xfVxuICAgICAgICBpbm5lclJlZj17aW5uZXJSZWZ9XG4gICAgICAgIG9uQ2xvc2U9e2xvY2FsT25DbG9zZX1cbiAgICAgICAgbWF4V2lkdGg9e21heFdpZHRofVxuICAgICAgICBtYXhIZWlnaHQ9e21heEhlaWdodH1cbiAgICAgICAgcG9ydGFsVGFyZ2V0PXtwb3J0YWxUYXJnZXR9XG4gICAgICAgIGR5bmFtaWNEb21SZW5kZXJpbmc9e2R5bmFtaWNEb21SZW5kZXJpbmd9XG4gICAgICAgIGFsaWduPXthbGlnbn1cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9TdHlsZWRQb3B1cD5cbiAgICApXG4gIH0sXG4pXG4iXX0= */"));
64
+ }) => theme.colors.neutral.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1BvcG92ZXIvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEaUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUG9wb3Zlci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50UHJvcHMsIFJlYWN0Tm9kZSwgUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQge1xuICBmb3J3YXJkUmVmLFxuICB1c2VDYWxsYmFjayxcbiAgdXNlQ29udGV4dCxcbiAgdXNlRWZmZWN0LFxuICB1c2VNZW1vLFxuICB1c2VSZWYsXG4gIHVzZVN0YXRlLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uL0J1dHRvbidcbmltcG9ydCB7IE1vZGFsQ29udGV4dCB9IGZyb20gJy4uL01vZGFsL01vZGFsUHJvdmlkZXInXG5pbXBvcnQgeyBQb3B1cCB9IGZyb20gJy4uL1BvcHVwJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuXG50eXBlIFNlbnRpbWVudFR5cGUgPSAnbmV1dHJhbCcgfCAncHJpbWFyeSdcblxuY29uc3QgU0laRVNfV0lEVEggPSB7XG4gIHNtYWxsOiAyMCwgLy8gaW4gcmVtXG4gIG1lZGl1bTogMjYuMjUsXG4gIGxhcmdlOiAzMi41LFxufVxuXG5jb25zdCBTdHlsZWRQb3B1cCA9IHN0eWxlZChQb3B1cCwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydzZW50aW1lbnQnLCAnc2l6ZSddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBzZW50aW1lbnQ6IFNlbnRpbWVudFR5cGVcbiAgc2l6ZToga2V5b2YgdHlwZW9mIFNJWkVTX1dJRFRIXG59PmBcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgd2lkdGg6ICR7KHsgc2l6ZSB9KSA9PiBTSVpFU19XSURUSFtzaXplXX1yZW07XG4gIG1heC13aWR0aDogJHsoeyBzaXplIH0pID0+IFNJWkVTX1dJRFRIW3NpemVdfXJlbTtcbiAgdGV4dC1hbGlnbjogaW5pdGlhbDtcblxuICAkeyh7IHRoZW1lLCBzZW50aW1lbnQgfSkgPT4ge1xuICAgIGlmIChzZW50aW1lbnQgPT09ICduZXV0cmFsJykge1xuICAgICAgcmV0dXJuIGBcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYmFja2dyb3VuZH07XG4gICAgICBib3gtc2hhZG93OiAke3RoZW1lLnNoYWRvd3MucG9wb3Zlcn07XG4gICAgICAmW2RhdGEtaGFzLWFycm93PSd0cnVlJ10ge1xuICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgYm9yZGVyLWNvbG9yOiAke3RoZW1lLmNvbG9ycy5uZXV0cmFsLmJhY2tncm91bmR9IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBgXG4gICAgfVxuXG4gICAgcmV0dXJuIGBcbiAgICAgIGJhY2tncm91bmQ6ICR7dGhlbWUuY29sb3JzLnByaW1hcnkuYmFja2dyb3VuZFN0cm9uZ307XG4gICAgICBib3gtc2hhZG93OiAke3RoZW1lLnNoYWRvd3MucG9wb3Zlcn07XG4gICAgICAmW2RhdGEtaGFzLWFycm93PSd0cnVlJ10ge1xuICAgICAgICAmOjphZnRlciB7XG4gICAgICAgICAgYm9yZGVyLWNvbG9yOiAke3RoZW1lLmNvbG9ycy5wcmltYXJ5LmJhY2tncm91bmRTdHJvbmd9IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50O1xuICAgICAgICB9XG4gICAgICB9XG4gICAgICBgXG4gIH19XG5gXG5cbi8vIFRoaXMgaXMgdG8gYXZvaWQgaGF2aW5nIHRleHQgaW5oZXJpdCBjb2xvciBmcm9tIHBvcHVwICh3aGljaCBpcyB3aGl0ZSBvbiB3aGl0ZSBiYWNrZ3JvdW5kKVxuY29uc3QgU3R5bGVkU3RhY2sgPSBzdHlsZWQoU3RhY2spYFxuICBjb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC50ZXh0fTtcbmBcblxudHlwZSBDb250ZW50V3JhcHBlclByb3BzID0gUGljazxcbiAgUG9wb3ZlclByb3BzLFxuICAndGl0bGUnIHwgJ29uQ2xvc2UnIHwgJ3NlbnRpbWVudCcgfCAnY2hpbGRyZW4nXG4+XG5cbmNvbnN0IENvbnRlbnRXcmFwcGVyID0gKHtcbiAgdGl0bGUsXG4gIG9uQ2xvc2UsXG4gIGNoaWxkcmVuLFxuICBzZW50aW1lbnQsXG59OiBDb250ZW50V3JhcHBlclByb3BzKSA9PiAoXG4gIDxTdHlsZWRTdGFjayBnYXA9ezF9PlxuICAgIDxTdGFjayBkaXJlY3Rpb249XCJyb3dcIiBqdXN0aWZ5Q29udGVudD1cInNwYWNlLWJldHdlZW5cIj5cbiAgICAgIDxUZXh0XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgYXM9XCJoM1wiXG4gICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICBwcm9taW5lbmNlPXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdzdHJvbmcnIDogJ3N0cm9uZ2VyJ31cbiAgICAgID5cbiAgICAgICAge3RpdGxlfVxuICAgICAgPC9UZXh0PlxuICAgICAgPEJ1dHRvblxuICAgICAgICB2YXJpYW50PXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICdnaG9zdCcgOiAnZmlsbGVkJ31cbiAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnQgPT09ICduZXV0cmFsJyA/ICduZXV0cmFsJyA6ICdwcmltYXJ5J31cbiAgICAgICAgb25DbGljaz17b25DbG9zZX1cbiAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgaWNvbj1cImNsb3NlXCJcbiAgICAgICAgYXJpYS1sYWJlbD1cImNsb3NlXCJcbiAgICAgIC8+XG4gICAgPC9TdGFjaz5cbiAgICB7dHlwZW9mIGNoaWxkcmVuID09PSAnc3RyaW5nJyA/IChcbiAgICAgIDxUZXh0XG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICBhcz1cInBcIlxuICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgcHJvbWluZW5jZT17c2VudGltZW50ID09PSAnbmV1dHJhbCcgPyAnc3Ryb25nJyA6ICdzdHJvbmdlcid9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvVGV4dD5cbiAgICApIDogKFxuICAgICAgY2hpbGRyZW5cbiAgICApfVxuICA8L1N0eWxlZFN0YWNrPlxuKVxuXG50eXBlIFBvcG92ZXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBjb250ZW50OiBSZWFjdE5vZGVcbiAgdGl0bGU6IHN0cmluZ1xuICBzZW50aW1lbnQ/OiBTZW50aW1lbnRUeXBlXG4gIHZpc2libGU/OiBib29sZWFuXG4gIHNpemU/OiBrZXlvZiB0eXBlb2YgU0laRVNfV0lEVEhcbiAgb25DbG9zZT86ICgpID0+IHZvaWRcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgbWF4V2lkdGg/OiBzdHJpbmdcbiAgbWF4SGVpZ2h0Pzogc3RyaW5nXG4gIC8qKlxuICAgKiBCeSBkZWZhdWx0LCB0aGUgcG9ydGFsIHRhcmdldCBpcyBjaGlsZHJlbiBjb250YWluZXIgb3IgZG9jdW1lbnQuYm9keSBpZiBjaGlsZHJlbiBpcyBhIGZ1bmN0aW9uLiBZb3UgY2FuIG92ZXJyaWRlIHRoaXNcbiAgICogYmVoYXZpb3IgYnkgc2V0dGluZyBhIHBvcnRhbFRhcmdldCBwcm9wLlxuICAgKi9cbiAgcG9ydGFsVGFyZ2V0PzogSFRNTEVsZW1lbnRcbn0gJiBQaWNrPFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgUG9wdXA+LFxuICAncGxhY2VtZW50JyB8ICdkeW5hbWljRG9tUmVuZGVyaW5nJyB8ICdhbGlnbidcbj5cblxuLyoqXG4gKiBQb3BvdmVyIGNvbXBvbmVudCBpcyB1c2VkIHRvIGRpc3BsYXkgYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBvciBhY3Rpb25zIG9uIHRvcCBvZiB0aGUgbWFpbiBjb250ZW50IG9mIHRoZSBwYWdlLlxuICogSXQgaXMgdXN1YWxseSB0cmlnZ2VyZWQgYnkgY2xpY2tpbmcgb24gYSBidXR0b24uIEl0IGluY2x1ZGVzIGEgdGl0bGUsIGEgY2xvc2UgYnV0dG9uIGFuZCBhIGNvbnRlbnQgYXJlYS5cbiAqL1xuZXhwb3J0IGNvbnN0IFBvcG92ZXIgPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgdmlzaWJsZSA9IGZhbHNlLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICBwbGFjZW1lbnQsXG4gICAgICBjb250ZW50LFxuICAgICAgdGl0bGUsXG4gICAgICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gICAgICBzaXplID0gJ21lZGl1bScsXG4gICAgICBvbkNsb3NlLFxuICAgICAgY2xhc3NOYW1lLFxuICAgICAgbWF4V2lkdGgsXG4gICAgICBtYXhIZWlnaHQsXG4gICAgICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICAgICAgcG9ydGFsVGFyZ2V0LFxuICAgICAgZHluYW1pY0RvbVJlbmRlcmluZyxcbiAgICAgIGFsaWduLFxuICAgIH06IFBvcG92ZXJQcm9wcyxcbiAgICByZWY6IFJlZjxIVE1MRGl2RWxlbWVudD4sXG4gICkgPT4ge1xuICAgIGNvbnN0IGlubmVyUmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKVxuICAgIGNvbnN0IGlzSW5zaWRlTW9kYWwgPSB1c2VDb250ZXh0KE1vZGFsQ29udGV4dClcbiAgICBjb25zdCBbbG9jYWxWaXNpYmxlLCBzZXRMb2NhbFZpc2libGVdID0gdXNlU3RhdGUodmlzaWJsZSlcblxuICAgIC8vIFdlIGNoYW5nZSBsb2NhbCB2YWx1ZSBpZiB2aXNpYmxlIHByb3AgY2hhbmdlc1xuICAgIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgICBzZXRMb2NhbFZpc2libGUodmlzaWJsZSlcbiAgICB9LCBbdmlzaWJsZV0pXG5cbiAgICBjb25zdCBsb2NhbE9uQ2xvc2UgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgICBzZXRMb2NhbFZpc2libGUoZmFsc2UpXG4gICAgICBvbkNsb3NlPy4oKVxuICAgIH0sIFtvbkNsb3NlXSlcblxuICAgIGNvbnN0IHNtYXJ0UG9ydGFsVGFyZ2V0ID0gdXNlTWVtbygoKSA9PiB7XG4gICAgICBpZiAoIXBvcnRhbFRhcmdldCAmJiBpc0luc2lkZU1vZGFsKSB7XG4gICAgICAgIHJldHVybiB1bmRlZmluZWRcbiAgICAgIH1cblxuICAgICAgaWYgKCFwb3J0YWxUYXJnZXQgJiYgIWlzSW5zaWRlTW9kYWwpIHtcbiAgICAgICAgcmV0dXJuIGRvY3VtZW50LmJvZHlcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHBvcnRhbFRhcmdldFxuICAgIH0sIFtpc0luc2lkZU1vZGFsLCBwb3J0YWxUYXJnZXRdKVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxTdHlsZWRQb3B1cFxuICAgICAgICBoaWRlT25DbGlja091dHNpZGVcbiAgICAgICAgZGVib3VuY2VEZWxheT17MH1cbiAgICAgICAgdmlzaWJsZT17bG9jYWxWaXNpYmxlfVxuICAgICAgICBwbGFjZW1lbnQ9e3BsYWNlbWVudH1cbiAgICAgICAgdGV4dD17XG4gICAgICAgICAgPENvbnRlbnRXcmFwcGVyXG4gICAgICAgICAgICB0aXRsZT17dGl0bGV9XG4gICAgICAgICAgICBvbkNsb3NlPXtsb2NhbE9uQ2xvc2V9XG4gICAgICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7Y29udGVudH1cbiAgICAgICAgICA8L0NvbnRlbnRXcmFwcGVyPlxuICAgICAgICB9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgIHJvbGU9XCJkaWFsb2dcIlxuICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgdGFiSW5kZXg9ey0xfVxuICAgICAgICBpbm5lclJlZj17aW5uZXJSZWZ9XG4gICAgICAgIG9uQ2xvc2U9e2xvY2FsT25DbG9zZX1cbiAgICAgICAgbWF4V2lkdGg9e21heFdpZHRofVxuICAgICAgICBtYXhIZWlnaHQ9e21heEhlaWdodH1cbiAgICAgICAgcG9ydGFsVGFyZ2V0PXtzbWFydFBvcnRhbFRhcmdldH1cbiAgICAgICAgZHluYW1pY0RvbVJlbmRlcmluZz17ZHluYW1pY0RvbVJlbmRlcmluZ31cbiAgICAgICAgYWxpZ249e2FsaWdufVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZFBvcHVwPlxuICAgIClcbiAgfSxcbilcbiJdfQ== */"));
64
65
  const ContentWrapper = ({
65
66
  title,
66
67
  onClose,
@@ -91,6 +92,7 @@ const Popover = React.forwardRef(({
91
92
  align
92
93
  }, ref) => {
93
94
  const innerRef = React.useRef(null);
95
+ const isInsideModal = React.useContext(ModalProvider.ModalContext);
94
96
  const [localVisible, setLocalVisible] = React.useState(visible);
95
97
  React.useEffect(() => {
96
98
  setLocalVisible(visible);
@@ -99,6 +101,15 @@ const Popover = React.forwardRef(({
99
101
  setLocalVisible(false);
100
102
  onClose?.();
101
103
  }, [onClose]);
102
- return /* @__PURE__ */ jsxRuntime.jsx(StyledPopup, { hideOnClickOutside: true, debounceDelay: 0, visible: localVisible, placement, text: /* @__PURE__ */ jsxRuntime.jsx(ContentWrapper, { title, onClose: localOnClose, sentiment, children: content }), className, sentiment, "data-testid": dataTestId, size, role: "dialog", ref, tabIndex: -1, innerRef, onClose: localOnClose, maxWidth, maxHeight, portalTarget, dynamicDomRendering, align, children });
104
+ const smartPortalTarget = React.useMemo(() => {
105
+ if (!portalTarget && isInsideModal) {
106
+ return void 0;
107
+ }
108
+ if (!portalTarget && !isInsideModal) {
109
+ return document.body;
110
+ }
111
+ return portalTarget;
112
+ }, [isInsideModal, portalTarget]);
113
+ return /* @__PURE__ */ jsxRuntime.jsx(StyledPopup, { hideOnClickOutside: true, debounceDelay: 0, visible: localVisible, placement, text: /* @__PURE__ */ jsxRuntime.jsx(ContentWrapper, { title, onClose: localOnClose, sentiment, children: content }), className, sentiment, "data-testid": dataTestId, size, role: "dialog", ref, tabIndex: -1, innerRef, onClose: localOnClose, maxWidth, maxHeight, portalTarget: smartPortalTarget, dynamicDomRendering, align, children });
103
114
  });
104
115
  exports.Popover = Popover;