@ultraviolet/ui 1.51.3 → 1.51.4

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 (149) hide show
  1. package/dist/components/ActionBar/index.cjs +32 -0
  2. package/dist/components/Alert/index.cjs +117 -0
  3. package/dist/components/Avatar/index.cjs +59 -0
  4. package/dist/components/Badge/index.cjs +101 -0
  5. package/dist/components/Banner/assets/default-image-small.svg.cjs +3 -0
  6. package/dist/components/Banner/assets/default-image.svg.cjs +3 -0
  7. package/dist/components/Banner/index.cjs +118 -0
  8. package/dist/components/BarChart/Tooltip.cjs +42 -0
  9. package/dist/components/BarChart/index.cjs +69 -0
  10. package/dist/components/BarStack/index.cjs +116 -0
  11. package/dist/components/Breadcrumbs/index.cjs +75 -0
  12. package/dist/components/Bullet/index.cjs +86 -0
  13. package/dist/components/Button/index.cjs +251 -0
  14. package/dist/components/Card/index.cjs +54 -0
  15. package/dist/components/Carousel/index.cjs +125 -0
  16. package/dist/components/Checkbox/index.cjs +264 -0
  17. package/dist/components/CheckboxGroup/index.cjs +118 -0
  18. package/dist/components/CopyButton/index.cjs +25 -0
  19. package/dist/components/DateInput/datepicker.css.cjs +3 -0
  20. package/dist/components/DateInput/index.cjs +185 -0
  21. package/dist/components/Dialog/Context.cjs +13 -0
  22. package/dist/components/Dialog/index.cjs +68 -0
  23. package/dist/components/Dialog/subComponents/Button.cjs +15 -0
  24. package/dist/components/Dialog/subComponents/Buttons.cjs +12 -0
  25. package/dist/components/Dialog/subComponents/CancelButton.cjs +9 -0
  26. package/dist/components/Dialog/subComponents/Stack.cjs +8 -0
  27. package/dist/components/Dialog/subComponents/Text.cjs +8 -0
  28. package/dist/components/EmptyState/index.cjs +92 -0
  29. package/dist/components/Expandable/index.cjs +77 -0
  30. package/dist/components/GlobalAlert/GlobalAlertLink.cjs +23 -0
  31. package/dist/components/GlobalAlert/index.cjs +61 -0
  32. package/dist/components/LineChart/CustomLegend.cjs +115 -0
  33. package/dist/components/LineChart/Tooltip.cjs +37 -0
  34. package/dist/components/LineChart/helpers.cjs +52 -0
  35. package/dist/components/LineChart/index.cjs +101 -0
  36. package/dist/components/Link/index.cjs +130 -0
  37. package/dist/components/List/Body.cjs +18 -0
  38. package/dist/components/List/Cell.cjs +43 -0
  39. package/dist/components/List/HeaderCell.cjs +84 -0
  40. package/dist/components/List/HeaderRow.cjs +38 -0
  41. package/dist/components/List/ListContext.cjs +136 -0
  42. package/dist/components/List/Row.cjs +163 -0
  43. package/dist/components/List/SelectBar.cjs +54 -0
  44. package/dist/components/List/SkeletonRows.cjs +57 -0
  45. package/dist/components/List/constants.cjs +6 -0
  46. package/dist/components/List/index.cjs +62 -0
  47. package/dist/components/Loader/index.cjs +79 -0
  48. package/dist/components/Menu/Item.cjs +92 -0
  49. package/dist/components/Menu/index.cjs +118 -0
  50. package/dist/components/MenuV2/Group.cjs +23 -0
  51. package/dist/components/MenuV2/Item.cjs +114 -0
  52. package/dist/components/MenuV2/index.cjs +92 -0
  53. package/dist/components/Meter/index.cjs +65 -0
  54. package/dist/components/Modal/Dialog.cjs +143 -0
  55. package/dist/components/Modal/Disclosure.cjs +44 -0
  56. package/dist/components/Modal/constants.cjs +52 -0
  57. package/dist/components/Modal/index.cjs +81 -0
  58. package/dist/components/Notice/index.cjs +25 -0
  59. package/dist/components/Notification/index.cjs +49 -0
  60. package/dist/components/Notification/react-toastify.css.cjs +3 -0
  61. package/dist/components/NumberInput/helpers.cjs +10 -0
  62. package/dist/components/NumberInput/index.cjs +264 -0
  63. package/dist/components/NumberInputV2/index.cjs +223 -0
  64. package/dist/components/Pagination/getPageNumbers.cjs +23 -0
  65. package/dist/components/Pagination/index.cjs +90 -0
  66. package/dist/components/PasswordCheck/index.cjs +26 -0
  67. package/dist/components/PasswordStrengthMeter/index.cjs +98 -0
  68. package/dist/components/PieChart/Legends.cjs +143 -0
  69. package/dist/components/PieChart/Tooltip.cjs +50 -0
  70. package/dist/components/PieChart/index.cjs +103 -0
  71. package/dist/components/Popover/index.cjs +102 -0
  72. package/dist/components/Popup/animations.cjs +25 -0
  73. package/dist/components/Popup/helpers.cjs +216 -0
  74. package/dist/components/Popup/index.cjs +299 -0
  75. package/dist/components/ProgressBar/index.cjs +55 -0
  76. package/dist/components/Radio/index.cjs +135 -0
  77. package/dist/components/RadioGroup/index.cjs +101 -0
  78. package/dist/components/Row/index.cjs +36 -0
  79. package/dist/components/SelectInput/index.cjs +520 -0
  80. package/dist/components/SelectInputV2/Dropdown.cjs +431 -0
  81. package/dist/components/SelectInputV2/DropdownOption.cjs +64 -0
  82. package/dist/components/SelectInputV2/SearchBarDropdown.cjs +109 -0
  83. package/dist/components/SelectInputV2/SelectBar.cjs +226 -0
  84. package/dist/components/SelectInputV2/SelectInputProvider.cjs +171 -0
  85. package/dist/components/SelectInputV2/findOptionInOptions.cjs +12 -0
  86. package/dist/components/SelectInputV2/index.cjs +89 -0
  87. package/dist/components/SelectInputV2/types.cjs +13 -0
  88. package/dist/components/SelectableCard/index.cjs +139 -0
  89. package/dist/components/SelectableCardGroup/index.cjs +109 -0
  90. package/dist/components/Separator/index.cjs +58 -0
  91. package/dist/components/Skeleton/Block.cjs +40 -0
  92. package/dist/components/Skeleton/Blocks.cjs +40 -0
  93. package/dist/components/Skeleton/BoxWithIcon.cjs +38 -0
  94. package/dist/components/Skeleton/Donut.cjs +63 -0
  95. package/dist/components/Skeleton/IconSkeleton.cjs +24 -0
  96. package/dist/components/Skeleton/Line.cjs +18 -0
  97. package/dist/components/Skeleton/List.cjs +58 -0
  98. package/dist/components/Skeleton/Slider.cjs +42 -0
  99. package/dist/components/Skeleton/Square.cjs +14 -0
  100. package/dist/components/Skeleton/index.cjs +81 -0
  101. package/dist/components/Snippet/index.cjs +184 -0
  102. package/dist/components/Stack/index.cjs +31 -0
  103. package/dist/components/Status/index.cjs +74 -0
  104. package/dist/components/StepList/index.cjs +60 -0
  105. package/dist/components/Stepper/index.cjs +147 -0
  106. package/dist/components/SwitchButton/FocusOverlay.cjs +40 -0
  107. package/dist/components/SwitchButton/index.cjs +78 -0
  108. package/dist/components/Table/Body.cjs +7 -0
  109. package/dist/components/Table/Cell.cjs +21 -0
  110. package/dist/components/Table/Header.cjs +18 -0
  111. package/dist/components/Table/HeaderCell.cjs +82 -0
  112. package/dist/components/Table/HeaderRow.cjs +23 -0
  113. package/dist/components/Table/Row.cjs +82 -0
  114. package/dist/components/Table/SelectBar.cjs +54 -0
  115. package/dist/components/Table/SkeletonRows.cjs +56 -0
  116. package/dist/components/Table/TableContext.cjs +88 -0
  117. package/dist/components/Table/index.cjs +69 -0
  118. package/dist/components/Tabs/Tab.cjs +122 -0
  119. package/dist/components/Tabs/TabMenu.cjs +64 -0
  120. package/dist/components/Tabs/TabMenuItem.cjs +36 -0
  121. package/dist/components/Tabs/TabsContext.cjs +7 -0
  122. package/dist/components/Tabs/index.cjs +104 -0
  123. package/dist/components/Tag/index.cjs +147 -0
  124. package/dist/components/TagInput/index.cjs +255 -0
  125. package/dist/components/TagList/index.cjs +100 -0
  126. package/dist/components/Text/index.cjs +84 -0
  127. package/dist/components/TextArea/index.cjs +160 -0
  128. package/dist/components/TextInput/index.cjs +390 -0
  129. package/dist/components/TextInputV2/index.cjs +192 -0
  130. package/dist/components/TimeInput/index.cjs +28 -0
  131. package/dist/components/Toaster/index.cjs +85 -0
  132. package/dist/components/Toaster/react-toastify.css.cjs +3 -0
  133. package/dist/components/Toggle/index.cjs +138 -0
  134. package/dist/components/ToggleGroup/index.cjs +98 -0
  135. package/dist/components/Tooltip/index.cjs +42 -0
  136. package/dist/components/VerificationCode/index.cjs +219 -0
  137. package/dist/helpers/isJSON.cjs +10 -0
  138. package/dist/helpers/legend.cjs +14 -0
  139. package/dist/helpers/recursivelyGetChildrenString.cjs +14 -0
  140. package/dist/hooks/useIsOverflowing.cjs +23 -0
  141. package/dist/index.cjs +196 -0
  142. package/dist/theme/index.cjs +34 -0
  143. package/dist/utils/animations.cjs +276 -0
  144. package/dist/utils/capitalize.cjs +3 -0
  145. package/dist/utils/ids.cjs +8 -0
  146. package/dist/utils/normalize.cjs +36 -0
  147. package/dist/utils/responsive/Breakpoint.cjs +16 -0
  148. package/dist/utils/responsive/utilities.cjs +15 -0
  149. package/package.json +22 -6
@@ -0,0 +1,135 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const React = require("react");
6
+ const index$2 = require("../Stack/index.cjs");
7
+ const index = require("../Text/index.cjs");
8
+ const index$1 = require("../Tooltip/index.cjs");
9
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
12
+ 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).";
13
+ }
14
+ const SIZE = 24;
15
+ const InnerCircleRing = /* @__PURE__ */ _styled__default.default("circle", process.env.NODE_ENV === "production" ? {
16
+ target: "ehkrmld6"
17
+ } : {
18
+ target: "ehkrmld6",
19
+ label: "InnerCircleRing"
20
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AASqC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &[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  &[aria-disabled='true'][data-checked='false'] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\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\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\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  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <Stack 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            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <StyledLabel htmlFor={`${computedName}-${value}`}>\n                {label}\n              </StyledLabel>\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        </Stack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
21
+ const RadioMark = /* @__PURE__ */ _styled__default.default("circle", process.env.NODE_ENV === "production" ? {
22
+ target: "ehkrmld5"
23
+ } : {
24
+ target: "ehkrmld5",
25
+ label: "RadioMark"
26
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAU+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &[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  &[aria-disabled='true'][data-checked='false'] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\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\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\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  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <Stack 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            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <StyledLabel htmlFor={`${computedName}-${value}`}>\n                {label}\n              </StyledLabel>\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        </Stack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
27
+ const RadioMarkedIcon = () => /* @__PURE__ */ jsxRuntime.jsxs("g", { children: [
28
+ /* @__PURE__ */ jsxRuntime.jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: "2" }),
29
+ /* @__PURE__ */ jsxRuntime.jsx(InnerCircleRing, { cx: "12", cy: "12", r: "8" }),
30
+ /* @__PURE__ */ jsxRuntime.jsx(RadioMark, { cx: "12", cy: "12", r: "5" })
31
+ ] });
32
+ const Ring = /* @__PURE__ */ _styled__default.default("svg", process.env.NODE_ENV === "production" ? {
33
+ target: "ehkrmld4"
34
+ } : {
35
+ target: "ehkrmld4",
36
+ label: "Ring"
37
+ })("height:", SIZE, "px;width:", SIZE, "px;min-width:", SIZE, "px;min-height:", SIZE, "px;border-radius:", ({
38
+ theme
39
+ }) => theme.radii.circle, ";fill:", ({
40
+ theme
41
+ }) => theme.colors.neutral.border, ";", InnerCircleRing, "{fill:", ({
42
+ theme
43
+ }) => 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":"AAoBuB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &[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  &[aria-disabled='true'][data-checked='false'] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\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\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\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  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <Stack 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            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <StyledLabel htmlFor={`${computedName}-${value}`}>\n                {label}\n              </StyledLabel>\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        </Stack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
44
+ const RadioInput = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
45
+ target: "ehkrmld3"
46
+ } : {
47
+ target: "ehkrmld3",
48
+ label: "RadioInput"
49
+ })("cursor:pointer;position:absolute;height:", SIZE, "px;width:", SIZE, "px;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:", ({
50
+ theme
51
+ }) => theme.colors.primary.backgroundStrong, ";}&[aria-invalid='true']:not([aria-disabled='true'])+", Ring, "{fill:", ({
52
+ theme
53
+ }) => theme.colors.danger.backgroundStrong, ";}&[aria-disabled='false']:active+", Ring, "{background-color:#5e127e40;fill:", ({
54
+ theme
55
+ }) => theme.colors.primary.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
56
+ theme
57
+ }) => 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:", ({
58
+ theme
59
+ }) => theme.colors.danger.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
60
+ theme
61
+ }) => 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":"AAgC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &[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  &[aria-disabled='true'][data-checked='false'] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\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\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\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  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <Stack 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            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <StyledLabel htmlFor={`${computedName}-${value}`}>\n                {label}\n              </StyledLabel>\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        </Stack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
62
+ const RadioContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
63
+ target: "ehkrmld2"
64
+ } : {
65
+ target: "ehkrmld2",
66
+ label: "RadioContainer"
67
+ })("position:relative;display:flex;flex:1;align-items:flex-start;gap:", ({
68
+ theme
69
+ }) => theme.space["1"], ";&[aria-disabled='false'],&[aria-disabled='false']>label{cursor:pointer;}&[aria-disabled='true'][data-checked='false']{color:", ({
70
+ theme
71
+ }) => theme.colors.neutral.textDisabled, ";}:hover[aria-disabled='false']{", RadioInput, "+", Ring, "{fill:", ({
72
+ theme
73
+ }) => theme.colors.primary.border, ";", InnerCircleRing, "{fill:", ({
74
+ theme
75
+ }) => theme.colors.primary.backgroundHover, ";}}", RadioInput, "[aria-invalid='true']+", Ring, "{fill:", ({
76
+ theme
77
+ }) => theme.colors.danger.border, ";", InnerCircleRing, "{fill:", ({
78
+ theme
79
+ }) => theme.colors.danger.backgroundHover, ";}}}&[aria-disabled='true']{cursor:not-allowed;&>label,", RadioInput, "{cursor:not-allowed;}", Ring, "{fill:", ({
80
+ theme
81
+ }) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;", InnerCircleRing, "{fill:", ({
82
+ theme
83
+ }) => 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":"AAmFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &[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  &[aria-disabled='true'][data-checked='false'] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\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\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\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  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <Stack 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            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <StyledLabel htmlFor={`${computedName}-${value}`}>\n                {label}\n              </StyledLabel>\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        </Stack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
84
+ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
85
+ target: "ehkrmld1"
86
+ } : {
87
+ target: "ehkrmld1",
88
+ label: "StyledLabel"
89
+ })(process.env.NODE_ENV === "production" ? {
90
+ name: "82a6rk",
91
+ styles: "flex:1"
92
+ } : {
93
+ name: "82a6rk",
94
+ styles: "flex:1",
95
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAqIgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &[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  &[aria-disabled='true'][data-checked='false'] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\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\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\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  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <Stack 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            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <StyledLabel htmlFor={`${computedName}-${value}`}>\n                {label}\n              </StyledLabel>\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        </Stack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
96
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
97
+ });
98
+ const MargedText = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
99
+ target: "ehkrmld0"
100
+ } : {
101
+ target: "ehkrmld0",
102
+ label: "MargedText"
103
+ })("margin-left:", ({
104
+ theme
105
+ }) => 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":"AAyI+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &[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  &[aria-disabled='true'][data-checked='false'] {\n    color: ${({ theme }) => theme.colors.neutral.textDisabled};\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\n    & > label,\n    ${RadioInput} {\n      cursor: not-allowed;\n    }\n\n    ${Ring} {\n      fill: ${({ theme }) => theme.colors.neutral.borderDisabled};\n      cursor: not-allowed;\n      ${InnerCircleRing} {\n        fill: ${({ theme }) => theme.colors.neutral.backgroundDisabled};\n      }\n    }\n  }\n`\n\nconst StyledLabel = styled.label`\n  flex: 1;\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  > &\n  (\n    | {\n        'aria-label': string\n        label?: never\n      }\n    | {\n        'aria-label'?: never\n        label: ReactNode\n      }\n  )\n\n/**\n * Radio component is used to select a single option from a list of options. It is a type of input component.\n */\nexport const Radio = forwardRef(\n  (\n    {\n      checked = false,\n      onChange,\n      onFocus,\n      onBlur,\n      disabled = false,\n      error,\n      name,\n      value,\n      label,\n      helper,\n      className,\n      autoFocus,\n      onKeyDown,\n      tooltip,\n      'aria-label': ariaLabel,\n      'data-testid': dataTestId,\n    }: RadioProps,\n    ref: ForwardedRef<HTMLInputElement>,\n  ) => {\n    const id = useId()\n    const computedName = name ?? id\n\n    return (\n      <Tooltip text={tooltip}>\n        <Stack 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            />\n            <Ring viewBox=\"0 0 24 24\">\n              <RadioMarkedIcon />\n            </Ring>\n            {label ? (\n              <StyledLabel htmlFor={`${computedName}-${value}`}>\n                {label}\n              </StyledLabel>\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        </Stack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
106
+ const Radio = React.forwardRef(({
107
+ checked = false,
108
+ onChange,
109
+ onFocus,
110
+ onBlur,
111
+ disabled = false,
112
+ error,
113
+ name,
114
+ value,
115
+ label,
116
+ helper,
117
+ className,
118
+ autoFocus,
119
+ onKeyDown,
120
+ tooltip,
121
+ "aria-label": ariaLabel,
122
+ "data-testid": dataTestId
123
+ }, ref) => {
124
+ const id = React.useId();
125
+ const computedName = name ?? id;
126
+ return /* @__PURE__ */ jsxRuntime.jsx(index$1.Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(index$2.Stack, { gap: 0.5, children: [
127
+ /* @__PURE__ */ jsxRuntime.jsxs(RadioContainer, { "aria-disabled": disabled, className, "data-checked": checked, "data-error": error, "data-testid": dataTestId, children: [
128
+ /* @__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 }),
129
+ /* @__PURE__ */ jsxRuntime.jsx(Ring, { viewBox: "0 0 24 24", children: /* @__PURE__ */ jsxRuntime.jsx(RadioMarkedIcon, {}) }),
130
+ label ? /* @__PURE__ */ jsxRuntime.jsx(StyledLabel, { htmlFor: `${computedName}-${value}`, children: label }) : null
131
+ ] }),
132
+ helper ? /* @__PURE__ */ jsxRuntime.jsx(MargedText, { as: "span", variant: "caption", prominence: "weak", sentiment: "neutral", children: helper }) : null
133
+ ] }) });
134
+ });
135
+ exports.Radio = Radio;
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const icons = require("@ultraviolet/icons");
6
+ const React = require("react");
7
+ const index$2 = require("../Radio/index.cjs");
8
+ const index = require("../Stack/index.cjs");
9
+ const index$1 = require("../Text/index.cjs");
10
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
11
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
12
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
13
+ 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).";
14
+ }
15
+ const RadioGroupContext = React.createContext(void 0);
16
+ const RadioGroupRadio = ({
17
+ onFocus,
18
+ onBlur,
19
+ disabled,
20
+ error,
21
+ name,
22
+ value,
23
+ label,
24
+ helper,
25
+ className,
26
+ autoFocus,
27
+ onKeyDown,
28
+ "data-testid": dataTestId
29
+ }) => {
30
+ const context = React.useContext(RadioGroupContext);
31
+ if (!context) {
32
+ throw new Error("RadioGroup.Radio can only be used inside a RadioGroup");
33
+ }
34
+ const {
35
+ groupName,
36
+ onChange,
37
+ groupValue
38
+ } = context;
39
+ return /* @__PURE__ */ jsxRuntime.jsx(index$2.Radio, { onChange, checked: groupValue === value, onFocus, onBlur, disabled, error, name: groupName ?? name, value, label, helper, className, autoFocus, onKeyDown, "data-testid": dataTestId });
40
+ };
41
+ const FieldSet = /* @__PURE__ */ _styled__default.default("fieldset", process.env.NODE_ENV === "production" ? {
42
+ target: "e15shfap1"
43
+ } : {
44
+ target: "e15shfap1",
45
+ label: "FieldSet"
46
+ })(process.env.NODE_ENV === "production" ? {
47
+ name: "7o2an9",
48
+ styles: "border:none;padding:0;margin:0"
49
+ } : {
50
+ name: "7o2an9",
51
+ styles: "border:none;padding:0;margin:0",
52
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRFZ0MiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFJhZGlvIH0gZnJvbSAnLi4vUmFkaW8nXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgUmFkaW9Hcm91cENvbnRleHRUeXBlID0ge1xuICBncm91cE5hbWU6IHN0cmluZ1xuICBncm91cFZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuY29uc3QgUmFkaW9Hcm91cENvbnRleHQgPSBjcmVhdGVDb250ZXh0PFJhZGlvR3JvdXBDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4oXG4gIHVuZGVmaW5lZCxcbilcblxudHlwZSBSYWRpb0dyb3VwUmFkaW9Qcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBSYWRpbz4sXG4gICdvbkNoYW5nZScgfCAnY2hlY2tlZCcgfCAncmVxdWlyZWQnXG4+ICYge1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgeW91IGRvbid0IG5lZWQgdG8gdXNlIGBuYW1lYCBhbnltb3JlLCB0aGUgbmFtZSB3aWxsIGJlIHBhc3NlZCBmcm9tIHRoZSBwYXJlbnQgYFJhZGlvR3JvdXBgLlxuICAgKi9cbiAgbmFtZT86IHN0cmluZ1xufVxuXG5jb25zdCBSYWRpb0dyb3VwUmFkaW8gPSAoe1xuICBvbkZvY3VzLFxuICBvbkJsdXIsXG4gIGRpc2FibGVkLFxuICBlcnJvcixcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIGxhYmVsLFxuICBoZWxwZXIsXG4gIGNsYXNzTmFtZSxcbiAgYXV0b0ZvY3VzLFxuICBvbktleURvd24sXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBSYWRpb0dyb3VwUmFkaW9Qcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChSYWRpb0dyb3VwQ29udGV4dClcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1JhZGlvR3JvdXAuUmFkaW8gY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBSYWRpb0dyb3VwJylcbiAgfVxuXG4gIGNvbnN0IHsgZ3JvdXBOYW1lLCBvbkNoYW5nZSwgZ3JvdXBWYWx1ZSB9ID0gY29udGV4dFxuXG4gIHJldHVybiAoXG4gICAgPFJhZGlvXG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBjaGVja2VkPXtncm91cFZhbHVlID09PSB2YWx1ZX1cbiAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAgIG5hbWU9e2dyb3VwTmFtZSA/PyBuYW1lfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgaGVscGVyPXtoZWxwZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGF1dG9Gb2N1cz17YXV0b0ZvY3VzfVxuICAgICAgb25LZXlEb3duPXtvbktleURvd259XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEljb24pYFxuICB2ZXJ0aWNhbC1hbGlnbjogc3VwZXI7XG5gXG5cbnR5cGUgUmFkaW9Hcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZTogc3RyaW5nIHwgbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnIHwgJ25hbWUnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbi8qKlxuICogUmFkaW9Hcm91cCBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB1c2VycyB0byBzZWxlY3Qgb25lIG9wdGlvbiBmcm9tIGEgbGlzdCBvZiBvcHRpb25zIHVzaW5nIHJhZGlvLlxuICovXG5leHBvcnQgY29uc3QgUmFkaW9Hcm91cCA9ICh7XG4gIGxlZ2VuZCxcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgcmVxdWlyZWQgPSBmYWxzZSxcbn06IFJhZGlvR3JvdXBQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0VmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICBncm91cE5hbWU6IG5hbWUsXG4gICAgICBncm91cFZhbHVlOiB2YWx1ZSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgICAgcmVxdWlyZWQsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZSwgcmVxdWlyZWRdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9Hcm91cENvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+XG4gICAgICA8U3RhY2sgZ2FwPXsxfT5cbiAgICAgICAgPEZpZWxkU2V0IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgICAgICA8U3RhY2sgZ2FwPXsxLjV9PlxuICAgICAgICAgICAgPFRleHQgYXM9XCJsZWdlbmRcIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBuYW1lPVwiYXN0ZXJpc2tcIiBjb2xvcj1cImRhbmdlclwiIHNpemU9ezh9IC8+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgPFN0YWNrIGdhcD17ZGlyZWN0aW9uID09PSAnY29sdW1uJyA/IDEgOiAyfSBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwic3BhblwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgc2VudGltZW50PVwiZGFuZ2VyXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9SYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5SYWRpb0dyb3VwLlJhZGlvID0gUmFkaW9Hcm91cFJhZGlvXG4iXX0= */",
53
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
54
+ });
55
+ const StyledRequiredIcon = /* @__PURE__ */ _styled__default.default(icons.Icon, process.env.NODE_ENV === "production" ? {
56
+ target: "e15shfap0"
57
+ } : {
58
+ target: "e15shfap0",
59
+ label: "StyledRequiredIcon"
60
+ })(process.env.NODE_ENV === "production" ? {
61
+ name: "1nglpc5",
62
+ styles: "vertical-align:super"
63
+ } : {
64
+ name: "1nglpc5",
65
+ styles: "vertical-align:super",
66
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1JhZGlvR3JvdXAvaW5kZXgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtGdUMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvUmFkaW9Hcm91cC9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB7IEljb24gfSBmcm9tICdAdWx0cmF2aW9sZXQvaWNvbnMnXG5pbXBvcnQge1xuICB0eXBlIENvbXBvbmVudFByb3BzLFxuICB0eXBlIElucHV0SFRNTEF0dHJpYnV0ZXMsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICBjcmVhdGVDb250ZXh0LFxuICB1c2VDb250ZXh0LFxuICB1c2VNZW1vLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFJhZGlvIH0gZnJvbSAnLi4vUmFkaW8nXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuaW1wb3J0IHsgVGV4dCB9IGZyb20gJy4uL1RleHQnXG5cbnR5cGUgUmFkaW9Hcm91cENvbnRleHRUeXBlID0ge1xuICBncm91cE5hbWU6IHN0cmluZ1xuICBncm91cFZhbHVlOiBzdHJpbmcgfCBudW1iZXJcbn0gJiBSZXF1aXJlZDxQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdvbkNoYW5nZSc+PiAmXG4gIFBpY2s8SW5wdXRIVE1MQXR0cmlidXRlczxIVE1MSW5wdXRFbGVtZW50PiwgJ3JlcXVpcmVkJz5cblxuY29uc3QgUmFkaW9Hcm91cENvbnRleHQgPSBjcmVhdGVDb250ZXh0PFJhZGlvR3JvdXBDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4oXG4gIHVuZGVmaW5lZCxcbilcblxudHlwZSBSYWRpb0dyb3VwUmFkaW9Qcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBSYWRpbz4sXG4gICdvbkNoYW5nZScgfCAnY2hlY2tlZCcgfCAncmVxdWlyZWQnXG4+ICYge1xuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgeW91IGRvbid0IG5lZWQgdG8gdXNlIGBuYW1lYCBhbnltb3JlLCB0aGUgbmFtZSB3aWxsIGJlIHBhc3NlZCBmcm9tIHRoZSBwYXJlbnQgYFJhZGlvR3JvdXBgLlxuICAgKi9cbiAgbmFtZT86IHN0cmluZ1xufVxuXG5jb25zdCBSYWRpb0dyb3VwUmFkaW8gPSAoe1xuICBvbkZvY3VzLFxuICBvbkJsdXIsXG4gIGRpc2FibGVkLFxuICBlcnJvcixcbiAgbmFtZSxcbiAgdmFsdWUsXG4gIGxhYmVsLFxuICBoZWxwZXIsXG4gIGNsYXNzTmFtZSxcbiAgYXV0b0ZvY3VzLFxuICBvbktleURvd24sXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG59OiBSYWRpb0dyb3VwUmFkaW9Qcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChSYWRpb0dyb3VwQ29udGV4dClcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1JhZGlvR3JvdXAuUmFkaW8gY2FuIG9ubHkgYmUgdXNlZCBpbnNpZGUgYSBSYWRpb0dyb3VwJylcbiAgfVxuXG4gIGNvbnN0IHsgZ3JvdXBOYW1lLCBvbkNoYW5nZSwgZ3JvdXBWYWx1ZSB9ID0gY29udGV4dFxuXG4gIHJldHVybiAoXG4gICAgPFJhZGlvXG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBjaGVja2VkPXtncm91cFZhbHVlID09PSB2YWx1ZX1cbiAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIGVycm9yPXtlcnJvcn1cbiAgICAgIG5hbWU9e2dyb3VwTmFtZSA/PyBuYW1lfVxuICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgbGFiZWw9e2xhYmVsfVxuICAgICAgaGVscGVyPXtoZWxwZXJ9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGF1dG9Gb2N1cz17YXV0b0ZvY3VzfVxuICAgICAgb25LZXlEb3duPXtvbktleURvd259XG4gICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAvPlxuICApXG59XG5cbmNvbnN0IEZpZWxkU2V0ID0gc3R5bGVkLmZpZWxkc2V0YFxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbmBcblxuY29uc3QgU3R5bGVkUmVxdWlyZWRJY29uID0gc3R5bGVkKEljb24pYFxuICB2ZXJ0aWNhbC1hbGlnbjogc3VwZXI7XG5gXG5cbnR5cGUgUmFkaW9Hcm91cFByb3BzID0ge1xuICBsZWdlbmQ6IHN0cmluZ1xuICB2YWx1ZTogc3RyaW5nIHwgbnVtYmVyXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBoZWxwZXI/OiBSZWFjdE5vZGVcbiAgZXJyb3I/OiBSZWFjdE5vZGVcbiAgZGlyZWN0aW9uPzogJ3JvdycgfCAnY29sdW1uJ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG59ICYgUmVxdWlyZWQ8UGljazxJbnB1dEhUTUxBdHRyaWJ1dGVzPEhUTUxJbnB1dEVsZW1lbnQ+LCAnb25DaGFuZ2UnIHwgJ25hbWUnPj4gJlxuICBQaWNrPElucHV0SFRNTEF0dHJpYnV0ZXM8SFRNTElucHV0RWxlbWVudD4sICdyZXF1aXJlZCc+XG5cbi8qKlxuICogUmFkaW9Hcm91cCBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB1c2VycyB0byBzZWxlY3Qgb25lIG9wdGlvbiBmcm9tIGEgbGlzdCBvZiBvcHRpb25zIHVzaW5nIHJhZGlvLlxuICovXG5leHBvcnQgY29uc3QgUmFkaW9Hcm91cCA9ICh7XG4gIGxlZ2VuZCxcbiAgdmFsdWUsXG4gIGNsYXNzTmFtZSxcbiAgaGVscGVyLFxuICBlcnJvcixcbiAgZGlyZWN0aW9uID0gJ2NvbHVtbicsXG4gIGNoaWxkcmVuLFxuICBvbkNoYW5nZSxcbiAgbmFtZSxcbiAgcmVxdWlyZWQgPSBmYWxzZSxcbn06IFJhZGlvR3JvdXBQcm9wcykgPT4ge1xuICBjb25zdCBjb250ZXh0VmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7XG4gICAgICBncm91cE5hbWU6IG5hbWUsXG4gICAgICBncm91cFZhbHVlOiB2YWx1ZSxcbiAgICAgIG9uQ2hhbmdlLFxuICAgICAgcmVxdWlyZWQsXG4gICAgfSksXG4gICAgW25hbWUsIHZhbHVlLCBvbkNoYW5nZSwgcmVxdWlyZWRdLFxuICApXG5cbiAgcmV0dXJuIChcbiAgICA8UmFkaW9Hcm91cENvbnRleHQuUHJvdmlkZXIgdmFsdWU9e2NvbnRleHRWYWx1ZX0+XG4gICAgICA8U3RhY2sgZ2FwPXsxfT5cbiAgICAgICAgPEZpZWxkU2V0IGNsYXNzTmFtZT17Y2xhc3NOYW1lfT5cbiAgICAgICAgICA8U3RhY2sgZ2FwPXsxLjV9PlxuICAgICAgICAgICAgPFRleHQgYXM9XCJsZWdlbmRcIiB2YXJpYW50PVwiYm9keVN0cm9uZ1wiPlxuICAgICAgICAgICAgICB7bGVnZW5kfSZuYnNwO1xuICAgICAgICAgICAgICB7cmVxdWlyZWQgPyAoXG4gICAgICAgICAgICAgICAgPFN0eWxlZFJlcXVpcmVkSWNvbiBuYW1lPVwiYXN0ZXJpc2tcIiBjb2xvcj1cImRhbmdlclwiIHNpemU9ezh9IC8+XG4gICAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgICAgPC9UZXh0PlxuICAgICAgICAgICAgPFN0YWNrIGdhcD17ZGlyZWN0aW9uID09PSAnY29sdW1uJyA/IDEgOiAyfSBkaXJlY3Rpb249e2RpcmVjdGlvbn0+XG4gICAgICAgICAgICAgIHtjaGlsZHJlbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgPC9GaWVsZFNldD5cbiAgICAgICAge2hlbHBlciA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJjYXB0aW9uXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJ3ZWFrXCJcbiAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHtoZWxwZXJ9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgICAge2Vycm9yID8gKFxuICAgICAgICAgIDxUZXh0IGFzPVwic3BhblwiIHZhcmlhbnQ9XCJjYXB0aW9uXCIgc2VudGltZW50PVwiZGFuZ2VyXCI+XG4gICAgICAgICAgICB7ZXJyb3J9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICApIDogbnVsbH1cbiAgICAgIDwvU3RhY2s+XG4gICAgPC9SYWRpb0dyb3VwQ29udGV4dC5Qcm92aWRlcj5cbiAgKVxufVxuXG5SYWRpb0dyb3VwLlJhZGlvID0gUmFkaW9Hcm91cFJhZGlvXG4iXX0= */",
67
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
68
+ });
69
+ const RadioGroup = ({
70
+ legend,
71
+ value,
72
+ className,
73
+ helper,
74
+ error,
75
+ direction = "column",
76
+ children,
77
+ onChange,
78
+ name,
79
+ required = false
80
+ }) => {
81
+ const contextValue = React.useMemo(() => ({
82
+ groupName: name,
83
+ groupValue: value,
84
+ onChange,
85
+ required
86
+ }), [name, value, onChange, required]);
87
+ return /* @__PURE__ */ jsxRuntime.jsx(RadioGroupContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 1, children: [
88
+ /* @__PURE__ */ jsxRuntime.jsx(FieldSet, { className, children: /* @__PURE__ */ jsxRuntime.jsxs(index.Stack, { gap: 1.5, children: [
89
+ /* @__PURE__ */ jsxRuntime.jsxs(index$1.Text, { as: "legend", variant: "bodyStrong", children: [
90
+ legend,
91
+ " ",
92
+ required ? /* @__PURE__ */ jsxRuntime.jsx(StyledRequiredIcon, { name: "asterisk", color: "danger", size: 8 }) : null
93
+ ] }),
94
+ /* @__PURE__ */ jsxRuntime.jsx(index.Stack, { gap: direction === "column" ? 1 : 2, direction, children })
95
+ ] }) }),
96
+ helper ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { as: "span", variant: "caption", prominence: "weak", sentiment: "neutral", children: helper }) : null,
97
+ error ? /* @__PURE__ */ jsxRuntime.jsx(index$1.Text, { as: "span", variant: "caption", sentiment: "danger", children: error }) : null
98
+ ] }) });
99
+ };
100
+ RadioGroup.Radio = RadioGroupRadio;
101
+ exports.RadioGroup = RadioGroup;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("@emotion/react/jsx-runtime");
4
+ const _styled = require("@emotion/styled/base");
5
+ const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
6
+ const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
7
+ const StyledRow = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
8
+ shouldForwardProp: (prop) => !["templateColumns", "gap", "alignItems", "justifyContent"].includes(prop),
9
+ target: "e3f5lzv0"
10
+ } : {
11
+ shouldForwardProp: (prop) => !["templateColumns", "gap", "alignItems", "justifyContent"].includes(prop),
12
+ target: "e3f5lzv0",
13
+ label: "StyledRow"
14
+ })("display:grid;", ({
15
+ theme,
16
+ gap,
17
+ alignItems = "normal",
18
+ templateColumns,
19
+ justifyContent = "normal"
20
+ }) => `
21
+ grid-template-columns: ${templateColumns};
22
+ ${gap ? `gap: ${theme.space[gap]};` : ""}
23
+ align-items: ${alignItems};
24
+ justify-content: ${justifyContent};
25
+ `, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1Jvdy9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV2tCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL1Jvdy9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgQ1NTUHJvcGVydGllcywgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgdHlwZSB7IFVsdHJhdmlvbGV0VUlUaGVtZSB9IGZyb20gJy4uLy4uL3RoZW1lJ1xuXG50eXBlIFN0eWxlZFJvd1Byb3BzID0gUGljazxcbiAgUm93UHJvcHMsXG4gICdnYXAnIHwgJ3RlbXBsYXRlQ29sdW1ucycgfCAnYWxpZ25JdGVtcycgfCAnanVzdGlmeUNvbnRlbnQnXG4+XG5leHBvcnQgY29uc3QgU3R5bGVkUm93ID0gc3R5bGVkKCdkaXYnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+XG4gICAgIVsndGVtcGxhdGVDb2x1bW5zJywgJ2dhcCcsICdhbGlnbkl0ZW1zJywgJ2p1c3RpZnlDb250ZW50J10uaW5jbHVkZXMocHJvcCksXG59KTxTdHlsZWRSb3dQcm9wcz5gXG4gIGRpc3BsYXk6IGdyaWQ7XG4gICR7KHtcbiAgICB0aGVtZSxcbiAgICBnYXAsXG4gICAgYWxpZ25JdGVtcyA9ICdub3JtYWwnLFxuICAgIHRlbXBsYXRlQ29sdW1ucyxcbiAgICBqdXN0aWZ5Q29udGVudCA9ICdub3JtYWwnLFxuICB9KSA9PiBgXG4gICAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAke3RlbXBsYXRlQ29sdW1uc307XG4gICAgJHtcbiAgICAgIGdhcFxuICAgICAgICA/IGBnYXA6ICR7dGhlbWUuc3BhY2VbZ2FwIGFzIGtleW9mIFVsdHJhdmlvbGV0VUlUaGVtZVsnc3BhY2UnXV19O2BcbiAgICAgICAgOiAnJ1xuICAgIH1cbiAgICBhbGlnbi1pdGVtczogJHthbGlnbkl0ZW1zfTtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6ICR7anVzdGlmeUNvbnRlbnR9O1xuICBgfVxuYFxuXG50eXBlIFJvd1Byb3BzID0ge1xuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG4gIHRlbXBsYXRlQ29sdW1uczogc3RyaW5nXG4gIGdhcD86IGtleW9mIFVsdHJhdmlvbGV0VUlUaGVtZVsnc3BhY2UnXSB8IG51bWJlclxuICBhbGlnbkl0ZW1zPzogQ1NTUHJvcGVydGllc1snYWxpZ25JdGVtcyddXG4gIGp1c3RpZnlDb250ZW50PzogQ1NTUHJvcGVydGllc1snanVzdGlmeUNvbnRlbnQnXVxufVxuXG4vKipcbiAqIFJvdyBjb21wb25lbnQgaXMgYSB3cmFwcGVyIGZvciBncmlkIGxheW91dC5cbiAqIEBleHBlcmltZW50YWwgVGhpcyBjb21wb25lbnQgaXMgZXhwZXJpbWVudGFsIGFuZCBtYXkgYmUgc3ViamVjdCB0byBicmVha2luZyBjaGFuZ2VzIGluIHRoZSBmdXR1cmUuXG4gKi9cbmV4cG9ydCBjb25zdCBSb3cgPSAoe1xuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGNoaWxkcmVuLFxuICB0ZW1wbGF0ZUNvbHVtbnMsXG4gIGFsaWduSXRlbXMsXG4gIGp1c3RpZnlDb250ZW50LFxuICBnYXAsXG59OiBSb3dQcm9wcykgPT4gKFxuICA8U3R5bGVkUm93XG4gICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgZ2FwPXtnYXB9XG4gICAgdGVtcGxhdGVDb2x1bW5zPXt0ZW1wbGF0ZUNvbHVtbnN9XG4gICAgYWxpZ25JdGVtcz17YWxpZ25JdGVtc31cbiAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gID5cbiAgICB7Y2hpbGRyZW59XG4gIDwvU3R5bGVkUm93PlxuKVxuIl19 */"));
26
+ const Row = ({
27
+ className,
28
+ "data-testid": dataTestId,
29
+ children,
30
+ templateColumns,
31
+ alignItems,
32
+ justifyContent,
33
+ gap
34
+ }) => /* @__PURE__ */ jsxRuntime.jsx(StyledRow, { className, "data-testid": dataTestId, gap, templateColumns, alignItems, justifyContent, children });
35
+ exports.Row = Row;
36
+ exports.StyledRow = StyledRow;