@ultraviolet/ui 2.0.4 → 3.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/README.md +10 -6
  2. package/dist/components/Button/constants.cjs +0 -17
  3. package/dist/components/Button/constants.js +1 -18
  4. package/dist/components/Button/index.cjs +18 -187
  5. package/dist/components/Button/index.d.ts +18 -60
  6. package/dist/components/Button/index.js +18 -185
  7. package/dist/components/Button/styles.css.cjs +8 -0
  8. package/dist/components/Button/styles.css.d.ts +82 -0
  9. package/dist/components/Button/styles.css.js +8 -0
  10. package/dist/components/Chip/index.d.ts +1 -1
  11. package/dist/components/Dialog/constants.d.ts +1 -1
  12. package/dist/components/Dialog/index.d.ts +8 -6
  13. package/dist/components/List/index.d.ts +1 -1
  14. package/dist/components/Menu/index.d.ts +1 -1
  15. package/dist/components/SelectInput/Dropdown.cjs +10 -10
  16. package/dist/components/SelectInput/Dropdown.js +10 -10
  17. package/dist/components/SelectInput/SelectBar.cjs +18 -12
  18. package/dist/components/SelectInput/SelectBar.js +19 -13
  19. package/dist/components/Slider/styles.d.ts +1 -1
  20. package/dist/components/Tabs/TabMenuItem.d.ts +1 -1
  21. package/dist/components/Tabs/index.d.ts +2 -2
  22. package/dist/components/Tooltip/index.d.ts +1 -1
  23. package/dist/index.cjs +3 -0
  24. package/dist/index.d.ts +1 -1
  25. package/dist/index.js +3 -0
  26. package/dist/theme/ThemeProvider.cjs +21 -0
  27. package/dist/theme/ThemeProvider.d.ts +737 -0
  28. package/dist/theme/ThemeProvider.js +21 -0
  29. package/dist/theme/index.d.ts +3 -2
  30. package/dist/themes/dist/vanilla/themes.css.js.vanilla.css.cjs +1 -0
  31. package/dist/themes/dist/vanilla/themes.css.js.vanilla.css.js +1 -0
  32. package/dist/themes/dist/vanilla/themes.css.ts.vanilla.css.js.vanilla.css.cjs +1 -0
  33. package/dist/themes/dist/vanilla/themes.css.ts.vanilla.css.js.vanilla.css.js +1 -0
  34. package/dist/ui.css +1 -1
  35. package/package.json +12 -4
@@ -1,188 +1,10 @@
1
1
  "use client";
2
2
  import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
- import { useTheme } from "@emotion/react";
5
3
  import { forwardRef, useMemo } from "react";
6
- import { StyledCircle, Loader } from "../Loader/index.js";
4
+ import { useTheme } from "../../theme/ThemeProvider.js";
5
+ import { Loader } from "../Loader/index.js";
7
6
  import { Tooltip } from "../Tooltip/index.js";
8
- import { SIZE_HEIGHT, SIZE_PADDING_KEY, SIZE_GAP_KEY } from "./constants.js";
9
- const FOCUS_RING_KEY = {
10
- black: "focusNeutral",
11
- danger: "focusDanger",
12
- info: "focusInfo",
13
- neutral: "focusNeutral",
14
- primary: "focusPrimary",
15
- // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine
16
- secondary: "focusPrimary",
17
- success: "focusSuccess",
18
- warning: "focusWarning",
19
- white: "focusNeutral"
20
- };
21
- const isMonochrome = (sentiment) => sentiment === "white" || sentiment === "black";
22
- const coreStyle = ({
23
- theme,
24
- size,
25
- sentiment,
26
- fullWidth,
27
- disabled
28
- }) => {
29
- const font = size === "large" ? theme.typography.bodyStrong : theme.typography.bodySmallStrong;
30
- let width = "auto";
31
- if (fullWidth) {
32
- width = "100%";
33
- }
34
- return `
35
- display: inline-flex;
36
- position: relative;
37
- height: ${theme.sizing[SIZE_HEIGHT[size]]};
38
- padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};
39
- flex-direction: row;
40
- gap: ${theme.space[SIZE_GAP_KEY[size]]};
41
- border-radius: ${theme.radii.default};
42
- box-sizing: border-box;
43
- width: ${width};
44
- align-items: center;
45
- cursor: ${disabled ? "not-allowed" : "pointer"};
46
- justify-content: center;
47
- outline-offset: 2px;
48
- white-space: nowrap;
49
- text-decoration: none;
50
- &:hover {
51
- text-decoration: none;
52
- }
53
-
54
-
55
- ${disabled ? "" : `
56
- &:active {
57
- box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};
58
- }
59
- `}
60
-
61
- /* We can't use Text component because of button hover effect, so we need to duplicate */
62
- font-size: ${font.fontSize};
63
- font-family: ${font.fontFamily};
64
- font-weight: ${font.weight};
65
- letter-spacing: ${font.letterSpacing};
66
- line-height: ${font.lineHeight};
67
- paragraph-spacing: ${font.paragraphSpacing};
68
- text-case: ${font.textCase};
69
- `;
70
- };
71
- const StyledFilledButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
72
- shouldForwardProp: (prop) => !["size", "sentiment", "fullWidth"].includes(prop),
73
- target: "e112qvla2"
74
- } : {
75
- shouldForwardProp: (prop) => !["size", "sentiment", "fullWidth"].includes(prop),
76
- target: "e112qvla2",
77
- label: "StyledFilledButton"
78
- })((args) => coreStyle(args), " ", StyledCircle, "{stroke:transparent;}background:", ({
79
- theme,
80
- sentiment
81
- }) => !isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrong : theme.colors.other.monochrome[sentiment].background, ";border:none;color:", ({
82
- theme,
83
- sentiment
84
- }) => !isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === "white" ? "black" : "white"].text, ";", ({
85
- theme,
86
- sentiment,
87
- disabled
88
- }) => disabled ? `
89
- background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};
90
- color:
91
- ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};
92
- ` : `
93
- &:hover, &:active
94
- {
95
- background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};
96
- color:
97
- ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === "white" ? "black" : "white"].textHover};
98
- }
99
- `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx"],"names":[],"mappings":"AAyGqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader, StyledCircle } from '../Loader'\nimport { Tooltip } from '../Tooltip'\nimport { SIZE_GAP_KEY, SIZE_HEIGHT, SIZE_PADDING_KEY } from './constants'\n\ntype ButtonSize = keyof typeof SIZE_HEIGHT\n\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  black: 'focusNeutral',\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<FinalProps, 'size' | 'sentiment' | 'disabled' | 'fullWidth'>\n>\n\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  fullWidth,\n  disabled,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  }\n\n  return `\n    display: inline-flex;\n    position: relative;\n    height: ${theme.sizing[SIZE_HEIGHT[size]]};\n    padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n    flex-direction: row;\n    gap: ${theme.space[SIZE_GAP_KEY[size]]};\n    border-radius: ${theme.radii.default};\n    box-sizing: border-box;\n    width: ${width};\n    align-items: center;\n    cursor: ${disabled ? 'not-allowed' : 'pointer'};\n    justify-content: center;\n    outline-offset: 2px;\n    white-space: nowrap;\n    text-decoration: none;\n    &:hover {\n      text-decoration: none;\n    }\n\n\n    ${\n      disabled\n        ? ''\n        : `\n            &:active {\n              box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n            }\n          `\n    }\n\n    /* We can't use Text component because of button hover effect, so we need to duplicate */\n    font-size: ${font.fontSize};\n    font-family: ${font.fontFamily};\n    font-weight: ${font.weight};\n    letter-spacing: ${font.letterSpacing};\n    line-height: ${font.lineHeight};\n    paragraph-spacing: ${font.paragraphSpacing};\n    text-case: ${font.textCase};\n  `\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  ${StyledCircle} {\n    stroke: transparent;\n  }\n    \n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n  \n  ${StyledCircle} {\n    stroke: transparent;\n  }\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  ${StyledCircle} {\n    stroke: transparent;\n  }\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n}\n\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  'aria-describedby'?: string\n  'aria-disabled'?: boolean\n  'aria-pressed'?: boolean\n  'aria-roledescription'?: string\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n  onPointerDown?: ButtonHTMLAttributes<HTMLButtonElement>['onPointerDown']\n  onKeyDown?: ButtonHTMLAttributes<HTMLButtonElement>['onKeyDown']\n}\n\ntype FinalProps = CommonProps & {\n  children: ReactNode\n  name?: string\n  href?: string\n  target?: string\n  download?: string\n}\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      onPointerDown,\n      onKeyDown,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      'aria-describedby': ariaDescribedby,\n      'aria-disabled': ariaDisabled,\n      'aria-pressed': ariaPressed,\n      'aria-roledescription': ariaRoledescription,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const { theme } = useTheme()\n    const computedSentimentLoader = useMemo(() => {\n      if (variant === 'filled' && !['black', 'white'].includes(sentiment)) {\n        if (theme === 'light') {\n          return 'white'\n        }\n\n        return 'black'\n      }\n\n      return sentiment\n    }, [sentiment, theme, variant])\n\n    const content = (\n      <>\n        {isLoading ? (\n          <Loader active sentiment={computedSentimentLoader} size=\"small\" />\n        ) : null}\n        {children}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip containerFullWidth={fullWidth} text={tooltip}>\n          <Component\n            aria-controls={ariaControls}\n            aria-current={ariaCurrent}\n            aria-describedby={ariaDescribedby}\n            aria-disabled={ariaDisabled ?? disabled}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            aria-label={ariaLabel}\n            aria-pressed={ariaPressed}\n            aria-roledescription={ariaRoledescription}\n            autoFocus={autoFocus}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            download={download}\n            fullWidth={fullWidth}\n            href={href}\n            onClick={onClick}\n            onMouseDown={onMouseDown}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n            onMouseOut={onMouseOut}\n            onMouseUp={onMouseUp}\n            ref={ref as Ref<HTMLAnchorElement>}\n            role={role}\n            sentiment={sentiment}\n            size={size}\n            tabIndex={tabIndex}\n            target={target}\n            type={type}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip containerFullWidth={fullWidth} text={tooltip}>\n        <Component\n          aria-controls={ariaControls}\n          aria-current={ariaCurrent}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          aria-label={ariaLabel}\n          autoFocus={autoFocus}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          name={name}\n          onClick={onClick}\n          onKeyDown={onKeyDown}\n          onMouseDown={onMouseDown}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          onMouseOut={onMouseOut}\n          onMouseUp={onMouseUp}\n          onPointerDown={onPointerDown}\n          ref={ref as Ref<HTMLButtonElement>}\n          role={role}\n          sentiment={sentiment}\n          size={size}\n          tabIndex={tabIndex}\n          type={type}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
100
- const StyledOutlinedButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
101
- shouldForwardProp: (prop) => !["size", "sentiment", "fullWidth"].includes(prop),
102
- target: "e112qvla1"
103
- } : {
104
- shouldForwardProp: (prop) => !["size", "sentiment", "fullWidth"].includes(prop),
105
- target: "e112qvla1",
106
- label: "StyledOutlinedButton"
107
- })((args) => coreStyle(args), " ", StyledCircle, "{stroke:transparent;}background:none;border:1px solid ", ({
108
- theme,
109
- sentiment
110
- }) => !isMonochrome(sentiment) ? theme.colors[sentiment][sentiment === "neutral" ? "borderStrong" : "border"] : theme.colors.other.monochrome[sentiment].border, ";color:", ({
111
- theme,
112
- sentiment
113
- }) => !isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text, ";", ({
114
- theme,
115
- sentiment,
116
- disabled
117
- }) => disabled ? `
118
- color:
119
- ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};
120
- border: 1px solid ${!isMonochrome(sentiment) ? theme.colors[sentiment][sentiment === "neutral" ? "borderStrongDisabled" : "borderDisabled"] : theme.colors.other.monochrome[sentiment].borderDisabled};
121
-
122
- ` : `
123
- &:hover, &:active
124
- {
125
- background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};
126
- color:
127
- ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === "white" ? "black" : "white"].textHover};
128
- border: 1px solid ${!isMonochrome(sentiment) ? theme.colors[sentiment][sentiment === "neutral" ? "borderStrongHover" : "borderHover"] : theme.colors.other.monochrome[sentiment].borderHover};
129
-
130
- }
131
- `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx"],"names":[],"mappings":"AA0IqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader, StyledCircle } from '../Loader'\nimport { Tooltip } from '../Tooltip'\nimport { SIZE_GAP_KEY, SIZE_HEIGHT, SIZE_PADDING_KEY } from './constants'\n\ntype ButtonSize = keyof typeof SIZE_HEIGHT\n\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  black: 'focusNeutral',\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<FinalProps, 'size' | 'sentiment' | 'disabled' | 'fullWidth'>\n>\n\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  fullWidth,\n  disabled,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  }\n\n  return `\n    display: inline-flex;\n    position: relative;\n    height: ${theme.sizing[SIZE_HEIGHT[size]]};\n    padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n    flex-direction: row;\n    gap: ${theme.space[SIZE_GAP_KEY[size]]};\n    border-radius: ${theme.radii.default};\n    box-sizing: border-box;\n    width: ${width};\n    align-items: center;\n    cursor: ${disabled ? 'not-allowed' : 'pointer'};\n    justify-content: center;\n    outline-offset: 2px;\n    white-space: nowrap;\n    text-decoration: none;\n    &:hover {\n      text-decoration: none;\n    }\n\n\n    ${\n      disabled\n        ? ''\n        : `\n            &:active {\n              box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n            }\n          `\n    }\n\n    /* We can't use Text component because of button hover effect, so we need to duplicate */\n    font-size: ${font.fontSize};\n    font-family: ${font.fontFamily};\n    font-weight: ${font.weight};\n    letter-spacing: ${font.letterSpacing};\n    line-height: ${font.lineHeight};\n    paragraph-spacing: ${font.paragraphSpacing};\n    text-case: ${font.textCase};\n  `\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  ${StyledCircle} {\n    stroke: transparent;\n  }\n    \n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n  \n  ${StyledCircle} {\n    stroke: transparent;\n  }\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  ${StyledCircle} {\n    stroke: transparent;\n  }\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n}\n\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  'aria-describedby'?: string\n  'aria-disabled'?: boolean\n  'aria-pressed'?: boolean\n  'aria-roledescription'?: string\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n  onPointerDown?: ButtonHTMLAttributes<HTMLButtonElement>['onPointerDown']\n  onKeyDown?: ButtonHTMLAttributes<HTMLButtonElement>['onKeyDown']\n}\n\ntype FinalProps = CommonProps & {\n  children: ReactNode\n  name?: string\n  href?: string\n  target?: string\n  download?: string\n}\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      onPointerDown,\n      onKeyDown,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      'aria-describedby': ariaDescribedby,\n      'aria-disabled': ariaDisabled,\n      'aria-pressed': ariaPressed,\n      'aria-roledescription': ariaRoledescription,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const { theme } = useTheme()\n    const computedSentimentLoader = useMemo(() => {\n      if (variant === 'filled' && !['black', 'white'].includes(sentiment)) {\n        if (theme === 'light') {\n          return 'white'\n        }\n\n        return 'black'\n      }\n\n      return sentiment\n    }, [sentiment, theme, variant])\n\n    const content = (\n      <>\n        {isLoading ? (\n          <Loader active sentiment={computedSentimentLoader} size=\"small\" />\n        ) : null}\n        {children}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip containerFullWidth={fullWidth} text={tooltip}>\n          <Component\n            aria-controls={ariaControls}\n            aria-current={ariaCurrent}\n            aria-describedby={ariaDescribedby}\n            aria-disabled={ariaDisabled ?? disabled}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            aria-label={ariaLabel}\n            aria-pressed={ariaPressed}\n            aria-roledescription={ariaRoledescription}\n            autoFocus={autoFocus}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            download={download}\n            fullWidth={fullWidth}\n            href={href}\n            onClick={onClick}\n            onMouseDown={onMouseDown}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n            onMouseOut={onMouseOut}\n            onMouseUp={onMouseUp}\n            ref={ref as Ref<HTMLAnchorElement>}\n            role={role}\n            sentiment={sentiment}\n            size={size}\n            tabIndex={tabIndex}\n            target={target}\n            type={type}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip containerFullWidth={fullWidth} text={tooltip}>\n        <Component\n          aria-controls={ariaControls}\n          aria-current={ariaCurrent}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          aria-label={ariaLabel}\n          autoFocus={autoFocus}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          name={name}\n          onClick={onClick}\n          onKeyDown={onKeyDown}\n          onMouseDown={onMouseDown}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          onMouseOut={onMouseOut}\n          onMouseUp={onMouseUp}\n          onPointerDown={onPointerDown}\n          ref={ref as Ref<HTMLButtonElement>}\n          role={role}\n          sentiment={sentiment}\n          size={size}\n          tabIndex={tabIndex}\n          type={type}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
132
- const StyledGhostButton = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
133
- shouldForwardProp: (prop) => !["size", "sentiment", "fullWidth"].includes(prop),
134
- target: "e112qvla0"
135
- } : {
136
- shouldForwardProp: (prop) => !["size", "sentiment", "fullWidth"].includes(prop),
137
- target: "e112qvla0",
138
- label: "StyledGhostButton"
139
- })((args) => coreStyle(args), " ", StyledCircle, "{stroke:transparent;}background:none;border:none;color:", ({
140
- theme,
141
- sentiment
142
- }) => !isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text, ";", ({
143
- theme,
144
- sentiment,
145
- disabled
146
- }) => disabled ? `
147
- color:
148
- ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};
149
- ` : `
150
- &:hover, &:active
151
- {
152
- background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};
153
- color:
154
- ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === "white" ? "black" : "white"].textHover};
155
- }
156
- `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx"],"names":[],"mappings":"AAiMqB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Button/index.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport type {\n  AriaRole,\n  ButtonHTMLAttributes,\n  MouseEventHandler,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useMemo } from 'react'\nimport type { ExtendedColor } from '../../theme'\nimport { Loader, StyledCircle } from '../Loader'\nimport { Tooltip } from '../Tooltip'\nimport { SIZE_GAP_KEY, SIZE_HEIGHT, SIZE_PADDING_KEY } from './constants'\n\ntype ButtonSize = keyof typeof SIZE_HEIGHT\n\nexport const buttonSizes = Object.keys(SIZE_HEIGHT) as ButtonSize[]\n\n// FOCUS RING\nconst FOCUS_RING_KEY = {\n  black: 'focusNeutral',\n  danger: 'focusDanger',\n  info: 'focusInfo',\n  neutral: 'focusNeutral',\n  primary: 'focusPrimary',\n  // @note: no focusSecondary so far, it will be added later, so far focusPrimary sounds fine\n  secondary: 'focusPrimary',\n  success: 'focusSuccess',\n  warning: 'focusWarning',\n  white: 'focusNeutral',\n} as const\n\nconst isMonochrome = (sentiment: ExtendedColor) =>\n  sentiment === 'white' || sentiment === 'black'\n\n// VARIANTS\ntype StyledButtonProps = Required<\n  Pick<FinalProps, 'size' | 'sentiment' | 'disabled' | 'fullWidth'>\n>\n\nconst coreStyle = ({\n  theme,\n  size,\n  sentiment,\n  fullWidth,\n  disabled,\n}: { theme: Theme } & StyledButtonProps) => {\n  const font =\n    size === 'large'\n      ? theme.typography.bodyStrong\n      : theme.typography.bodySmallStrong\n\n  let width = 'auto'\n  if (fullWidth) {\n    width = '100%'\n  }\n\n  return `\n    display: inline-flex;\n    position: relative;\n    height: ${theme.sizing[SIZE_HEIGHT[size]]};\n    padding: 0 ${theme.space[SIZE_PADDING_KEY[size]]};\n    flex-direction: row;\n    gap: ${theme.space[SIZE_GAP_KEY[size]]};\n    border-radius: ${theme.radii.default};\n    box-sizing: border-box;\n    width: ${width};\n    align-items: center;\n    cursor: ${disabled ? 'not-allowed' : 'pointer'};\n    justify-content: center;\n    outline-offset: 2px;\n    white-space: nowrap;\n    text-decoration: none;\n    &:hover {\n      text-decoration: none;\n    }\n\n\n    ${\n      disabled\n        ? ''\n        : `\n            &:active {\n              box-shadow: ${theme.shadows[FOCUS_RING_KEY[sentiment]]};\n            }\n          `\n    }\n\n    /* We can't use Text component because of button hover effect, so we need to duplicate */\n    font-size: ${font.fontSize};\n    font-family: ${font.fontFamily};\n    font-weight: ${font.weight};\n    letter-spacing: ${font.letterSpacing};\n    line-height: ${font.lineHeight};\n    paragraph-spacing: ${font.paragraphSpacing};\n    text-case: ${font.textCase};\n  `\n}\n\nconst StyledFilledButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  ${StyledCircle} {\n    stroke: transparent;\n  }\n    \n  background: ${({ theme, sentiment }) =>\n    !isMonochrome(sentiment)\n      ? theme.colors[sentiment].backgroundStrong\n      : theme.colors.other.monochrome[sentiment].background};\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].textStrong : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongDisabled : theme.colors.other.monochrome[sentiment].backgroundDisabled};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        `\n      : `\n            &:hover, &:active\n            {\n                background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundStrongHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n                color:\n                ${!isMonochrome(sentiment) ? theme.colors[sentiment].textStrongHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            }\n  `}\n`\n\nconst StyledOutlinedButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n  \n  ${StyledCircle} {\n    stroke: transparent;\n  }\n\n  background: none;\n  border: 1px solid\n    ${({ theme, sentiment }) =>\n      !isMonochrome(sentiment)\n        ? theme.colors[sentiment][\n            sentiment === 'neutral' ? 'borderStrong' : 'border'\n          ]\n        : theme.colors.other.monochrome[sentiment].border};\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n        border: 1px solid ${\n          !isMonochrome(sentiment)\n            ? theme.colors[sentiment][\n                sentiment === 'neutral'\n                  ? 'borderStrongDisabled'\n                  : 'borderDisabled'\n              ]\n            : theme.colors.other.monochrome[sentiment].borderDisabled\n        };\n\n    `\n      : `\n        &:hover, &:active\n       {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n            ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n            border: 1px solid ${\n              !isMonochrome(sentiment)\n                ? theme.colors[sentiment][\n                    sentiment === 'neutral'\n                      ? 'borderStrongHover'\n                      : 'borderHover'\n                  ]\n                : theme.colors.other.monochrome[sentiment].borderHover\n            };\n\n        }\n`};\n`\n\nconst StyledGhostButton = styled('button', {\n  shouldForwardProp: prop => !['size', 'sentiment', 'fullWidth'].includes(prop),\n})<StyledButtonProps>`\n  ${args => coreStyle(args)}\n\n  ${StyledCircle} {\n    stroke: transparent;\n  }\n\n  background: none;\n  border: none;\n  color: ${({ theme, sentiment }) => (!isMonochrome(sentiment) ? theme.colors[sentiment].text : theme.colors.other.monochrome[sentiment].text)};\n\n  ${({ theme, sentiment, disabled }) =>\n    disabled\n      ? `\n        color:\n          ${!isMonochrome(sentiment) ? theme.colors[sentiment].textDisabled : theme.colors.other.monochrome[sentiment].textDisabled};\n      `\n      : `\n        &:hover, &:active\n        {\n            background: ${!isMonochrome(sentiment) ? theme.colors[sentiment].backgroundHover : theme.colors.other.monochrome[sentiment].backgroundHover};\n            color:\n              ${!isMonochrome(sentiment) ? theme.colors[sentiment].textHover : theme.colors.other.monochrome[sentiment === 'white' ? 'black' : 'white'].textHover};\n        }\n`}\n`\n\nconst VARIANTS_COMPONENTS = {\n  filled: {\n    button: StyledFilledButton,\n    link: StyledFilledButton.withComponent('a'),\n  },\n  ghost: {\n    button: StyledGhostButton,\n    link: StyledGhostButton.withComponent('a'),\n  },\n  outlined: {\n    button: StyledOutlinedButton,\n    link: StyledOutlinedButton.withComponent('a'),\n  },\n}\n\ntype ButtonVariant = keyof typeof VARIANTS_COMPONENTS\nexport const buttonVariants = Object.keys(\n  VARIANTS_COMPONENTS,\n) as ButtonVariant[]\n\ntype CommonProps = {\n  type?: ButtonHTMLAttributes<HTMLButtonElement>['type']\n  autoFocus?: ButtonHTMLAttributes<HTMLButtonElement>['autoFocus']\n  variant?: ButtonVariant\n  role?: AriaRole\n  size?: ButtonSize\n  className?: string\n  'data-testid'?: string\n  sentiment?: ExtendedColor\n  disabled?: boolean\n  fullWidth?: boolean\n  isLoading?: boolean\n  'aria-label'?: string\n  'aria-current'?: boolean\n  'aria-controls'?: string\n  'aria-expanded'?: boolean\n  'aria-haspopup'?: boolean\n  'aria-describedby'?: string\n  'aria-disabled'?: boolean\n  'aria-pressed'?: boolean\n  'aria-roledescription'?: string\n  onClick?: MouseEventHandler<HTMLElement>\n  tooltip?: string\n  tabIndex?: ButtonHTMLAttributes<HTMLButtonElement>['tabIndex']\n  onMouseDown?: MouseEventHandler<HTMLElement>\n  onMouseUp?: MouseEventHandler<HTMLElement>\n  onMouseOut?: MouseEventHandler<HTMLElement>\n  onMouseEnter?: MouseEventHandler<HTMLElement>\n  onMouseLeave?: MouseEventHandler<HTMLElement>\n  onPointerDown?: ButtonHTMLAttributes<HTMLButtonElement>['onPointerDown']\n  onKeyDown?: ButtonHTMLAttributes<HTMLButtonElement>['onKeyDown']\n}\n\ntype FinalProps = CommonProps & {\n  children: ReactNode\n  name?: string\n  href?: string\n  target?: string\n  download?: string\n}\n\n/**\n * Button component is used to trigger an action or event, such as submitting a form, opening a dialog,\n * canceling an action, or performing a delete operation.\n */\nexport const Button = forwardRef<Element, FinalProps>(\n  (\n    {\n      type = 'button',\n      className,\n      'data-testid': dataTestId,\n      sentiment = 'primary',\n      variant = 'filled',\n      size = 'large',\n      disabled = false,\n      fullWidth = false,\n      isLoading = false,\n      children,\n      onClick,\n      onMouseDown,\n      onMouseUp,\n      onMouseOut,\n      onMouseEnter,\n      onMouseLeave,\n      onPointerDown,\n      onKeyDown,\n      name,\n      'aria-label': ariaLabel,\n      'aria-current': ariaCurrent,\n      'aria-controls': ariaControls,\n      'aria-expanded': ariaExpanded,\n      'aria-haspopup': ariaHaspopup,\n      'aria-describedby': ariaDescribedby,\n      'aria-disabled': ariaDisabled,\n      'aria-pressed': ariaPressed,\n      'aria-roledescription': ariaRoledescription,\n      href,\n      download,\n      target,\n      role,\n      tooltip,\n      tabIndex,\n      autoFocus,\n    },\n    ref,\n  ) => {\n    const computeIsDisabled = disabled || isLoading\n    const { theme } = useTheme()\n    const computedSentimentLoader = useMemo(() => {\n      if (variant === 'filled' && !['black', 'white'].includes(sentiment)) {\n        if (theme === 'light') {\n          return 'white'\n        }\n\n        return 'black'\n      }\n\n      return sentiment\n    }, [sentiment, theme, variant])\n\n    const content = (\n      <>\n        {isLoading ? (\n          <Loader active sentiment={computedSentimentLoader} size=\"small\" />\n        ) : null}\n        {children}\n      </>\n    )\n\n    // @note: an anchor can't be disabled\n    if (href && !computeIsDisabled) {\n      const Component = VARIANTS_COMPONENTS[variant].link\n\n      return (\n        <Tooltip containerFullWidth={fullWidth} text={tooltip}>\n          <Component\n            aria-controls={ariaControls}\n            aria-current={ariaCurrent}\n            aria-describedby={ariaDescribedby}\n            aria-disabled={ariaDisabled ?? disabled}\n            aria-expanded={ariaExpanded}\n            aria-haspopup={ariaHaspopup}\n            aria-label={ariaLabel}\n            aria-pressed={ariaPressed}\n            aria-roledescription={ariaRoledescription}\n            autoFocus={autoFocus}\n            className={className}\n            data-testid={dataTestId}\n            disabled={false}\n            download={download}\n            fullWidth={fullWidth}\n            href={href}\n            onClick={onClick}\n            onMouseDown={onMouseDown}\n            onMouseEnter={onMouseEnter}\n            onMouseLeave={onMouseLeave}\n            onMouseOut={onMouseOut}\n            onMouseUp={onMouseUp}\n            ref={ref as Ref<HTMLAnchorElement>}\n            role={role}\n            sentiment={sentiment}\n            size={size}\n            tabIndex={tabIndex}\n            target={target}\n            type={type}\n          >\n            {content}\n          </Component>\n        </Tooltip>\n      )\n    }\n\n    const Component = VARIANTS_COMPONENTS[variant].button\n\n    return (\n      <Tooltip containerFullWidth={fullWidth} text={tooltip}>\n        <Component\n          aria-controls={ariaControls}\n          aria-current={ariaCurrent}\n          aria-expanded={ariaExpanded}\n          aria-haspopup={ariaHaspopup}\n          aria-label={ariaLabel}\n          autoFocus={autoFocus}\n          className={className}\n          data-testid={dataTestId}\n          disabled={computeIsDisabled}\n          fullWidth={fullWidth}\n          name={name}\n          onClick={onClick}\n          onKeyDown={onKeyDown}\n          onMouseDown={onMouseDown}\n          onMouseEnter={onMouseEnter}\n          onMouseLeave={onMouseLeave}\n          onMouseOut={onMouseOut}\n          onMouseUp={onMouseUp}\n          onPointerDown={onPointerDown}\n          ref={ref as Ref<HTMLButtonElement>}\n          role={role}\n          sentiment={sentiment}\n          size={size}\n          tabIndex={tabIndex}\n          type={type}\n        >\n          {content}\n        </Component>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
157
- const VARIANTS_COMPONENTS = {
158
- filled: {
159
- button: StyledFilledButton,
160
- link: StyledFilledButton.withComponent("a", process.env.NODE_ENV === "production" ? {
161
- target: "e112qvla3"
162
- } : {
163
- target: "e112qvla3",
164
- label: "link"
165
- })
166
- },
167
- ghost: {
168
- button: StyledGhostButton,
169
- link: StyledGhostButton.withComponent("a", process.env.NODE_ENV === "production" ? {
170
- target: "e112qvla4"
171
- } : {
172
- target: "e112qvla4",
173
- label: "link"
174
- })
175
- },
176
- outlined: {
177
- button: StyledOutlinedButton,
178
- link: StyledOutlinedButton.withComponent("a", process.env.NODE_ENV === "production" ? {
179
- target: "e112qvla5"
180
- } : {
181
- target: "e112qvla5",
182
- label: "link"
183
- })
184
- }
185
- };
7
+ import { button } from "./styles.css.js";
186
8
  const Button = forwardRef(({
187
9
  type = "button",
188
10
  className,
@@ -198,6 +20,7 @@ const Button = forwardRef(({
198
20
  onMouseDown,
199
21
  onMouseUp,
200
22
  onMouseOut,
23
+ onBlur,
201
24
  onMouseEnter,
202
25
  onMouseLeave,
203
26
  onPointerDown,
@@ -238,11 +61,21 @@ const Button = forwardRef(({
238
61
  children
239
62
  ] });
240
63
  if (href && !computeIsDisabled) {
241
- const Component2 = VARIANTS_COMPONENTS[variant].link;
242
- return /* @__PURE__ */ jsx(Tooltip, { containerFullWidth: fullWidth, text: tooltip, children: /* @__PURE__ */ jsx(Component2, { "aria-controls": ariaControls, "aria-current": ariaCurrent, "aria-describedby": ariaDescribedby, "aria-disabled": ariaDisabled ?? disabled, "aria-expanded": ariaExpanded, "aria-haspopup": ariaHaspopup, "aria-label": ariaLabel, "aria-pressed": ariaPressed, "aria-roledescription": ariaRoledescription, autoFocus, className, "data-testid": dataTestId, disabled: false, download, fullWidth, href, onClick, onMouseDown, onMouseEnter, onMouseLeave, onMouseOut, onMouseUp, ref, role, sentiment, size, tabIndex, target, type, children: content }) });
64
+ return /* @__PURE__ */ jsx(Tooltip, { containerFullWidth: fullWidth, text: tooltip, children: /* @__PURE__ */ jsx("a", { "aria-controls": ariaControls, "aria-current": ariaCurrent, "aria-describedby": ariaDescribedby, "aria-disabled": ariaDisabled ?? disabled, "aria-expanded": ariaExpanded, "aria-haspopup": ariaHaspopup, "aria-label": ariaLabel, "aria-pressed": ariaPressed, "aria-roledescription": ariaRoledescription, autoFocus, className: `${className ?? ""} ${button({
65
+ disabled,
66
+ fullWidth,
67
+ sentiment,
68
+ size,
69
+ variant
70
+ })}`, "data-testid": dataTestId, download, href, onBlur, onClick, onMouseDown, onMouseEnter, onMouseLeave, onMouseOut, onMouseUp, ref, role, tabIndex, target, type, children: content }) });
243
71
  }
244
- const Component = VARIANTS_COMPONENTS[variant].button;
245
- return /* @__PURE__ */ jsx(Tooltip, { containerFullWidth: fullWidth, text: tooltip, children: /* @__PURE__ */ jsx(Component, { "aria-controls": ariaControls, "aria-current": ariaCurrent, "aria-expanded": ariaExpanded, "aria-haspopup": ariaHaspopup, "aria-label": ariaLabel, autoFocus, className, "data-testid": dataTestId, disabled: computeIsDisabled, fullWidth, name, onClick, onKeyDown, onMouseDown, onMouseEnter, onMouseLeave, onMouseOut, onMouseUp, onPointerDown, ref, role, sentiment, size, tabIndex, type, children: content }) });
72
+ return /* @__PURE__ */ jsx(Tooltip, { containerFullWidth: fullWidth, text: tooltip, children: /* @__PURE__ */ jsx("button", { "aria-controls": ariaControls, "aria-current": ariaCurrent, "aria-expanded": ariaExpanded, "aria-haspopup": ariaHaspopup, "aria-label": ariaLabel, autoFocus, className: `${className ?? ""} ${button({
73
+ disabled,
74
+ fullWidth,
75
+ sentiment,
76
+ size,
77
+ variant
78
+ })}`, "data-testid": dataTestId, disabled: computeIsDisabled, name, onBlur, onClick, onKeyDown, onMouseDown, onMouseEnter, onMouseLeave, onMouseOut, onMouseUp, onPointerDown, ref, role, tabIndex, type, children: content }) });
246
79
  });
247
80
  export {
248
81
  Button
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ require("../../themes/dist/vanilla/themes.css.ts.vanilla.css.js.vanilla.css.cjs");
4
+ require("../../themes/dist/vanilla/themes.css.js.vanilla.css.cjs");
5
+ ;/* empty css */
6
+ const createRuntimeFn = require("@vanilla-extract/recipes/createRuntimeFn");
7
+ var button = createRuntimeFn.createRuntimeFn({ defaultClassName: "uv_e1wcoe0", variantClassNames: { size: { large: "uv_e1wcoe1", medium: "uv_e1wcoe2", small: "uv_e1wcoe3", xsmall: "uv_e1wcoe4" }, fullWidth: { true: "uv_e1wcoe5", false: "uv_e1wcoe6" }, sentiment: { primary: "uv_e1wcoe7", secondary: "uv_e1wcoe8", danger: "uv_e1wcoe9", info: "uv_e1wcoea", success: "uv_e1wcoeb", warning: "uv_e1wcoec", neutral: "uv_e1wcoed", black: "uv_e1wcoee", white: "uv_e1wcoef" }, variant: { filled: "uv_e1wcoeg", outlined: "uv_e1wcoeh", ghost: "uv_e1wcoei" }, disabled: { true: "uv_e1wcoej", false: "uv_e1wcoek" } }, defaultVariants: { size: "large", fullWidth: false, disabled: false, variant: "filled", sentiment: "primary" }, compoundVariants: [[{ variant: "filled", sentiment: "primary" }, "uv_e1wcoel"], [{ variant: "filled", sentiment: "secondary" }, "uv_e1wcoem"], [{ variant: "filled", sentiment: "danger" }, "uv_e1wcoen"], [{ variant: "filled", sentiment: "info" }, "uv_e1wcoeo"], [{ variant: "filled", sentiment: "success" }, "uv_e1wcoep"], [{ variant: "filled", sentiment: "warning" }, "uv_e1wcoeq"], [{ variant: "filled", sentiment: "neutral" }, "uv_e1wcoer"], [{ variant: "filled", sentiment: "black" }, "uv_e1wcoes"], [{ variant: "filled", sentiment: "white" }, "uv_e1wcoet"], [{ variant: "outlined", sentiment: "primary" }, "uv_e1wcoeu"], [{ variant: "outlined", sentiment: "secondary" }, "uv_e1wcoev"], [{ variant: "outlined", sentiment: "danger" }, "uv_e1wcoew"], [{ variant: "outlined", sentiment: "info" }, "uv_e1wcoex"], [{ variant: "outlined", sentiment: "success" }, "uv_e1wcoey"], [{ variant: "outlined", sentiment: "warning" }, "uv_e1wcoez"], [{ variant: "outlined", sentiment: "neutral" }, "uv_e1wcoe10"], [{ variant: "outlined", sentiment: "black" }, "uv_e1wcoe11"], [{ variant: "outlined", sentiment: "white" }, "uv_e1wcoe12"], [{ variant: "ghost", sentiment: "primary" }, "uv_e1wcoe13"], [{ variant: "ghost", sentiment: "secondary" }, "uv_e1wcoe14"], [{ variant: "ghost", sentiment: "danger" }, "uv_e1wcoe15"], [{ variant: "ghost", sentiment: "info" }, "uv_e1wcoe16"], [{ variant: "ghost", sentiment: "success" }, "uv_e1wcoe17"], [{ variant: "ghost", sentiment: "warning" }, "uv_e1wcoe18"], [{ variant: "ghost", sentiment: "neutral" }, "uv_e1wcoe19"], [{ variant: "ghost", sentiment: "black" }, "uv_e1wcoe1a"], [{ variant: "ghost", sentiment: "white" }, "uv_e1wcoe1b"]] });
8
+ exports.button = button;
@@ -0,0 +1,82 @@
1
+ import type { RecipeVariants } from '@vanilla-extract/recipes';
2
+ export declare const button: import("@vanilla-extract/recipes").RuntimeFn<{
3
+ size: {
4
+ large: {
5
+ fontSize: `var(--${string})`;
6
+ fontFamily: `var(--${string})`;
7
+ fontWeight: `var(--${string})`;
8
+ letterSpacing: `var(--${string})`;
9
+ lineHeight: `var(--${string})`;
10
+ height: `var(--${string})`;
11
+ paddingLeft: `var(--${string})`;
12
+ paddingRight: `var(--${string})`;
13
+ gap: `var(--${string})`;
14
+ };
15
+ medium: {
16
+ fontSize: `var(--${string})`;
17
+ fontFamily: `var(--${string})`;
18
+ fontWeight: `var(--${string})`;
19
+ letterSpacing: `var(--${string})`;
20
+ lineHeight: `var(--${string})`;
21
+ height: `var(--${string})`;
22
+ paddingLeft: `var(--${string})`;
23
+ paddingRight: `var(--${string})`;
24
+ gap: `var(--${string})`;
25
+ };
26
+ small: {
27
+ fontSize: `var(--${string})`;
28
+ fontFamily: `var(--${string})`;
29
+ fontWeight: `var(--${string})`;
30
+ letterSpacing: `var(--${string})`;
31
+ lineHeight: `var(--${string})`;
32
+ height: `var(--${string})`;
33
+ paddingLeft: `var(--${string})`;
34
+ paddingRight: `var(--${string})`;
35
+ gap: `var(--${string})`;
36
+ };
37
+ xsmall: {
38
+ fontSize: `var(--${string})`;
39
+ fontFamily: `var(--${string})`;
40
+ fontWeight: `var(--${string})`;
41
+ letterSpacing: `var(--${string})`;
42
+ lineHeight: `var(--${string})`;
43
+ height: `var(--${string})`;
44
+ paddingLeft: `var(--${string})`;
45
+ paddingRight: `var(--${string})`;
46
+ gap: `var(--${string})`;
47
+ };
48
+ };
49
+ fullWidth: {
50
+ true: {
51
+ width: "100%";
52
+ };
53
+ false: {
54
+ width: "auto";
55
+ };
56
+ };
57
+ sentiment: {
58
+ primary: {};
59
+ secondary: {};
60
+ danger: {};
61
+ info: {};
62
+ success: {};
63
+ warning: {};
64
+ neutral: {};
65
+ black: {};
66
+ white: {};
67
+ };
68
+ variant: {
69
+ filled: {};
70
+ outlined: {};
71
+ ghost: {};
72
+ };
73
+ disabled: {
74
+ true: {
75
+ cursor: "not-allowed";
76
+ };
77
+ false: {
78
+ cursor: "pointer";
79
+ };
80
+ };
81
+ }>;
82
+ export type ButtonVariants = NonNullable<RecipeVariants<typeof button>>;
@@ -0,0 +1,8 @@
1
+ import "../../themes/dist/vanilla/themes.css.ts.vanilla.css.js.vanilla.css.js";
2
+ import "../../themes/dist/vanilla/themes.css.js.vanilla.css.js";
3
+ /* empty css */
4
+ import { createRuntimeFn } from "@vanilla-extract/recipes/createRuntimeFn";
5
+ var button = createRuntimeFn({ defaultClassName: "uv_e1wcoe0", variantClassNames: { size: { large: "uv_e1wcoe1", medium: "uv_e1wcoe2", small: "uv_e1wcoe3", xsmall: "uv_e1wcoe4" }, fullWidth: { true: "uv_e1wcoe5", false: "uv_e1wcoe6" }, sentiment: { primary: "uv_e1wcoe7", secondary: "uv_e1wcoe8", danger: "uv_e1wcoe9", info: "uv_e1wcoea", success: "uv_e1wcoeb", warning: "uv_e1wcoec", neutral: "uv_e1wcoed", black: "uv_e1wcoee", white: "uv_e1wcoef" }, variant: { filled: "uv_e1wcoeg", outlined: "uv_e1wcoeh", ghost: "uv_e1wcoei" }, disabled: { true: "uv_e1wcoej", false: "uv_e1wcoek" } }, defaultVariants: { size: "large", fullWidth: false, disabled: false, variant: "filled", sentiment: "primary" }, compoundVariants: [[{ variant: "filled", sentiment: "primary" }, "uv_e1wcoel"], [{ variant: "filled", sentiment: "secondary" }, "uv_e1wcoem"], [{ variant: "filled", sentiment: "danger" }, "uv_e1wcoen"], [{ variant: "filled", sentiment: "info" }, "uv_e1wcoeo"], [{ variant: "filled", sentiment: "success" }, "uv_e1wcoep"], [{ variant: "filled", sentiment: "warning" }, "uv_e1wcoeq"], [{ variant: "filled", sentiment: "neutral" }, "uv_e1wcoer"], [{ variant: "filled", sentiment: "black" }, "uv_e1wcoes"], [{ variant: "filled", sentiment: "white" }, "uv_e1wcoet"], [{ variant: "outlined", sentiment: "primary" }, "uv_e1wcoeu"], [{ variant: "outlined", sentiment: "secondary" }, "uv_e1wcoev"], [{ variant: "outlined", sentiment: "danger" }, "uv_e1wcoew"], [{ variant: "outlined", sentiment: "info" }, "uv_e1wcoex"], [{ variant: "outlined", sentiment: "success" }, "uv_e1wcoey"], [{ variant: "outlined", sentiment: "warning" }, "uv_e1wcoez"], [{ variant: "outlined", sentiment: "neutral" }, "uv_e1wcoe10"], [{ variant: "outlined", sentiment: "black" }, "uv_e1wcoe11"], [{ variant: "outlined", sentiment: "white" }, "uv_e1wcoe12"], [{ variant: "ghost", sentiment: "primary" }, "uv_e1wcoe13"], [{ variant: "ghost", sentiment: "secondary" }, "uv_e1wcoe14"], [{ variant: "ghost", sentiment: "danger" }, "uv_e1wcoe15"], [{ variant: "ghost", sentiment: "info" }, "uv_e1wcoe16"], [{ variant: "ghost", sentiment: "success" }, "uv_e1wcoe17"], [{ variant: "ghost", sentiment: "warning" }, "uv_e1wcoe18"], [{ variant: "ghost", sentiment: "neutral" }, "uv_e1wcoe19"], [{ variant: "ghost", sentiment: "black" }, "uv_e1wcoe1a"], [{ variant: "ghost", sentiment: "white" }, "uv_e1wcoe1b"]] });
6
+ export {
7
+ button
8
+ };
@@ -14,7 +14,7 @@ type ChipType = {
14
14
  export declare const Chip: {
15
15
  ({ children, size, disabled, active, className, "data-testid": dataTestId, onClick, }: ChipType): import("@emotion/react/jsx-runtime").JSX.Element;
16
16
  Icon: ({ name, onClick, "data-testid": dataTestId, }: {
17
- name: "address" | "search" | "filter" | "stop" | "view" | "sort" | "id" | "anchor" | "bold" | "arrowLeft" | "cancel" | "close" | "drag" | "play" | "download" | "italic" | "underline" | "upload" | "email" | "addressOutline" | "addressPlay" | "adjustmentsHorizontal" | "adjustmentsHorizontalOutline" | "alertCircle" | "alertCircleOutline" | "arrowDown" | "arrowLeftBottom" | "arrowLeftDouble" | "arrowRightBottom" | "arrowRightDouble" | "arrowRight" | "arrowUp" | "attach" | "autoFix" | "autoFixOutline" | "bookOpenOutline" | "bookOpenOutlineOutline" | "boxEssentials" | "boxEssentialsOutline" | "bullhorn" | "bullhornOutline" | "burger" | "calculator" | "calculatorOutline" | "calendarRange" | "calendarRangeOutline" | "chat" | "chatOutline" | "checkCircle" | "checkCircleOutline" | "check" | "clickhouse" | "lockOutline" | "clockOutline" | "clockOutlineOutline" | "closeCircleOutline" | "console" | "consoleOutline" | "copyContent" | "credential" | "credentialOutline" | "creditCard" | "creditCardOutline" | "database" | "databaseOutline" | "delete" | "deleteOutline" | "detach" | "doc" | "docOutline" | "dotsHorizontal" | "dotsVertical" | "earth" | "earthOutline" | "east" | "eastShort" | "emailOutline" | "emailRemove" | "emailRemoveOutline" | "equal" | "escape" | "expand" | "expandMore" | "eye" | "eyeOff" | "eyeOffOutline" | "eyeOutline" | "filterOutline" | "folder" | "folderOutline" | "github" | "helpCircle" | "helpCircleOutline" | "idOutline" | "information" | "informationOutline" | "instagram" | "leaf" | "leafOutline" | "leftRightArrow" | "lightBulb" | "lightBulbOutline" | "linkedin" | "listBullet" | "listNumber" | "lock" | "logout" | "members" | "membersOutline" | "minus" | "moon" | "moonOutline" | "mosaic" | "mosaicOutline" | "north" | "northShort" | "notification" | "notificationOutline" | "openInNew" | "organization" | "partnerSpace" | "pen2" | "pen2Outline" | "pencil" | "pencilOutline" | "pen" | "penOutline" | "phone" | "phoneOutline" | "pin" | "pinOutline" | "playOutline" | "plus" | "privacy" | "privacyOutline" | "profile" | "profileOutline" | "progressCheck" | "rayEndArrow" | "rayStartArrow" | "rayStartEnd" | "rayTopArrow" | "reboot" | "restore" | "revoke" | "rocket" | "rocketOutline" | "rss" | "send" | "sendOutline" | "settings" | "settingsOutline" | "sidebar" | "sidebarOutline" | "slack" | "south" | "southShort" | "sparkles" | "sparklesOutline" | "star" | "starOutline" | "stopOutline" | "sun" | "sunOutline" | "support" | "supportOutline" | "switchOrga" | "thumbsDown" | "thumbsDownOutline" | "thumbsUp" | "thumbsUpOutline" | "twitter" | "unlock" | "unlockOutline" | "unpin" | "unpinOutline" | "weatherNight" | "weatherNightOutline" | "west" | "westShort" | "youtube";
17
+ name: "search" | "anchor" | "bold" | "sort" | "filter" | "address" | "stop" | "view" | "id" | "arrowLeft" | "cancel" | "close" | "drag" | "play" | "underline" | "italic" | "download" | "upload" | "email" | "addressOutline" | "addressPlay" | "adjustmentsHorizontal" | "adjustmentsHorizontalOutline" | "alertCircle" | "alertCircleOutline" | "arrowDown" | "arrowLeftBottom" | "arrowLeftDouble" | "arrowRightBottom" | "arrowRightDouble" | "arrowRight" | "arrowUp" | "attach" | "autoFix" | "autoFixOutline" | "bookOpenOutline" | "bookOpenOutlineOutline" | "boxEssentials" | "boxEssentialsOutline" | "bullhorn" | "bullhornOutline" | "burger" | "calculator" | "calculatorOutline" | "calendarRange" | "calendarRangeOutline" | "chat" | "chatOutline" | "checkCircle" | "checkCircleOutline" | "check" | "clickhouse" | "lockOutline" | "clockOutline" | "clockOutlineOutline" | "closeCircleOutline" | "console" | "consoleOutline" | "copyContent" | "credential" | "credentialOutline" | "creditCard" | "creditCardOutline" | "database" | "databaseOutline" | "delete" | "deleteOutline" | "detach" | "doc" | "docOutline" | "dotsHorizontal" | "dotsVertical" | "earth" | "earthOutline" | "east" | "eastShort" | "emailOutline" | "emailRemove" | "emailRemoveOutline" | "equal" | "escape" | "expand" | "expandMore" | "eye" | "eyeOff" | "eyeOffOutline" | "eyeOutline" | "filterOutline" | "folder" | "folderOutline" | "github" | "helpCircle" | "helpCircleOutline" | "idOutline" | "information" | "informationOutline" | "instagram" | "leaf" | "leafOutline" | "leftRightArrow" | "lightBulb" | "lightBulbOutline" | "linkedin" | "listBullet" | "listNumber" | "lock" | "logout" | "members" | "membersOutline" | "minus" | "moon" | "moonOutline" | "mosaic" | "mosaicOutline" | "north" | "northShort" | "notification" | "notificationOutline" | "openInNew" | "organization" | "partnerSpace" | "pen2" | "pen2Outline" | "pencil" | "pencilOutline" | "pen" | "penOutline" | "phone" | "phoneOutline" | "pin" | "pinOutline" | "playOutline" | "plus" | "privacy" | "privacyOutline" | "profile" | "profileOutline" | "progressCheck" | "rayEndArrow" | "rayStartArrow" | "rayStartEnd" | "rayTopArrow" | "reboot" | "restore" | "revoke" | "rocket" | "rocketOutline" | "rss" | "send" | "sendOutline" | "settings" | "settingsOutline" | "sidebar" | "sidebarOutline" | "slack" | "south" | "southShort" | "sparkles" | "sparklesOutline" | "star" | "starOutline" | "stopOutline" | "sun" | "sunOutline" | "support" | "supportOutline" | "switchOrga" | "thumbsDown" | "thumbsDownOutline" | "thumbsUp" | "thumbsUpOutline" | "twitter" | "unlock" | "unlockOutline" | "unpin" | "unpinOutline" | "weatherNight" | "weatherNightOutline" | "west" | "westShort" | "youtube";
18
18
  onClick?: () => void;
19
19
  'data-testid'?: string;
20
20
  }) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -1,2 +1,2 @@
1
- export declare const DIALOG_SENTIMENTS: ("primary" | "success" | "danger" | "warning")[];
1
+ export declare const DIALOG_SENTIMENTS: ("danger" | "success" | "primary" | "warning")[];
2
2
  export type DialogSentiment = (typeof DIALOG_SENTIMENTS)[number];
@@ -16,14 +16,9 @@ export declare const Dialog: (({ ariaLabel, className, children, "data-testid":
16
16
  } & Pick<{
17
17
  type?: import("react").ButtonHTMLAttributes<HTMLButtonElement>["type"];
18
18
  autoFocus?: import("react").ButtonHTMLAttributes<HTMLButtonElement>["autoFocus"];
19
- variant?: "filled" | "ghost" | "outlined";
20
19
  role?: import("react").AriaRole;
21
- size?: "large" | "medium" | "small" | "xsmall";
22
20
  className?: string;
23
21
  'data-testid'?: string;
24
- sentiment?: import("../../theme").ExtendedColor;
25
- disabled?: boolean;
26
- fullWidth?: boolean;
27
22
  isLoading?: boolean;
28
23
  'aria-label'?: string;
29
24
  'aria-current'?: boolean;
@@ -40,17 +35,24 @@ export declare const Dialog: (({ ariaLabel, className, children, "data-testid":
40
35
  onMouseDown?: import("react").MouseEventHandler<HTMLElement>;
41
36
  onMouseUp?: import("react").MouseEventHandler<HTMLElement>;
42
37
  onMouseOut?: import("react").MouseEventHandler<HTMLElement>;
38
+ onBlur?: import("react").ButtonHTMLAttributes<HTMLElement>["onBlur"];
43
39
  onMouseEnter?: import("react").MouseEventHandler<HTMLElement>;
44
40
  onMouseLeave?: import("react").MouseEventHandler<HTMLElement>;
45
41
  onPointerDown?: import("react").ButtonHTMLAttributes<HTMLButtonElement>["onPointerDown"];
46
42
  onKeyDown?: import("react").ButtonHTMLAttributes<HTMLButtonElement>["onKeyDown"];
43
+ } & {
44
+ size?: "small" | "large" | "medium" | "xsmall" | undefined;
45
+ fullWidth?: boolean | undefined;
46
+ sentiment?: "danger" | "info" | "neutral" | "success" | "primary" | "warning" | "black" | "white" | "secondary" | undefined;
47
+ variant?: "filled" | "outlined" | "ghost" | undefined;
48
+ disabled?: boolean | undefined;
47
49
  } & {
48
50
  children: import("react").ReactNode;
49
51
  name?: string;
50
52
  href?: string;
51
53
  target?: string;
52
54
  download?: string;
53
- } & import("react").RefAttributes<Element>, "tooltip" | "onClick" | "disabled">) => import("@emotion/react/jsx-runtime").JSX.Element;
55
+ } & import("react").RefAttributes<Element>, "onClick" | "tooltip" | "disabled">) => import("@emotion/react/jsx-runtime").JSX.Element;
54
56
  Buttons: ({ secondaryButton, primaryButton, }: {
55
57
  secondaryButton: import("react").ReactNode;
56
58
  primaryButton: import("react").ReactNode;
@@ -35,7 +35,7 @@ export declare const List: import("react").ForwardRefExoticComponent<ListProps &
35
35
  expandable?: ReactNode;
36
36
  selectDisabled?: boolean | string;
37
37
  disabled?: boolean;
38
- sentiment?: "primary" | "secondary" | "neutral" | "success" | "danger" | "warning" | "info";
38
+ sentiment?: "danger" | "info" | "neutral" | "success" | "primary" | "warning" | "secondary";
39
39
  expanded?: boolean;
40
40
  className?: string;
41
41
  expandablePadding?: "0" | "1" | "0.5" | "0.25" | "1.5" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9" | "10";
@@ -69,7 +69,7 @@ export declare const Menu: import("react").ForwardRefExoticComponent<{
69
69
  children: import("react").ReactNode;
70
70
  onClick?: import("react").MouseEventHandler<HTMLElement> | undefined;
71
71
  borderless?: boolean;
72
- sentiment?: "primary" | "neutral" | "danger";
72
+ sentiment?: "danger" | "neutral" | "primary";
73
73
  active?: boolean;
74
74
  'data-testid'?: string;
75
75
  searchText?: string;