@ultraviolet/ui 1.84.3 → 1.84.5

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.
@@ -21,7 +21,7 @@ const ErrorText = /* @__PURE__ */ _styled__default.default(index.Text, process.e
21
21
  label: "ErrorText"
22
22
  })("padding-top:", ({
23
23
  theme
24
- }) => `${theme.space["0.5"]}`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAU8B","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
24
+ }) => `${theme.space["0.5"]}`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAU8B","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
25
25
  const InnerCheckbox = /* @__PURE__ */ _styled__default.default("rect", process.env.NODE_ENV === "production" ? {
26
26
  target: "eqr7bqq7"
27
27
  } : {
@@ -31,13 +31,13 @@ const InnerCheckbox = /* @__PURE__ */ _styled__default.default("rect", process.e
31
31
  theme
32
32
  }) => theme.colors.neutral.background, ";stroke:", ({
33
33
  theme
34
- }) => theme.colors.neutral.border, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAaiC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
34
+ }) => theme.colors.neutral.border, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAaiC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
35
35
  const CheckMixedMark = /* @__PURE__ */ _styled__default.default("rect", process.env.NODE_ENV === "production" ? {
36
36
  target: "eqr7bqq6"
37
37
  } : {
38
38
  target: "eqr7bqq6",
39
39
  label: "CheckMixedMark"
40
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAkBkC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
40
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAkBkC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
41
41
  const CheckboxIconContainer = ({
42
42
  children
43
43
  }) => {
@@ -64,7 +64,7 @@ const StyledIcon = /* @__PURE__ */ _styled__default.default("svg", process.env.N
64
64
  size
65
65
  }) => typeof size === "string" ? size : `${size}px`, ";& path{fill:", ({
66
66
  theme
67
- }) => theme.colors.neutral.background, ";transform:translate(2px, 2px);transform:scale(0);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAsC2D","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
67
+ }) => theme.colors.neutral.background, ";transform:translate(2px, 2px);transform:scale(0);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAsC2D","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
68
68
  const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
69
69
  target: "eqr7bqq4"
70
70
  } : {
@@ -75,7 +75,7 @@ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.en
75
75
  styles: "width:100%;cursor:pointer"
76
76
  } : {
77
77
  name: "h9u7nh",
78
- styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAmDmC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
78
+ styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAmDmC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
79
79
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
80
80
  });
81
81
  const StyledTextLabel = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
@@ -88,7 +88,7 @@ const StyledTextLabel = /* @__PURE__ */ _styled__default.default(index.Text, pro
88
88
  styles: "width:100%;cursor:pointer"
89
89
  } : {
90
90
  name: "h9u7nh",
91
- styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAwDoC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
91
+ styles: "width:100%;cursor:pointer/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AAwDoC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
92
92
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
93
93
  });
94
94
  const CheckboxInput = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
@@ -130,13 +130,13 @@ const CheckboxInput = /* @__PURE__ */ _styled__default.default("input", process.
130
130
  theme
131
131
  }) => theme.colors.danger.borderHover, ";fill:", ({
132
132
  theme
133
- }) => theme.colors.danger.backgroundHover, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AA+DkC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
133
+ }) => theme.colors.danger.backgroundHover, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"AA+DkC","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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
134
134
  const CheckboxContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
135
135
  target: "eqr7bqq1"
136
136
  } : {
137
137
  target: "eqr7bqq1",
138
138
  label: "CheckboxContainer"
139
- })("position:relative;display:inline-flex;align-items:start;gap:", ({
139
+ })("position:relative;display:inline-flex;align-items:center;gap:", ({
140
140
  theme
141
141
  }) => theme.space["1"], ";", StyledLabel, "{cursor:pointer;}&[aria-disabled='true']{cursor:not-allowed;color:", ({
142
142
  theme
@@ -210,7 +210,7 @@ const CheckboxContainer = /* @__PURE__ */ _styled__default.default("div", proces
210
210
  theme
211
211
  }) => theme.colors.danger.backgroundStrong, ";fill:", ({
212
212
  theme
213
- }) => theme.colors.danger.background, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
213
+ }) => theme.colors.danger.background, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
214
214
  const StyledActivityContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
215
215
  target: "eqr7bqq0"
216
216
  } : {
@@ -221,7 +221,7 @@ const StyledActivityContainer = /* @__PURE__ */ _styled__default.default("div",
221
221
  styles: "display:flex"
222
222
  } : {
223
223
  name: "zjik7",
224
- styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== 'indeterminate' ? (\n                  <path\n                    fillRule=\"evenodd\"\n                    clipRule=\"evenodd\"\n                    width={12}\n                    height={9}\n                    x=\"5\"\n                    y=\"4\"\n                    d=\"M15.6678 5.26709C16.0849 5.6463 16.113 6.28907 15.7307 6.70276L9.29172 13.6705C9.10291 13.8748 8.83818 13.9937 8.55884 13.9998C8.2795 14.0058 8.0098 13.8984 7.81223 13.7024L4.30004 10.2185C3.89999 9.82169 3.89999 9.17831 4.30004 8.78149C4.70009 8.38467 5.34869 8.38467 5.74874 8.78149L8.50441 11.5149L14.2205 5.32951C14.6028 4.91583 15.2508 4.88788 15.6678 5.26709Z\"\n                    fill=\"white\"\n                  />\n                ) : (\n                  <CheckMixedMark x=\"6\" y=\"11\" rx=\"1\" width=\"12\" height=\"2\" />\n                )}\n              </CheckboxIconContainer>\n            </StyledIcon>\n          ) : null}\n\n          <Stack gap={0.5} flex={1}>\n            <Stack gap={0.5} direction=\"row\" alignItems=\"center\" flex={1}>\n              {children ? (\n                <>\n                  {typeof children === 'string' ? (\n                    <StyledTextLabel\n                      as=\"label\"\n                      variant=\"body\"\n                      sentiment=\"neutral\"\n                      prominence=\"default\"\n                      htmlFor={localId}\n                    >\n                      {children}\n                    </StyledTextLabel>\n                  ) : (\n                    <StyledLabel htmlFor={localId}>{children}</StyledLabel>\n                  )}\n                </>\n              ) : null}\n              {required ? (\n                <sup>\n                  <AsteriskIcon size={8} sentiment=\"danger\" />\n                </sup>\n              ) : null}\n            </Stack>\n\n            {helper ? (\n              <Text\n                variant=\"caption\"\n                as=\"span\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {helper}\n              </Text>\n            ) : null}\n\n            {error && typeof error !== 'boolean' ? (\n              <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                {error}\n              </ErrorText>\n            ) : null}\n          </Stack>\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
224
+ styles: "display:flex/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Checkbox/index.tsx"],"names":[],"mappings":"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 { InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Loader } from '../Loader'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst ErrorText = styled(Text)`\n  padding-top: ${({ theme }) => `${theme.space['0.5']}`};\n`\nconst InnerCheckbox = styled.rect`\n  fill: ${({ theme }) => theme.colors.neutral.background};\n  stroke: ${({ theme }) => theme.colors.neutral.border};\n`\n\nconst CheckMixedMark = styled.rect``\n\nconst CheckboxIconContainer = ({ children }: { children: ReactNode }) => {\n  const theme = useTheme()\n\n  return (\n    <g>\n      <InnerCheckbox\n        x=\"4\"\n        y=\"4\"\n        width=\"16\"\n        height=\"16\"\n        rx={theme.radii.small}\n        strokeWidth=\"2\"\n      />\n      {children}\n    </g>\n  )\n}\n\nconst StyledIcon = styled('svg')<{ size: number | string }>`\n  border-radius: ${({ theme }) => theme.radii.default};\n  height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-width: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n  min-height: ${({ size }) => (typeof size === 'string' ? size : `${size}px`)};\n\n  & path {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n    transform: translate(2px, 2px);\n    transform: scale(0);\n  }\n`\nconst StyledLabel = styled('label')`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  width: 100%;\n  cursor: pointer;\n`\n\nconst CheckboxInput = styled('input', {\n  shouldForwardProp: prop => !['inputSize'].includes(prop),\n})<{ inputSize: number | string }>`\n  position: absolute;\n  white-space: nowrap;\n  height: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  width: ${({ inputSize }) => (typeof inputSize === 'string' ? inputSize : `${inputSize}px`)};\n  opacity: 0;\n  border-width: 0;\n\n  &:not(:disabled) {\n    cursor: pointer;\n  }\n\n  &:disabled {\n    cursor: not-allowed;\n  }\n\n  &:not(:disabled) {\n    &:checked + ${StyledIcon}, &[aria-checked='mixed'] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n      }\n    }\n\n    &[aria-invalid='true']\n      + ${StyledIcon},\n      &[aria-invalid='mixed']\n      + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.border};\n      }\n    }\n  }\n\n  &:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.primary.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusPrimary};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.primary.borderHover};\n      fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n    }\n  }\n\n  &[aria-invalid='true']:focus + ${StyledIcon} {\n    background-color: ${({ theme }) => theme.colors.danger.background};\n    fill: ${({ theme }) => theme.colors.danger.background};\n    outline: 1px solid ${({ theme }) => theme.shadows.focusDanger};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.borderHover};\n      fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n    }\n  }\n`\n\nexport const CheckboxContainer = styled.div`\n  position: relative;\n  display: inline-flex;\n  align-items: center;\n  gap: ${({ theme }) => theme.space['1']};\n\n  ${StyledLabel} {\n    cursor: pointer;\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n\n    ${StyledLabel} {\n      cursor: not-allowed;\n    }\n\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.neutral.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderDisabled};\n        fill: ${({ theme }) => theme.colors.danger.background};\n      }\n    }\n\n    ${CheckboxInput}:checked + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderDisabled};\n        fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n      }\n    }\n\n    ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n\n      ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongDisabled};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongDisabled};\n      }\n    }\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} path {\n    transform-origin: center;\n    transition: 200ms transform ease-in-out;\n    transform: scale(1);\n    transform: translate(2px, 2px);\n  }\n\n  ${CheckboxInput}:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"]:checked + ${StyledIcon} ${InnerCheckbox} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    stroke: ${({ theme }) => theme.colors.danger.borderStrong};\n  }\n\n  ${CheckboxInput}[aria-checked=\"mixed\"] + ${StyledIcon} {\n    ${CheckMixedMark} {\n      fill: ${({ theme }) => theme.colors.neutral.iconStronger};\n    }\n\n    ${InnerCheckbox} {\n      fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n      stroke: ${({ theme }) => theme.colors.primary.borderStrong};\n    }\n  }\n\n  &:hover[aria-disabled='false'] {\n    ${CheckboxInput}[aria-invalid='false'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n\n      &[aria-checked='mixed'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.primary.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.primary.backgroundStrongHover};\n      }\n    }\n\n    ${CheckboxInput}[aria-invalid='true'] {\n      &[aria-checked='false'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n\n      &[aria-checked='true'] + ${StyledIcon} ${InnerCheckbox} {\n        stroke: ${({ theme }) => theme.colors.danger.borderStrongHover};\n        fill: ${({ theme }) => theme.colors.danger.backgroundStrongHover};\n      }\n    }\n  }\n\n  ${CheckboxInput}[aria-invalid=\"true\"] + ${StyledIcon} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n\n    ${InnerCheckbox} {\n      stroke: ${({ theme }) => theme.colors.danger.backgroundStrong};\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst StyledActivityContainer = styled.div`\n  display: flex;\n`\n\ntype LabelProp =\n  | {\n      children: ReactNode\n      'aria-label'?: never\n    }\n  | {\n      children?: never\n      'aria-label': string\n    }\n\ntype CheckboxProps = {\n  error?: string | ReactNode\n  /**\n   * @deprecated Size prop is deprecated and will be removed in next major update.\n   */\n  size?: number\n  /**\n   * @deprecated Progress prop is deprecated and will be removed in next major update.\n   */\n  progress?: boolean\n  helper?: ReactNode\n  disabled?: boolean\n  checked?: boolean | 'indeterminate'\n  className?: string\n  ['data-visibility']?: string\n  required?: boolean\n  'data-testid'?: string\n  tooltip?: string\n} & Pick<\n  InputHTMLAttributes<HTMLInputElement>,\n  | 'autoFocus'\n  | 'id'\n  | 'name'\n  | 'onBlur'\n  | 'onChange'\n  | 'onClick'\n  | 'onFocus'\n  | 'tabIndex'\n  | 'value'\n> &\n  LabelProp\n\n/**\n * Checkbox is an input component used to select or deselect an option.\n */\nexport const Checkbox = forwardRef<HTMLInputElement, CheckboxProps>(\n  (\n    {\n      id,\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      error,\n      name,\n      helper,\n      value,\n      size,\n      children,\n      progress = false,\n      disabled = false,\n      autoFocus = false,\n      className,\n      'data-visibility': dataVisibility,\n      'aria-label': ariaLabel,\n      required,\n      'data-testid': dataTestId,\n      tooltip,\n      tabIndex,\n    },\n    ref,\n  ) => {\n    const theme = useTheme()\n    const uniqId = useId()\n    const localId = id ?? uniqId\n\n    const isDisabled = disabled || progress\n    const isCheck = checked === true ? checked : false\n\n    return (\n      <Tooltip text={tooltip}>\n        <CheckboxContainer\n          className={className}\n          aria-disabled={isDisabled}\n          data-visibility={dataVisibility}\n          data-checked={checked}\n          data-error={!!error}\n          data-testid={dataTestId}\n        >\n          {progress ? (\n            <StyledActivityContainer>\n              <Loader active size={size ?? theme.sizing['300']} />\n            </StyledActivityContainer>\n          ) : null}\n\n          <CheckboxInput\n            id={localId}\n            type=\"checkbox\"\n            aria-invalid={!!error}\n            aria-describedby={error ? `${localId}-hint` : undefined}\n            aria-checked={checked === 'indeterminate' ? 'mixed' : isCheck}\n            aria-label={ariaLabel}\n            checked={isCheck}\n            inputSize={size ?? theme.sizing['300']}\n            onChange={onChange}\n            onFocus={onFocus}\n            onBlur={onBlur}\n            disabled={isDisabled}\n            value={value}\n            name={name}\n            autoFocus={autoFocus}\n            ref={ref}\n            required={required}\n            tabIndex={tabIndex}\n          />\n\n          {!progress ? (\n            <StyledIcon\n              size={size ?? theme.sizing['300']}\n              viewBox=\"0 0 24 24\"\n              fill=\"none\"\n            >\n              <CheckboxIconContainer>\n                {checked !== '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          {!children && !required && !helper && !error ? null : (\n            <Stack gap={0.5} flex={1}>\n              {!children && !required ? null : (\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\n              {helper ? (\n                <Text\n                  variant=\"caption\"\n                  as=\"span\"\n                  prominence=\"weak\"\n                  sentiment=\"neutral\"\n                >\n                  {helper}\n                </Text>\n              ) : null}\n\n              {error && typeof error !== 'boolean' ? (\n                <ErrorText variant=\"caption\" as=\"span\" sentiment=\"danger\">\n                  {error}\n                </ErrorText>\n              ) : null}\n            </Stack>\n          )}\n        </CheckboxContainer>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
225
225
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
226
226
  });
227
227
  const Checkbox = React.forwardRef(({
@@ -256,8 +256,8 @@ const Checkbox = React.forwardRef(({
256
256
  progress ? /* @__PURE__ */ jsxRuntime.jsx(StyledActivityContainer, { children: /* @__PURE__ */ jsxRuntime.jsx(index$2.Loader, { active: true, size: size ?? theme.sizing["300"] }) }) : null,
257
257
  /* @__PURE__ */ jsxRuntime.jsx(CheckboxInput, { id: localId, type: "checkbox", "aria-invalid": !!error, "aria-describedby": error ? `${localId}-hint` : void 0, "aria-checked": checked === "indeterminate" ? "mixed" : isCheck, "aria-label": ariaLabel, checked: isCheck, inputSize: size ?? theme.sizing["300"], onChange, onFocus, onBlur, disabled: isDisabled, value, name, autoFocus, ref, required, tabIndex }),
258
258
  !progress ? /* @__PURE__ */ jsxRuntime.jsx(StyledIcon, { size: size ?? theme.sizing["300"], viewBox: "0 0 24 24", fill: "none", children: /* @__PURE__ */ jsxRuntime.jsx(CheckboxIconContainer, { children: checked !== "indeterminate" ? /* @__PURE__ */ jsxRuntime.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__ */ jsxRuntime.jsx(CheckMixedMark, { x: "6", y: "11", rx: "1", width: "12", height: "2" }) }) }) : null,
259
- /* @__PURE__ */ jsxRuntime.jsxs(index$3.Stack, { gap: 0.5, flex: 1, children: [
260
- /* @__PURE__ */ jsxRuntime.jsxs(index$3.Stack, { gap: 0.5, direction: "row", alignItems: "center", flex: 1, children: [
259
+ !children && !required && !helper && !error ? null : /* @__PURE__ */ jsxRuntime.jsxs(index$3.Stack, { gap: 0.5, flex: 1, children: [
260
+ !children && !required ? null : /* @__PURE__ */ jsxRuntime.jsxs(index$3.Stack, { gap: 0.5, direction: "row", alignItems: "center", flex: 1, children: [
261
261
  children ? /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: typeof children === "string" ? /* @__PURE__ */ jsxRuntime.jsx(StyledTextLabel, { as: "label", variant: "body", sentiment: "neutral", prominence: "default", htmlFor: localId, children }) : /* @__PURE__ */ jsxRuntime.jsx(StyledLabel, { htmlFor: localId, children }) }) : null,
262
262
  required ? /* @__PURE__ */ jsxRuntime.jsx("sup", { children: /* @__PURE__ */ jsxRuntime.jsx(Icon.AsteriskIcon, { size: 8, sentiment: "danger" }) }) : null
263
263
  ] }),