@ultraviolet/ui 1.73.0 → 1.73.2

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.
@@ -13,19 +13,19 @@ const InnerCircleRing = /* @__PURE__ */ _styled("circle", process.env.NODE_ENV =
13
13
  } : {
14
14
  target: "ehkrmld8",
15
15
  label: "InnerCircleRing"
16
- })(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/Radio/index.tsx"],"names":[],"mappings":"AASqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
16
+ })(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/Radio/index.tsx"],"names":[],"mappings":"AAUqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
17
17
  const RadioMark = /* @__PURE__ */ _styled("circle", process.env.NODE_ENV === "production" ? {
18
18
  target: "ehkrmld7"
19
19
  } : {
20
20
  target: "ehkrmld7",
21
21
  label: "RadioMark"
22
- })(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/Radio/index.tsx"],"names":[],"mappings":"AAU+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
22
+ })(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/Radio/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
23
23
  const RadioStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
24
24
  target: "ehkrmld6"
25
25
  } : {
26
26
  target: "ehkrmld6",
27
27
  label: "RadioStack"
28
- })(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/Radio/index.tsx"],"names":[],"mappings":"AAYuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
28
+ })(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/Radio/index.tsx"],"names":[],"mappings":"AAauC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
29
29
  const RadioMarkedIcon = () => /* @__PURE__ */ jsxs("g", { children: [
30
30
  /* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: "2" }),
31
31
  /* @__PURE__ */ jsx(InnerCircleRing, { cx: "12", cy: "12", r: "8" }),
@@ -42,7 +42,7 @@ const Ring = /* @__PURE__ */ _styled("svg", process.env.NODE_ENV === "production
42
42
  theme
43
43
  }) => theme.colors.neutral.border, ";", InnerCircleRing, "{fill:", ({
44
44
  theme
45
- }) => theme.colors.neutral.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/Radio/index.tsx"],"names":[],"mappings":"AAsBuB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
45
+ }) => theme.colors.neutral.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/Radio/index.tsx"],"names":[],"mappings":"AAuBuB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
46
46
  const RadioInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
47
47
  target: "ehkrmld4"
48
48
  } : {
@@ -62,7 +62,7 @@ const RadioInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "pr
62
62
  theme
63
63
  }) => theme.colors.danger.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
64
64
  theme
65
- }) => 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/Radio/index.tsx"],"names":[],"mappings":"AAkC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
65
+ }) => 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/Radio/index.tsx"],"names":[],"mappings":"AAmC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
66
66
  const RadioContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
67
67
  target: "ehkrmld3"
68
68
  } : {
@@ -84,7 +84,7 @@ const RadioContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "
84
84
  theme
85
85
  }) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;", InnerCircleRing, "{fill:", ({
86
86
  theme
87
- }) => theme.colors.neutral.backgroundDisabled, ";}}}" + (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/Radio/index.tsx"],"names":[],"mappings":"AAyFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
87
+ }) => theme.colors.neutral.backgroundDisabled, ";}}}" + (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/Radio/index.tsx"],"names":[],"mappings":"AA0FiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
88
88
  const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "production" ? {
89
89
  target: "ehkrmld2"
90
90
  } : {
@@ -96,7 +96,7 @@ const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "p
96
96
  } : {
97
97
  name: "1co5109",
98
98
  styles: "flex:1;cursor:pointer",
99
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAyIgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
99
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AA0IgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
100
100
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
101
101
  });
102
102
  const StyledTextLabel = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
@@ -110,7 +110,7 @@ const StyledTextLabel = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "
110
110
  } : {
111
111
  name: "1co5109",
112
112
  styles: "flex:1;cursor:pointer",
113
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AA8IoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
113
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AA+IoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
114
114
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
115
115
  });
116
116
  const MargedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
@@ -120,7 +120,7 @@ const MargedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "produ
120
120
  label: "MargedText"
121
121
  })("margin-left:", ({
122
122
  theme
123
- }) => theme.space["4"], ";" + (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/Radio/index.tsx"],"names":[],"mappings":"AAmJ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
123
+ }) => theme.space["4"], ";" + (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/Radio/index.tsx"],"names":[],"mappings":"AAoJ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport type { LabelProp } from '../../types'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  :hover[aria-disabled='false'] {\n    ${RadioInput} + ${Ring} {\n      fill: ${({ theme }) => theme.colors.primary.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.primary.backgroundHover};\n      }\n    }\n\n    ${RadioInput}[aria-invalid='true'] + ${Ring} {\n      fill: ${({ theme }) => theme.colors.danger.border};\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.danger.backgroundHover};\n      }\n    }\n  }\n\n  &[aria-disabled='true'] {\n    cursor: not-allowed;\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\n\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst StyledTextLabel = styled(Text)`\n  flex: 1;\n  cursor: pointer;\n`\n\nconst MargedText = styled(Text)`\n  margin-left: ${({ theme }) => theme.space['4']};\n`\n\ntype RadioProps = {\n  error?: ReactNode\n  checked?: boolean\n  value: string | number\n  helper?: ReactNode\n  className?: string\n  'data-testid'?: string\n  tooltip?: string\n} & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> &\n  Pick<\n    InputHTMLAttributes<HTMLInputElement>,\n    | 'onFocus'\n    | 'onBlur'\n    | 'disabled'\n    | 'autoFocus'\n    | 'onKeyDown'\n    | 'id'\n    | 'name'\n    | 'required'\n    | 'tabIndex'\n  > &\n  LabelProp\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n      tabIndex,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n              tabIndex={tabIndex}\n            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <>\n                {typeof label === 'string' ? (\n                  <StyledTextLabel\n                    as=\"label\"\n                    variant=\"body\"\n                    prominence=\"default\"\n                    htmlFor={`${computedName}-${value}`}\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={`${computedName}-${value}`}>\n                    {label}\n                  </StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              variant=\"caption\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
124
124
  const Radio = forwardRef(({
125
125
  checked = false,
126
126
  onChange,