@ultraviolet/ui 3.0.0-beta.11 → 3.0.0-beta.13

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 (70) hide show
  1. package/dist/components/ActionBar/styles.css.cjs +0 -1
  2. package/dist/components/ActionBar/styles.css.js +0 -1
  3. package/dist/components/BarStack/styles.css.cjs +0 -1
  4. package/dist/components/BarStack/styles.css.js +0 -1
  5. package/dist/components/BarStack/variables.css.cjs +1 -0
  6. package/dist/components/BarStack/variables.css.js +1 -0
  7. package/dist/components/Bullet/constants.d.ts +10 -0
  8. package/dist/components/Bullet/index.cjs +9 -75
  9. package/dist/components/Bullet/index.d.ts +5 -14
  10. package/dist/components/Bullet/index.js +10 -74
  11. package/dist/components/Bullet/styles.css.cjs +6 -0
  12. package/dist/components/Bullet/styles.css.d.ts +23 -0
  13. package/dist/components/Bullet/styles.css.js +6 -0
  14. package/dist/components/Button/constants.cjs +0 -1
  15. package/dist/components/Button/constants.js +0 -1
  16. package/dist/components/Chip/styles.css.cjs +1 -0
  17. package/dist/components/Chip/styles.css.js +1 -0
  18. package/dist/components/Expandable/index.cjs +5 -17
  19. package/dist/components/Expandable/index.d.ts +0 -6
  20. package/dist/components/Expandable/index.js +6 -16
  21. package/dist/components/Expandable/styles.css.cjs +7 -0
  22. package/dist/components/Expandable/styles.css.d.ts +2 -0
  23. package/dist/components/Expandable/styles.css.js +7 -0
  24. package/dist/components/GlobalAlert/index.cjs +3 -30
  25. package/dist/components/GlobalAlert/index.js +3 -28
  26. package/dist/components/GlobalAlert/styles.css.cjs +7 -0
  27. package/dist/components/GlobalAlert/styles.css.d.ts +2 -0
  28. package/dist/components/GlobalAlert/styles.css.js +7 -0
  29. package/dist/components/Link/constants.d.ts +6 -0
  30. package/dist/components/Link/index.cjs +11 -114
  31. package/dist/components/Link/index.d.ts +1 -6
  32. package/dist/components/Link/index.js +12 -113
  33. package/dist/components/Link/styles.css.cjs +14 -0
  34. package/dist/components/Link/styles.css.d.ts +78 -0
  35. package/dist/components/Link/styles.css.js +14 -0
  36. package/dist/components/ProgressBar/constants.d.ts +1 -0
  37. package/dist/components/ProgressBar/index.cjs +7 -77
  38. package/dist/components/ProgressBar/index.d.ts +2 -2
  39. package/dist/components/ProgressBar/index.js +7 -75
  40. package/dist/components/ProgressBar/styles.css.cjs +11 -0
  41. package/dist/components/ProgressBar/styles.css.d.ts +4 -0
  42. package/dist/components/ProgressBar/styles.css.js +11 -0
  43. package/dist/components/ProgressBar/variables.css.cjs +5 -0
  44. package/dist/components/ProgressBar/variables.css.d.ts +1 -0
  45. package/dist/components/ProgressBar/variables.css.js +5 -0
  46. package/dist/components/Radio/index.cjs +30 -136
  47. package/dist/components/Radio/index.d.ts +0 -49
  48. package/dist/components/Radio/index.js +31 -135
  49. package/dist/components/Radio/styles.css.cjs +21 -0
  50. package/dist/components/Radio/styles.css.d.ts +9 -0
  51. package/dist/components/Radio/styles.css.js +21 -0
  52. package/dist/components/SelectableCard/index.cjs +29 -28
  53. package/dist/components/SelectableCard/index.js +21 -20
  54. package/dist/components/SelectableCardOptionGroup/components/Option.cjs +8 -8
  55. package/dist/components/SelectableCardOptionGroup/components/Option.js +6 -6
  56. package/dist/components/StepList/index.cjs +1 -1
  57. package/dist/components/StepList/index.js +1 -1
  58. package/dist/components/VerificationCode/constants.d.ts +12 -0
  59. package/dist/components/VerificationCode/index.cjs +5 -88
  60. package/dist/components/VerificationCode/index.d.ts +1 -1
  61. package/dist/components/VerificationCode/index.js +5 -86
  62. package/dist/components/VerificationCode/styles.css.cjs +9 -0
  63. package/dist/components/VerificationCode/styles.css.d.ts +3 -0
  64. package/dist/components/VerificationCode/styles.css.js +9 -0
  65. package/dist/theme/index.cjs +0 -4
  66. package/dist/theme/index.js +0 -4
  67. package/dist/ui.css +1 -1
  68. package/package.json +3 -3
  69. package/dist/utils/capitalize.cjs +0 -3
  70. package/dist/utils/capitalize.js +0 -4
@@ -1,136 +1,15 @@
1
1
  "use client";
2
2
  import { jsx, jsxs, Fragment } from "@emotion/react/jsx-runtime";
3
- import _styled from "@emotion/styled/base";
4
3
  import { forwardRef, useId } from "react";
5
4
  import { Stack } from "../Stack/index.js";
6
5
  import { Text } from "../Text/index.js";
7
6
  import { Tooltip } from "../Tooltip/index.js";
8
- function _EMOTION_STRINGIFIED_CSS_ERROR__() {
9
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
10
- }
11
- const InnerCircleRing = /* @__PURE__ */ _styled("circle", process.env.NODE_ENV === "production" ? {
12
- target: "ehkrmld8"
13
- } : {
14
- target: "ehkrmld8",
15
- label: "InnerCircleRing"
16
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAU4C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
17
- const RadioMark = /* @__PURE__ */ _styled("circle", process.env.NODE_ENV === "production" ? {
18
- target: "ehkrmld7"
19
- } : {
20
- target: "ehkrmld7",
21
- label: "RadioMark"
22
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
23
- const RadioStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
24
- target: "ehkrmld6"
25
- } : {
26
- target: "ehkrmld6",
27
- label: "RadioStack"
28
- })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAauC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
7
+ import { radioStack, container, radio, ring, textLabel, labelStyle, margedText, innerCircleRing, radioMark } from "./styles.css.js";
29
8
  const RadioMarkedIcon = () => /* @__PURE__ */ jsxs("g", { children: [
30
9
  /* @__PURE__ */ jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: "2" }),
31
- /* @__PURE__ */ jsx(InnerCircleRing, { cx: "12", cy: "12", r: "8" }),
32
- /* @__PURE__ */ jsx(RadioMark, { cx: "12", cy: "12", r: "5" })
10
+ /* @__PURE__ */ jsx("circle", { className: innerCircleRing, cx: "12", cy: "12", r: "8" }),
11
+ /* @__PURE__ */ jsx("circle", { className: radioMark, cx: "12", cy: "12", r: "5" })
33
12
  ] });
34
- const Ring = /* @__PURE__ */ _styled("svg", process.env.NODE_ENV === "production" ? {
35
- target: "ehkrmld5"
36
- } : {
37
- target: "ehkrmld5",
38
- label: "Ring"
39
- })("height:", ({
40
- theme
41
- }) => theme.sizing["300"], ";width:", ({
42
- theme
43
- }) => theme.sizing["300"], ";min-width:", ({
44
- theme
45
- }) => theme.sizing["300"], ";min-height:", ({
46
- theme
47
- }) => theme.sizing["300"], ";border-radius:", ({
48
- theme
49
- }) => theme.radii.circle, ";fill:", ({
50
- theme
51
- }) => theme.colors.neutral.border, ";", InnerCircleRing, "{fill:", ({
52
- theme
53
- }) => 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":"AAuB8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
54
- const RadioInput = /* @__PURE__ */ _styled("input", process.env.NODE_ENV === "production" ? {
55
- target: "ehkrmld4"
56
- } : {
57
- target: "ehkrmld4",
58
- label: "RadioInput"
59
- })("cursor:pointer;position:absolute;height:", ({
60
- theme
61
- }) => theme.sizing["300"], ";width:", ({
62
- theme
63
- }) => theme.sizing["300"], ";opacity:0;white-space:nowrap;border-width:0;&+", Ring, "{", RadioMark, "{transform-origin:center;transition:200ms transform ease-in-out;transform:scale(0);}}&:checked+svg{", RadioMark, "{transform:scale(1);}}&:checked[aria-disabled='false'][aria-invalid='false']+", Ring, "{fill:", ({
64
- theme
65
- }) => theme.colors.primary.backgroundStrong, ";}&:checked[aria-disabled='true'][aria-invalid='false']+", Ring, "{fill:", ({
66
- theme
67
- }) => theme.colors.primary.borderDisabled, ";}&[aria-invalid='true']:not([aria-disabled='true'])+", Ring, "{fill:", ({
68
- theme
69
- }) => theme.colors.danger.backgroundStrong, ";}&[aria-disabled='false']:active+", Ring, "{background-color:#5e127e40;fill:", ({
70
- theme
71
- }) => theme.colors.primary.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
72
- theme
73
- }) => theme.colors.primary.background, ";}}&[aria-disabled='false']:focus-visible+", Ring, "{outline:-webkit-focus-ring-color auto 1px;}&[aria-invalid='true']:focus+", Ring, "{background-color:#f91b6c40;fill:", ({
74
- theme
75
- }) => theme.colors.danger.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
76
- theme
77
- }) => 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":"AAmCsC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
78
- const RadioContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
79
- target: "ehkrmld3"
80
- } : {
81
- target: "ehkrmld3",
82
- label: "RadioContainer"
83
- })("position:relative;display:flex;flex:1;align-items:flex-start;gap:", ({
84
- theme
85
- }) => theme.space["1"], ";&[aria-disabled='false'],&[aria-disabled='false']>label{cursor:pointer;}:hover[aria-disabled='false']{", RadioInput, "+", Ring, "{fill:", ({
86
- theme
87
- }) => theme.colors.primary.border, ";", InnerCircleRing, "{fill:", ({
88
- theme
89
- }) => theme.colors.primary.backgroundHover, ";}}", RadioInput, "[aria-invalid='true']+", Ring, "{fill:", ({
90
- theme
91
- }) => theme.colors.danger.border, ";", InnerCircleRing, "{fill:", ({
92
- theme
93
- }) => theme.colors.danger.backgroundHover, ";}}}&[aria-disabled='true']{cursor:not-allowed;color:", ({
94
- theme
95
- }) => theme.colors.neutral.textDisabled, ";&>label,", RadioInput, "{cursor:not-allowed;}", Ring, "{fill:", ({
96
- theme
97
- }) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;", InnerCircleRing, "{fill:", ({
98
- theme
99
- }) => theme.colors.neutral.backgroundDisabled, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AA0FiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
100
- const StyledLabel = /* @__PURE__ */ _styled("label", process.env.NODE_ENV === "production" ? {
101
- target: "ehkrmld2"
102
- } : {
103
- target: "ehkrmld2",
104
- label: "StyledLabel"
105
- })(process.env.NODE_ENV === "production" ? {
106
- name: "1co5109",
107
- styles: "flex:1;cursor:pointer"
108
- } : {
109
- name: "1co5109",
110
- 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":"AA0IgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
111
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
112
- });
113
- const StyledTextLabel = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
114
- target: "ehkrmld1"
115
- } : {
116
- target: "ehkrmld1",
117
- label: "StyledTextLabel"
118
- })(process.env.NODE_ENV === "production" ? {
119
- name: "1co5109",
120
- styles: "flex:1;cursor:pointer"
121
- } : {
122
- name: "1co5109",
123
- 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":"AA+IoC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
124
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__
125
- });
126
- const MargedText = /* @__PURE__ */ _styled(Text, process.env.NODE_ENV === "production" ? {
127
- target: "ehkrmld0"
128
- } : {
129
- target: "ehkrmld0",
130
- label: "MargedText"
131
- })("margin-left:", ({
132
- theme
133
- }) => theme.space["4"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAoJ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["'use client'\n\nimport 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\nexport const 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\nexport const 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\nexport const 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    | 'onClick'\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      id,\n    },\n    forwadedRef,\n  ) => {\n    const generatedId = useId()\n    const localId = id || generatedId\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              aria-disabled={disabled}\n              aria-invalid={!!error}\n              aria-label={ariaLabel}\n              autoFocus={autoFocus}\n              checked={checked}\n              disabled={disabled}\n              id={localId}\n              name={name}\n              onBlur={onBlur}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              ref={forwadedRef}\n              tabIndex={tabIndex}\n              type=\"radio\"\n              value={value}\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                    htmlFor={localId}\n                    prominence=\"default\"\n                    variant=\"body\"\n                  >\n                    {label}\n                  </StyledTextLabel>\n                ) : (\n                  <StyledLabel htmlFor={localId}>{label}</StyledLabel>\n                )}\n              </>\n            ) : null}\n          </RadioContainer>\n          {helper ? (\n            <MargedText\n              as=\"span\"\n              prominence=\"weak\"\n              sentiment=\"neutral\"\n              variant=\"caption\"\n            >\n              {helper}\n            </MargedText>\n          ) : null}\n        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
134
13
  const Radio = forwardRef(({
135
14
  checked = false,
136
15
  onChange,
@@ -153,19 +32,36 @@ const Radio = forwardRef(({
153
32
  }, forwadedRef) => {
154
33
  const generatedId = useId();
155
34
  const localId = id || generatedId;
156
- return /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxs(RadioStack, { gap: 0.5, children: [
157
- /* @__PURE__ */ jsxs(RadioContainer, { "aria-disabled": disabled, className, "data-checked": checked, "data-error": error, "data-testid": dataTestId, children: [
158
- /* @__PURE__ */ jsx(RadioInput, { "aria-disabled": disabled, "aria-invalid": !!error, "aria-label": ariaLabel, autoFocus, checked, disabled, id: localId, name, onBlur, onChange, onFocus, onKeyDown, ref: forwadedRef, tabIndex, type: "radio", value }),
159
- /* @__PURE__ */ jsx(Ring, { viewBox: "0 0 24 24", children: /* @__PURE__ */ jsx(RadioMarkedIcon, {}) }),
160
- label ? /* @__PURE__ */ jsx(Fragment, { children: typeof label === "string" ? /* @__PURE__ */ jsx(StyledTextLabel, { as: "label", htmlFor: localId, prominence: "default", variant: "body", children: label }) : /* @__PURE__ */ jsx(StyledLabel, { htmlFor: localId, children: label }) }) : null
35
+ return /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxs(Stack, { className: radioStack, gap: 0.5, children: [
36
+ /* @__PURE__ */ jsxs("div", { "aria-disabled": disabled, className: `${className ? `${className} ` : ""}${container}`, "data-checked": checked, "data-error": error, "data-testid": dataTestId, children: [
37
+ /* @__PURE__ */ jsx(
38
+ "input",
39
+ {
40
+ "aria-disabled": disabled,
41
+ "aria-invalid": !!error,
42
+ "aria-label": ariaLabel,
43
+ autoFocus,
44
+ checked,
45
+ className: radio,
46
+ disabled,
47
+ id: localId,
48
+ name,
49
+ onBlur,
50
+ onChange,
51
+ onFocus,
52
+ onKeyDown,
53
+ ref: forwadedRef,
54
+ tabIndex,
55
+ type: "radio",
56
+ value
57
+ }
58
+ ),
59
+ /* @__PURE__ */ jsx("svg", { className: ring, viewBox: "0 0 24 24", children: /* @__PURE__ */ jsx(RadioMarkedIcon, {}) }),
60
+ label ? /* @__PURE__ */ jsx(Fragment, { children: typeof label === "string" ? /* @__PURE__ */ jsx(Text, { as: "label", className: textLabel, htmlFor: localId, prominence: "default", variant: "body", children: label }) : /* @__PURE__ */ jsx("label", { className: labelStyle, htmlFor: localId, children: label }) }) : null
161
61
  ] }),
162
- helper ? /* @__PURE__ */ jsx(MargedText, { as: "span", prominence: "weak", sentiment: "neutral", variant: "caption", children: helper }) : null
62
+ helper ? /* @__PURE__ */ jsx(Text, { as: "span", className: margedText, prominence: "weak", sentiment: "neutral", variant: "caption", children: helper }) : null
163
63
  ] }) });
164
64
  });
165
65
  export {
166
- InnerCircleRing,
167
- Radio,
168
- RadioInput,
169
- RadioStack,
170
- Ring
66
+ Radio
171
67
  };
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
4
+ var innerCircleRing = "uv_17da2jl0";
5
+ var radioStack = "uv_17da2jl1";
6
+ var margedText = "uv_17da2jl2";
7
+ var container = "uv_17da2jl3";
8
+ var textLabel = "uv_17da2jl4";
9
+ var labelStyle = "uv_17da2jl5";
10
+ var radio = "uv_17da2jl6";
11
+ var ring = "uv_17da2jl7";
12
+ var radioMark = "uv_17da2jl8";
13
+ exports.container = container;
14
+ exports.innerCircleRing = innerCircleRing;
15
+ exports.labelStyle = labelStyle;
16
+ exports.margedText = margedText;
17
+ exports.radio = radio;
18
+ exports.radioMark = radioMark;
19
+ exports.radioStack = radioStack;
20
+ exports.ring = ring;
21
+ exports.textLabel = textLabel;
@@ -0,0 +1,9 @@
1
+ export declare const innerCircleRing: string;
2
+ export declare const radioStack: string;
3
+ export declare const margedText: string;
4
+ export declare const container: string;
5
+ export declare const textLabel: string;
6
+ export declare const labelStyle: string;
7
+ export declare const radio: string;
8
+ export declare const ring: string;
9
+ export declare const radioMark: string;
@@ -0,0 +1,21 @@
1
+ /* empty css */
2
+ var innerCircleRing = "uv_17da2jl0";
3
+ var radioStack = "uv_17da2jl1";
4
+ var margedText = "uv_17da2jl2";
5
+ var container = "uv_17da2jl3";
6
+ var textLabel = "uv_17da2jl4";
7
+ var labelStyle = "uv_17da2jl5";
8
+ var radio = "uv_17da2jl6";
9
+ var ring = "uv_17da2jl7";
10
+ var radioMark = "uv_17da2jl8";
11
+ export {
12
+ container,
13
+ innerCircleRing,
14
+ labelStyle,
15
+ margedText,
16
+ radio,
17
+ radioMark,
18
+ radioStack,
19
+ ring,
20
+ textLabel
21
+ };