@ultraviolet/ui 1.82.0 → 1.82.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.
Files changed (38) hide show
  1. package/dist/components/Checkbox/index.cjs +14 -20
  2. package/dist/components/Checkbox/index.d.ts +1 -1
  3. package/dist/components/Checkbox/index.js +15 -21
  4. package/dist/components/Chip/index.d.ts +1 -1
  5. package/dist/components/Dialog/index.cjs +3 -3
  6. package/dist/components/Dialog/index.js +3 -3
  7. package/dist/components/List/Cell.cjs +1 -1
  8. package/dist/components/List/Cell.js +1 -1
  9. package/dist/components/List/HeaderRow.cjs +4 -5
  10. package/dist/components/List/HeaderRow.js +4 -5
  11. package/dist/components/List/ListContext.cjs +105 -104
  12. package/dist/components/List/ListContext.d.ts +14 -11
  13. package/dist/components/List/ListContext.js +105 -104
  14. package/dist/components/List/Row.cjs +33 -26
  15. package/dist/components/List/Row.js +33 -26
  16. package/dist/components/List/index.cjs +2 -2
  17. package/dist/components/List/index.d.ts +1 -22
  18. package/dist/components/List/index.js +2 -2
  19. package/dist/components/Radio/index.cjs +11 -11
  20. package/dist/components/Radio/index.d.ts +1 -2
  21. package/dist/components/Radio/index.js +11 -11
  22. package/dist/components/SearchInput/index.cjs +2 -2
  23. package/dist/components/SearchInput/index.js +2 -2
  24. package/dist/components/SelectInput/index.cjs +8 -8
  25. package/dist/components/SelectInput/index.js +8 -8
  26. package/dist/components/SwitchButton/index.cjs +3 -3
  27. package/dist/components/SwitchButton/index.js +3 -3
  28. package/dist/components/Table/HeaderRow.cjs +2 -3
  29. package/dist/components/Table/HeaderRow.js +2 -3
  30. package/dist/components/Table/Row.cjs +29 -22
  31. package/dist/components/Table/Row.js +29 -22
  32. package/dist/components/Table/TableContext.cjs +19 -157
  33. package/dist/components/Table/TableContext.d.ts +5 -30
  34. package/dist/components/Table/TableContext.js +20 -158
  35. package/dist/components/Table/index.cjs +2 -2
  36. package/dist/components/Table/index.d.ts +26 -33
  37. package/dist/components/Table/index.js +2 -2
  38. package/package.json +4 -4
@@ -16,19 +16,19 @@ const InnerCircleRing = /* @__PURE__ */ _styled__default.default("circle", proce
16
16
  } : {
17
17
  target: "ehkrmld8",
18
18
  label: "InnerCircleRing"
19
- })(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":"AAQqC","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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */");
19
+ })(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":"AAQqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */");
20
20
  const RadioMark = /* @__PURE__ */ _styled__default.default("circle", process.env.NODE_ENV === "production" ? {
21
21
  target: "ehkrmld7"
22
22
  } : {
23
23
  target: "ehkrmld7",
24
24
  label: "RadioMark"
25
- })(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":"AAS+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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */");
25
+ })(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":"AAS+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */");
26
26
  const RadioStack = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
27
27
  target: "ehkrmld6"
28
28
  } : {
29
29
  target: "ehkrmld6",
30
30
  label: "RadioStack"
31
- })(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":"AAWuC","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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */");
31
+ })(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":"AAWuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */");
32
32
  const RadioMarkedIcon = () => /* @__PURE__ */ jsxRuntime.jsxs("g", { children: [
33
33
  /* @__PURE__ */ jsxRuntime.jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: "2" }),
34
34
  /* @__PURE__ */ jsxRuntime.jsx(InnerCircleRing, { cx: "12", cy: "12", r: "8" }),
@@ -53,7 +53,7 @@ const Ring = /* @__PURE__ */ _styled__default.default("svg", process.env.NODE_EN
53
53
  theme
54
54
  }) => theme.colors.neutral.border, ";", InnerCircleRing, "{fill:", ({
55
55
  theme
56
- }) => 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":"AAqBuB","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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */"));
56
+ }) => 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":"AAqBuB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */"));
57
57
  const RadioInput = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
58
58
  target: "ehkrmld4"
59
59
  } : {
@@ -77,7 +77,7 @@ const RadioInput = /* @__PURE__ */ _styled__default.default("input", process.env
77
77
  theme
78
78
  }) => theme.colors.danger.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
79
79
  theme
80
- }) => 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":"AAiC+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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */"));
80
+ }) => 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":"AAiC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */"));
81
81
  const RadioContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
82
82
  target: "ehkrmld3"
83
83
  } : {
@@ -99,7 +99,7 @@ const RadioContainer = /* @__PURE__ */ _styled__default.default("div", process.e
99
99
  theme
100
100
  }) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;", InnerCircleRing, "{fill:", ({
101
101
  theme
102
- }) => 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":"AAwFiC","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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */"));
102
+ }) => 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":"AAwFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */"));
103
103
  const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
104
104
  target: "ehkrmld2"
105
105
  } : {
@@ -110,7 +110,7 @@ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.en
110
110
  styles: "flex:1;cursor:pointer"
111
111
  } : {
112
112
  name: "1co5109",
113
- styles: "flex:1;cursor:pointer/*# 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":"AAwIgC","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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */",
113
+ styles: "flex:1;cursor:pointer/*# 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":"AAwIgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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 StyledTextLabel = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
@@ -123,7 +123,7 @@ const StyledTextLabel = /* @__PURE__ */ _styled__default.default(index$1.Text, p
123
123
  styles: "flex:1;cursor:pointer"
124
124
  } : {
125
125
  name: "1co5109",
126
- styles: "flex:1;cursor:pointer/*# 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":"AA6IoC","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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */",
126
+ styles: "flex:1;cursor:pointer/*# 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":"AA6IoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */",
127
127
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
128
128
  });
129
129
  const MargedText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
@@ -133,7 +133,7 @@ const MargedText = /* @__PURE__ */ _styled__default.default(index$1.Text, proces
133
133
  label: "MargedText"
134
134
  })("margin-left:", ({
135
135
  theme
136
- }) => 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":"AAkJ+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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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"]} */"));
136
+ }) => 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":"AAkJ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { 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 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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\n  min-width: ${({ theme }) => theme.sizing['300']};\n  min-height: ${({ theme }) => theme.sizing['300']};\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: ${({ theme }) => theme.sizing['300']};\n  width: ${({ theme }) => theme.sizing['300']};\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  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    | 'checked'\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<HTMLInputElement, RadioProps>(\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    },\n    forwadedRef,\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={forwadedRef}\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"]} */"));
137
137
  const Radio = React.forwardRef(({
138
138
  checked = false,
139
139
  onChange,
@@ -152,12 +152,12 @@ const Radio = React.forwardRef(({
152
152
  "aria-label": ariaLabel,
153
153
  "data-testid": dataTestId,
154
154
  tabIndex
155
- }, ref) => {
155
+ }, forwadedRef) => {
156
156
  const id = React.useId();
157
157
  const computedName = name ?? id;
158
158
  return /* @__PURE__ */ jsxRuntime.jsx(index$2.Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(RadioStack, { gap: 0.5, children: [
159
159
  /* @__PURE__ */ jsxRuntime.jsxs(RadioContainer, { "aria-disabled": disabled, className, "data-checked": checked, "data-error": error, "data-testid": dataTestId, children: [
160
- /* @__PURE__ */ jsxRuntime.jsx(RadioInput, { type: "radio", "aria-invalid": !!error, "aria-disabled": disabled, "aria-label": ariaLabel, checked, id: `${computedName}-${value}`, onChange, onFocus, onKeyDown, onBlur, value, disabled, name: computedName, autoFocus, ref, tabIndex }),
160
+ /* @__PURE__ */ jsxRuntime.jsx(RadioInput, { type: "radio", "aria-invalid": !!error, "aria-disabled": disabled, "aria-label": ariaLabel, checked, id: `${computedName}-${value}`, onChange, onFocus, onKeyDown, onBlur, value, disabled, name: computedName, autoFocus, ref: forwadedRef, tabIndex }),
161
161
  /* @__PURE__ */ jsxRuntime.jsx(Ring, { viewBox: "0 0 24 24", children: /* @__PURE__ */ jsxRuntime.jsx(RadioMarkedIcon, {}) }),
162
162
  label ? /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children: typeof label === "string" ? /* @__PURE__ */ jsxRuntime.jsx(StyledTextLabel, { as: "label", variant: "body", prominence: "default", htmlFor: `${computedName}-${value}`, children: label }) : /* @__PURE__ */ jsxRuntime.jsx(StyledLabel, { htmlFor: `${computedName}-${value}`, children: label }) }) : null
163
163
  ] }),
@@ -19,13 +19,12 @@ export declare const RadioStack: import("@emotion/styled").StyledComponent<{
19
19
  }, {}, {}>;
20
20
  type RadioProps = {
21
21
  error?: ReactNode;
22
- checked?: boolean;
23
22
  value: string | number;
24
23
  helper?: ReactNode;
25
24
  className?: string;
26
25
  'data-testid'?: string;
27
26
  tooltip?: string;
28
- } & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> & Pick<InputHTMLAttributes<HTMLInputElement>, 'onFocus' | 'onBlur' | 'disabled' | 'autoFocus' | 'onKeyDown' | 'id' | 'name' | 'required' | 'tabIndex'> & LabelProp;
27
+ } & Required<Pick<InputHTMLAttributes<HTMLInputElement>, 'onChange'>> & Pick<InputHTMLAttributes<HTMLInputElement>, 'onFocus' | 'onBlur' | 'disabled' | 'autoFocus' | 'onKeyDown' | 'id' | 'name' | 'required' | 'tabIndex' | 'checked'> & LabelProp;
29
28
  /**
30
29
  * Radio component is used to select a single option from a list of options. It is a type of input component.
31
30
  */