@ultraviolet/ui 1.82.2 → 1.82.3
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.
- package/dist/components/Badge/index.cjs +3 -3
- package/dist/components/Badge/index.js +3 -3
- package/dist/components/Modal/components/Dialog.cjs +4 -7
- package/dist/components/Modal/components/Dialog.js +4 -7
- package/dist/components/Slider/components/DoubleSlider.cjs +13 -10
- package/dist/components/Slider/components/DoubleSlider.js +13 -10
- package/dist/components/Snippet/index.cjs +13 -15
- package/dist/components/Snippet/index.js +13 -15
- package/dist/components/Stepper/Step.cjs +8 -8
- package/dist/components/Stepper/Step.js +8 -8
- package/dist/components/Text/index.cjs +11 -5
- package/dist/components/Text/index.d.ts +6 -4
- package/dist/components/Text/index.js +11 -5
- package/package.json +8 -8
|
@@ -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'\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"]} */");
|
|
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`\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          whiteSpace=\"normal\"\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,18 +40,18 @@ 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'\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"]} */"));
|
|
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`\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          whiteSpace=\"normal\"\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
|
} : {
|
|
47
47
|
target: "ewvv9211",
|
|
48
48
|
label: "StyledText"
|
|
49
49
|
})(process.env.NODE_ENV === "production" ? {
|
|
50
|
-
name: "
|
|
51
|
-
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent
|
|
50
|
+
name: "12r2vby",
|
|
51
|
+
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent"
|
|
52
52
|
} : {
|
|
53
|
-
name: "
|
|
54
|
-
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent;white-space:normal/*# 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"]} */",
|
|
53
|
+
name: "12r2vby",
|
|
54
|
+
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent/*# 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`\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          whiteSpace=\"normal\"\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */",
|
|
55
55
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
56
56
|
});
|
|
57
57
|
const StyledStepContainer = /* @__PURE__ */ _styled__default.default(index$2.Stack, process.env.NODE_ENV === "production" ? {
|
|
@@ -108,7 +108,7 @@ const StyledStepContainer = /* @__PURE__ */ _styled__default.default(index$2.Sta
|
|
|
108
108
|
}) => size === "small" ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium, "px;}}&:last-child{margin-top:", ({
|
|
109
109
|
theme,
|
|
110
110
|
size
|
|
111
|
-
}) => 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"]} */"));
|
|
111
|
+
}) => 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":"AAgFE","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`\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          whiteSpace=\"normal\"\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
|
|
112
112
|
const Step = ({
|
|
113
113
|
index: index2 = 0,
|
|
114
114
|
onClick,
|
|
@@ -136,7 +136,7 @@ const Step = ({
|
|
|
136
136
|
}
|
|
137
137
|
}, "data-disabled": disabled, "data-testid": dataTestId ?? `stepper-step-${index2}`, "data-hide-separator": !currentState.separator, "data-label-position": currentState.labelPosition, size: currentState.size, "data-selected": isActive, "data-done": isDone, "data-animated": currentState.animated, children: [
|
|
138
138
|
isDone && !disabled ? /* @__PURE__ */ jsxRuntime.jsx(StyledBullet, { sentiment: "primary", icon: "check", prominence: "strong", size: currentState.size, isActive }) : /* @__PURE__ */ jsxRuntime.jsx(StyledBullet, { sentiment: isDone || isActive ? "primary" : "neutral", text: (index2 + 1).toString(), prominence: "strong", size: currentState.size, isActive }),
|
|
139
|
-
title ? /* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "span", variant: textVariant, prominence: isDone || isActive ? "default" : "weak", sentiment: isActive ? "primary" : "neutral", children: title }) : null,
|
|
139
|
+
title ? /* @__PURE__ */ jsxRuntime.jsx(StyledText, { as: "span", variant: textVariant, prominence: isDone || isActive ? "default" : "weak", sentiment: isActive ? "primary" : "neutral", whiteSpace: "normal", children: title }) : null,
|
|
140
140
|
children ?? null
|
|
141
141
|
] });
|
|
142
142
|
};
|
|
@@ -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'\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"]} */");
|
|
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`\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          whiteSpace=\"normal\"\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,18 +36,18 @@ 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'\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"]} */"));
|
|
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`\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          whiteSpace=\"normal\"\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
|
} : {
|
|
43
43
|
target: "ewvv9211",
|
|
44
44
|
label: "StyledText"
|
|
45
45
|
})(process.env.NODE_ENV === "production" ? {
|
|
46
|
-
name: "
|
|
47
|
-
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent
|
|
46
|
+
name: "12r2vby",
|
|
47
|
+
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent"
|
|
48
48
|
} : {
|
|
49
|
-
name: "
|
|
50
|
-
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent;white-space:normal/*# 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"]} */",
|
|
49
|
+
name: "12r2vby",
|
|
50
|
+
styles: "transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent/*# 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`\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          whiteSpace=\"normal\"\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */",
|
|
51
51
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
52
52
|
});
|
|
53
53
|
const StyledStepContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
@@ -104,7 +104,7 @@ const StyledStepContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV
|
|
|
104
104
|
}) => size === "small" ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium, "px;}}&:last-child{margin-top:", ({
|
|
105
105
|
theme,
|
|
106
106
|
size
|
|
107
|
-
}) => 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"]} */"));
|
|
107
|
+
}) => 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":"AAgFE","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`\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          whiteSpace=\"normal\"\n        >\n          {title}\n        </StyledText>\n      ) : null}\n      {children ?? null}\n    </StyledStepContainer>\n  )\n}\n"]} */"));
|
|
108
108
|
const Step = ({
|
|
109
109
|
index = 0,
|
|
110
110
|
onClick,
|
|
@@ -132,7 +132,7 @@ const Step = ({
|
|
|
132
132
|
}
|
|
133
133
|
}, "data-disabled": disabled, "data-testid": dataTestId ?? `stepper-step-${index}`, "data-hide-separator": !currentState.separator, "data-label-position": currentState.labelPosition, size: currentState.size, "data-selected": isActive, "data-done": isDone, "data-animated": currentState.animated, children: [
|
|
134
134
|
isDone && !disabled ? /* @__PURE__ */ jsx(StyledBullet, { sentiment: "primary", icon: "check", prominence: "strong", size: currentState.size, isActive }) : /* @__PURE__ */ jsx(StyledBullet, { sentiment: isDone || isActive ? "primary" : "neutral", text: (index + 1).toString(), prominence: "strong", size: currentState.size, isActive }),
|
|
135
|
-
title ? /* @__PURE__ */ jsx(StyledText, { as: "span", variant: textVariant, prominence: isDone || isActive ? "default" : "weak", sentiment: isActive ? "primary" : "neutral", children: title }) : null,
|
|
135
|
+
title ? /* @__PURE__ */ jsx(StyledText, { as: "span", variant: textVariant, prominence: isDone || isActive ? "default" : "weak", sentiment: isActive ? "primary" : "neutral", whiteSpace: "normal", children: title }) : null,
|
|
136
136
|
children ?? null
|
|
137
137
|
] });
|
|
138
138
|
};
|
|
@@ -24,7 +24,9 @@ const generateStyles = ({
|
|
|
24
24
|
oneLine,
|
|
25
25
|
disabled,
|
|
26
26
|
italic,
|
|
27
|
-
underline
|
|
27
|
+
underline,
|
|
28
|
+
whiteSpace,
|
|
29
|
+
strikeThrough
|
|
28
30
|
}) => {
|
|
29
31
|
const definedProminence = sentiment !== "neutral" && prominence === "stronger" ? capitalize(PROMINENCES.default) : capitalize(PROMINENCES[prominence]);
|
|
30
32
|
const isSentimentMonochrome = sentiment === "black" || sentiment === "white";
|
|
@@ -42,22 +44,24 @@ const generateStyles = ({
|
|
|
42
44
|
text-transform: ${theme.typography[variant].textCase};
|
|
43
45
|
text-decoration: ${theme.typography[variant].textDecoration};
|
|
44
46
|
${placement ? ` text-align: ${placement};` : ""}
|
|
47
|
+
${whiteSpace ? `white-space: ${whiteSpace};` : ""}
|
|
45
48
|
|
|
46
49
|
${oneLine ? `white-space: nowrap;
|
|
47
50
|
text-overflow: ellipsis;
|
|
48
51
|
overflow: hidden;` : ""}
|
|
49
52
|
${italic ? `font-style: italic;` : ""}
|
|
50
53
|
${underline ? `text-decoration: underline;` : ""}
|
|
54
|
+
${strikeThrough ? `text-decoration: line-through;` : ""}
|
|
51
55
|
`;
|
|
52
56
|
};
|
|
53
57
|
const StyledText = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
54
|
-
shouldForwardProp: (prop) => !["as", "placement", "variant", "sentiment", "prominence", "oneLine", "disabled", "italic", "underline"].includes(prop),
|
|
58
|
+
shouldForwardProp: (prop) => !["as", "placement", "variant", "sentiment", "prominence", "oneLine", "disabled", "italic", "underline", "strikeThrough", "whiteSpace"].includes(prop),
|
|
55
59
|
target: "e13y3mga0"
|
|
56
60
|
} : {
|
|
57
|
-
shouldForwardProp: (prop) => !["as", "placement", "variant", "sentiment", "prominence", "oneLine", "disabled", "italic", "underline"].includes(prop),
|
|
61
|
+
shouldForwardProp: (prop) => !["as", "placement", "variant", "sentiment", "prominence", "oneLine", "disabled", "italic", "underline", "strikeThrough", "whiteSpace"].includes(prop),
|
|
58
62
|
target: "e13y3mga0",
|
|
59
63
|
label: "StyledText"
|
|
60
|
-
})(generateStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
})(generateStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RleHQvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBIbUIiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvVGV4dC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ1NTUHJvcGVydGllcywgRWxlbWVudFR5cGUsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgcmVjdXJzaXZlbHlHZXRDaGlsZHJlblN0cmluZyBmcm9tICcuLi8uLi9oZWxwZXJzL3JlY3Vyc2l2ZWx5R2V0Q2hpbGRyZW5TdHJpbmcnXG5pbXBvcnQgeyB1c2VJc092ZXJmbG93aW5nIH0gZnJvbSAnLi4vLi4vaG9va3MvdXNlSXNPdmVyZmxvd2luZydcbmltcG9ydCB0eXBlIHsgQ29sb3IsIEV4dGVuZGVkQ29sb3IgfSBmcm9tICcuLi8uLi90aGVtZSdcbmltcG9ydCB7IHR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi90aGVtZSdcbmltcG9ydCBjYXBpdGFsaXplIGZyb20gJy4uLy4uL3V0aWxzL2NhcGl0YWxpemUnXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCdcblxuY29uc3QgUFJPTUlORU5DRVMgPSB7XG4gIGRlZmF1bHQ6ICcnLFxuICBzdHJvbmc6ICdzdHJvbmcnLFxuICBzdHJvbmdlcjogJ3N0cm9uZ2VyJyxcbiAgd2VhazogJ3dlYWsnLFxufVxuXG50eXBlIFByb21pbmVuY2VQcm9wcyA9IGtleW9mIHR5cGVvZiBQUk9NSU5FTkNFU1xudHlwZSBQbGFjZW1lbnRQcm9wcyA9IENTU1Byb3BlcnRpZXNbJ3RleHRBbGlnbiddXG50eXBlIFdoaXRlU3BhY2VQcm9wcyA9IENTU1Byb3BlcnRpZXNbJ3doaXRlU3BhY2UnXVxudHlwZSBUZXh0VmFyaWFudCA9IGtleW9mIHR5cGVvZiB0eXBvZ3JhcGh5XG5leHBvcnQgY29uc3QgdGV4dFZhcmlhbnRzID0gT2JqZWN0LmtleXModHlwb2dyYXBoeSkgYXMgVGV4dFZhcmlhbnRbXVxuXG4vKipcbiAqIEdlbmVyYXRlIGFsbCBzdHlsZXMgYXZhaWxhYmxlIGZvciB0ZXh0IGJhc2VkIG9uIHByb21pbmVuY2UgYW5kIHZhcmlhbnRzXG4gKi9cbmNvbnN0IGdlbmVyYXRlU3R5bGVzID0gKHtcbiAgcGxhY2VtZW50LFxuICBwcm9taW5lbmNlLFxuICBzZW50aW1lbnQsXG4gIHZhcmlhbnQsXG4gIHRoZW1lLFxuICBvbmVMaW5lLFxuICBkaXNhYmxlZCxcbiAgaXRhbGljLFxuICB1bmRlcmxpbmUsXG4gIHdoaXRlU3BhY2UsXG4gIHN0cmlrZVRocm91Z2gsXG59OiB7XG4gIHBsYWNlbWVudD86IFBsYWNlbWVudFByb3BzXG4gIHByb21pbmVuY2U6IFByb21pbmVuY2VQcm9wc1xuICB0aGVtZTogVGhlbWVcbiAgdmFyaWFudDogVGV4dFZhcmlhbnRcbiAgc2VudGltZW50PzogRXh0ZW5kZWRDb2xvclxuICBvbmVMaW5lOiBib29sZWFuXG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGl0YWxpYzogYm9vbGVhblxuICB1bmRlcmxpbmU6IGJvb2xlYW5cbiAgd2hpdGVTcGFjZT86IFdoaXRlU3BhY2VQcm9wc1xuICBzdHJpa2VUaHJvdWdoPzogYm9vbGVhblxufSk6IHN0cmluZyA9PiB7XG4gIC8vIHN0cm9uZ2VyIGlzIGF2YWlsYWJsZSBvbmx5IGZvciBuZXV0cmFsIHNlbnRpbWVudFxuICBjb25zdCBkZWZpbmVkUHJvbWluZW5jZSA9XG4gICAgc2VudGltZW50ICE9PSAnbmV1dHJhbCcgJiYgcHJvbWluZW5jZSA9PT0gJ3N0cm9uZ2VyJ1xuICAgICAgPyBjYXBpdGFsaXplKFBST01JTkVOQ0VTLmRlZmF1bHQpXG4gICAgICA6IGNhcGl0YWxpemUoUFJPTUlORU5DRVNbcHJvbWluZW5jZV0pXG5cbiAgY29uc3QgaXNTZW50aW1lbnRNb25vY2hyb21lID0gc2VudGltZW50ID09PSAnYmxhY2snIHx8IHNlbnRpbWVudCA9PT0gJ3doaXRlJ1xuXG4gIGNvbnN0IHRoZW1lQ29sb3IgPVxuICAgIHNlbnRpbWVudCAmJiAhaXNTZW50aW1lbnRNb25vY2hyb21lID8gdGhlbWUuY29sb3JzW3NlbnRpbWVudF0gOiB1bmRlZmluZWRcblxuICBjb25zdCB0ZXh0ID0gYHRleHQke2RlZmluZWRQcm9taW5lbmNlfSR7XG4gICAgZGlzYWJsZWQgPyAnRGlzYWJsZWQnIDogJydcbiAgfWAgYXMga2V5b2YgdHlwZW9mIHRoZW1lQ29sb3JcblxuICBjb25zdCB0ZXh0Q29sb3IgPVxuICAgIHNlbnRpbWVudCAmJiAhaXNTZW50aW1lbnRNb25vY2hyb21lXG4gICAgICA/IHRoZW1lLmNvbG9yc1tzZW50aW1lbnRdW3RleHRdXG4gICAgICA6IHVuZGVmaW5lZFxuXG4gIHJldHVybiBgXG4gICAgJHtzZW50aW1lbnQgPyBgY29sb3I6ICR7IWlzU2VudGltZW50TW9ub2Nocm9tZSA/IHRleHRDb2xvciA6IHRoZW1lLmNvbG9ycy5vdGhlci5tb25vY2hyb21lW3NlbnRpbWVudF0udGV4dH07YCA6ICcnfVxuXG4gICAgZm9udC1zaXplOiAke3RoZW1lLnR5cG9ncmFwaHlbdmFyaWFudF0uZm9udFNpemV9O1xuICAgIGZvbnQtZmFtaWx5OiAke3RoZW1lLnR5cG9ncmFwaHlbdmFyaWFudF0uZm9udEZhbWlseX07XG4gICAgZm9udC13ZWlnaHQ6ICR7dGhlbWUudHlwb2dyYXBoeVt2YXJpYW50XS53ZWlnaHR9O1xuICAgIGxldHRlci1zcGFjaW5nOiAke3RoZW1lLnR5cG9ncmFwaHlbdmFyaWFudF0ubGV0dGVyU3BhY2luZ307XG4gICAgbGluZS1oZWlnaHQ6ICR7dGhlbWUudHlwb2dyYXBoeVt2YXJpYW50XS5saW5lSGVpZ2h0fTtcbiAgICB0ZXh0LXRyYW5zZm9ybTogJHt0aGVtZS50eXBvZ3JhcGh5W3ZhcmlhbnRdLnRleHRDYXNlfTtcbiAgICB0ZXh0LWRlY29yYXRpb246ICR7dGhlbWUudHlwb2dyYXBoeVt2YXJpYW50XS50ZXh0RGVjb3JhdGlvbn07XG4gICAgJHtwbGFjZW1lbnQgPyBgIHRleHQtYWxpZ246ICR7cGxhY2VtZW50fTtgIDogJyd9XG4gICAgJHt3aGl0ZVNwYWNlID8gYHdoaXRlLXNwYWNlOiAke3doaXRlU3BhY2V9O2AgOiAnJ31cblxuICAgICR7XG4gICAgICBvbmVMaW5lXG4gICAgICAgID8gYHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgb3ZlcmZsb3c6IGhpZGRlbjtgXG4gICAgICAgIDogJydcbiAgICB9XG4gICAgJHtpdGFsaWMgPyBgZm9udC1zdHlsZTogaXRhbGljO2AgOiAnJ31cbiAgICAke3VuZGVybGluZSA/IGB0ZXh0LWRlY29yYXRpb246IHVuZGVybGluZTtgIDogJyd9XG4gICAgJHtzdHJpa2VUaHJvdWdoID8gYHRleHQtZGVjb3JhdGlvbjogbGluZS10aHJvdWdoO2AgOiAnJ31cbiAgYFxufVxuXG50eXBlIFRleHRQcm9wcyA9IHtcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgcGxhY2VtZW50PzogUGxhY2VtZW50UHJvcHNcbiAgdmFyaWFudDogVGV4dFZhcmlhbnRcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIHVzZSBgc2VudGltZW50YCBwcm9wZXJ0eSBpbnN0ZWFkXG4gICAqL1xuICBjb2xvcj86IENvbG9yXG4gIHNlbnRpbWVudD86IEV4dGVuZGVkQ29sb3JcbiAgcHJvbWluZW5jZT86IFByb21pbmVuY2VQcm9wc1xuICBhczogRWxlbWVudFR5cGVcbiAgb25lTGluZT86IGJvb2xlYW5cbiAgZGlzYWJsZWQ/OiBib29sZWFuXG4gIGl0YWxpYz86IGJvb2xlYW5cbiAgdW5kZXJsaW5lPzogYm9vbGVhblxuICBpZD86IHN0cmluZ1xuICBkaXI/OiAnbHRyJyB8ICdydGwnIHwgJ2F1dG8nXG4gIGh0bWxGb3I/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBzdHJpa2VUaHJvdWdoPzogYm9vbGVhblxuICB3aGl0ZVNwYWNlPzogV2hpdGVTcGFjZVByb3BzXG59XG5cbmNvbnN0IFN0eWxlZFRleHQgPSBzdHlsZWQoJ2RpdicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT5cbiAgICAhW1xuICAgICAgJ2FzJyxcbiAgICAgICdwbGFjZW1lbnQnLFxuICAgICAgJ3ZhcmlhbnQnLFxuICAgICAgJ3NlbnRpbWVudCcsXG4gICAgICAncHJvbWluZW5jZScsXG4gICAgICAnb25lTGluZScsXG4gICAgICAnZGlzYWJsZWQnLFxuICAgICAgJ2l0YWxpYycsXG4gICAgICAndW5kZXJsaW5lJyxcbiAgICAgICdzdHJpa2VUaHJvdWdoJyxcbiAgICAgICd3aGl0ZVNwYWNlJyxcbiAgICBdLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBwbGFjZW1lbnQ/OiBQbGFjZW1lbnRQcm9wc1xuICBzZW50aW1lbnQ/OiBFeHRlbmRlZENvbG9yXG4gIHByb21pbmVuY2U6IFByb21pbmVuY2VQcm9wc1xuICB2YXJpYW50OiBUZXh0VmFyaWFudFxuICBvbmVMaW5lOiBib29sZWFuXG4gIGRpc2FibGVkOiBib29sZWFuXG4gIGl0YWxpYzogYm9vbGVhblxuICB1bmRlcmxpbmU6IGJvb2xlYW5cbiAgaHRtbEZvcj86IHN0cmluZ1xuICBzdHJpa2VUaHJvdWdoPzogYm9vbGVhblxuICB3aGl0ZVNwYWNlPzogV2hpdGVTcGFjZVByb3BzXG59PihnZW5lcmF0ZVN0eWxlcylcblxuLyoqXG4gKiBUZXh0IGNvbXBvbmVudCBpcyB1c2VkIHRvIGRpc3BsYXkgdGV4dCB3aXRoIGRpZmZlcmVudCB2YXJpYW50cyBhbmQgc2VudGltZW50cy5cbiAqL1xuZXhwb3J0IGNvbnN0IFRleHQgPSAoe1xuICB2YXJpYW50LFxuICBjaGlsZHJlbixcbiAgYXMsXG4gIGNvbG9yLFxuICBzZW50aW1lbnQsXG4gIG9uZUxpbmUgPSBmYWxzZSxcbiAgcGxhY2VtZW50LFxuICBwcm9taW5lbmNlID0gJ2RlZmF1bHQnLFxuICBjbGFzc05hbWUsXG4gIGRpc2FibGVkID0gZmFsc2UsXG4gIGl0YWxpYyA9IGZhbHNlLFxuICB1bmRlcmxpbmUgPSBmYWxzZSxcbiAgc3RyaWtlVGhyb3VnaCA9IGZhbHNlLFxuICBpZCxcbiAgZGlyLFxuICB3aGl0ZVNwYWNlLFxuICBodG1sRm9yLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogVGV4dFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbXB1dGVkU2VudGltZW50ID0gc2VudGltZW50ID8/IGNvbG9yXG4gIGNvbnN0IGVsZW1lbnRSZWYgPSB1c2VSZWYobnVsbClcbiAgY29uc3QgaXNPdmVyZmxvd2luZyA9IHVzZUlzT3ZlcmZsb3dpbmcoZWxlbWVudFJlZilcblxuICBjb25zdCBmaW5hbFN0cmluZ0NoaWxkcmVuID0gcmVjdXJzaXZlbHlHZXRDaGlsZHJlblN0cmluZyhjaGlsZHJlbilcblxuICByZXR1cm4gKFxuICAgIDxUb29sdGlwIHRleHQ9e29uZUxpbmUgJiYgaXNPdmVyZmxvd2luZyA/IGZpbmFsU3RyaW5nQ2hpbGRyZW4gOiAnJ30+XG4gICAgICA8U3R5bGVkVGV4dFxuICAgICAgICByZWY9e2VsZW1lbnRSZWZ9XG4gICAgICAgIGFzPXthc31cbiAgICAgICAgcGxhY2VtZW50PXtwbGFjZW1lbnR9XG4gICAgICAgIHByb21pbmVuY2U9e3Byb21pbmVuY2V9XG4gICAgICAgIHNlbnRpbWVudD17Y29tcHV0ZWRTZW50aW1lbnR9XG4gICAgICAgIHZhcmlhbnQ9e3ZhcmlhbnR9XG4gICAgICAgIG9uZUxpbmU9e29uZUxpbmV9XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgIGl0YWxpYz17aXRhbGljfVxuICAgICAgICB1bmRlcmxpbmU9e3VuZGVybGluZX1cbiAgICAgICAgc3RyaWtlVGhyb3VnaD17c3RyaWtlVGhyb3VnaH1cbiAgICAgICAgaWQ9e2lkfVxuICAgICAgICBkaXI9e2Rpcn1cbiAgICAgICAgaHRtbEZvcj17aHRtbEZvcn1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIHdoaXRlU3BhY2U9e3doaXRlU3BhY2V9XG4gICAgICA+XG4gICAgICAgIHtjaGlsZHJlbn1cbiAgICAgIDwvU3R5bGVkVGV4dD5cbiAgICA8L1Rvb2x0aXA+XG4gIClcbn1cbiJdfQ== */");
|
|
61
65
|
const Text = ({
|
|
62
66
|
variant,
|
|
63
67
|
children,
|
|
@@ -71,8 +75,10 @@ const Text = ({
|
|
|
71
75
|
disabled = false,
|
|
72
76
|
italic = false,
|
|
73
77
|
underline = false,
|
|
78
|
+
strikeThrough = false,
|
|
74
79
|
id,
|
|
75
80
|
dir,
|
|
81
|
+
whiteSpace,
|
|
76
82
|
htmlFor,
|
|
77
83
|
"data-testid": dataTestId
|
|
78
84
|
}) => {
|
|
@@ -80,6 +86,6 @@ const Text = ({
|
|
|
80
86
|
const elementRef = React.useRef(null);
|
|
81
87
|
const isOverflowing = useIsOverflowing.useIsOverflowing(elementRef);
|
|
82
88
|
const finalStringChildren = recursivelyGetChildrenString(children);
|
|
83
|
-
return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: oneLine && isOverflowing ? finalStringChildren : "", children: /* @__PURE__ */ jsxRuntime.jsx(StyledText, { ref: elementRef, as, placement, prominence, sentiment: computedSentiment, variant, oneLine, className, disabled, italic, underline, id, dir, htmlFor, "data-testid": dataTestId, children }) });
|
|
89
|
+
return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: oneLine && isOverflowing ? finalStringChildren : "", children: /* @__PURE__ */ jsxRuntime.jsx(StyledText, { ref: elementRef, as, placement, prominence, sentiment: computedSentiment, variant, oneLine, className, disabled, italic, underline, strikeThrough, id, dir, htmlFor, "data-testid": dataTestId, whiteSpace, children }) });
|
|
84
90
|
};
|
|
85
91
|
exports.Text = Text;
|