@ultraviolet/ui 1.72.2 → 1.73.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.
@@ -1,4 +1,4 @@
1
- import { jsx, jsxs } from "@emotion/react/jsx-runtime";
1
+ import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
2
2
  import _styled from "@emotion/styled/base";
3
3
  import { useTheme } from "@emotion/react";
4
4
  import { AsteriskIcon } from "@ultraviolet/icons";
@@ -11,29 +11,29 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
11
11
  return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
12
12
  }
13
13
  const ErrorText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
14
- target: "eqr7bqq7"
14
+ target: "eqr7bqq8"
15
15
  } : {
16
- target: "eqr7bqq7",
16
+ target: "eqr7bqq8",
17
17
  label: "ErrorText"
18
18
  })("padding-top:", ({
19
19
  theme
20
- }) => `${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":"AAgB8B","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */"));
20
+ }) => `${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":"AAgB8B","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */"));
21
21
  const InnerCheckbox = /* @__PURE__ */ _styled("rect", process.env.NODE_ENV === "production" ? {
22
- target: "eqr7bqq6"
22
+ target: "eqr7bqq7"
23
23
  } : {
24
- target: "eqr7bqq6",
24
+ target: "eqr7bqq7",
25
25
  label: "InnerCheckbox"
26
26
  })("fill:", ({
27
27
  theme
28
28
  }) => theme.colors.neutral.background, ";stroke:", ({
29
29
  theme
30
- }) => 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":"AAmBiC","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */"));
30
+ }) => 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":"AAmBiC","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */"));
31
31
  const CheckMixedMark = /* @__PURE__ */ _styled("rect", process.env.NODE_ENV === "production" ? {
32
- target: "eqr7bqq5"
32
+ target: "eqr7bqq6"
33
33
  } : {
34
- target: "eqr7bqq5",
34
+ target: "eqr7bqq6",
35
35
  label: "CheckMixedMark"
36
- })(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":"AAwBkC","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */");
36
+ })(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":"AAwBkC","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */");
37
37
  const CheckboxIconContainer = ({
38
38
  children
39
39
  }) => {
@@ -44,9 +44,9 @@ const CheckboxIconContainer = ({
44
44
  ] });
45
45
  };
46
46
  const StyledIcon = /* @__PURE__ */ _styled("svg", process.env.NODE_ENV === "production" ? {
47
- target: "eqr7bqq4"
47
+ target: "eqr7bqq5"
48
48
  } : {
49
- target: "eqr7bqq4",
49
+ target: "eqr7bqq5",
50
50
  label: "StyledIcon"
51
51
  })("border-radius:", ({
52
52
  theme
@@ -60,19 +60,33 @@ const StyledIcon = /* @__PURE__ */ _styled("svg", process.env.NODE_ENV === "prod
60
60
  size
61
61
  }) => size, "px;& path{fill:", ({
62
62
  theme
63
- }) => 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":"AA4CkD","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */"));
63
+ }) => 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":"AA4CkD","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */"));
64
64
  const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "production" ? {
65
+ target: "eqr7bqq4"
66
+ } : {
67
+ target: "eqr7bqq4",
68
+ label: "StyledLabel"
69
+ })(process.env.NODE_ENV === "production" ? {
70
+ name: "h9u7nh",
71
+ styles: "width:100%;cursor:pointer"
72
+ } : {
73
+ name: "h9u7nh",
74
+ styles: "width:100%;cursor:pointer",
75
+ map: "/*# 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":"AAyDmC","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */",
76
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
77
+ });
78
+ const StyledTextLabel = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
65
79
  target: "eqr7bqq3"
66
80
  } : {
67
81
  target: "eqr7bqq3",
68
- label: "StyledLabel"
82
+ label: "StyledTextLabel"
69
83
  })(process.env.NODE_ENV === "production" ? {
70
- name: "1d3w5wq",
71
- styles: "width:100%"
84
+ name: "h9u7nh",
85
+ styles: "width:100%;cursor:pointer"
72
86
  } : {
73
- name: "1d3w5wq",
74
- styles: "width:100%",
75
- map: "/*# 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":"AAyDmC","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */",
87
+ name: "h9u7nh",
88
+ styles: "width:100%;cursor:pointer",
89
+ map: "/*# 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":"AA8DoC","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */",
76
90
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
77
91
  });
78
92
  const CheckboxInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
@@ -114,7 +128,7 @@ const CheckboxInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV ===
114
128
  theme
115
129
  }) => theme.colors.danger.borderHover, ";fill:", ({
116
130
  theme
117
- }) => 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":"AA+DE","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */"));
131
+ }) => 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":"AAqEE","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */"));
118
132
  const CheckboxContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
119
133
  target: "eqr7bqq1"
120
134
  } : {
@@ -194,7 +208,7 @@ const CheckboxContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ==
194
208
  theme
195
209
  }) => theme.colors.danger.backgroundStrong, ";fill:", ({
196
210
  theme
197
- }) => 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":"AA2H2C","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */"));
211
+ }) => 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":"AAiI2C","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */"));
198
212
  const StyledActivityContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
199
213
  target: "eqr7bqq0"
200
214
  } : {
@@ -206,7 +220,7 @@ const StyledActivityContainer = /* @__PURE__ */ _styled("div", process.env.NODE_
206
220
  } : {
207
221
  name: "zjik7",
208
222
  styles: "display:flex",
209
- map: "/*# 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":"AAiQ0C","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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                <StyledLabel htmlFor={localId}>\n                  {typeof children === 'string' ? (\n                    <Text\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                    >\n                      {children}\n                    </Text>\n                  ) : (\n                    children\n                  )}\n                </StyledLabel>\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"]} */",
223
+ map: "/*# 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":"AAuQ0C","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 type { XOR } from '../../types'\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 }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}px;\n  min-width: ${({ size }) => size}px;\n  min-height: ${({ 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 => !['size'].includes(prop),\n})`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ size }) => size}px;\n  width: ${({ size }) => size}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 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  XOR<\n    [\n      {\n        /**\n         * **`children` or `aria-label` property is required**\n         */\n        'aria-label': string\n      },\n      {\n        children: ReactNode\n      },\n    ]\n  >\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 = 24,\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 [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} />\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            size={size}\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 size={size} viewBox=\"0 0 24 24\" fill=\"none\">\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"]} */",
210
224
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
211
225
  });
212
226
  const Checkbox = forwardRef(({
@@ -248,7 +262,7 @@ const Checkbox = forwardRef(({
248
262
  !progress ? /* @__PURE__ */ jsx(StyledIcon, { size, viewBox: "0 0 24 24", fill: "none", children: /* @__PURE__ */ jsx(CheckboxIconContainer, { children: state !== "indeterminate" ? /* @__PURE__ */ jsx("path", { fillRule: "evenodd", clipRule: "evenodd", width: 12, height: 9, x: "5", y: "4", 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", fill: "white" }) : /* @__PURE__ */ jsx(CheckMixedMark, { x: "6", y: "11", rx: "1", width: "12", height: "2" }) }) }) : null,
249
263
  /* @__PURE__ */ jsxs(Stack, { gap: 0.5, flex: 1, children: [
250
264
  /* @__PURE__ */ jsxs(Stack, { gap: 0.5, direction: "row", alignItems: "center", flex: 1, children: [
251
- children ? /* @__PURE__ */ jsx(StyledLabel, { htmlFor: localId, children: typeof children === "string" ? /* @__PURE__ */ jsx(Text, { as: "label", variant: "body", sentiment: "neutral", prominence: "default", children }) : children }) : null,
265
+ children ? /* @__PURE__ */ jsx(Fragment, { children: typeof children === "string" ? /* @__PURE__ */ jsx(StyledTextLabel, { as: "label", variant: "body", sentiment: "neutral", prominence: "default", htmlFor: localId, children }) : /* @__PURE__ */ jsx(StyledLabel, { htmlFor: localId, children }) }) : null,
252
266
  required ? /* @__PURE__ */ jsx("sup", { children: /* @__PURE__ */ jsx(AsteriskIcon, { size: 8, sentiment: "danger" }) }) : null
253
267
  ] }),
254
268
  helper ? /* @__PURE__ */ jsx(Text, { variant: "caption", as: "span", prominence: "weak", sentiment: "neutral", children: helper }) : null,