@ultraviolet/ui 1.53.4 → 1.55.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Card/index.cjs +3 -3
- package/dist/components/Card/index.js +3 -3
- package/dist/components/GlobalAlert/index.d.ts +1 -5
- package/dist/components/Link/index.cjs +14 -10
- package/dist/components/Link/index.d.ts +1 -1
- package/dist/components/Link/index.js +15 -11
- package/dist/components/SelectInputV2/DropdownOption.cjs +23 -22
- package/dist/components/SelectInputV2/DropdownOption.js +10 -9
- package/dist/components/SelectInputV2/types.d.ts +2 -1
- package/dist/components/Stepper/Step.cjs +129 -0
- package/dist/components/Stepper/Step.d.ts +25 -0
- package/dist/components/Stepper/Step.js +127 -0
- package/dist/components/Stepper/StepperProvider.cjs +40 -0
- package/dist/components/Stepper/StepperProvider.d.ts +25 -0
- package/dist/components/Stepper/StepperProvider.js +40 -0
- package/dist/components/Stepper/index.cjs +48 -91
- package/dist/components/Stepper/index.d.ts +24 -5
- package/dist/components/Stepper/index.js +47 -90
- package/dist/components/SwitchButton/index.cjs +22 -17
- package/dist/components/SwitchButton/index.d.ts +2 -1
- package/dist/components/SwitchButton/index.js +22 -17
- package/package.json +5 -5
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import { jsxs, jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import _styled from "@emotion/styled/base";
|
|
3
|
+
import { css, keyframes } from "@emotion/react";
|
|
4
|
+
import { useMemo } from "react";
|
|
5
|
+
import { Bullet } from "../Bullet/index.js";
|
|
6
|
+
import { Stack } from "../Stack/index.js";
|
|
7
|
+
import { Text } from "../Text/index.js";
|
|
8
|
+
import { useStepper } from "./StepperProvider.js";
|
|
9
|
+
const LINE_HEIGHT_SIZES = {
|
|
10
|
+
small: 2,
|
|
11
|
+
medium: 4
|
|
12
|
+
};
|
|
13
|
+
const loadingAnimation = (size) => keyframes`
|
|
14
|
+
from {
|
|
15
|
+
width: 0;
|
|
16
|
+
}
|
|
17
|
+
to {
|
|
18
|
+
width: calc(
|
|
19
|
+
100% - ${size === "small" ? "24px" : "32px"} -
|
|
20
|
+
8px}
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
`;
|
|
24
|
+
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":"AAgDsD","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(\n      100% - ${size === 'small' ? '24px' : '32px'} -\n       8px}\n    );\n  }\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  margin-top: ${({ theme }) => theme.space['1']};\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  'aria-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    &[aria-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    &:not(:last-child) {\n      &:after {\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\n        top: 20px;\n        width: calc(\n          100% - ${({ size }) => (size === 'small' ? '24px' : '32px')} -\n            ${({ theme }) => theme.space[2]}\n        );\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\n      &[aria-selected='true'][data-animated='true']:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n        ${({ size }) => loadingStyle(size)}\n      }\n    }\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '6px' : 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.5}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems={\n        currentState.labelPosition === 'right' ? 'baseline' : 'center'\n      }\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      aria-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.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"]} */");
|
|
25
|
+
const StyledBullet = /* @__PURE__ */ _styled(Bullet, process.env.NODE_ENV === "production" ? {
|
|
26
|
+
target: "ewvv9212"
|
|
27
|
+
} : {
|
|
28
|
+
target: "ewvv9212",
|
|
29
|
+
label: "StyledBullet"
|
|
30
|
+
})("margin-top:", ({
|
|
31
|
+
theme,
|
|
32
|
+
size
|
|
33
|
+
}) => size === "small" ? theme.space["0.5"] : 0, ";transition:box-shadow 300ms;min-width:", ({
|
|
34
|
+
theme,
|
|
35
|
+
size
|
|
36
|
+
}) => size === "small" ? theme.space[3] : theme.space[4], ";", ({
|
|
37
|
+
theme,
|
|
38
|
+
isActive
|
|
39
|
+
}) => isActive ? `background-color: ${theme.colors.primary.backgroundStrongHover};
|
|
40
|
+
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":"AAuDE","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(\n      100% - ${size === 'small' ? '24px' : '32px'} -\n       8px}\n    );\n  }\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  margin-top: ${({ theme }) => theme.space['1']};\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  'aria-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    &[aria-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    &:not(:last-child) {\n      &:after {\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\n        top: 20px;\n        width: calc(\n          100% - ${({ size }) => (size === 'small' ? '24px' : '32px')} -\n            ${({ theme }) => theme.space[2]}\n        );\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\n      &[aria-selected='true'][data-animated='true']:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n        ${({ size }) => loadingStyle(size)}\n      }\n    }\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '6px' : 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.5}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems={\n        currentState.labelPosition === 'right' ? 'baseline' : 'center'\n      }\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      aria-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.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"]} */"));
|
|
41
|
+
const StyledText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
|
|
42
|
+
target: "ewvv9211"
|
|
43
|
+
} : {
|
|
44
|
+
target: "ewvv9211",
|
|
45
|
+
label: "StyledText"
|
|
46
|
+
})("margin-top:", ({
|
|
47
|
+
theme
|
|
48
|
+
}) => theme.space["1"], ";transition:text-decoration-color 250ms ease-out;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:transparent;white-space:normal;" + (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":"AAoE+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(\n      100% - ${size === 'small' ? '24px' : '32px'} -\n       8px}\n    );\n  }\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  margin-top: ${({ theme }) => theme.space['1']};\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  'aria-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    &[aria-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    &:not(:last-child) {\n      &:after {\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\n        top: 20px;\n        width: calc(\n          100% - ${({ size }) => (size === 'small' ? '24px' : '32px')} -\n            ${({ theme }) => theme.space[2]}\n        );\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\n      &[aria-selected='true'][data-animated='true']:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n        ${({ size }) => loadingStyle(size)}\n      }\n    }\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '6px' : 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.5}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems={\n        currentState.labelPosition === 'right' ? 'baseline' : 'center'\n      }\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      aria-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.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
|
+
const StyledStepContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
50
|
+
target: "ewvv9210"
|
|
51
|
+
} : {
|
|
52
|
+
target: "ewvv9210",
|
|
53
|
+
label: "StyledStepContainer"
|
|
54
|
+
})("display:flex;white-space:nowrap;transition:text-decoration 300ms;&[data-interactive='true']:not([data-disabled='true']){cursor:pointer;&[aria-selected='true']:hover{&>", StyledBullet, "{box-shadow:", ({
|
|
55
|
+
theme
|
|
56
|
+
}) => theme.shadows.focusPrimary, ";&>", StyledText, "{color:", ({
|
|
57
|
+
theme
|
|
58
|
+
}) => theme.colors.primary.textHover, ";text-decoration:underline ", ({
|
|
59
|
+
theme
|
|
60
|
+
}) => theme.colors.primary.textHover, ";text-decoration-thickness:1px;}}}&[data-done='true']:hover{&>", StyledBullet, "{box-shadow:", ({
|
|
61
|
+
theme
|
|
62
|
+
}) => theme.shadows.focusPrimary, ";}&>", StyledText, "{color:", ({
|
|
63
|
+
theme
|
|
64
|
+
}) => theme.colors.neutral.textHover, ";text-decoration:underline ", ({
|
|
65
|
+
theme
|
|
66
|
+
}) => theme.colors.neutral.textHover, ";text-decoration-thickness:1px;}}}&[data-disabled='true']{cursor:not-allowed;&>", StyledText, "{color:", ({
|
|
67
|
+
theme
|
|
68
|
+
}) => theme.colors.neutral.textDisabled, ";}&>", StyledBullet, "{background-color:", ({
|
|
69
|
+
theme
|
|
70
|
+
}) => theme.colors.neutral.backgroundDisabled, ";box-shadow:none;color:", ({
|
|
71
|
+
theme
|
|
72
|
+
}) => theme.colors.neutral.textDisabled, ";border-color:", ({
|
|
73
|
+
theme
|
|
74
|
+
}) => theme.colors.neutral.borderDisabled, ";}}&:not([data-hide-separator='true']):not([data-label-position='right']){flex-direction:column;flex:1;&:not(:last-child){&:after{content:'';position:relative;align-self:baseline;border-radius:", ({
|
|
75
|
+
theme
|
|
76
|
+
}) => theme.radii.default, ";background-color:", ({
|
|
77
|
+
theme
|
|
78
|
+
}) => theme.colors.neutral.backgroundStrong, ";top:20px;width:calc(\n 100% - ", ({
|
|
79
|
+
size
|
|
80
|
+
}) => size === "small" ? "24px" : "32px", " -\n ", ({
|
|
81
|
+
theme
|
|
82
|
+
}) => theme.space[2], "\n );left:calc(50% + 25px);order:-1;height:", ({
|
|
83
|
+
size
|
|
84
|
+
}) => size === "small" ? LINE_HEIGHT_SIZES.small : LINE_HEIGHT_SIZES.medium, "px;}&[data-done='true']:after{background-color:", ({
|
|
85
|
+
theme
|
|
86
|
+
}) => theme.colors.primary.backgroundStrong, ";}&[aria-selected='true'][data-animated='true']:after{background-color:", ({
|
|
87
|
+
theme
|
|
88
|
+
}) => theme.colors.primary.backgroundStrong, ";", ({
|
|
89
|
+
size
|
|
90
|
+
}) => loadingStyle(size), ";}}&:last-child{margin-top:", ({
|
|
91
|
+
theme,
|
|
92
|
+
size
|
|
93
|
+
}) => size === "small" ? "6px" : 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":"AAsFE","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(\n      100% - ${size === 'small' ? '24px' : '32px'} -\n       8px}\n    );\n  }\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  margin-top: ${({ theme }) => theme.space['1']};\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  'aria-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    &[aria-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    &:not(:last-child) {\n      &:after {\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\n        top: 20px;\n        width: calc(\n          100% - ${({ size }) => (size === 'small' ? '24px' : '32px')} -\n            ${({ theme }) => theme.space[2]}\n        );\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\n      &[aria-selected='true'][data-animated='true']:after {\n        background-color: ${({ theme }) =>\n          theme.colors.primary.backgroundStrong};\n        ${({ size }) => loadingStyle(size)}\n      }\n    }\n    &:last-child {\n      margin-top: ${({ theme, size }) =>\n        size === 'small' ? '6px' : 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.5}\n      direction={currentState.labelPosition === 'right' ? 'row' : 'column'}\n      alignItems={\n        currentState.labelPosition === 'right' ? 'baseline' : 'center'\n      }\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      aria-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.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"]} */"));
|
|
94
|
+
const Step = ({
|
|
95
|
+
index = 0,
|
|
96
|
+
onClick,
|
|
97
|
+
disabled = false,
|
|
98
|
+
title,
|
|
99
|
+
children,
|
|
100
|
+
className,
|
|
101
|
+
"data-testid": dataTestId
|
|
102
|
+
}) => {
|
|
103
|
+
const currentState = useStepper();
|
|
104
|
+
const isActive = index === currentState.step;
|
|
105
|
+
const isDone = index < currentState.step;
|
|
106
|
+
const textVariant = useMemo(() => {
|
|
107
|
+
if (currentState.size === "medium") {
|
|
108
|
+
return isActive ? "bodyStrong" : "body";
|
|
109
|
+
}
|
|
110
|
+
return isActive ? "bodySmallStrong" : "bodySmall";
|
|
111
|
+
}, [currentState.size, isActive]);
|
|
112
|
+
return /* @__PURE__ */ jsxs(StyledStepContainer, { gap: currentState.labelPosition === "right" ? 1 : 0.5, direction: currentState.labelPosition === "right" ? "row" : "column", alignItems: currentState.labelPosition === "right" ? "baseline" : "center", justifyContent: "flex-start", className: className ?? "step", "data-interactive": currentState.interactive && isDone, onClick: () => {
|
|
113
|
+
if (currentState.interactive && !disabled) {
|
|
114
|
+
if (index < currentState.step) {
|
|
115
|
+
currentState.setStep(index);
|
|
116
|
+
}
|
|
117
|
+
onClick?.(index);
|
|
118
|
+
}
|
|
119
|
+
}, "data-disabled": disabled, "data-testid": dataTestId ?? `stepper-step-${index}`, "data-hide-separator": !currentState.separator, "data-label-position": currentState.labelPosition, size: currentState.size, "aria-selected": isActive, "data-done": isDone, "data-animated": currentState.animated, children: [
|
|
120
|
+
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.toString(), prominence: "strong", size: currentState.size, isActive }),
|
|
121
|
+
title ? /* @__PURE__ */ jsx(StyledText, { as: "span", variant: textVariant, prominence: isDone || isActive ? "default" : "weak", sentiment: isActive ? "primary" : "neutral", children: title }) : null,
|
|
122
|
+
children ?? null
|
|
123
|
+
] });
|
|
124
|
+
};
|
|
125
|
+
export {
|
|
126
|
+
Step
|
|
127
|
+
};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
4
|
+
const React = require("react");
|
|
5
|
+
const StepperContext = React.createContext({
|
|
6
|
+
step: 0,
|
|
7
|
+
setStep: () => {
|
|
8
|
+
},
|
|
9
|
+
interactive: false,
|
|
10
|
+
size: "medium",
|
|
11
|
+
animated: false,
|
|
12
|
+
labelPosition: "bottom",
|
|
13
|
+
separator: true
|
|
14
|
+
});
|
|
15
|
+
const useStepper = () => React.useContext(StepperContext);
|
|
16
|
+
const StepperProvider = ({
|
|
17
|
+
children,
|
|
18
|
+
interactive,
|
|
19
|
+
selected,
|
|
20
|
+
animated,
|
|
21
|
+
labelPosition,
|
|
22
|
+
size,
|
|
23
|
+
separator
|
|
24
|
+
}) => {
|
|
25
|
+
const currentSelected = React.useMemo(() => selected, [selected]);
|
|
26
|
+
const [step, setStep] = React.useState(currentSelected);
|
|
27
|
+
const value = React.useMemo(() => ({
|
|
28
|
+
step,
|
|
29
|
+
setStep,
|
|
30
|
+
interactive,
|
|
31
|
+
size,
|
|
32
|
+
animated,
|
|
33
|
+
labelPosition,
|
|
34
|
+
separator
|
|
35
|
+
}), [step, interactive, size, animated, labelPosition, separator]);
|
|
36
|
+
React.useEffect(() => setStep(selected), [selected]);
|
|
37
|
+
return /* @__PURE__ */ jsxRuntime.jsx(StepperContext.Provider, { value, children });
|
|
38
|
+
};
|
|
39
|
+
exports.StepperProvider = StepperProvider;
|
|
40
|
+
exports.useStepper = useStepper;
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { ReactNode } from 'react';
|
|
2
|
+
type ContextType = {
|
|
3
|
+
step: number;
|
|
4
|
+
setStep: React.Dispatch<React.SetStateAction<number>>;
|
|
5
|
+
interactive: boolean;
|
|
6
|
+
size: 'medium' | 'small';
|
|
7
|
+
animated: boolean;
|
|
8
|
+
labelPosition: 'bottom' | 'right';
|
|
9
|
+
separator: boolean;
|
|
10
|
+
};
|
|
11
|
+
type StepperProviderProps = {
|
|
12
|
+
children: ReactNode;
|
|
13
|
+
interactive: boolean;
|
|
14
|
+
animated: boolean;
|
|
15
|
+
selected: number;
|
|
16
|
+
labelPosition: 'bottom' | 'right';
|
|
17
|
+
size: 'small' | 'medium';
|
|
18
|
+
separator: boolean;
|
|
19
|
+
};
|
|
20
|
+
export declare const useStepper: () => ContextType;
|
|
21
|
+
/**
|
|
22
|
+
* Stepper component to show the progress of a process in a linear way.
|
|
23
|
+
*/
|
|
24
|
+
export declare const StepperProvider: ({ children, interactive, selected, animated, labelPosition, size, separator, }: StepperProviderProps) => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
25
|
+
export {};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { jsx } from "@emotion/react/jsx-runtime";
|
|
2
|
+
import { createContext, useMemo, useState, useEffect, useContext } from "react";
|
|
3
|
+
const StepperContext = createContext({
|
|
4
|
+
step: 0,
|
|
5
|
+
setStep: () => {
|
|
6
|
+
},
|
|
7
|
+
interactive: false,
|
|
8
|
+
size: "medium",
|
|
9
|
+
animated: false,
|
|
10
|
+
labelPosition: "bottom",
|
|
11
|
+
separator: true
|
|
12
|
+
});
|
|
13
|
+
const useStepper = () => useContext(StepperContext);
|
|
14
|
+
const StepperProvider = ({
|
|
15
|
+
children,
|
|
16
|
+
interactive,
|
|
17
|
+
selected,
|
|
18
|
+
animated,
|
|
19
|
+
labelPosition,
|
|
20
|
+
size,
|
|
21
|
+
separator
|
|
22
|
+
}) => {
|
|
23
|
+
const currentSelected = useMemo(() => selected, [selected]);
|
|
24
|
+
const [step, setStep] = useState(currentSelected);
|
|
25
|
+
const value = useMemo(() => ({
|
|
26
|
+
step,
|
|
27
|
+
setStep,
|
|
28
|
+
interactive,
|
|
29
|
+
size,
|
|
30
|
+
animated,
|
|
31
|
+
labelPosition,
|
|
32
|
+
separator
|
|
33
|
+
}), [step, interactive, size, animated, labelPosition, separator]);
|
|
34
|
+
useEffect(() => setStep(selected), [selected]);
|
|
35
|
+
return /* @__PURE__ */ jsx(StepperContext.Provider, { value, children });
|
|
36
|
+
};
|
|
37
|
+
export {
|
|
38
|
+
StepperProvider,
|
|
39
|
+
useStepper
|
|
40
|
+
};
|