@ultraviolet/ui 1.73.2 → 1.75.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/dist/components/Checkbox/index.cjs +2 -2
  2. package/dist/components/CheckboxGroup/index.cjs +2 -2
  3. package/dist/components/Chip/ChipContext.cjs +5 -0
  4. package/dist/components/Chip/ChipContext.d.ts +8 -0
  5. package/dist/components/Chip/ChipContext.js +5 -0
  6. package/dist/components/Chip/ChipIcon.cjs +62 -0
  7. package/dist/components/Chip/ChipIcon.d.ts +13 -0
  8. package/dist/components/Chip/ChipIcon.js +42 -0
  9. package/dist/components/Chip/index.cjs +106 -0
  10. package/dist/components/Chip/index.d.ts +22 -0
  11. package/dist/components/Chip/index.js +104 -0
  12. package/dist/components/CopyButton/index.cjs +6 -2
  13. package/dist/components/CopyButton/index.d.ts +2 -1
  14. package/dist/components/CopyButton/index.js +6 -2
  15. package/dist/components/DateInput/index.cjs +2 -2
  16. package/dist/components/List/HeaderCell.cjs +4 -4
  17. package/dist/components/NumberInputV2/index.cjs +2 -2
  18. package/dist/components/RadioGroup/index.cjs +2 -2
  19. package/dist/components/SelectInputV2/Dropdown.cjs +10 -10
  20. package/dist/components/SelectInputV2/Dropdown.js +10 -10
  21. package/dist/components/SelectInputV2/SearchBarDropdown.cjs +2 -2
  22. package/dist/components/SelectInputV2/SelectBar.cjs +5 -5
  23. package/dist/components/SelectInputV2/index.cjs +2 -2
  24. package/dist/components/SelectableCardGroup/index.cjs +2 -2
  25. package/dist/components/Slider/components/Label.cjs +2 -2
  26. package/dist/components/Snippet/index.cjs +14 -13
  27. package/dist/components/Snippet/index.d.ts +2 -1
  28. package/dist/components/Snippet/index.js +12 -11
  29. package/dist/components/Stepper/Step.cjs +4 -4
  30. package/dist/components/Stepper/Step.js +4 -4
  31. package/dist/components/Table/HeaderCell.cjs +4 -4
  32. package/dist/components/TagInput/index.cjs +4 -4
  33. package/dist/components/TextArea/index.cjs +23 -11
  34. package/dist/components/TextArea/index.d.ts +4 -1
  35. package/dist/components/TextArea/index.js +20 -8
  36. package/dist/components/TextInputV2/index.cjs +4 -4
  37. package/dist/components/Toggle/index.cjs +2 -2
  38. package/dist/components/ToggleGroup/index.cjs +2 -2
  39. package/dist/components/UnitInput/index.cjs +4 -4
  40. package/dist/components/index.d.ts +1 -0
  41. package/dist/index.cjs +122 -120
  42. package/dist/index.js +2 -0
  43. package/package.json +3 -3
@@ -24,7 +24,7 @@ const loadingAnimation = (size) => react.keyframes`
24
24
  to {
25
25
  width: calc(100% - ${size === "small" ? "24px" : "32px"} - 8px)};
26
26
  `;
27
- const loadingStyle = (size) => /* @__PURE__ */ react.css("animation:", loadingAnimation(size), " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : ";label:loadingStyle;"), 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/Stepper/Step.tsx"],"names":[],"mappings":"AA4CsD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */");
27
+ const loadingStyle = (size) => /* @__PURE__ */ react.css("animation:", loadingAnimation(size), " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : ";label:loadingStyle;"), 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/Stepper/Step.tsx"],"names":[],"mappings":"AA4CsD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */");
28
28
  const StyledBullet = /* @__PURE__ */ _styled__default.default(index.Bullet, process.env.NODE_ENV === "production" ? {
29
29
  target: "ewvv9212"
30
30
  } : {
@@ -40,7 +40,7 @@ const StyledBullet = /* @__PURE__ */ _styled__default.default(index.Bullet, proc
40
40
  theme,
41
41
  isActive
42
42
  }) => isActive ? `background-color: ${theme.colors.primary.backgroundStrongHover};
43
- box-shadow: ${theme.shadows.focusPrimary};` : null, ";" + (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/Stepper/Step.tsx"],"names":[],"mappings":"AAmDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
43
+ box-shadow: ${theme.shadows.focusPrimary};` : null, ";" + (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/Stepper/Step.tsx"],"names":[],"mappings":"AAmDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
44
44
  const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
45
45
  target: "ewvv9211"
46
46
  } : {
@@ -52,7 +52,7 @@ const StyledText = /* @__PURE__ */ _styled__default.default(index$1.Text, proces
52
52
  } : {
53
53
  name: "55d43u",
54
54
  styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent;white-space:normal",
55
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAgE+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */",
55
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAgE+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */",
56
56
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
57
57
  });
58
58
  const StyledStepContainer = /* @__PURE__ */ _styled__default.default(index$2.Stack, process.env.NODE_ENV === "production" ? {
@@ -109,7 +109,7 @@ const StyledStepContainer = /* @__PURE__ */ _styled__default.default(index$2.Sta
109
109
  }) => size === "small" ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium, "px;}}&:last-child{margin-top:", ({
110
110
  theme,
111
111
  size
112
- }) => size === "small" ? "0px" : theme.space[1], ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAiFE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
112
+ }) => size === "small" ? "0px" : theme.space[1], ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAiFE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
113
113
  const Step = ({
114
114
  index: index2 = 0,
115
115
  onClick,
@@ -20,7 +20,7 @@ const loadingAnimation = (size) => keyframes`
20
20
  to {
21
21
  width: calc(100% - ${size === "small" ? "24px" : "32px"} - 8px)};
22
22
  `;
23
- const loadingStyle = (size) => /* @__PURE__ */ css("animation:", loadingAnimation(size), " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : ";label:loadingStyle;"), 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/Stepper/Step.tsx"],"names":[],"mappings":"AA4CsD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */");
23
+ const loadingStyle = (size) => /* @__PURE__ */ css("animation:", loadingAnimation(size), " 1s linear infinite;" + (process.env.NODE_ENV === "production" ? "" : ";label:loadingStyle;"), 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/Stepper/Step.tsx"],"names":[],"mappings":"AA4CsD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */");
24
24
  const StyledBullet = /* @__PURE__ */ _styled(Bullet, process.env.NODE_ENV === "production" ? {
25
25
  target: "ewvv9212"
26
26
  } : {
@@ -36,7 +36,7 @@ const StyledBullet = /* @__PURE__ */ _styled(Bullet, process.env.NODE_ENV === "p
36
36
  theme,
37
37
  isActive
38
38
  }) => isActive ? `background-color: ${theme.colors.primary.backgroundStrongHover};
39
- box-shadow: ${theme.shadows.focusPrimary};` : null, ";" + (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/Stepper/Step.tsx"],"names":[],"mappings":"AAmDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
39
+ box-shadow: ${theme.shadows.focusPrimary};` : null, ";" + (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/Stepper/Step.tsx"],"names":[],"mappings":"AAmDE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
40
40
  const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
41
41
  target: "ewvv9211"
42
42
  } : {
@@ -48,7 +48,7 @@ const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
48
48
  } : {
49
49
  name: "55d43u",
50
50
  styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent;white-space:normal",
51
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAgE+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */",
51
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAgE+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */",
52
52
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
53
53
  });
54
54
  const StyledStepContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
@@ -105,7 +105,7 @@ const StyledStepContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV
105
105
  }) => size === "small" ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium, "px;}}&:last-child{margin-top:", ({
106
106
  theme,
107
107
  size
108
- }) => size === "small" ? "0px" : theme.space[1], ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAiFE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small' ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
108
+ }) => size === "small" ? "0px" : theme.space[1], ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx"],"names":[],"mappings":"AAiFE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Stepper/Step.tsx","sourcesContent":["import { css, keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type { ReactNode } from 'react'\nimport { useMemo } from 'react'\nimport { Bullet } from '../Bullet'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { useStepper } from './StepperProvider'\n\nconst LINE_HEIGHT_SIZES = {\n  small: 2,\n  medium: 4,\n} as const\n\ntype StepProps = {\n  onClick?: (index: number) => void\n  /**\n   * Automatically attribued by the parent Stepper\n   */\n  index?: number\n  /**\n   * Whether the step is disabled\n   */\n  disabled?: boolean\n  /**\n   * Title of the step\n   */\n  title?: ReactNode\n  /**\n   * For additional information.\n   * Use prop `title` to properly name the step\n   */\n  children?: ReactNode\n  className?: string\n  'data-testid'?: string\n}\nconst loadingAnimation = (size: 'small' | 'medium') => keyframes`\n  from {\n    width: 0;\n  }\n  to {\n    width: calc(100% - ${size === 'small' ? '24px' : '32px'} - 8px)};\n`\n\nconst loadingStyle = (size: 'small' | 'medium') => css`\n  animation: ${loadingAnimation(size)} 1s linear infinite;\n`\n\nconst StyledBullet = styled(Bullet)<{\n  size: 'small' | 'medium'\n  isActive: boolean\n}>`\n  margin-top: ${({ theme, size }) =>\n    size === 'small' ? theme.space['0.5'] : 0};\n  transition: box-shadow 300ms;\n  min-width: ${({ theme, size }) =>\n    size === 'small' ? theme.space[3] : theme.space[4]};\n  ${({ theme, isActive }) =>\n    isActive\n      ? `background-color: ${theme.colors.primary.backgroundStrongHover};\n          box-shadow: ${theme.shadows.focusPrimary};`\n      : null};\n`\n\nconst StyledText = styled(Text)`\n  transition: text-decoration-color 250ms ease-out;\n  text-decoration-thickness: 1px;\n  text-underline-offset: 2px;\n  text-decoration-color: transparent;\n  white-space: normal;\n`\n\nconst StyledStepContainer = styled(Stack)<{\n  'data-disabled': boolean\n  'data-interactive': boolean\n  'data-hide-separator': boolean\n  'data-label-position': 'bottom' | 'right'\n  size: 'small' | 'medium'\n  'data-selected': boolean\n  'data-done': boolean\n  'data-animated': boolean\n}>`\n  display: flex;\n  white-space: nowrap;\n  transition: text-decoration 300ms;\n\n  &[data-interactive=\"true\"]:not([data-disabled=\"true\"]) {\n    cursor: pointer;\n\n    &[data-selected=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n        & > ${StyledText} {\n          color: ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration: underline\n            ${({ theme }) => theme.colors.primary.textHover};\n          text-decoration-thickness: 1px;\n        }\n      }\n    }\n\n    &[data-done=\"true\"]:hover {\n      & > ${StyledBullet} {\n        box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n      }\n      & > ${StyledText} {\n        color: ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration: underline\n          ${({ theme }) => theme.colors.neutral.textHover};\n        text-decoration-thickness: 1px;\n      }\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    cursor: not-allowed;\n\n    & > ${StyledText} {\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n    }\n\n    & > ${StyledBullet} {\n      background-color: ${({ theme }) =>\n        theme.colors.neutral.backgroundDisabled};\n      box-shadow: none;\n      color: ${({ theme }) => theme.colors.neutral.textDisabled};\n      border-color: ${({ theme }) => theme.colors.neutral.borderDisabled};\n    }\n  }\n\n  &:not([data-hide-separator=\"true\"]):not([data-label-position=\"right\"]) {\n    flex-direction: column;\n    flex: 1;\n\n    & > ${StyledText} {\n      margin-top: ${({ theme }) => theme.space[1]};\n    }\n\n    &:not(:last-child){\n      &:after {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        top: ${({ theme }) => theme.space[2]};\n        width: calc(100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n\n      &[data-done=\"true\"]:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n      }\n      &[data-selected=\"true\"][data-animated=\"true\"]:after {\n        ${({ size }) => loadingStyle(size)}\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n\n      }\n    }\n      &:not(:last-child){\n      &::before {\n        content: \"\";\n        position: relative;\n        align-self: baseline;\n        border-radius: ${({ theme }) => theme.radii.default};\n        background-color: ${({ theme }) =>\n          theme.colors.neutral.backgroundStrong};\n        top: 20px;\n        width: calc(\n          100% - ${({ theme, size }) => (size === 'small' ? theme.space[5] : theme.space[6])});\n        left: calc(50% + 25px);\n        order: -1;\n        height: ${({ size }) =>\n          size === 'small'\n            ? LINE_HEIGHT_SIZES.small\n            : LINE_HEIGHT_SIZES.medium}px;\n      }\n    }\n\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '0px' : theme.space[1]};\n    }\n  }\n`\n\nexport const Step = ({\n  index = 0,\n  onClick,\n  disabled = false,\n  title,\n  children,\n  className,\n  'data-testid': dataTestId,\n}: StepProps) => {\n  const currentState = useStepper()\n  const isActive = index === currentState.step\n  const isDone = index < currentState.step\n\n  const textVariant = useMemo(() => {\n    if (currentState.size === 'medium') {\n      return isActive ? 'bodyStrong' : 'body'\n    }\n\n    return isActive ? 'bodySmallStrong' : 'bodySmall'\n  }, [currentState.size, isActive])\n\n  return (\n    <StyledStepContainer\n      gap={currentState.labelPosition === 'right' ? 1 : 0}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems=\"center\"\n      justifyContent=\"flex-start\"\n      className={className ?? 'step'}\n      data-interactive={currentState.interactive && isDone}\n      onClick={() => {\n        if (currentState.interactive && !disabled) {\n          if (index < currentState.step) {\n            currentState.setStep(index)\n          }\n          onClick?.(index)\n        }\n      }}\n      data-disabled={disabled}\n      data-testid={dataTestId ?? `stepper-step-${index}`}\n      data-hide-separator={!currentState.separator}\n      data-label-position={currentState.labelPosition}\n      size={currentState.size}\n      data-selected={isActive}\n      data-done={isDone}\n      data-animated={currentState.animated}\n    >\n      {isDone && !disabled ? (\n        <StyledBullet\n          sentiment=\"primary\"\n          icon=\"check\"\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      ) : (\n        <StyledBullet\n          sentiment={isDone || isActive ? 'primary' : 'neutral'}\n          text={(index + 1).toString()}\n          prominence=\"strong\"\n          size={currentState.size}\n          isActive={isActive}\n        />\n      )}\n      {title ? (\n        <StyledText\n          as=\"span\"\n          variant={textVariant}\n          prominence={isDone || isActive ? 'default' : 'weak'}\n          sentiment={isActive ? 'primary' : 'neutral'}\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
109
109
  const Step = ({
110
110
  index = 0,
111
111
  onClick,
@@ -2,13 +2,13 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const _styled = require("@emotion/styled/base");
5
- const icons = require("@ultraviolet/icons");
5
+ const Icon = require("@ultraviolet/icons");
6
6
  const index = require("../Text/index.cjs");
7
7
  const index$1 = require("../Tooltip/index.cjs");
8
8
  const constants = require("./constants.cjs");
9
9
  const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
10
  const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
- const StyledSortIcon = /* @__PURE__ */ _styled__default.default(icons.SouthShortIcon, process.env.NODE_ENV === "production" ? {
11
+ const StyledSortIcon = /* @__PURE__ */ _styled__default.default(Icon.SouthShortIcon, process.env.NODE_ENV === "production" ? {
12
12
  shouldForwardProp: (prop) => !["order"].includes(prop),
13
13
  target: "ev6jkq82"
14
14
  } : {
@@ -20,7 +20,7 @@ const StyledSortIcon = /* @__PURE__ */ _styled__default.default(icons.SouthShort
20
20
  }) => order === "ascending" ? "rotate(-180deg)" : "none", ";transition:transform 0.2s;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RhYmxlL0hlYWRlckNlbGwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWF5QyIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9UYWJsZS9IZWFkZXJDZWxsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHtcbiAgSW5mb3JtYXRpb25JY29uLFxuICBTb3J0SWNvbiBhcyBTb3J0SWNvblVWLFxuICBTb3V0aFNob3J0SWNvbixcbn0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuLi9UZXh0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uL1Rvb2x0aXAnXG5pbXBvcnQgeyBBbGlnbmVtZW50RmxleCB9IGZyb20gJy4vY29uc3RhbnRzJ1xuXG5jb25zdCBTdHlsZWRTb3J0SWNvbiA9IHN0eWxlZChTb3V0aFNob3J0SWNvbiwge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydvcmRlciddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBvcmRlcjogJ2FzY2VuZGluZycgfCAnZGVzY2VuZGluZycgfT5gXG4gICAgdHJhbnNmb3JtOiAkeyh7IG9yZGVyIH0pID0+IChvcmRlciA9PT0gJ2FzY2VuZGluZycgPyAncm90YXRlKC0xODBkZWcpJyA6ICdub25lJyl9O1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAwLjJzO1xuYFxuXG5jb25zdCBTb3J0SWNvbiA9ICh7IG9yZGVyIH06IHsgb3JkZXI/OiAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJyB9KSA9PlxuICBvcmRlciA/IChcbiAgICA8U3R5bGVkU29ydEljb24gb3JkZXI9e29yZGVyfSBzZW50aW1lbnQ9XCJwcmltYXJ5XCIgLz5cbiAgKSA6IChcbiAgICA8U29ydEljb25VViBzZW50aW1lbnQ9XCJuZXV0cmFsXCIgLz5cbiAgKVxuXG50eXBlIFN0eWxlZEhlYWRlckNlbGxQcm9wcyA9IFBpY2s8XG4gIEhlYWRlckNlbGxQcm9wcyxcbiAgJ3dpZHRoJyB8ICdtYXhXaWR0aCcgfCAnbWluV2lkdGgnXG4+ICYge1xuICBhbGlnbj86ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0J1xufVxuXG5jb25zdCBTdHlsZWRIZWFkZXJDZWxsID0gc3R5bGVkKCd0aCcsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhWydhbGlnbicsICd3aWR0aCcsICdtYXhXaWR0aCcsICdtaW5XaWR0aCddLmluY2x1ZGVzKHByb3ApLFxufSk8U3R5bGVkSGVhZGVyQ2VsbFByb3BzPmBcbiR7KHsgd2lkdGgsIG1heFdpZHRoLCBtaW5XaWR0aCB9KSA9PiBgXG4gICAgJHt3aWR0aCA/IGB3aWR0aDogJHt3aWR0aH07YCA6ICcnfVxuICAgICR7bWF4V2lkdGggPyBgbWF4LXdpZHRoOiAke21heFdpZHRofTtgIDogJyd9XG4gICAgJHttaW5XaWR0aCA/IGBtaW4td2lkdGg6ICR7bWluV2lkdGh9O2AgOiAnJ31cbiAgYH1cbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiAkeyh7IGFsaWduIH0pID0+IChhbGlnbiA/IEFsaWduZW1lbnRGbGV4W2FsaWduXSA6IG51bGwpfTtcbiAgcGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcblxuICAmW3JvbGUqPSdidXR0b24nXSB7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICAgIHVzZXItc2VsZWN0OiBub25lO1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoVGV4dClgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiByb3c7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMSddfTtcbmBcblxudHlwZSBIZWFkZXJDZWxsUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGlzT3JkZXJlZD86IGJvb2xlYW5cbiAgb3JkZXJEaXJlY3Rpb24/OiAnYXNjJyB8ICdkZXNjJyB8ICdub25lJ1xuICBvbk9yZGVyPzogKG5ld09yZGVyOiAnYXNjJyB8ICdkZXNjJykgPT4gdm9pZFxuICBpbmZvPzogc3RyaW5nXG4gIGFsaWduPzogJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnXG4gIHdpZHRoPzogc3RyaW5nXG4gIG1heFdpZHRoPzogc3RyaW5nXG4gIG1pbldpZHRoPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBIZWFkZXJDZWxsID0gKHtcbiAgY2hpbGRyZW4sXG4gIGNsYXNzTmFtZSxcbiAgaXNPcmRlcmVkLFxuICBvbk9yZGVyLFxuICBvcmRlckRpcmVjdGlvbixcbiAgaW5mbyxcbiAgYWxpZ24sXG4gIHdpZHRoLFxuICBtYXhXaWR0aCxcbiAgbWluV2lkdGgsXG59OiBIZWFkZXJDZWxsUHJvcHMpID0+IHtcbiAgbGV0IG9yZGVyOiB1bmRlZmluZWQgfCAnYXNjZW5kaW5nJyB8ICdkZXNjZW5kaW5nJ1xuICBpZiAoaXNPcmRlcmVkICYmIG9yZGVyRGlyZWN0aW9uID09PSAnYXNjJykge1xuICAgIG9yZGVyID0gJ2FzY2VuZGluZydcbiAgfSBlbHNlIGlmIChpc09yZGVyZWQgJiYgb3JkZXJEaXJlY3Rpb24gPT09ICdkZXNjJykge1xuICAgIG9yZGVyID0gJ2Rlc2NlbmRpbmcnXG4gIH1cblxuICBjb25zdCBoYW5kbGVPcmRlciA9IG9uT3JkZXJcbiAgICA/ICgpID0+IG9uT3JkZXIob3JkZXIgPT09ICdhc2NlbmRpbmcnID8gJ2Rlc2MnIDogJ2FzYycpXG4gICAgOiB1bmRlZmluZWRcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRIZWFkZXJDZWxsXG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIG9uQ2xpY2s9e2hhbmRsZU9yZGVyfVxuICAgICAgb25LZXlEb3duPXtcbiAgICAgICAgaGFuZGxlT3JkZXJcbiAgICAgICAgICA/IGV2ZW50ID0+IHtcbiAgICAgICAgICAgICAgaWYgKGV2ZW50LmtleSA9PT0gJyAnIHx8IGV2ZW50LmtleSA9PT0gJ0VudGVyJykge1xuICAgICAgICAgICAgICAgIGhhbmRsZU9yZGVyKClcbiAgICAgICAgICAgICAgICBpZiAoZXZlbnQua2V5ID09PSAnICcpIHtcbiAgICAgICAgICAgICAgICAgIC8vIEBub3RlOiBpdCBhdm9pZCBzY3JvbGwgd2hlbiBwcmVzc2luZyBTcGFjZVxuICAgICAgICAgICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIDogdW5kZWZpbmVkXG4gICAgICB9XG4gICAgICByb2xlPXtvbk9yZGVyID8gJ2J1dHRvbiBjb2x1bW5oZWFkZXInIDogdW5kZWZpbmVkfVxuICAgICAgdGFiSW5kZXg9e2hhbmRsZU9yZGVyID8gMCA6IC0xfVxuICAgICAgYXJpYS1zb3J0PXtvcmRlcn1cbiAgICAgIGFsaWduPXthbGlnbn1cbiAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgIG1heFdpZHRoPXttYXhXaWR0aH1cbiAgICAgIG1pbldpZHRoPXttaW5XaWR0aH1cbiAgICA+XG4gICAgICA8U3R5bGVkVGV4dFxuICAgICAgICBhcz1cImRpdlwiXG4gICAgICAgIHZhcmlhbnQ9XCJib2R5U21hbGxcIlxuICAgICAgICBjb2xvcj17b3JkZXIgIT09IHVuZGVmaW5lZCA/ICdwcmltYXJ5JyA6ICduZXV0cmFsJ31cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgICB7aW5mbyA/IChcbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXtpbmZvfT5cbiAgICAgICAgICAgIDxJbmZvcm1hdGlvbkljb25cbiAgICAgICAgICAgICAgc2l6ZT1cImxhcmdlXCJcbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cIndlYWtcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge29yZGVyRGlyZWN0aW9uICE9PSB1bmRlZmluZWQgJiYgaXNPcmRlcmVkICE9PSB1bmRlZmluZWQgPyAoXG4gICAgICAgICAgPFNvcnRJY29uIGFyaWEtZGlzYWJsZWQ9eyFvbk9yZGVyfSBvcmRlcj17b3JkZXJ9IC8+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgPC9TdHlsZWRUZXh0PlxuICAgIDwvU3R5bGVkSGVhZGVyQ2VsbD5cbiAgKVxufVxuIl19 */"));
21
21
  const SortIcon = ({
22
22
  order
23
- }) => order ? /* @__PURE__ */ jsxRuntime.jsx(StyledSortIcon, { order, sentiment: "primary" }) : /* @__PURE__ */ jsxRuntime.jsx(icons.SortIcon, { sentiment: "neutral" });
23
+ }) => order ? /* @__PURE__ */ jsxRuntime.jsx(StyledSortIcon, { order, sentiment: "primary" }) : /* @__PURE__ */ jsxRuntime.jsx(Icon.SortIcon, { sentiment: "neutral" });
24
24
  const StyledHeaderCell = /* @__PURE__ */ _styled__default.default("th", process.env.NODE_ENV === "production" ? {
25
25
  shouldForwardProp: (prop) => !["align", "width", "maxWidth", "minWidth"].includes(prop),
26
26
  target: "ev6jkq81"
@@ -77,7 +77,7 @@ const HeaderCell = ({
77
77
  }
78
78
  } : void 0, role: onOrder ? "button columnheader" : void 0, tabIndex: handleOrder ? 0 : -1, "aria-sort": order, align, width, maxWidth, minWidth, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledText, { as: "div", variant: "bodySmall", color: order !== void 0 ? "primary" : "neutral", children: [
79
79
  children,
80
- info ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: info, children: /* @__PURE__ */ jsxRuntime.jsx(icons.InformationIcon, { size: "large", prominence: "weak", sentiment: "neutral" }) }) : null,
80
+ info ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: info, children: /* @__PURE__ */ jsxRuntime.jsx(Icon.InformationIcon, { size: "large", prominence: "weak", sentiment: "neutral" }) }) : null,
81
81
  orderDirection !== void 0 && isOrdered !== void 0 ? /* @__PURE__ */ jsxRuntime.jsx(SortIcon, { "aria-disabled": !onOrder, order }) : null
82
82
  ] }) });
83
83
  };
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const _styled = require("@emotion/styled/base");
5
- const icons = require("@ultraviolet/icons");
5
+ const Icon = require("@ultraviolet/icons");
6
6
  const React = require("react");
7
7
  const index$4 = require("../Button/index.cjs");
8
8
  const index = require("../Stack/index.cjs");
@@ -237,7 +237,7 @@ const TagInput = ({
237
237
  label || labelDescription ? /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { direction: "row", gap: "1", alignItems: "center", children: [
238
238
  label ? /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { direction: "row", gap: "0.5", alignItems: "start", children: [
239
239
  /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { as: "label", variant: size === "large" ? "bodyStrong" : "bodySmallStrong", sentiment: "neutral", htmlFor: id ?? localId, prominence: "strong", children: label }),
240
- required ? /* @__PURE__ */ jsxRuntime.jsx(icons.AsteriskIcon, { sentiment: "danger", size: 8 }) : null
240
+ required ? /* @__PURE__ */ jsxRuntime.jsx(Icon.AsteriskIcon, { sentiment: "danger", size: 8 }) : null
241
241
  ] }) : null,
242
242
  labelDescription ?? null
243
243
  ] }) : null,
@@ -251,8 +251,8 @@ const TagInput = ({
251
251
  ] }),
252
252
  computedClearable || success || error ? /* @__PURE__ */ jsxRuntime.jsxs(StateContainer, { children: [
253
253
  computedClearable ? /* @__PURE__ */ jsxRuntime.jsx(index$4.Button, { "aria-label": "clear value", disabled, variant: "ghost", size: "xsmall", icon: "close", onClick: clearAll, sentiment: "neutral" }) : null,
254
- success ? /* @__PURE__ */ jsxRuntime.jsx(icons.CheckCircleOutlineIcon, { sentiment: "success", size: 16, disabled }) : null,
255
- error ? /* @__PURE__ */ jsxRuntime.jsx(icons.AlertCircleIcon, { sentiment: "danger", size: 16, disabled }) : null
254
+ success ? /* @__PURE__ */ jsxRuntime.jsx(Icon.CheckCircleOutlineIcon, { sentiment: "success", size: 16, disabled }) : null,
255
+ error ? /* @__PURE__ */ jsxRuntime.jsx(Icon.AlertCircleIcon, { sentiment: "danger", size: 16, disabled }) : null
256
256
  ] }) : null
257
257
  ] }) }) }),
258
258
  error || typeof success === "string" || helper ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { variant: "caption", as: "span", prominence: !error && !success ? "weak" : void 0, sentiment: helperSentiment, disabled: disabled || readOnly, children: error || success || helper }) : null