@ultraviolet/ui 1.71.0 → 1.72.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/dist/components/Checkbox/index.cjs +12 -12
  2. package/dist/components/Checkbox/index.js +12 -12
  3. package/dist/components/CheckboxGroup/index.cjs +7 -7
  4. package/dist/components/CheckboxGroup/index.js +7 -7
  5. package/dist/components/DateInput/index.cjs +5 -5
  6. package/dist/components/DateInput/index.js +5 -5
  7. package/dist/components/List/HeaderCell.cjs +15 -31
  8. package/dist/components/List/HeaderCell.js +14 -30
  9. package/dist/components/NumberInputV2/index.cjs +23 -15
  10. package/dist/components/NumberInputV2/index.js +23 -15
  11. package/dist/components/Radio/index.cjs +13 -9
  12. package/dist/components/Radio/index.js +13 -9
  13. package/dist/components/RadioGroup/index.cjs +6 -6
  14. package/dist/components/RadioGroup/index.js +6 -6
  15. package/dist/components/SelectInputV2/SelectBar.cjs +11 -11
  16. package/dist/components/SelectInputV2/SelectBar.js +11 -11
  17. package/dist/components/SelectInputV2/index.cjs +5 -5
  18. package/dist/components/SelectInputV2/index.js +5 -5
  19. package/dist/components/SelectableCardGroup/index.cjs +6 -6
  20. package/dist/components/SelectableCardGroup/index.js +6 -6
  21. package/dist/components/Slider/components/Label.cjs +3 -3
  22. package/dist/components/Slider/components/Label.js +3 -3
  23. package/dist/components/Slider/index.cjs +2 -2
  24. package/dist/components/Slider/index.js +2 -2
  25. package/dist/components/Table/Cell.cjs +14 -4
  26. package/dist/components/Table/Cell.d.ts +5 -1
  27. package/dist/components/Table/Cell.js +14 -4
  28. package/dist/components/Table/HeaderCell.cjs +25 -23
  29. package/dist/components/Table/HeaderCell.d.ts +4 -3
  30. package/dist/components/Table/HeaderCell.js +22 -20
  31. package/dist/components/Table/HeaderRow.cjs +5 -3
  32. package/dist/components/Table/HeaderRow.js +5 -3
  33. package/dist/components/Table/Row.cjs +52 -16
  34. package/dist/components/Table/Row.d.ts +3 -1
  35. package/dist/components/Table/Row.js +53 -17
  36. package/dist/components/Table/TableContext.cjs +38 -3
  37. package/dist/components/Table/TableContext.d.ts +8 -1
  38. package/dist/components/Table/TableContext.js +38 -3
  39. package/dist/components/Table/constants.cjs +12 -0
  40. package/dist/components/Table/constants.d.ts +7 -0
  41. package/dist/components/Table/constants.js +12 -0
  42. package/dist/components/Table/index.cjs +33 -22
  43. package/dist/components/Table/index.d.ts +19 -2
  44. package/dist/components/Table/index.js +33 -22
  45. package/dist/components/TagInput/index.cjs +9 -9
  46. package/dist/components/TagInput/index.js +9 -9
  47. package/dist/components/TextArea/index.cjs +14 -11
  48. package/dist/components/TextArea/index.d.ts +8 -2
  49. package/dist/components/TextArea/index.js +14 -11
  50. package/dist/components/TextInputV2/index.cjs +11 -11
  51. package/dist/components/TextInputV2/index.js +11 -11
  52. package/dist/components/Toggle/index.cjs +7 -7
  53. package/dist/components/Toggle/index.js +7 -7
  54. package/dist/components/ToggleGroup/index.cjs +6 -6
  55. package/dist/components/ToggleGroup/index.js +6 -6
  56. package/dist/components/UnitInput/index.cjs +10 -10
  57. package/dist/components/UnitInput/index.js +10 -10
  58. package/package.json +4 -4
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const _styled = require("@emotion/styled/base");
5
- const legacy = require("@ultraviolet/icons/legacy");
5
+ const icons = require("@ultraviolet/icons");
6
6
  const React = require("react");
7
7
  const index$2 = require("../Row/index.cjs");
8
8
  const index$1 = require("../Stack/index.cjs");
@@ -76,7 +76,7 @@ const StyledToggle = /* @__PURE__ */ _styled__default.default("div", process.env
76
76
  theme
77
77
  }) => theme.colors.danger.backgroundDisabled, ';&[data-checked="true"]{background-color:', ({
78
78
  theme
79
- }) => 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":"AAiCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
79
+ }) => 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":"AAiCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <AsteriskIcon size={8} sentiment=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"label\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
80
80
  const StyledCheckbox = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
81
81
  target: "e1wstm611"
82
82
  } : {
@@ -88,7 +88,7 @@ const StyledCheckbox = /* @__PURE__ */ _styled__default.default("input", process
88
88
  } : {
89
89
  name: "p9zju0",
90
90
  styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}",
91
- map: "/*# 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":"AA6HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
91
+ map: "/*# 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":"AA6HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <AsteriskIcon size={8} sentiment=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"label\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
92
92
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
93
  });
94
94
  const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
@@ -104,8 +104,8 @@ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.en
104
104
  size
105
105
  }) => SIZES[size].ball * 1.3775, 'px;}&[aria-disabled="true"]{cursor:not-allowed;color:', ({
106
106
  theme
107
- }) => 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":"AA8IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
108
- const RequiredIcon = () => /* @__PURE__ */ jsxRuntime.jsx("sup", { children: /* @__PURE__ */ jsxRuntime.jsx(legacy.Icon, { name: "asterisk", size: 10, color: "danger" }) });
107
+ }) => 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":"AA8IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <AsteriskIcon size={8} sentiment=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"label\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
108
+ const RequiredIcon = () => /* @__PURE__ */ jsxRuntime.jsx("sup", { children: /* @__PURE__ */ jsxRuntime.jsx(icons.AsteriskIcon, { size: 8, sentiment: "danger" }) });
109
109
  const Toggle = React.forwardRef(({
110
110
  checked = false,
111
111
  disabled = false,
@@ -135,11 +135,11 @@ const Toggle = React.forwardRef(({
135
135
  return /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(StyledLabel, { "aria-disabled": disabled, size, onClick: (evt) => evt.stopPropagation(), className, "data-testid": dataTestId, labelPosition, children: [
136
136
  /* @__PURE__ */ jsxRuntime.jsxs(index$1.Stack, { gap: 0.25, alignItems: "baseline", children: [
137
137
  label ? /* @__PURE__ */ jsxRuntime.jsxs(index$2.Row, { templateColumns: "auto 1fr", gap: 1, alignItems: "center", children: [
138
- label,
138
+ typeof label === "string" ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "label", variant: size === "large" ? "body" : "bodySmall", prominence: "default", sentiment: "neutral", children: label }) : label,
139
139
  required ? /* @__PURE__ */ jsxRuntime.jsx(RequiredIcon, {}) : null
140
140
  ] }) : null,
141
141
  typeof error === "string" ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "p", variant: "bodySmall", prominence: "default", sentiment: "danger", disabled, children: error }) : null,
142
- helper && !error ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "p", variant: "bodySmall", prominence: "weak", children: helper }) : null
142
+ helper && !error ? /* @__PURE__ */ jsxRuntime.jsx(index$3.Text, { as: "p", variant: "caption", prominence: "weak", sentiment: "neutral", children: helper }) : null
143
143
  ] }),
144
144
  /* @__PURE__ */ jsxRuntime.jsx(StyledToggle, { size, "data-checked": state, "data-disabled": disabled, "data-error": !!error, children: /* @__PURE__ */ jsxRuntime.jsx(StyledCheckbox, { id: id || uniqueId, checked: state, "aria-checked": state, disabled, name, onChange: onLocalChange, type: "checkbox", ref, value }) })
145
145
  ] }) });
@@ -1,6 +1,6 @@
1
1
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
2
  import _styled from "@emotion/styled/base";
3
- import { Icon } from "@ultraviolet/icons/legacy";
3
+ import { AsteriskIcon } from "@ultraviolet/icons";
4
4
  import { forwardRef, useState, useId, useCallback, useEffect } from "react";
5
5
  import { Row } from "../Row/index.js";
6
6
  import { Stack } from "../Stack/index.js";
@@ -72,7 +72,7 @@ const StyledToggle = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pr
72
72
  theme
73
73
  }) => theme.colors.danger.backgroundDisabled, ';&[data-checked="true"]{background-color:', ({
74
74
  theme
75
- }) => 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":"AAiCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
75
+ }) => 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":"AAiCE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <AsteriskIcon size={8} sentiment=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"label\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
76
76
  const StyledCheckbox = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
77
77
  target: "e1wstm611"
78
78
  } : {
@@ -84,7 +84,7 @@ const StyledCheckbox = /* @__PURE__ */ _styled("input", process.env.NODE_ENV ===
84
84
  } : {
85
85
  name: "p9zju0",
86
86
  styles: "position:absolute;opacity:0;top:0;left:0;width:100%;height:100%;cursor:pointer;&[disabled]{cursor:not-allowed;}",
87
- map: "/*# 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":"AA6HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
87
+ map: "/*# 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":"AA6HmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <AsteriskIcon size={8} sentiment=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"label\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
88
88
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
89
89
  });
90
90
  const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "production" ? {
@@ -100,8 +100,8 @@ const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "p
100
100
  size
101
101
  }) => SIZES[size].ball * 1.3775, 'px;}&[aria-disabled="true"]{cursor:not-allowed;color:', ({
102
102
  theme
103
- }) => 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":"AA8IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Icon } from '@ultraviolet/icons/legacy'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <Icon name=\"asterisk\" size={10} color=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {label}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text as=\"p\" variant=\"bodySmall\" prominence=\"weak\">\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
104
- const RequiredIcon = () => /* @__PURE__ */ jsx("sup", { children: /* @__PURE__ */ jsx(Icon, { name: "asterisk", size: 10, color: "danger" }) });
103
+ }) => 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":"AA8IE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Toggle/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\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: 16,\n    height: 24,\n    width: 48,\n  },\n  small: {\n    ball: 12,\n    height: 20,\n    width: 40,\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 }) => SIZES[size].width}px;\n  height: ${({ size }) => SIZES[size].height}px;\n\n  &:hover {\n    background-color: ${({ theme }) =>\n      theme.colors.neutral.backgroundStrongHover};\n  }\n\n  &:after {\n    content: \"\";\n    position: absolute;\n    top: ${({ size }) => SIZES[size].height / 2 - SIZES[size].ball / 2}px;\n    left: 5px;\n    width: ${({ size }) => SIZES[size].ball}px;\n    height: ${({ size }) => SIZES[size].ball}px;\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 }) => SIZES[size].ball * 1.3775}px;\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 }) => SIZES[size].ball * 1.3775}px;\n  }\n\n  &[aria-disabled=\"true\"] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n  }\n`\n\nconst RequiredIcon = () => (\n  <sup>\n    <AsteriskIcon size={8} sentiment=\"danger\" />\n  </sup>\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  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    }: 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          size={size}\n          onClick={evt => evt.stopPropagation()}\n          className={className}\n          data-testid={dataTestId}\n          labelPosition={labelPosition}\n        >\n          <Stack gap={0.25} alignItems=\"baseline\">\n            {label ? (\n              <Row templateColumns=\"auto 1fr\" gap={1} alignItems=\"center\">\n                {typeof label === 'string' ? (\n                  <Text\n                    as=\"label\"\n                    variant={size === 'large' ? 'body' : 'bodySmall'}\n                    prominence=\"default\"\n                    sentiment=\"neutral\"\n                  >\n                    {label}\n                  </Text>\n                ) : (\n                  label\n                )}\n                {required ? <RequiredIcon /> : null}\n              </Row>\n            ) : null}\n            {typeof error === 'string' ? (\n              <Text\n                as=\"p\"\n                variant=\"bodySmall\"\n                prominence=\"default\"\n                sentiment=\"danger\"\n                disabled={disabled}\n              >\n                {error}\n              </Text>\n            ) : null}\n            {helper && !error ? (\n              <Text\n                as=\"p\"\n                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n          </Stack>\n          <StyledToggle\n            size={size}\n            data-checked={state}\n            data-disabled={disabled}\n            data-error={!!error}\n          >\n            <StyledCheckbox\n              id={id || uniqueId}\n              checked={state}\n              aria-checked={state}\n              disabled={disabled}\n              name={name}\n              onChange={onLocalChange}\n              type=\"checkbox\"\n              ref={ref}\n              value={value}\n            />\n          </StyledToggle>\n        </StyledLabel>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
104
+ const RequiredIcon = () => /* @__PURE__ */ jsx("sup", { children: /* @__PURE__ */ jsx(AsteriskIcon, { size: 8, sentiment: "danger" }) });
105
105
  const Toggle = forwardRef(({
106
106
  checked = false,
107
107
  disabled = false,
@@ -131,11 +131,11 @@ const Toggle = forwardRef(({
131
131
  return /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxs(StyledLabel, { "aria-disabled": disabled, size, onClick: (evt) => evt.stopPropagation(), className, "data-testid": dataTestId, labelPosition, children: [
132
132
  /* @__PURE__ */ jsxs(Stack, { gap: 0.25, alignItems: "baseline", children: [
133
133
  label ? /* @__PURE__ */ jsxs(Row, { templateColumns: "auto 1fr", gap: 1, alignItems: "center", children: [
134
- label,
134
+ typeof label === "string" ? /* @__PURE__ */ jsx(Text, { as: "label", variant: size === "large" ? "body" : "bodySmall", prominence: "default", sentiment: "neutral", children: label }) : label,
135
135
  required ? /* @__PURE__ */ jsx(RequiredIcon, {}) : null
136
136
  ] }) : null,
137
137
  typeof error === "string" ? /* @__PURE__ */ jsx(Text, { as: "p", variant: "bodySmall", prominence: "default", sentiment: "danger", disabled, children: error }) : null,
138
- helper && !error ? /* @__PURE__ */ jsx(Text, { as: "p", variant: "bodySmall", prominence: "weak", children: helper }) : null
138
+ helper && !error ? /* @__PURE__ */ jsx(Text, { as: "p", variant: "caption", prominence: "weak", sentiment: "neutral", children: helper }) : null
139
139
  ] }),
140
140
  /* @__PURE__ */ jsx(StyledToggle, { size, "data-checked": state, "data-disabled": disabled, "data-error": !!error, children: /* @__PURE__ */ jsx(StyledCheckbox, { id: id || uniqueId, checked: state, "aria-checked": state, disabled, name, onChange: onLocalChange, type: "checkbox", ref, value }) })
141
141
  ] }) });
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const _styled = require("@emotion/styled/base");
5
- const legacy = require("@ultraviolet/icons/legacy");
5
+ const icons = require("@ultraviolet/icons");
6
6
  const React = require("react");
7
7
  const index = require("../Stack/index.cjs");
8
8
  const index$1 = require("../Text/index.cjs");
@@ -47,10 +47,10 @@ const FieldSet = /* @__PURE__ */ _styled__default.default("fieldset", process.en
47
47
  } : {
48
48
  name: "7o2an9",
49
49
  styles: "border:none;padding:0;margin:0",
50
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RWdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCB7IFRvZ2dsZSB9IGZyb20gJy4uL1RvZ2dsZSdcblxudHlwZSBUb2dnbGVHcm91cENvbnRleHRUeXBlID0ge1xuICBncm91cE5hbWU6IHN0cmluZ1xuICBncm91cFZhbHVlczogc3RyaW5nW11cbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuY29uc3QgVG9nZ2xlR3JvdXBDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxUb2dnbGVHcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMgPSBPbWl0PFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgVG9nZ2xlPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCdcbj4gJiB7XG4gIHZhbHVlOiBzdHJpbmdcbn1cblxuLyoqXG4gKiBUb2dnbGVHcm91cCBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB5b3UgdG8gZ3JvdXAgYSBzZXQgb2YgVG9nZ2xlIGNvbXBvbmVudHMgdG9nZXRoZXIgdW5kZXIgdGhlIHNhbWUgbGVnZW5kLlxuICovXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXBUb2dnbGUgPSAoe1xuICBkaXNhYmxlZCxcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIGxhYmVsLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBUb2dnbGVHcm91cFRvZ2dsZVByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFRvZ2dsZUdyb3VwQ29udGV4dClcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RvZ2dsZUdyb3VwLlRvZ2dsZSBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFRvZ2dsZUdyb3VwJylcbiAgfVxuXG4gIGNvbnN0IHsgZ3JvdXBOYW1lLCBvbkNoYW5nZSwgZ3JvdXBWYWx1ZXMgfSA9IGNvbnRleHRcblxuICBjb25zdCBUb2dnbGVOYW1lID0gYCR7Z3JvdXBOYW1lfS4ke25hbWV9YFxuICBjb25zdCBUb2dnbGVWYWx1ZSA9IGAke3ZhbHVlfWBcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVcbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWVzPy5pbmNsdWRlcyhUb2dnbGVWYWx1ZSl9XG4gICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICBuYW1lPXtUb2dnbGVOYW1lfVxuICAgICAgdmFsdWU9e1RvZ2dsZVZhbHVlfVxuICAgICAgaGVscGVyPXtoZWxwZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgZXJyb3I9e2Vycm9yfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRSZXF1aXJlZEljb24gPSBzdHlsZWQoSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwibGVnZW5kXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIj5cbiAgICAgICAgICAgICAge2xlZ2VuZH0mbmJzcDtcbiAgICAgICAgICAgICAge3JlcXVpcmVkID8gKFxuICAgICAgICAgICAgICAgIDxTdHlsZWRSZXF1aXJlZEljb24gbmFtZT1cImFzdGVyaXNrXCIgY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBnYXA9ezJ9IGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L0ZpZWxkU2V0PlxuICAgICAgICB7aGVscGVyID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2hlbHBlcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7ZXJyb3IgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHNlbnRpbWVudD1cImRhbmdlclwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9Ub2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuVG9nZ2xlR3JvdXAuVG9nZ2xlID0gVG9nZ2xlR3JvdXBUb2dnbGVcbiJdfQ== */",
50
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RWdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgQXN0ZXJpc2tJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHtcbiAgdHlwZSBDb21wb25lbnRQcm9wcyxcbiAgdHlwZSBJbnB1dEhUTUxBdHRyaWJ1dGVzLFxuICB0eXBlIFJlYWN0Tm9kZSxcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlQ29udGV4dCxcbiAgdXNlTWVtbyxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb2dnbGUgfSBmcm9tICcuLi9Ub2dnbGUnXG5cbnR5cGUgVG9nZ2xlR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lOiBzdHJpbmdcbiAgZ3JvdXBWYWx1ZXM6IHN0cmluZ1tdXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmNvbnN0IFRvZ2dsZUdyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8VG9nZ2xlR3JvdXBDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4oXG4gIHVuZGVmaW5lZCxcbilcblxudHlwZSBUb2dnbGVHcm91cFRvZ2dsZVByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFRvZ2dsZT4sXG4gICdvbkNoYW5nZScgfCAnY2hlY2tlZCcgfCAncmVxdWlyZWQnXG4+ICYge1xuICB2YWx1ZTogc3RyaW5nXG59XG5cbi8qKlxuICogVG9nZ2xlR3JvdXAgaXMgYSBjb21wb25lbnQgdGhhdCBhbGxvd3MgeW91IHRvIGdyb3VwIGEgc2V0IG9mIFRvZ2dsZSBjb21wb25lbnRzIHRvZ2V0aGVyIHVuZGVyIHRoZSBzYW1lIGxlZ2VuZC5cbiAqL1xuZXhwb3J0IGNvbnN0IFRvZ2dsZUdyb3VwVG9nZ2xlID0gKHtcbiAgZGlzYWJsZWQsXG4gIG5hbWUsXG4gIHZhbHVlLFxuICBsYWJlbCxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChUb2dnbGVHcm91cENvbnRleHQpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdUb2dnbGVHcm91cC5Ub2dnbGUgY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBUb2dnbGVHcm91cCcpXG4gIH1cblxuICBjb25zdCB7IGdyb3VwTmFtZSwgb25DaGFuZ2UsIGdyb3VwVmFsdWVzIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgVG9nZ2xlTmFtZSA9IGAke2dyb3VwTmFtZX0uJHtuYW1lfWBcbiAgY29uc3QgVG9nZ2xlVmFsdWUgPSBgJHt2YWx1ZX1gXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlXG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBjaGVja2VkPXtncm91cFZhbHVlcz8uaW5jbHVkZXMoVG9nZ2xlVmFsdWUpfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgbmFtZT17VG9nZ2xlTmFtZX1cbiAgICAgIHZhbHVlPXtUb2dnbGVWYWx1ZX1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEFzdGVyaXNrSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwibGVnZW5kXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cInN0cm9uZ1wiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsZWdlbmR9Jm5ic3A7XG4gICAgICAgICAgICAgIHtyZXF1aXJlZCA/IDxTdHlsZWRSZXF1aXJlZEljb24gY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPiA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgZ2FwPXsyfSBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBzZW50aW1lbnQ9XCJkYW5nZXJcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2Vycm9yfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvVG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblRvZ2dsZUdyb3VwLlRvZ2dsZSA9IFRvZ2dsZUdyb3VwVG9nZ2xlXG4iXX0= */",
51
51
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
52
  });
53
- const StyledRequiredIcon = /* @__PURE__ */ _styled__default.default(legacy.Icon, process.env.NODE_ENV === "production" ? {
53
+ const StyledRequiredIcon = /* @__PURE__ */ _styled__default.default(icons.AsteriskIcon, process.env.NODE_ENV === "production" ? {
54
54
  target: "e1qvneex0"
55
55
  } : {
56
56
  target: "e1qvneex0",
@@ -61,7 +61,7 @@ const StyledRequiredIcon = /* @__PURE__ */ _styled__default.default(legacy.Icon,
61
61
  } : {
62
62
  name: "1nglpc5",
63
63
  styles: "vertical-align:super",
64
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RXVDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCB7IFRvZ2dsZSB9IGZyb20gJy4uL1RvZ2dsZSdcblxudHlwZSBUb2dnbGVHcm91cENvbnRleHRUeXBlID0ge1xuICBncm91cE5hbWU6IHN0cmluZ1xuICBncm91cFZhbHVlczogc3RyaW5nW11cbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuY29uc3QgVG9nZ2xlR3JvdXBDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxUb2dnbGVHcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMgPSBPbWl0PFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgVG9nZ2xlPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCdcbj4gJiB7XG4gIHZhbHVlOiBzdHJpbmdcbn1cblxuLyoqXG4gKiBUb2dnbGVHcm91cCBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB5b3UgdG8gZ3JvdXAgYSBzZXQgb2YgVG9nZ2xlIGNvbXBvbmVudHMgdG9nZXRoZXIgdW5kZXIgdGhlIHNhbWUgbGVnZW5kLlxuICovXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXBUb2dnbGUgPSAoe1xuICBkaXNhYmxlZCxcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIGxhYmVsLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBUb2dnbGVHcm91cFRvZ2dsZVByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFRvZ2dsZUdyb3VwQ29udGV4dClcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RvZ2dsZUdyb3VwLlRvZ2dsZSBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFRvZ2dsZUdyb3VwJylcbiAgfVxuXG4gIGNvbnN0IHsgZ3JvdXBOYW1lLCBvbkNoYW5nZSwgZ3JvdXBWYWx1ZXMgfSA9IGNvbnRleHRcblxuICBjb25zdCBUb2dnbGVOYW1lID0gYCR7Z3JvdXBOYW1lfS4ke25hbWV9YFxuICBjb25zdCBUb2dnbGVWYWx1ZSA9IGAke3ZhbHVlfWBcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVcbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWVzPy5pbmNsdWRlcyhUb2dnbGVWYWx1ZSl9XG4gICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICBuYW1lPXtUb2dnbGVOYW1lfVxuICAgICAgdmFsdWU9e1RvZ2dsZVZhbHVlfVxuICAgICAgaGVscGVyPXtoZWxwZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgZXJyb3I9e2Vycm9yfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRSZXF1aXJlZEljb24gPSBzdHlsZWQoSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwibGVnZW5kXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIj5cbiAgICAgICAgICAgICAge2xlZ2VuZH0mbmJzcDtcbiAgICAgICAgICAgICAge3JlcXVpcmVkID8gKFxuICAgICAgICAgICAgICAgIDxTdHlsZWRSZXF1aXJlZEljb24gbmFtZT1cImFzdGVyaXNrXCIgY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBnYXA9ezJ9IGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L0ZpZWxkU2V0PlxuICAgICAgICB7aGVscGVyID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2hlbHBlcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7ZXJyb3IgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHNlbnRpbWVudD1cImRhbmdlclwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9Ub2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuVG9nZ2xlR3JvdXAuVG9nZ2xlID0gVG9nZ2xlR3JvdXBUb2dnbGVcbiJdfQ== */",
64
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RStDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgQXN0ZXJpc2tJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHtcbiAgdHlwZSBDb21wb25lbnRQcm9wcyxcbiAgdHlwZSBJbnB1dEhUTUxBdHRyaWJ1dGVzLFxuICB0eXBlIFJlYWN0Tm9kZSxcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlQ29udGV4dCxcbiAgdXNlTWVtbyxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb2dnbGUgfSBmcm9tICcuLi9Ub2dnbGUnXG5cbnR5cGUgVG9nZ2xlR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lOiBzdHJpbmdcbiAgZ3JvdXBWYWx1ZXM6IHN0cmluZ1tdXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmNvbnN0IFRvZ2dsZUdyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8VG9nZ2xlR3JvdXBDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4oXG4gIHVuZGVmaW5lZCxcbilcblxudHlwZSBUb2dnbGVHcm91cFRvZ2dsZVByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFRvZ2dsZT4sXG4gICdvbkNoYW5nZScgfCAnY2hlY2tlZCcgfCAncmVxdWlyZWQnXG4+ICYge1xuICB2YWx1ZTogc3RyaW5nXG59XG5cbi8qKlxuICogVG9nZ2xlR3JvdXAgaXMgYSBjb21wb25lbnQgdGhhdCBhbGxvd3MgeW91IHRvIGdyb3VwIGEgc2V0IG9mIFRvZ2dsZSBjb21wb25lbnRzIHRvZ2V0aGVyIHVuZGVyIHRoZSBzYW1lIGxlZ2VuZC5cbiAqL1xuZXhwb3J0IGNvbnN0IFRvZ2dsZUdyb3VwVG9nZ2xlID0gKHtcbiAgZGlzYWJsZWQsXG4gIG5hbWUsXG4gIHZhbHVlLFxuICBsYWJlbCxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChUb2dnbGVHcm91cENvbnRleHQpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdUb2dnbGVHcm91cC5Ub2dnbGUgY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBUb2dnbGVHcm91cCcpXG4gIH1cblxuICBjb25zdCB7IGdyb3VwTmFtZSwgb25DaGFuZ2UsIGdyb3VwVmFsdWVzIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgVG9nZ2xlTmFtZSA9IGAke2dyb3VwTmFtZX0uJHtuYW1lfWBcbiAgY29uc3QgVG9nZ2xlVmFsdWUgPSBgJHt2YWx1ZX1gXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlXG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBjaGVja2VkPXtncm91cFZhbHVlcz8uaW5jbHVkZXMoVG9nZ2xlVmFsdWUpfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgbmFtZT17VG9nZ2xlTmFtZX1cbiAgICAgIHZhbHVlPXtUb2dnbGVWYWx1ZX1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEFzdGVyaXNrSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwibGVnZW5kXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cInN0cm9uZ1wiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsZWdlbmR9Jm5ic3A7XG4gICAgICAgICAgICAgIHtyZXF1aXJlZCA/IDxTdHlsZWRSZXF1aXJlZEljb24gY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPiA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgZ2FwPXsyfSBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBzZW50aW1lbnQ9XCJkYW5nZXJcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2Vycm9yfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvVG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblRvZ2dsZUdyb3VwLlRvZ2dsZSA9IFRvZ2dsZUdyb3VwVG9nZ2xlXG4iXX0= */",
65
65
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
66
66
  });
67
67
  const ToggleGroup = ({
@@ -83,10 +83,10 @@ const ToggleGroup = ({
83
83
  }), [name, value, onChange]);
84
84
  return /* @__PURE__ */ jsxRuntime.jsx(ToggleGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 1, children: [
85
85
  /* @__PURE__ */ jsxRuntime.jsx(FieldSet, { className, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 1.5, children: [
86
- /* @__PURE__ */ jsxRuntime.jsxs(index$1.Text, { as: "legend", variant: "bodyStrong", children: [
86
+ /* @__PURE__ */ jsxRuntime.jsxs(index$1.Text, { as: "legend", variant: "bodyStrong", sentiment: "neutral", prominence: "strong", children: [
87
87
  legend,
88
88
  " ",
89
- required ? /* @__PURE__ */ jsxRuntime.jsx(StyledRequiredIcon, { name: "asterisk", color: "danger", size: 8 }) : null
89
+ required ? /* @__PURE__ */ jsxRuntime.jsx(StyledRequiredIcon, { color: "danger", size: 8 }) : null
90
90
  ] }),
91
91
  /* @__PURE__ */ jsxRuntime.jsx(index.Stack, { gap: 2, direction, children })
92
92
  ] }) }),
@@ -1,6 +1,6 @@
1
1
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
2
2
  import _styled from "@emotion/styled/base";
3
- import { Icon } from "@ultraviolet/icons/legacy";
3
+ import { AsteriskIcon } from "@ultraviolet/icons";
4
4
  import { createContext, useMemo, useContext } from "react";
5
5
  import { Stack } from "../Stack/index.js";
6
6
  import { Text } from "../Text/index.js";
@@ -43,10 +43,10 @@ const FieldSet = /* @__PURE__ */ _styled("fieldset", process.env.NODE_ENV === "p
43
43
  } : {
44
44
  name: "7o2an9",
45
45
  styles: "border:none;padding:0;margin:0",
46
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RWdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCB7IFRvZ2dsZSB9IGZyb20gJy4uL1RvZ2dsZSdcblxudHlwZSBUb2dnbGVHcm91cENvbnRleHRUeXBlID0ge1xuICBncm91cE5hbWU6IHN0cmluZ1xuICBncm91cFZhbHVlczogc3RyaW5nW11cbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuY29uc3QgVG9nZ2xlR3JvdXBDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxUb2dnbGVHcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMgPSBPbWl0PFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgVG9nZ2xlPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCdcbj4gJiB7XG4gIHZhbHVlOiBzdHJpbmdcbn1cblxuLyoqXG4gKiBUb2dnbGVHcm91cCBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB5b3UgdG8gZ3JvdXAgYSBzZXQgb2YgVG9nZ2xlIGNvbXBvbmVudHMgdG9nZXRoZXIgdW5kZXIgdGhlIHNhbWUgbGVnZW5kLlxuICovXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXBUb2dnbGUgPSAoe1xuICBkaXNhYmxlZCxcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIGxhYmVsLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBUb2dnbGVHcm91cFRvZ2dsZVByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFRvZ2dsZUdyb3VwQ29udGV4dClcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RvZ2dsZUdyb3VwLlRvZ2dsZSBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFRvZ2dsZUdyb3VwJylcbiAgfVxuXG4gIGNvbnN0IHsgZ3JvdXBOYW1lLCBvbkNoYW5nZSwgZ3JvdXBWYWx1ZXMgfSA9IGNvbnRleHRcblxuICBjb25zdCBUb2dnbGVOYW1lID0gYCR7Z3JvdXBOYW1lfS4ke25hbWV9YFxuICBjb25zdCBUb2dnbGVWYWx1ZSA9IGAke3ZhbHVlfWBcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVcbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWVzPy5pbmNsdWRlcyhUb2dnbGVWYWx1ZSl9XG4gICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICBuYW1lPXtUb2dnbGVOYW1lfVxuICAgICAgdmFsdWU9e1RvZ2dsZVZhbHVlfVxuICAgICAgaGVscGVyPXtoZWxwZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgZXJyb3I9e2Vycm9yfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRSZXF1aXJlZEljb24gPSBzdHlsZWQoSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwibGVnZW5kXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIj5cbiAgICAgICAgICAgICAge2xlZ2VuZH0mbmJzcDtcbiAgICAgICAgICAgICAge3JlcXVpcmVkID8gKFxuICAgICAgICAgICAgICAgIDxTdHlsZWRSZXF1aXJlZEljb24gbmFtZT1cImFzdGVyaXNrXCIgY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBnYXA9ezJ9IGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L0ZpZWxkU2V0PlxuICAgICAgICB7aGVscGVyID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2hlbHBlcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7ZXJyb3IgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHNlbnRpbWVudD1cImRhbmdlclwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9Ub2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuVG9nZ2xlR3JvdXAuVG9nZ2xlID0gVG9nZ2xlR3JvdXBUb2dnbGVcbiJdfQ== */",
46
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RWdDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgQXN0ZXJpc2tJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHtcbiAgdHlwZSBDb21wb25lbnRQcm9wcyxcbiAgdHlwZSBJbnB1dEhUTUxBdHRyaWJ1dGVzLFxuICB0eXBlIFJlYWN0Tm9kZSxcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlQ29udGV4dCxcbiAgdXNlTWVtbyxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb2dnbGUgfSBmcm9tICcuLi9Ub2dnbGUnXG5cbnR5cGUgVG9nZ2xlR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lOiBzdHJpbmdcbiAgZ3JvdXBWYWx1ZXM6IHN0cmluZ1tdXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmNvbnN0IFRvZ2dsZUdyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8VG9nZ2xlR3JvdXBDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4oXG4gIHVuZGVmaW5lZCxcbilcblxudHlwZSBUb2dnbGVHcm91cFRvZ2dsZVByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFRvZ2dsZT4sXG4gICdvbkNoYW5nZScgfCAnY2hlY2tlZCcgfCAncmVxdWlyZWQnXG4+ICYge1xuICB2YWx1ZTogc3RyaW5nXG59XG5cbi8qKlxuICogVG9nZ2xlR3JvdXAgaXMgYSBjb21wb25lbnQgdGhhdCBhbGxvd3MgeW91IHRvIGdyb3VwIGEgc2V0IG9mIFRvZ2dsZSBjb21wb25lbnRzIHRvZ2V0aGVyIHVuZGVyIHRoZSBzYW1lIGxlZ2VuZC5cbiAqL1xuZXhwb3J0IGNvbnN0IFRvZ2dsZUdyb3VwVG9nZ2xlID0gKHtcbiAgZGlzYWJsZWQsXG4gIG5hbWUsXG4gIHZhbHVlLFxuICBsYWJlbCxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChUb2dnbGVHcm91cENvbnRleHQpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdUb2dnbGVHcm91cC5Ub2dnbGUgY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBUb2dnbGVHcm91cCcpXG4gIH1cblxuICBjb25zdCB7IGdyb3VwTmFtZSwgb25DaGFuZ2UsIGdyb3VwVmFsdWVzIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgVG9nZ2xlTmFtZSA9IGAke2dyb3VwTmFtZX0uJHtuYW1lfWBcbiAgY29uc3QgVG9nZ2xlVmFsdWUgPSBgJHt2YWx1ZX1gXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlXG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBjaGVja2VkPXtncm91cFZhbHVlcz8uaW5jbHVkZXMoVG9nZ2xlVmFsdWUpfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgbmFtZT17VG9nZ2xlTmFtZX1cbiAgICAgIHZhbHVlPXtUb2dnbGVWYWx1ZX1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEFzdGVyaXNrSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwibGVnZW5kXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cInN0cm9uZ1wiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsZWdlbmR9Jm5ic3A7XG4gICAgICAgICAgICAgIHtyZXF1aXJlZCA/IDxTdHlsZWRSZXF1aXJlZEljb24gY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPiA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgZ2FwPXsyfSBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBzZW50aW1lbnQ9XCJkYW5nZXJcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2Vycm9yfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvVG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblRvZ2dsZUdyb3VwLlRvZ2dsZSA9IFRvZ2dsZUdyb3VwVG9nZ2xlXG4iXX0= */",
47
47
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
48
48
  });
49
- const StyledRequiredIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV === "production" ? {
49
+ const StyledRequiredIcon = /* @__PURE__ */ _styled(AsteriskIcon, process.env.NODE_ENV === "production" ? {
50
50
  target: "e1qvneex0"
51
51
  } : {
52
52
  target: "e1qvneex0",
@@ -57,7 +57,7 @@ const StyledRequiredIcon = /* @__PURE__ */ _styled(Icon, process.env.NODE_ENV ==
57
57
  } : {
58
58
  name: "1nglpc5",
59
59
  styles: "vertical-align:super",
60
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RXVDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0B1bHRyYXZpb2xldC9pY29ucy9sZWdhY3knXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFN0YWNrIH0gZnJvbSAnLi4vU3RhY2snXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVGV4dCdcbmltcG9ydCB7IFRvZ2dsZSB9IGZyb20gJy4uL1RvZ2dsZSdcblxudHlwZSBUb2dnbGVHcm91cENvbnRleHRUeXBlID0ge1xuICBncm91cE5hbWU6IHN0cmluZ1xuICBncm91cFZhbHVlczogc3RyaW5nW11cbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuY29uc3QgVG9nZ2xlR3JvdXBDb250ZXh0ID0gY3JlYXRlQ29udGV4dDxUb2dnbGVHcm91cENvbnRleHRUeXBlIHwgdW5kZWZpbmVkPihcbiAgdW5kZWZpbmVkLFxuKVxuXG50eXBlIFRvZ2dsZUdyb3VwVG9nZ2xlUHJvcHMgPSBPbWl0PFxuICBDb21wb25lbnRQcm9wczx0eXBlb2YgVG9nZ2xlPixcbiAgJ29uQ2hhbmdlJyB8ICdjaGVja2VkJyB8ICdyZXF1aXJlZCdcbj4gJiB7XG4gIHZhbHVlOiBzdHJpbmdcbn1cblxuLyoqXG4gKiBUb2dnbGVHcm91cCBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB5b3UgdG8gZ3JvdXAgYSBzZXQgb2YgVG9nZ2xlIGNvbXBvbmVudHMgdG9nZXRoZXIgdW5kZXIgdGhlIHNhbWUgbGVnZW5kLlxuICovXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXBUb2dnbGUgPSAoe1xuICBkaXNhYmxlZCxcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIGxhYmVsLFxuICBoZWxwZXIsXG4gIGVycm9yLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBUb2dnbGVHcm91cFRvZ2dsZVByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHQgPSB1c2VDb250ZXh0KFRvZ2dsZUdyb3VwQ29udGV4dClcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RvZ2dsZUdyb3VwLlRvZ2dsZSBjYW4gb25seSBiZSB1c2VkIGluc2lkZSBhIFRvZ2dsZUdyb3VwJylcbiAgfVxuXG4gIGNvbnN0IHsgZ3JvdXBOYW1lLCBvbkNoYW5nZSwgZ3JvdXBWYWx1ZXMgfSA9IGNvbnRleHRcblxuICBjb25zdCBUb2dnbGVOYW1lID0gYCR7Z3JvdXBOYW1lfS4ke25hbWV9YFxuICBjb25zdCBUb2dnbGVWYWx1ZSA9IGAke3ZhbHVlfWBcblxuICByZXR1cm4gKFxuICAgIDxUb2dnbGVcbiAgICAgIG9uQ2hhbmdlPXtvbkNoYW5nZX1cbiAgICAgIGNoZWNrZWQ9e2dyb3VwVmFsdWVzPy5pbmNsdWRlcyhUb2dnbGVWYWx1ZSl9XG4gICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICBuYW1lPXtUb2dnbGVOYW1lfVxuICAgICAgdmFsdWU9e1RvZ2dsZVZhbHVlfVxuICAgICAgaGVscGVyPXtoZWxwZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgZXJyb3I9e2Vycm9yfVxuICAgIC8+XG4gIClcbn1cblxuY29uc3QgRmllbGRTZXQgPSBzdHlsZWQuZmllbGRzZXRgXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuYFxuXG5jb25zdCBTdHlsZWRSZXF1aXJlZEljb24gPSBzdHlsZWQoSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0IGFzPVwibGVnZW5kXCIgdmFyaWFudD1cImJvZHlTdHJvbmdcIj5cbiAgICAgICAgICAgICAge2xlZ2VuZH0mbmJzcDtcbiAgICAgICAgICAgICAge3JlcXVpcmVkID8gKFxuICAgICAgICAgICAgICAgIDxTdHlsZWRSZXF1aXJlZEljb24gbmFtZT1cImFzdGVyaXNrXCIgY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPlxuICAgICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDxTdGFjayBnYXA9ezJ9IGRpcmVjdGlvbj17ZGlyZWN0aW9ufT5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICA8L0ZpZWxkU2V0PlxuICAgICAgICB7aGVscGVyID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2hlbHBlcn1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiBudWxsfVxuICAgICAgICB7ZXJyb3IgPyAoXG4gICAgICAgICAgPFRleHQgYXM9XCJwXCIgdmFyaWFudD1cImJvZHlTbWFsbFwiIHNlbnRpbWVudD1cImRhbmdlclwiIHByb21pbmVuY2U9XCJ3ZWFrXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9Ub2dnbGVHcm91cENvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuVG9nZ2xlR3JvdXAuVG9nZ2xlID0gVG9nZ2xlR3JvdXBUb2dnbGVcbiJdfQ== */",
60
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RStDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1RvZ2dsZUdyb3VwL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHsgQXN0ZXJpc2tJY29uIH0gZnJvbSAnQHVsdHJhdmlvbGV0L2ljb25zJ1xuaW1wb3J0IHtcbiAgdHlwZSBDb21wb25lbnRQcm9wcyxcbiAgdHlwZSBJbnB1dEhUTUxBdHRyaWJ1dGVzLFxuICB0eXBlIFJlYWN0Tm9kZSxcbiAgY3JlYXRlQ29udGV4dCxcbiAgdXNlQ29udGV4dCxcbiAgdXNlTWVtbyxcbn0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5pbXBvcnQgeyBUb2dnbGUgfSBmcm9tICcuLi9Ub2dnbGUnXG5cbnR5cGUgVG9nZ2xlR3JvdXBDb250ZXh0VHlwZSA9IHtcbiAgZ3JvdXBOYW1lOiBzdHJpbmdcbiAgZ3JvdXBWYWx1ZXM6IHN0cmluZ1tdXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbmNvbnN0IFRvZ2dsZUdyb3VwQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8VG9nZ2xlR3JvdXBDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4oXG4gIHVuZGVmaW5lZCxcbilcblxudHlwZSBUb2dnbGVHcm91cFRvZ2dsZVByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIFRvZ2dsZT4sXG4gICdvbkNoYW5nZScgfCAnY2hlY2tlZCcgfCAncmVxdWlyZWQnXG4+ICYge1xuICB2YWx1ZTogc3RyaW5nXG59XG5cbi8qKlxuICogVG9nZ2xlR3JvdXAgaXMgYSBjb21wb25lbnQgdGhhdCBhbGxvd3MgeW91IHRvIGdyb3VwIGEgc2V0IG9mIFRvZ2dsZSBjb21wb25lbnRzIHRvZ2V0aGVyIHVuZGVyIHRoZSBzYW1lIGxlZ2VuZC5cbiAqL1xuZXhwb3J0IGNvbnN0IFRvZ2dsZUdyb3VwVG9nZ2xlID0gKHtcbiAgZGlzYWJsZWQsXG4gIG5hbWUsXG4gIHZhbHVlLFxuICBsYWJlbCxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogVG9nZ2xlR3JvdXBUb2dnbGVQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChUb2dnbGVHcm91cENvbnRleHQpXG5cbiAgaWYgKCFjb250ZXh0KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdUb2dnbGVHcm91cC5Ub2dnbGUgY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBUb2dnbGVHcm91cCcpXG4gIH1cblxuICBjb25zdCB7IGdyb3VwTmFtZSwgb25DaGFuZ2UsIGdyb3VwVmFsdWVzIH0gPSBjb250ZXh0XG5cbiAgY29uc3QgVG9nZ2xlTmFtZSA9IGAke2dyb3VwTmFtZX0uJHtuYW1lfWBcbiAgY29uc3QgVG9nZ2xlVmFsdWUgPSBgJHt2YWx1ZX1gXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlXG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBjaGVja2VkPXtncm91cFZhbHVlcz8uaW5jbHVkZXMoVG9nZ2xlVmFsdWUpfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgbmFtZT17VG9nZ2xlTmFtZX1cbiAgICAgIHZhbHVlPXtUb2dnbGVWYWx1ZX1cbiAgICAgIGhlbHBlcj17aGVscGVyfVxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgIGxhYmVsPXtsYWJlbH1cbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEFzdGVyaXNrSWNvbilgXG4gIHZlcnRpY2FsLWFsaWduOiBzdXBlcjtcbmBcblxudHlwZSBUb2dnbGVHcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZT86IHN0cmluZ1tdXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHJlcXVpcmVkPzogYm9vbGVhblxufSAmIFJlcXVpcmVkPFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ29uQ2hhbmdlJyB8ICduYW1lJz4+ICZcbiAgUGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAncmVxdWlyZWQnPlxuXG5leHBvcnQgY29uc3QgVG9nZ2xlR3JvdXAgPSAoe1xuICBsZWdlbmQsXG4gIHZhbHVlLFxuICBjbGFzc05hbWUsXG4gIGhlbHBlcixcbiAgZXJyb3IsXG4gIGRpcmVjdGlvbiA9ICdjb2x1bW4nLFxuICBjaGlsZHJlbixcbiAgb25DaGFuZ2UsXG4gIG5hbWUsXG4gIHJlcXVpcmVkID0gZmFsc2UsXG59OiBUb2dnbGVHcm91cFByb3BzKSA9PiB7XG4gIGNvbnN0IGNvbnRleHRWYWx1ZSA9IHVzZU1lbW8oXG4gICAgKCkgPT4gKHtcbiAgICAgIGdyb3VwTmFtZTogbmFtZSxcbiAgICAgIGdyb3VwVmFsdWVzOiB2YWx1ZSA/PyBbXSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgIH0pLFxuICAgIFtuYW1lLCB2YWx1ZSwgb25DaGFuZ2VdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8VG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyIHZhbHVlPXtjb250ZXh0VmFsdWV9PlxuICAgICAgPFN0YWNrIGdhcD17MX0+XG4gICAgICAgIDxGaWVsZFNldCBjbGFzc05hbWU9e2NsYXNzTmFtZX0+XG4gICAgICAgICAgPFN0YWNrIGdhcD17MS41fT5cbiAgICAgICAgICAgIDxUZXh0XG4gICAgICAgICAgICAgIGFzPVwibGVnZW5kXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cInN0cm9uZ1wiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsZWdlbmR9Jm5ic3A7XG4gICAgICAgICAgICAgIHtyZXF1aXJlZCA/IDxTdHlsZWRSZXF1aXJlZEljb24gY29sb3I9XCJkYW5nZXJcIiBzaXplPXs4fSAvPiA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8U3RhY2sgZ2FwPXsyfSBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dCBhcz1cInBcIiB2YXJpYW50PVwiYm9keVNtYWxsXCIgcHJvbWluZW5jZT1cIndlYWtcIj5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwicFwiIHZhcmlhbnQ9XCJib2R5U21hbGxcIiBzZW50aW1lbnQ9XCJkYW5nZXJcIiBwcm9taW5lbmNlPVwid2Vha1wiPlxuICAgICAgICAgICAge2Vycm9yfVxuICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgKSA6IG51bGx9XG4gICAgICA8L1N0YWNrPlxuICAgIDwvVG9nZ2xlR3JvdXBDb250ZXh0LlByb3ZpZGVyPlxuICApXG59XG5cblRvZ2dsZUdyb3VwLlRvZ2dsZSA9IFRvZ2dsZUdyb3VwVG9nZ2xlXG4iXX0= */",
61
61
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
62
62
  });
63
63
  const ToggleGroup = ({
@@ -79,10 +79,10 @@ const ToggleGroup = ({
79
79
  }), [name, value, onChange]);
80
80
  return /* @__PURE__ */ jsx(ToggleGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxs(Stack, { gap: 1, children: [
81
81
  /* @__PURE__ */ jsx(FieldSet, { className, children: /* @__PURE__ */ jsxs(Stack, { gap: 1.5, children: [
82
- /* @__PURE__ */ jsxs(Text, { as: "legend", variant: "bodyStrong", children: [
82
+ /* @__PURE__ */ jsxs(Text, { as: "legend", variant: "bodyStrong", sentiment: "neutral", prominence: "strong", children: [
83
83
  legend,
84
84
  " ",
85
- required ? /* @__PURE__ */ jsx(StyledRequiredIcon, { name: "asterisk", color: "danger", size: 8 }) : null
85
+ required ? /* @__PURE__ */ jsx(StyledRequiredIcon, { color: "danger", size: 8 }) : null
86
86
  ] }),
87
87
  /* @__PURE__ */ jsx(Stack, { gap: 2, direction, children })
88
88
  ] }) }),