@ultraviolet/ui 2.0.2 → 2.0.4

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 (98) hide show
  1. package/dist/components/Alert/index.cjs +10 -8
  2. package/dist/components/Alert/index.js +10 -8
  3. package/dist/components/Badge/index.cjs +7 -3
  4. package/dist/components/Badge/index.js +7 -3
  5. package/dist/components/Banner/index.cjs +10 -8
  6. package/dist/components/Banner/index.js +10 -8
  7. package/dist/components/Button/index.cjs +6 -4
  8. package/dist/components/Button/index.js +6 -4
  9. package/dist/components/Chip/index.cjs +10 -4
  10. package/dist/components/Chip/index.js +10 -4
  11. package/dist/components/DateInput/components/CalendarDaily.cjs +23 -9
  12. package/dist/components/DateInput/components/CalendarDaily.js +23 -9
  13. package/dist/components/DateInput/components/CalendarMonthly.cjs +7 -3
  14. package/dist/components/DateInput/components/CalendarMonthly.js +7 -3
  15. package/dist/components/DateInput/index.cjs +29 -11
  16. package/dist/components/DateInput/index.js +29 -11
  17. package/dist/components/Drawer/index.cjs +13 -9
  18. package/dist/components/Drawer/index.js +13 -9
  19. package/dist/components/Expandable/index.cjs +4 -2
  20. package/dist/components/Expandable/index.js +4 -2
  21. package/dist/components/GlobalAlert/index.cjs +5 -3
  22. package/dist/components/GlobalAlert/index.js +5 -3
  23. package/dist/components/InfiniteScroll/index.cjs +15 -5
  24. package/dist/components/InfiniteScroll/index.js +15 -5
  25. package/dist/components/LineChart/helpers.cjs +15 -5
  26. package/dist/components/LineChart/helpers.js +15 -5
  27. package/dist/components/Link/index.cjs +10 -6
  28. package/dist/components/Link/index.js +10 -6
  29. package/dist/components/List/ListContext.cjs +2 -4
  30. package/dist/components/List/ListContext.js +2 -4
  31. package/dist/components/List/Row.cjs +10 -8
  32. package/dist/components/List/Row.d.ts +3 -1
  33. package/dist/components/List/Row.js +10 -8
  34. package/dist/components/List/index.d.ts +2 -0
  35. package/dist/components/Menu/MenuContent.cjs +35 -17
  36. package/dist/components/Menu/MenuContent.d.ts +1 -0
  37. package/dist/components/Menu/MenuContent.js +35 -17
  38. package/dist/components/Menu/MenuProvider.cjs +3 -1
  39. package/dist/components/Menu/MenuProvider.js +3 -1
  40. package/dist/components/Menu/components/Item.cjs +6 -4
  41. package/dist/components/Menu/components/Item.js +6 -4
  42. package/dist/components/Menu/index.d.ts +1 -0
  43. package/dist/components/Menu/types.d.ts +4 -0
  44. package/dist/components/NumberInput/index.cjs +11 -7
  45. package/dist/components/NumberInput/index.js +11 -7
  46. package/dist/components/Pagination/index.cjs +3 -1
  47. package/dist/components/Pagination/index.js +3 -1
  48. package/dist/components/Popup/index.cjs +16 -12
  49. package/dist/components/Popup/index.js +16 -12
  50. package/dist/components/SelectInput/Dropdown.cjs +21 -16
  51. package/dist/components/SelectInput/Dropdown.d.ts +2 -1
  52. package/dist/components/SelectInput/Dropdown.js +21 -16
  53. package/dist/components/SelectInput/SearchBarDropdown.cjs +8 -4
  54. package/dist/components/SelectInput/SearchBarDropdown.js +8 -4
  55. package/dist/components/SelectInput/SelectBar.cjs +13 -10
  56. package/dist/components/SelectInput/SelectBar.d.ts +2 -1
  57. package/dist/components/SelectInput/SelectBar.js +13 -10
  58. package/dist/components/SelectInput/SelectInputProvider.cjs +14 -7
  59. package/dist/components/SelectInput/SelectInputProvider.js +14 -7
  60. package/dist/components/SelectInput/index.cjs +5 -4
  61. package/dist/components/SelectInput/index.js +5 -4
  62. package/dist/components/SelectableCard/index.cjs +18 -16
  63. package/dist/components/SelectableCard/index.js +18 -16
  64. package/dist/components/Slider/components/DoubleSlider.cjs +23 -11
  65. package/dist/components/Slider/components/DoubleSlider.js +23 -11
  66. package/dist/components/Slider/index.cjs +6 -2
  67. package/dist/components/Slider/index.js +6 -2
  68. package/dist/components/Stepper/index.cjs +12 -6
  69. package/dist/components/Stepper/index.js +12 -6
  70. package/dist/components/SwitchButton/index.cjs +13 -5
  71. package/dist/components/SwitchButton/index.js +13 -5
  72. package/dist/components/Table/HeaderCell.cjs +7 -6
  73. package/dist/components/Table/HeaderCell.d.ts +2 -1
  74. package/dist/components/Table/HeaderCell.js +7 -6
  75. package/dist/components/Table/HeaderRow.cjs +1 -1
  76. package/dist/components/Table/HeaderRow.js +1 -1
  77. package/dist/components/Tabs/Tab.cjs +8 -6
  78. package/dist/components/Tabs/Tab.js +8 -6
  79. package/dist/components/Tabs/TabMenu.cjs +5 -4
  80. package/dist/components/Tabs/TabMenu.js +5 -4
  81. package/dist/components/Tabs/index.cjs +6 -4
  82. package/dist/components/Tabs/index.js +6 -4
  83. package/dist/components/TimeInput/helpers.cjs +24 -8
  84. package/dist/components/TimeInput/helpers.js +24 -8
  85. package/dist/components/TimeInput/index.cjs +47 -21
  86. package/dist/components/TimeInput/index.js +47 -21
  87. package/dist/components/Toggle/index.cjs +23 -31
  88. package/dist/components/Toggle/index.js +24 -32
  89. package/dist/components/VerificationCode/index.cjs +13 -8
  90. package/dist/components/VerificationCode/index.js +13 -8
  91. package/dist/helpers/recursivelyGetChildrenString.cjs +9 -3
  92. package/dist/helpers/recursivelyGetChildrenString.js +9 -3
  93. package/dist/mocks/list.d.ts +2 -2
  94. package/dist/utils/responsive/utilities.cjs +6 -2
  95. package/dist/utils/responsive/utilities.js +6 -2
  96. package/dist/utils/searchAlgorithm.cjs +15 -5
  97. package/dist/utils/searchAlgorithm.js +15 -5
  98. package/package.json +6 -6
@@ -26,10 +26,23 @@ const SIZES = {
26
26
  width: "500"
27
27
  }
28
28
  };
29
- const StyledToggle = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
29
+ const StyledCheckbox = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
30
30
  target: "e1wstm612"
31
31
  } : {
32
32
  target: "e1wstm612",
33
+ label: "StyledCheckbox"
34
+ })(process.env.NODE_ENV === "production" ? {
35
+ name: "p9zju0",
36
+ styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}"
37
+ } : {
38
+ name: "p9zju0",
39
+ styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA4BmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledToggle = styled.div<{\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &:has(:checked) {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &:has(:checked) {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &:has(:checked) {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &:has(:checked) {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const uniqueId = useId()\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              checked={checked}\n              disabled={disabled}\n              id={id ?? uniqueId}\n              name={name}\n              onChange={onChange}\n              ref={ref}\n              required={required}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
40
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
41
+ });
42
+ const StyledToggle = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
43
+ target: "e1wstm611"
44
+ } : {
45
+ target: "e1wstm611",
33
46
  label: "StyledToggle"
34
47
  })("box-sizing:content-box;outline:none;overflow:hidden;display:flex;align-items:center;border:none;border-radius:", ({
35
48
  theme
@@ -61,7 +74,7 @@ const StyledToggle = /* @__PURE__ */ _styled__default.default("div", process.env
61
74
  }) => theme.shadows.focusNeutral, ';}&[data-disabled="false"]:active:after{width:', ({
62
75
  size,
63
76
  theme
64
- }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`, ';}&[data-checked="true"]{color:', ({
77
+ }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`, ";}&:has(:checked){color:", ({
65
78
  theme
66
79
  }) => theme.colors.neutral.textStrong, ";background-color:", ({
67
80
  theme
@@ -71,32 +84,19 @@ const StyledToggle = /* @__PURE__ */ _styled__default.default("div", process.env
71
84
  theme
72
85
  }) => theme.shadows.focusPrimary, ';}}&[data-disabled="true"]{background:', ({
73
86
  theme
74
- }) => theme.colors.neutral.backgroundStrongDisabled, ';&[data-checked="true"]{background:', ({
87
+ }) => theme.colors.neutral.backgroundStrongDisabled, ";&:has(:checked){background:", ({
75
88
  theme
76
89
  }) => theme.colors.primary.backgroundStrongDisabled, ';}}&[data-error="true"]{background-color:', ({
77
90
  theme
78
91
  }) => theme.colors.danger.background, ";&:focus-within,&:focus{box-shadow:", ({
79
92
  theme
80
- }) => theme.shadows.focusDanger, ';}&[data-checked="true"]{background-color:', ({
93
+ }) => theme.shadows.focusDanger, ";}&:has(:checked){background-color:", ({
81
94
  theme
82
95
  }) => theme.colors.danger.backgroundStrong, ';}&[data-disabled="true"]{background-color:', ({
83
96
  theme
84
- }) => theme.colors.danger.backgroundDisabled, ';&[data-checked="true"]{background-color:', ({
97
+ }) => theme.colors.danger.backgroundDisabled, ";&:has(:checked){background-color:", ({
85
98
  theme
86
- }) => theme.colors.danger.backgroundStrongDisabled, ";}}}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AAkCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[data-checked=\"true\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked=\"true\"] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &[data-checked=\"true\"] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          onClick={evt => evt.stopPropagation()}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-checked={state}\n              aria-label={ariaLabel}\n              checked={state}\n              disabled={disabled}\n              id={id || uniqueId}\n              name={name}\n              onChange={onLocalChange}\n              ref={ref}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
87
- const StyledCheckbox = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
88
- target: "e1wstm611"
89
- } : {
90
- target: "e1wstm611",
91
- label: "StyledCheckbox"
92
- })(process.env.NODE_ENV === "production" ? {
93
- name: "p9zju0",
94
- styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}"
95
- } : {
96
- name: "p9zju0",
97
- styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA8HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[data-checked=\"true\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked=\"true\"] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &[data-checked=\"true\"] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          onClick={evt => evt.stopPropagation()}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-checked={state}\n              aria-label={ariaLabel}\n              checked={state}\n              disabled={disabled}\n              id={id || uniqueId}\n              name={name}\n              onChange={onLocalChange}\n              ref={ref}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
98
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
99
- });
99
+ }) => theme.colors.danger.backgroundStrongDisabled, ";}}}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AA4CE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledToggle = styled.div<{\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &:has(:checked) {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &:has(:checked) {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &:has(:checked) {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &:has(:checked) {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const uniqueId = useId()\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              checked={checked}\n              disabled={disabled}\n              id={id ?? uniqueId}\n              name={name}\n              onChange={onChange}\n              ref={ref}\n              required={required}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
100
100
  const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
101
101
  target: "e1wstm610"
102
102
  } : {
@@ -111,9 +111,9 @@ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.en
111
111
  theme
112
112
  }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`, ';}&[aria-disabled="true"]{cursor:not-allowed;color:', ({
113
113
  theme
114
- }) => theme.colors.neutral.textDisabled, ";}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AA+IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[data-checked=\"true\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked=\"true\"] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &[data-checked=\"true\"] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          onClick={evt => evt.stopPropagation()}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-checked={state}\n              aria-label={ariaLabel}\n              checked={state}\n              disabled={disabled}\n              id={id || uniqueId}\n              name={name}\n              onChange={onLocalChange}\n              ref={ref}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
114
+ }) => theme.colors.neutral.textDisabled, ";}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AA2IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledToggle = styled.div<{\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &:has(:checked) {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &:has(:checked) {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &:has(:checked) {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &:has(:checked) {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const uniqueId = useId()\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              checked={checked}\n              disabled={disabled}\n              id={id ?? uniqueId}\n              name={name}\n              onChange={onChange}\n              ref={ref}\n              required={required}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
115
115
  const Toggle = react.forwardRef(({
116
- checked = false,
116
+ checked,
117
117
  disabled = false,
118
118
  id,
119
119
  name,
@@ -130,16 +130,8 @@ const Toggle = react.forwardRef(({
130
130
  error,
131
131
  "aria-label": ariaLabel
132
132
  }, ref) => {
133
- const [state, setState] = react.useState(checked);
134
133
  const uniqueId = react.useId();
135
- const onLocalChange = react.useCallback((event) => {
136
- if (onChange) onChange?.(event);
137
- else setState(event.target.checked);
138
- }, [onChange, setState]);
139
- react.useEffect(() => {
140
- setState(checked);
141
- }, [checked, setState]);
142
- return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledLabel, { "aria-disabled": disabled, className, "data-testid": dataTestId, labelPosition, onClick: (evt) => evt.stopPropagation(), size, children: [
134
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledLabel, { "aria-disabled": disabled, className, "data-testid": dataTestId, labelPosition, size, children: [
143
135
  /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { alignItems: "baseline", gap: 0.25, children: [
144
136
  label ? /* @__PURE__ */ jsxRuntime.jsxs(index$2.Row, { alignItems: "center", gap: 1, templateColumns: "auto 1fr", children: [
145
137
  typeof label === "string" ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "span", prominence: "default", sentiment: "neutral", variant: size === "large" ? "body" : "bodySmall", children: label }) : label,
@@ -148,7 +140,7 @@ const Toggle = react.forwardRef(({
148
140
  typeof error === "string" ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "p", disabled, prominence: "default", sentiment: "danger", variant: "bodySmall", children: error }) : null,
149
141
  helper && !error ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "p", prominence: "weak", sentiment: "neutral", variant: "caption", children: helper }) : null
150
142
  ] }),
151
- /* @__PURE__ */ jsxRuntime.jsx(StyledToggle, { "data-checked": state, "data-disabled": disabled, "data-error": !!error, size, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { "aria-checked": state, "aria-label": ariaLabel, checked: state, disabled, id: id || uniqueId, name, onChange: onLocalChange, ref, type: "checkbox", value }) })
143
+ /* @__PURE__ */ jsxRuntime.jsx(StyledToggle, { "data-disabled": disabled, "data-error": !!error, size, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { "aria-invalid": !!error, "aria-label": ariaLabel, checked, disabled, id: id ?? uniqueId, name, onChange, ref, required, type: "checkbox", value }) })
152
144
  ] }) });
153
145
  });
154
146
  exports.SIZES = SIZES;
@@ -1,7 +1,7 @@
1
1
  "use client";
2
2
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
3
3
  import _styled from "@emotion/styled/base";
4
- import { forwardRef, useState, useId, useCallback, useEffect } from "react";
4
+ import { forwardRef, useId } from "react";
5
5
  import { Row } from "../Row/index.js";
6
6
  import { Stack } from "../Stack/index.js";
7
7
  import { Text } from "../Text/index.js";
@@ -22,10 +22,23 @@ const SIZES = {
22
22
  width: "500"
23
23
  }
24
24
  };
25
- const StyledToggle = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
25
+ const StyledCheckbox = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
26
26
  target: "e1wstm612"
27
27
  } : {
28
28
  target: "e1wstm612",
29
+ label: "StyledCheckbox"
30
+ })(process.env.NODE_ENV === "production" ? {
31
+ name: "p9zju0",
32
+ styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}"
33
+ } : {
34
+ name: "p9zju0",
35
+ styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA4BmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledToggle = styled.div<{\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &:has(:checked) {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &:has(:checked) {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &:has(:checked) {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &:has(:checked) {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const uniqueId = useId()\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              checked={checked}\n              disabled={disabled}\n              id={id ?? uniqueId}\n              name={name}\n              onChange={onChange}\n              ref={ref}\n              required={required}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
36
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
+ });
38
+ const StyledToggle = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
39
+ target: "e1wstm611"
40
+ } : {
41
+ target: "e1wstm611",
29
42
  label: "StyledToggle"
30
43
  })("box-sizing:content-box;outline:none;overflow:hidden;display:flex;align-items:center;border:none;border-radius:", ({
31
44
  theme
@@ -57,7 +70,7 @@ const StyledToggle = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pr
57
70
  }) => theme.shadows.focusNeutral, ';}&[data-disabled="false"]:active:after{width:', ({
58
71
  size,
59
72
  theme
60
- }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`, ';}&[data-checked="true"]{color:', ({
73
+ }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`, ";}&:has(:checked){color:", ({
61
74
  theme
62
75
  }) => theme.colors.neutral.textStrong, ";background-color:", ({
63
76
  theme
@@ -67,32 +80,19 @@ const StyledToggle = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pr
67
80
  theme
68
81
  }) => theme.shadows.focusPrimary, ';}}&[data-disabled="true"]{background:', ({
69
82
  theme
70
- }) => theme.colors.neutral.backgroundStrongDisabled, ';&[data-checked="true"]{background:', ({
83
+ }) => theme.colors.neutral.backgroundStrongDisabled, ";&:has(:checked){background:", ({
71
84
  theme
72
85
  }) => theme.colors.primary.backgroundStrongDisabled, ';}}&[data-error="true"]{background-color:', ({
73
86
  theme
74
87
  }) => theme.colors.danger.background, ";&:focus-within,&:focus{box-shadow:", ({
75
88
  theme
76
- }) => theme.shadows.focusDanger, ';}&[data-checked="true"]{background-color:', ({
89
+ }) => theme.shadows.focusDanger, ";}&:has(:checked){background-color:", ({
77
90
  theme
78
91
  }) => theme.colors.danger.backgroundStrong, ';}&[data-disabled="true"]{background-color:', ({
79
92
  theme
80
- }) => theme.colors.danger.backgroundDisabled, ';&[data-checked="true"]{background-color:', ({
93
+ }) => theme.colors.danger.backgroundDisabled, ";&:has(:checked){background-color:", ({
81
94
  theme
82
- }) => theme.colors.danger.backgroundStrongDisabled, ";}}}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AAkCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[data-checked=\"true\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked=\"true\"] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &[data-checked=\"true\"] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          onClick={evt => evt.stopPropagation()}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-checked={state}\n              aria-label={ariaLabel}\n              checked={state}\n              disabled={disabled}\n              id={id || uniqueId}\n              name={name}\n              onChange={onLocalChange}\n              ref={ref}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
83
- const StyledCheckbox = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
84
- target: "e1wstm611"
85
- } : {
86
- target: "e1wstm611",
87
- label: "StyledCheckbox"
88
- })(process.env.NODE_ENV === "production" ? {
89
- name: "p9zju0",
90
- styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}"
91
- } : {
92
- name: "p9zju0",
93
- styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx"],"names":[],"mappings":"AA8HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[data-checked=\"true\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked=\"true\"] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &[data-checked=\"true\"] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          onClick={evt => evt.stopPropagation()}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-checked={state}\n              aria-label={ariaLabel}\n              checked={state}\n              disabled={disabled}\n              id={id || uniqueId}\n              name={name}\n              onChange={onLocalChange}\n              ref={ref}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
94
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
95
- });
95
+ }) => theme.colors.danger.backgroundStrongDisabled, ";}}}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AA4CE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledToggle = styled.div<{\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &:has(:checked) {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &:has(:checked) {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &:has(:checked) {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &:has(:checked) {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const uniqueId = useId()\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              checked={checked}\n              disabled={disabled}\n              id={id ?? uniqueId}\n              name={name}\n              onChange={onChange}\n              ref={ref}\n              required={required}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
96
96
  const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "production" ? {
97
97
  target: "e1wstm610"
98
98
  } : {
@@ -107,9 +107,9 @@ const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "p
107
107
  theme
108
108
  }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`, ';}&[aria-disabled="true"]{cursor:not-allowed;color:', ({
109
109
  theme
110
- }) => theme.colors.neutral.textDisabled, ";}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AA+IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEvent,\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledToggle = styled.div<{\n  'data-checked': boolean\n  'data-disabled': boolean\n  size: 'small' | 'large'\n  'data-error': boolean\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[data-checked=\"true\"] {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &[data-checked=\"true\"] {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &[data-checked=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &[data-checked=\"true\"] {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked = false,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const [state, setState] = useState(checked)\n    const uniqueId = useId()\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (onChange) onChange?.(event)\n        else setState(event.target.checked)\n      },\n      [onChange, setState],\n    )\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked, setState])\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          onClick={evt => evt.stopPropagation()}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-checked={state}\n              aria-label={ariaLabel}\n              checked={state}\n              disabled={disabled}\n              id={id || uniqueId}\n              name={name}\n              onChange={onLocalChange}\n              ref={ref}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
110
+ }) => theme.colors.neutral.textDisabled, ";}" + (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/Toggle/index.tsx"],"names":[],"mappings":"AA2IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type {\n  ChangeEventHandler,\n  InputHTMLAttributes,\n  ReactNode,\n  Ref,\n} from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Row } from '../Row'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nexport const SIZES = {\n  large: {\n    ball: '200', // sizing token from theme\n    height: '300',\n    width: '600',\n  },\n  small: {\n    ball: '150',\n    height: '250',\n    width: '500',\n  },\n} as const\n\nconst StyledCheckbox = styled.input`\n  position: absolute;\n  opacity: 0;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  cursor: pointer;\n\n  &[disabled] {\n    cursor: not-allowed;\n  }\n`\n\nconst StyledToggle = styled.div<{\n  size: 'small' | 'large'\n}>`\n  box-sizing: content-box;\n  outline: none;\n  overflow: hidden;\n  display: flex;\n  align-items: center;\n  border: none;\n  border-radius: ${({ theme }) => theme.radii.xlarge};\n  position: relative;\n  transition: all 300ms;\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundStrong};\n  width: ${({ size, theme }) => theme.sizing[SIZES[size].width]};\n  height: ${({ size, theme }) => theme.sizing[SIZES[size].height]};\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].height]} / 2 - ${theme.sizing[SIZES[size].ball]} / 2)`};\n    left: 5px;\n    width: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    height: ${({ size, theme }) => theme.sizing[SIZES[size].ball]};\n    border-radius: ${({ theme }) => theme.radii.circle};\n    background-color: ${({ theme }) => theme.colors.neutral.background};\n    transition: all 300ms;\n  }\n\n  &:focus-within,\n  &:focus {\n    box-shadow: ${({ theme }) => theme.shadows.focusNeutral};\n  }\n\n  &[data-disabled=\"false\"]:active:after {\n    width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &:has(:checked) {\n    color: ${({ theme }) => theme.colors.neutral.textStrong};\n    background-color: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n    &:hover {\n      background-color: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongHover};\n    }\n\n    &:after {\n      left: calc(100% - 5px);\n      transform: translateX(-100%);\n    }\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusPrimary};\n    }\n  }\n\n  &[data-disabled=\"true\"] {\n    background: ${({ theme }) => theme.colors.neutral.backgroundStrongDisabled};\n\n    &:has(:checked) {\n      background: ${({ theme }) =>\n        theme.colors.primary.backgroundStrongDisabled};\n    }\n  }\n\n  &[data-error=\"true\"] {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n\n    &:focus-within,\n    &:focus {\n      box-shadow: ${({ theme }) => theme.shadows.focusDanger};\n    }\n\n    &:has(:checked) {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    }\n\n    &[data-disabled=\"true\"] {\n      background-color: ${({ theme }) => theme.colors.danger.backgroundDisabled};\n\n      &:has(:checked) {\n        background-color: ${({ theme }) =>\n          theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label<{\n  size: 'small' | 'large'\n  labelPosition: 'left' | 'right'\n}>`\n  display: flex;\n  gap: ${({ theme }) => theme.space['1']};\n  align-items: start;\n  width: fit-content;\n  cursor: pointer;\n  flex-direction: ${({ labelPosition }) =>\n    labelPosition === 'left' ? 'row' : 'row-reverse'};\n\n  &:active ${StyledToggle}[data-disabled='false']:after {\n  width: ${({ size, theme }) => `calc(${theme.sizing[SIZES[size].ball]} * 1.3775)`};\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\ntype ToggleProps = {\n  id?: string\n  checked?: boolean\n  name?: string\n  tooltip?: string\n  /**\n   * If `onChange` is given component will work as a controlled component if not it will work as an uncontrolled component.\n   */\n  onChange?: ChangeEventHandler<HTMLInputElement>\n  size?: 'large' | 'small'\n  labelPosition?: 'left' | 'right'\n  label?: ReactNode\n  'aria-label'?: string\n  helper?: ReactNode\n  disabled?: boolean\n  className?: string\n  required?: boolean\n  error?: boolean | string\n  'data-testid'?: string\n} & Pick<InputHTMLAttributes<HTMLInputElement>, 'value'>\n\n/**\n * Toggle component is used to toggle between two states (on/off, true/false, etc.).\n */\nexport const Toggle = forwardRef(\n  (\n    {\n      checked,\n      disabled = false,\n      id,\n      name,\n      onChange,\n      size = 'large',\n      tooltip,\n      labelPosition = 'right',\n      label,\n      helper,\n      required,\n      className,\n      'data-testid': dataTestId,\n      value,\n      error,\n      'aria-label': ariaLabel,\n    }: ToggleProps,\n    ref: Ref<HTMLInputElement>,\n  ) => {\n    const uniqueId = useId()\n\n    return (\n      <Tooltip text={tooltip}>\n        <StyledLabel\n          aria-disabled={disabled}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n          size={size}\n        >\n          <Stack alignItems=\"baseline\" gap={0.25}>\n            {label ? (\n              <Row alignItems=\"center\" gap={1} templateColumns=\"auto 1fr\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"span\"\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? (\n                  <Text as=\"sup\" sentiment=\"danger\" variant=\"body\">\n                    *\n                  </Text>\n                ) : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                disabled={disabled}\n                prominence=\"default\"\n                sentiment=\"danger\"\n                variant=\"bodySmall\"\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            data-disabled={disabled}\n            data-error={!!error}\n            size={size}\n          >\n            <StyledCheckbox\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              checked={checked}\n              disabled={disabled}\n              id={id ?? uniqueId}\n              name={name}\n              onChange={onChange}\n              ref={ref}\n              required={required}\n              type=\"checkbox\"\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
111
111
  const Toggle = forwardRef(({
112
- checked = false,
112
+ checked,
113
113
  disabled = false,
114
114
  id,
115
115
  name,
@@ -126,16 +126,8 @@ const Toggle = forwardRef(({
126
126
  error,
127
127
  "aria-label": ariaLabel
128
128
  }, ref) => {
129
- const [state, setState] = useState(checked);
130
129
  const uniqueId = useId();
131
- const onLocalChange = useCallback((event) => {
132
- if (onChange) onChange?.(event);
133
- else setState(event.target.checked);
134
- }, [onChange, setState]);
135
- useEffect(() => {
136
- setState(checked);
137
- }, [checked, setState]);
138
- return /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxs(StyledLabel, { "aria-disabled": disabled, className, "data-testid": dataTestId, labelPosition, onClick: (evt) => evt.stopPropagation(), size, children: [
130
+ return /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxs(StyledLabel, { "aria-disabled": disabled, className, "data-testid": dataTestId, labelPosition, size, children: [
139
131
  /* @__PURE__ */ jsxs(Stack, { alignItems: "baseline", gap: 0.25, children: [
140
132
  label ? /* @__PURE__ */ jsxs(Row, { alignItems: "center", gap: 1, templateColumns: "auto 1fr", children: [
141
133
  typeof label === "string" ? /* @__PURE__ */ jsx(Text, { as: "span", prominence: "default", sentiment: "neutral", variant: size === "large" ? "body" : "bodySmall", children: label }) : label,
@@ -144,7 +136,7 @@ const Toggle = forwardRef(({
144
136
  typeof error === "string" ? /* @__PURE__ */ jsx(Text, { as: "p", disabled, prominence: "default", sentiment: "danger", variant: "bodySmall", children: error }) : null,
145
137
  helper && !error ? /* @__PURE__ */ jsx(Text, { as: "p", prominence: "weak", sentiment: "neutral", variant: "caption", children: helper }) : null
146
138
  ] }),
147
- /* @__PURE__ */ jsx(StyledToggle, { "data-checked": state, "data-disabled": disabled, "data-error": !!error, size, children: /* @__PURE__ */ jsx(StyledCheckbox, { "aria-checked": state, "aria-label": ariaLabel, checked: state, disabled, id: id || uniqueId, name, onChange: onLocalChange, ref, type: "checkbox", value }) })
139
+ /* @__PURE__ */ jsx(StyledToggle, { "data-disabled": disabled, "data-error": !!error, size, children: /* @__PURE__ */ jsx(StyledCheckbox, { "aria-invalid": !!error, "aria-label": ariaLabel, checked, disabled, id: id ?? uniqueId, name, onChange, ref, required, type: "checkbox", value }) })
148
140
  ] }) });
149
141
  });
150
142
  export {