@ultraviolet/ui 1.78.0 → 1.79.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 (68) hide show
  1. package/dist/components/Banner/index.cjs +7 -7
  2. package/dist/components/Banner/index.d.ts +4 -0
  3. package/dist/components/Banner/index.js +7 -7
  4. package/dist/components/Breadcrumbs/components/Item.cjs +3 -3
  5. package/dist/components/Breadcrumbs/components/Item.d.ts +1 -1
  6. package/dist/components/Breadcrumbs/components/Item.js +3 -3
  7. package/dist/components/Checkbox/index.cjs +10 -10
  8. package/dist/components/Checkbox/index.js +10 -10
  9. package/dist/components/CheckboxGroup/index.cjs +9 -7
  10. package/dist/components/CheckboxGroup/index.js +9 -7
  11. package/dist/components/Chip/index.d.ts +1 -1
  12. package/dist/components/DateInput/index.cjs +2 -2
  13. package/dist/components/DateInput/index.js +2 -2
  14. package/dist/components/Drawer/index.d.ts +19 -0
  15. package/dist/components/LineChart/CustomLegend.cjs +55 -30
  16. package/dist/components/LineChart/CustomLegend.js +55 -30
  17. package/dist/components/LineChart/helpers.cjs +6 -6
  18. package/dist/components/LineChart/helpers.js +6 -6
  19. package/dist/components/List/index.cjs +2 -12
  20. package/dist/components/List/index.js +2 -12
  21. package/dist/components/Loader/index.cjs +18 -4
  22. package/dist/components/Loader/index.js +18 -4
  23. package/dist/components/Modal/components/Dialog.cjs +7 -7
  24. package/dist/components/Modal/components/Dialog.js +7 -7
  25. package/dist/components/NumberInputV2/index.cjs +7 -7
  26. package/dist/components/NumberInputV2/index.js +7 -7
  27. package/dist/components/Popup/index.cjs +10 -8
  28. package/dist/components/Popup/index.js +11 -9
  29. package/dist/components/RadioGroup/index.cjs +8 -6
  30. package/dist/components/RadioGroup/index.js +8 -6
  31. package/dist/components/SelectInput/index.cjs +19 -19
  32. package/dist/components/SelectInput/index.js +19 -19
  33. package/dist/components/SelectInputV2/Dropdown.cjs +12 -12
  34. package/dist/components/SelectInputV2/Dropdown.js +12 -12
  35. package/dist/components/SelectInputV2/SearchBarDropdown.cjs +6 -3
  36. package/dist/components/SelectInputV2/SearchBarDropdown.js +6 -3
  37. package/dist/components/SelectInputV2/SelectInputProvider.cjs +14 -7
  38. package/dist/components/SelectInputV2/SelectInputProvider.js +14 -7
  39. package/dist/components/SelectInputV2/findOptionInOptions.cjs +1 -1
  40. package/dist/components/SelectInputV2/findOptionInOptions.js +1 -1
  41. package/dist/components/SelectableCard/index.cjs +16 -11
  42. package/dist/components/SelectableCard/index.js +16 -11
  43. package/dist/components/SelectableCardGroup/index.cjs +8 -6
  44. package/dist/components/SelectableCardGroup/index.js +8 -6
  45. package/dist/components/Slider/components/DoubleSlider.cjs +8 -8
  46. package/dist/components/Slider/components/DoubleSlider.js +8 -8
  47. package/dist/components/Slider/components/SingleSlider.cjs +4 -4
  48. package/dist/components/Slider/components/SingleSlider.js +4 -4
  49. package/dist/components/Slider/styles.d.ts +1 -1
  50. package/dist/components/Snippet/index.cjs +11 -11
  51. package/dist/components/Snippet/index.js +11 -11
  52. package/dist/components/Stepper/index.cjs +7 -10
  53. package/dist/components/Stepper/index.js +7 -10
  54. package/dist/components/Table/index.cjs +2 -16
  55. package/dist/components/Table/index.js +2 -16
  56. package/dist/components/TagInput/index.cjs +10 -10
  57. package/dist/components/TagInput/index.js +10 -10
  58. package/dist/components/TagList/index.cjs +9 -9
  59. package/dist/components/TagList/index.js +9 -9
  60. package/dist/components/TextArea/index.cjs +4 -4
  61. package/dist/components/TextArea/index.js +4 -4
  62. package/dist/components/ToggleGroup/index.cjs +8 -6
  63. package/dist/components/ToggleGroup/index.js +8 -6
  64. package/dist/components/VerificationCode/index.cjs +16 -33
  65. package/dist/components/VerificationCode/index.js +16 -33
  66. package/dist/helpers/isJSON.cjs +1 -1
  67. package/dist/helpers/isJSON.js +1 -1
  68. package/package.json +3 -3
@@ -21,7 +21,7 @@ const ErrorText = /* @__PURE__ */ _styled__default.default(index.Text, process.e
21
21
  label: "ErrorText"
22
22
  })("padding-top:", ({
23
23
  theme
24
- }) => `${theme.space["0.5"]}`, ";" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAe8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
24
+ }) => `${theme.space["0.5"]}`, ";" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAe8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
25
25
  const InnerCheckbox = /* @__PURE__ */ _styled__default.default("rect", process.env.NODE_ENV === "production" ? {
26
26
  target: "eqr7bqq7"
27
27
  } : {
@@ -31,13 +31,13 @@ const InnerCheckbox = /* @__PURE__ */ _styled__default.default("rect", process.e
31
31
  theme
32
32
  }) => theme.colors.neutral.background, ";stroke:", ({
33
33
  theme
34
- }) => theme.colors.neutral.border, ";" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAkBiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
34
+ }) => theme.colors.neutral.border, ";" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAkBiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
35
35
  const CheckMixedMark = /* @__PURE__ */ _styled__default.default("rect", process.env.NODE_ENV === "production" ? {
36
36
  target: "eqr7bqq6"
37
37
  } : {
38
38
  target: "eqr7bqq6",
39
39
  label: "CheckMixedMark"
40
- })(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/Checkbox/index.tsx"],"names":[],"mappings":"AAuBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
40
+ })(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/Checkbox/index.tsx"],"names":[],"mappings":"AAuBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
41
41
  const CheckboxIconContainer = ({
42
42
  children
43
43
  }) => {
@@ -64,7 +64,7 @@ const StyledIcon = /* @__PURE__ */ _styled__default.default("svg", process.env.N
64
64
  size
65
65
  }) => typeof size === "string" ? size : `${size}px`, ";& path{fill:", ({
66
66
  theme
67
- }) => theme.colors.neutral.background, ";transform:translate(2px, 2px);transform:scale(0);}" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AA2C2D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
67
+ }) => theme.colors.neutral.background, ";transform:translate(2px, 2px);transform:scale(0);}" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AA2C2D","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
68
68
  const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
69
69
  target: "eqr7bqq4"
70
70
  } : {
@@ -75,7 +75,7 @@ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.en
75
75
  styles: "width:100%;cursor:pointer"
76
76
  } : {
77
77
  name: "h9u7nh",
78
- styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAwDmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
78
+ styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAwDmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
79
79
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
80
80
  });
81
81
  const StyledTextLabel = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
@@ -88,7 +88,7 @@ const StyledTextLabel = /* @__PURE__ */ _styled__default.default(index.Text, pro
88
88
  styles: "width:100%;cursor:pointer"
89
89
  } : {
90
90
  name: "h9u7nh",
91
- styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AA6DoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
91
+ styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AA6DoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
92
92
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
93
  });
94
94
  const CheckboxInput = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
@@ -130,7 +130,7 @@ const CheckboxInput = /* @__PURE__ */ _styled__default.default("input", process.
130
130
  theme
131
131
  }) => theme.colors.danger.borderHover, ";fill:", ({
132
132
  theme
133
- }) => theme.colors.danger.backgroundHover, ";}}" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAoEkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
133
+ }) => theme.colors.danger.backgroundHover, ";}}" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAoEkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
134
134
  const CheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
135
135
  target: "eqr7bqq1"
136
136
  } : {
@@ -210,7 +210,7 @@ const CheckboxContainer = /* @__PURE__ */ _styled__default.default("div", proces
210
210
  theme
211
211
  }) => theme.colors.danger.backgroundStrong, ";fill:", ({
212
212
  theme
213
- }) => theme.colors.danger.background, ";}}" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAgI2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
213
+ }) => theme.colors.danger.background, ";}}" + (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/Checkbox/index.tsx"],"names":[],"mappings":"AAgI2C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
214
214
  const StyledActivityContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
215
215
  target: "eqr7bqq0"
216
216
  } : {
@@ -221,7 +221,7 @@ const StyledActivityContainer = /* @__PURE__ */ _styled__default.default("div",
221
221
  styles: "display:flex"
222
222
  } : {
223
223
  name: "zjik7",
224
- styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAsQ0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
224
+ styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAsQ0C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx","sourcesContent":["import { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { AsteriskIcon } from '@ultraviolet/icons'\nimport type {\n  ChangeEvent,\n  ForwardedRef,\n  InputHTMLAttributes,\n  ReactNode,\n} from 'react'\nimport { forwardRef, useCallback, useEffect, useId, useState } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'onFocus'\n  | 'onBlur'\n  | 'name'\n  | 'value'\n  | 'autoFocus'\n  | 'id'\n  | 'onChange'\n  | 'tabIndex'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    }: CheckboxProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const theme = useTheme()\n    const [state, setState] = useState<boolean | 'indeterminate'>(checked)\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    useEffect(() => {\n      setState(checked)\n    }, [checked])\n\n    const onLocalChange = useCallback(\n      (event: ChangeEvent<HTMLInputElement>) => {\n        if (!progress) onChange?.(event)\n        setState(current =>\n          current === 'indeterminate' ? false : event.target.checked,\n        )\n      },\n      [onChange, progress, setState],\n    )\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={disabled}\n          data-visibility={dataVisibility}\n          data-checked={state}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={state === 'indeterminate' ? 'mixed' : state}\n            aria-label={ariaLabel}\n            checked={state === 'indeterminate' ? false : state}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onLocalChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={disabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {state !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
225
225
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
226
226
  });
227
227
  const Checkbox = React.forwardRef(({
@@ -268,7 +268,7 @@ const Checkbox = React.forwardRef(({
268
268
  required ? /* @__PURE__ */ jsxRuntime.jsx("sup", { children: /* @__PURE__ */ jsxRuntime.jsx(Icon.AsteriskIcon, { size: 8, sentiment: "danger" }) }) : null
269
269
  ] }),
270
270
  helper ? /* @__PURE__ */ jsxRuntime.jsx(index.Text, { variant: "caption", as: "span", prominence: "weak", sentiment: "neutral", children: helper }) : null,
271
- error ? /* @__PURE__ */ jsxRuntime.jsx(ErrorText, { variant: "caption", as: "span", sentiment: "danger", children: error }) : null
271
+ error && typeof error !== "boolean" ? /* @__PURE__ */ jsxRuntime.jsx(ErrorText, { variant: "caption", as: "span", sentiment: "danger", children: error }) : null
272
272
  ] })
273
273
  ] }) });
274
274
  });