@ultraviolet/ui 1.57.0 → 1.58.0

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 (60) hide show
  1. package/README.md +1 -1
  2. package/dist/components/Checkbox/index.cjs +9 -8
  3. package/dist/components/Checkbox/index.d.ts +4 -0
  4. package/dist/components/Checkbox/index.js +10 -9
  5. package/dist/components/Dialog/index.cjs +2 -2
  6. package/dist/components/Dialog/index.js +2 -2
  7. package/dist/components/Dialog/subComponents/Text.cjs +1 -1
  8. package/dist/components/Dialog/subComponents/Text.js +1 -1
  9. package/dist/components/List/Row.cjs +13 -3
  10. package/dist/components/List/Row.d.ts +1 -0
  11. package/dist/components/List/Row.js +13 -3
  12. package/dist/components/List/index.d.ts +1 -0
  13. package/dist/components/Modal/Disclosure.cjs +2 -2
  14. package/dist/components/Modal/Disclosure.d.ts +1 -1
  15. package/dist/components/Modal/Disclosure.js +3 -3
  16. package/dist/components/Modal/index.cjs +5 -3
  17. package/dist/components/Modal/index.js +6 -4
  18. package/dist/components/Modal/types.d.ts +1 -0
  19. package/dist/components/Radio/index.cjs +25 -16
  20. package/dist/components/Radio/index.d.ts +17 -0
  21. package/dist/components/Radio/index.js +22 -13
  22. package/dist/components/RadioGroup/index.cjs +4 -3
  23. package/dist/components/RadioGroup/index.d.ts +1 -1
  24. package/dist/components/RadioGroup/index.js +4 -3
  25. package/dist/components/SelectInputV2/Dropdown.cjs +9 -9
  26. package/dist/components/SelectInputV2/Dropdown.js +9 -9
  27. package/dist/components/SelectInputV2/SelectBar.cjs +13 -11
  28. package/dist/components/SelectInputV2/SelectBar.d.ts +2 -1
  29. package/dist/components/SelectInputV2/SelectBar.js +9 -7
  30. package/dist/components/SelectInputV2/index.cjs +4 -3
  31. package/dist/components/SelectInputV2/index.d.ts +5 -1
  32. package/dist/components/SelectInputV2/index.js +4 -3
  33. package/dist/components/SelectableCard/index.cjs +4 -4
  34. package/dist/components/SelectableCard/index.js +6 -6
  35. package/dist/components/Slider/DoubleSlider.cjs +280 -0
  36. package/dist/components/Slider/DoubleSlider.d.ts +2 -0
  37. package/dist/components/Slider/DoubleSlider.js +278 -0
  38. package/dist/components/Slider/Label.cjs +17 -0
  39. package/dist/components/Slider/Label.d.ts +2 -0
  40. package/dist/components/Slider/Label.js +17 -0
  41. package/dist/components/Slider/Options.cjs +27 -0
  42. package/dist/components/Slider/Options.d.ts +2 -0
  43. package/dist/components/Slider/Options.js +27 -0
  44. package/dist/components/Slider/SingleSlider.cjs +207 -0
  45. package/dist/components/Slider/SingleSlider.d.ts +2 -0
  46. package/dist/components/Slider/SingleSlider.js +205 -0
  47. package/dist/components/Slider/constant.cjs +9 -0
  48. package/dist/components/Slider/constant.d.ts +5 -0
  49. package/dist/components/Slider/constant.js +9 -0
  50. package/dist/components/Slider/index.cjs +55 -0
  51. package/dist/components/Slider/index.d.ts +7 -0
  52. package/dist/components/Slider/index.js +55 -0
  53. package/dist/components/Slider/styles.cjs +100 -0
  54. package/dist/components/Slider/styles.d.ts +79 -0
  55. package/dist/components/Slider/styles.js +98 -0
  56. package/dist/components/Slider/types.d.ts +114 -0
  57. package/dist/components/index.d.ts +1 -0
  58. package/dist/index.cjs +47 -45
  59. package/dist/index.js +2 -0
  60. package/package.json +3 -3
@@ -1,6 +1,6 @@
1
1
  import { jsxs, Fragment, jsx } from "@emotion/react/jsx-runtime";
2
2
  import _styled from "@emotion/styled/base";
3
- import { useState, useId, useCallback } from "react";
3
+ import { useState, useId, useRef, useCallback } from "react";
4
4
  import { Button } from "../Button/index.js";
5
5
  import { Dialog } from "./Dialog.js";
6
6
  import { Disclosure } from "./Disclosure.js";
@@ -13,7 +13,7 @@ const StyledContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV ===
13
13
  theme
14
14
  }) => theme.space["2"], ";right:", ({
15
15
  theme
16
- }) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q2tDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlSWQsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi9CdXR0b24nXG5pbXBvcnQgeyBEaWFsb2cgfSBmcm9tICcuL0RpYWxvZydcbmltcG9ydCB7IERpc2Nsb3N1cmUgfSBmcm9tICcuL0Rpc2Nsb3N1cmUnXG5pbXBvcnQgdHlwZSB7IE1vZGFsUGxhY2VtZW50LCBNb2RhbFNpemUsIE1vZGFsU3RhdGUgfSBmcm9tICcuL3R5cGVzJ1xuXG5leHBvcnQgdHlwZSBNb2RhbFByb3BzID0ge1xuICBpZD86IHN0cmluZ1xuICBoaWRlT25Fc2M/OiBib29sZWFuXG4gIGhpZGVPbkNsaWNrT3V0c2lkZT86IGJvb2xlYW5cbiAgcHJldmVudEJvZHlTY3JvbGw/OiBib29sZWFuXG4gIGFyaWFMYWJlbD86IHN0cmluZ1xuICBkaXNjbG9zdXJlPzogUmVhY3RFbGVtZW50IHwgKChzdGF0ZTogTW9kYWxTdGF0ZSkgPT4gUmVhY3RFbGVtZW50KVxuICBpc0Nsb3NhYmxlPzogYm9vbGVhblxuICBvbkNsb3NlPzogKCkgPT4gdm9pZFxuICBvbkJlZm9yZUNsb3NlPzogKCkgPT4gUHJvbWlzZTx2b2lkPiB8IHZvaWRcbiAgb3Blbj86IGJvb2xlYW5cbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIFlvdSBzaG91bGQgdXNlIG9wZW4gcHJvcCBpbnN0ZWFkXG4gICAqL1xuICBvcGVuZWQ/OiBib29sZWFuXG4gIHBsYWNlbWVudD86IE1vZGFsUGxhY2VtZW50XG4gIHNpemU/OiBNb2RhbFNpemVcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIFlvdSBzaG91bGQgdXNlIHNpemUgcHJvcCBpbnN0ZWFkXG4gICAqL1xuICB3aWR0aD86IE1vZGFsU2l6ZVxuICBjaGlsZHJlbjogUmVhY3ROb2RlIHwgKChhcmdzOiBNb2RhbFN0YXRlKSA9PiBSZWFjdE5vZGUpXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG4gIGJhY2tkcm9wQ2xhc3NOYW1lPzogc3RyaW5nXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBZb3Ugc2hvdWxkIHVzZSBiYWNrZHJvcENsYXNzTmFtZSBpbnN0ZWFkXG4gICAqL1xuICBjdXN0b21EaWFsb2dCYWNrZHJvcFN0eWxlcz86IFJlYWN0LkpTWC5JbnRyaW5zaWNBdHRyaWJ1dGVzWydjc3MnXVxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgWW91IHNob3VsZCB1c2UgY2xhc3NOYW1lIGluc3RlYWRcbiAgICovXG4gIGN1c3RvbURpYWxvZ1N0eWxlcz86IFJlYWN0LkpTWC5JbnRyaW5zaWNBdHRyaWJ1dGVzWydjc3MnXVxufVxuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbiAgcmlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG5gXG5cbi8qKlxuICogTW9kYWwgaXMgYSBjb21wb25lbnQgdGhhdCBhbGxvd3MgeW91IHRvIGRpc3BsYXkgY29udGVudCBvbiB0b3Agb2Ygb3RoZXIgY29udGVudC5cbiAqIEl0IGlzIG9mdGVuIHVzZWQgdG8gZGlzcGxheSBhIGRpYWxvZyB3aXRoIGFkZGl0aW9uYWwgaW5mb3JtYXRpb24gb3IgdG8gYXNrIGZvciBhIGNvbmZpcm1hdGlvbi5cbiAqL1xuZXhwb3J0IGNvbnN0IE1vZGFsID0gKHtcbiAgYXJpYUxhYmVsID0gJ21vZGFsJyxcbiAgaWQsXG4gIGNoaWxkcmVuLFxuICBkaXNjbG9zdXJlLFxuICBoaWRlT25DbGlja091dHNpZGUgPSB0cnVlLFxuICBoaWRlT25Fc2MgPSB0cnVlLFxuICBpc0Nsb3NhYmxlID0gdHJ1ZSxcbiAgb25DbG9zZSxcbiAgb25CZWZvcmVDbG9zZSxcbiAgb3BlbiA9IGZhbHNlLFxuICBvcGVuZWQgPSBmYWxzZSxcbiAgcGxhY2VtZW50ID0gJ2NlbnRlcicsXG4gIHByZXZlbnRCb2R5U2Nyb2xsID0gdHJ1ZSxcbiAgc2l6ZSxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICBiYWNrZHJvcENsYXNzTmFtZSxcbiAgd2lkdGggPSAnc21hbGwnLFxuICBjdXN0b21EaWFsb2dTdHlsZXMsXG4gIGN1c3RvbURpYWxvZ0JhY2tkcm9wU3R5bGVzLFxufTogTW9kYWxQcm9wcykgPT4ge1xuICAvLyBVc2VkIGZvciBkaXNjbG9zdXJlIHVzYWdlIG9ubHlcbiAgY29uc3QgW3Zpc2libGUsIHNldFZpc2libGVdID0gdXNlU3RhdGUoZmFsc2UpXG4gIGNvbnN0IGNvbnRyb2xJZCA9IHVzZUlkKClcblxuICBjb25zdCBoYW5kbGVPcGVuID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIHNldFZpc2libGUodHJ1ZSlcbiAgfSwgW10pXG5cbiAgY29uc3QgaGFuZGxlQ2xvc2UgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgaWYgKG9uQ2xvc2UpIHtcbiAgICAgIG9uQ2xvc2UoKVxuICAgIH0gZWxzZSB7XG4gICAgICBjb25zdCBwcm9taXNlID0gb25CZWZvcmVDbG9zZT8uKClcbiAgICAgIGlmIChwcm9taXNlICYmICdjYXRjaCcgaW4gcHJvbWlzZSkge1xuICAgICAgICBwcm9taXNlLmNhdGNoKCgpID0+IG51bGwpXG4gICAgICB9XG4gICAgICBzZXRWaXNpYmxlKGZhbHNlKVxuICAgIH1cbiAgfSwgW29uQmVmb3JlQ2xvc2UsIG9uQ2xvc2VdKVxuXG4gIGNvbnN0IGhhbmRsZVRvZ2dsZSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRWaXNpYmxlKGN1cnJlbnQgPT4gIWN1cnJlbnQpXG4gIH0sIFtdKVxuXG4gIGNvbnN0IGZpbmFsSWQgPSBpZCA/PyBjb250cm9sSWRcbiAgY29uc3QgZmluYWxTaXplID0gc2l6ZSA/PyB3aWR0aFxuXG4gIHJldHVybiAoXG4gICAgPD5cbiAgICAgIHtkaXNjbG9zdXJlID8gKFxuICAgICAgICA8RGlzY2xvc3VyZVxuICAgICAgICAgIGlkPXtmaW5hbElkfVxuICAgICAgICAgIGhhbmRsZU9wZW49e2hhbmRsZU9wZW59XG4gICAgICAgICAgZGlzY2xvc3VyZT17ZGlzY2xvc3VyZX1cbiAgICAgICAgICBoYW5kbGVDbG9zZT17aGFuZGxlQ2xvc2V9XG4gICAgICAgICAgdmlzaWJsZT17dmlzaWJsZX1cbiAgICAgICAgICB0b2dnbGU9e2hhbmRsZVRvZ2dsZX1cbiAgICAgICAgLz5cbiAgICAgICkgOiBudWxsfVxuICAgICAgPERpYWxvZ1xuICAgICAgICBvcGVuPXt2aXNpYmxlIHx8IG9wZW4gfHwgb3BlbmVkfVxuICAgICAgICBwbGFjZW1lbnQ9e3BsYWNlbWVudH1cbiAgICAgICAgc2l6ZT17ZmluYWxTaXplfVxuICAgICAgICBhcmlhTGFiZWw9e2FyaWFMYWJlbH1cbiAgICAgICAgaGlkZU9uQ2xpY2tPdXRzaWRlPXtoaWRlT25DbGlja091dHNpZGV9XG4gICAgICAgIGhpZGVPbkVzYz17aGlkZU9uRXNjfVxuICAgICAgICBwcmV2ZW50Qm9keVNjcm9sbD17cHJldmVudEJvZHlTY3JvbGx9XG4gICAgICAgIG9uQ2xvc2U9e2hhbmRsZUNsb3NlfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgYmFja2Ryb3BDbGFzc05hbWU9e2JhY2tkcm9wQ2xhc3NOYW1lfVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgaWQ9e2ZpbmFsSWR9XG4gICAgICAgIGRpYWxvZ0Nzcz17Y3VzdG9tRGlhbG9nU3R5bGVzfVxuICAgICAgICBiYWNrZHJvcENzcz17Y3VzdG9tRGlhbG9nQmFja2Ryb3BTdHlsZXN9XG4gICAgICA+XG4gICAgICAgIDw+XG4gICAgICAgICAge3R5cGVvZiBjaGlsZHJlbiA9PT0gJ2Z1bmN0aW9uJ1xuICAgICAgICAgICAgPyBjaGlsZHJlbih7XG4gICAgICAgICAgICAgICAgdmlzaWJsZSxcbiAgICAgICAgICAgICAgICBvbkNsb3NlOiBoYW5kbGVDbG9zZSxcbiAgICAgICAgICAgICAgICBvbk9wZW46IGhhbmRsZU9wZW4sXG4gICAgICAgICAgICAgICAgdG9nZ2xlOiBoYW5kbGVUb2dnbGUsXG4gICAgICAgICAgICAgICAgbW9kYWxJZDogZmluYWxJZCxcbiAgICAgICAgICAgICAgICBoaWRlOiBoYW5kbGVDbG9zZSxcbiAgICAgICAgICAgICAgICBjbG9zZTogaGFuZGxlQ2xvc2UsXG4gICAgICAgICAgICAgICAgc2hvdzogaGFuZGxlT3BlbixcbiAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIDogY2hpbGRyZW59XG4gICAgICAgICAgPFN0eWxlZENvbnRhaW5lcj5cbiAgICAgICAgICAgIHtpc0Nsb3NhYmxlID8gKFxuICAgICAgICAgICAgICA8QnV0dG9uXG4gICAgICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e1xuICAgICAgICAgICAgICAgICAgZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9LWNsb3NlLWJ1dHRvbmAgOiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgb25DbGljaz17aGFuZGxlQ2xvc2V9XG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImdob3N0XCJcbiAgICAgICAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgICAgICAgIGljb249XCJjbG9zZVwiXG4gICAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgICAgYXJpYS1sYWJlbD1cImNsb3NlXCJcbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICkgOiBudWxsfVxuICAgICAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgICAgICA8Lz5cbiAgICAgIDwvRGlhbG9nPlxuICAgIDwvPlxuICApXG59XG4iXX0= */"));
16
+ }) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q2tDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01vZGFsL2luZGV4LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdEVsZW1lbnQsIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHR5cGUgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VDYWxsYmFjaywgdXNlSWQsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uL0J1dHRvbidcbmltcG9ydCB7IERpYWxvZyB9IGZyb20gJy4vRGlhbG9nJ1xuaW1wb3J0IHsgRGlzY2xvc3VyZSB9IGZyb20gJy4vRGlzY2xvc3VyZSdcbmltcG9ydCB0eXBlIHsgTW9kYWxQbGFjZW1lbnQsIE1vZGFsU2l6ZSwgTW9kYWxTdGF0ZSB9IGZyb20gJy4vdHlwZXMnXG5cbmV4cG9ydCB0eXBlIE1vZGFsUHJvcHMgPSB7XG4gIGlkPzogc3RyaW5nXG4gIGhpZGVPbkVzYz86IGJvb2xlYW5cbiAgaGlkZU9uQ2xpY2tPdXRzaWRlPzogYm9vbGVhblxuICBwcmV2ZW50Qm9keVNjcm9sbD86IGJvb2xlYW5cbiAgYXJpYUxhYmVsPzogc3RyaW5nXG4gIGRpc2Nsb3N1cmU/OiBSZWFjdEVsZW1lbnQgfCAoKHN0YXRlOiBNb2RhbFN0YXRlKSA9PiBSZWFjdEVsZW1lbnQpXG4gIGlzQ2xvc2FibGU/OiBib29sZWFuXG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkXG4gIG9uQmVmb3JlQ2xvc2U/OiAoKSA9PiBQcm9taXNlPHZvaWQ+IHwgdm9pZFxuICBvcGVuPzogYm9vbGVhblxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgWW91IHNob3VsZCB1c2Ugb3BlbiBwcm9wIGluc3RlYWRcbiAgICovXG4gIG9wZW5lZD86IGJvb2xlYW5cbiAgcGxhY2VtZW50PzogTW9kYWxQbGFjZW1lbnRcbiAgc2l6ZT86IE1vZGFsU2l6ZVxuICAvKipcbiAgICogQGRlcHJlY2F0ZWQgWW91IHNob3VsZCB1c2Ugc2l6ZSBwcm9wIGluc3RlYWRcbiAgICovXG4gIHdpZHRoPzogTW9kYWxTaXplXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGUgfCAoKGFyZ3M6IE1vZGFsU3RhdGUpID0+IFJlYWN0Tm9kZSlcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgYmFja2Ryb3BDbGFzc05hbWU/OiBzdHJpbmdcbiAgLyoqXG4gICAqIEBkZXByZWNhdGVkIFlvdSBzaG91bGQgdXNlIGJhY2tkcm9wQ2xhc3NOYW1lIGluc3RlYWRcbiAgICovXG4gIGN1c3RvbURpYWxvZ0JhY2tkcm9wU3R5bGVzPzogUmVhY3QuSlNYLkludHJpbnNpY0F0dHJpYnV0ZXNbJ2NzcyddXG4gIC8qKlxuICAgKiBAZGVwcmVjYXRlZCBZb3Ugc2hvdWxkIHVzZSBjbGFzc05hbWUgaW5zdGVhZFxuICAgKi9cbiAgY3VzdG9tRGlhbG9nU3R5bGVzPzogUmVhY3QuSlNYLkludHJpbnNpY0F0dHJpYnV0ZXNbJ2NzcyddXG59XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNwYWNlWycyJ119O1xuICByaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbmBcblxuLyoqXG4gKiBNb2RhbCBpcyBhIGNvbXBvbmVudCB0aGF0IGFsbG93cyB5b3UgdG8gZGlzcGxheSBjb250ZW50IG9uIHRvcCBvZiBvdGhlciBjb250ZW50LlxuICogSXQgaXMgb2Z0ZW4gdXNlZCB0byBkaXNwbGF5IGEgZGlhbG9nIHdpdGggYWRkaXRpb25hbCBpbmZvcm1hdGlvbiBvciB0byBhc2sgZm9yIGEgY29uZmlybWF0aW9uLlxuICovXG5leHBvcnQgY29uc3QgTW9kYWwgPSAoe1xuICBhcmlhTGFiZWwgPSAnbW9kYWwnLFxuICBpZCxcbiAgY2hpbGRyZW4sXG4gIGRpc2Nsb3N1cmUsXG4gIGhpZGVPbkNsaWNrT3V0c2lkZSA9IHRydWUsXG4gIGhpZGVPbkVzYyA9IHRydWUsXG4gIGlzQ2xvc2FibGUgPSB0cnVlLFxuICBvbkNsb3NlLFxuICBvbkJlZm9yZUNsb3NlLFxuICBvcGVuID0gZmFsc2UsXG4gIG9wZW5lZCA9IGZhbHNlLFxuICBwbGFjZW1lbnQgPSAnY2VudGVyJyxcbiAgcHJldmVudEJvZHlTY3JvbGwgPSB0cnVlLFxuICBzaXplLFxuICBjbGFzc05hbWUsXG4gICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gIGJhY2tkcm9wQ2xhc3NOYW1lLFxuICB3aWR0aCA9ICdzbWFsbCcsXG4gIGN1c3RvbURpYWxvZ1N0eWxlcyxcbiAgY3VzdG9tRGlhbG9nQmFja2Ryb3BTdHlsZXMsXG59OiBNb2RhbFByb3BzKSA9PiB7XG4gIC8vIFVzZWQgZm9yIGRpc2Nsb3N1cmUgdXNhZ2Ugb25seVxuICBjb25zdCBbdmlzaWJsZSwgc2V0VmlzaWJsZV0gPSB1c2VTdGF0ZShmYWxzZSlcbiAgY29uc3QgY29udHJvbElkID0gdXNlSWQoKVxuICBjb25zdCBkaXNjbG9zdXJlUmVmID0gdXNlUmVmPEhUTUxFbGVtZW50PihudWxsKVxuXG4gIGNvbnN0IGhhbmRsZU9wZW4gPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0VmlzaWJsZSh0cnVlKVxuICB9LCBbXSlcblxuICBjb25zdCBoYW5kbGVDbG9zZSA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBpZiAob25DbG9zZSkge1xuICAgICAgb25DbG9zZSgpXG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IHByb21pc2UgPSBvbkJlZm9yZUNsb3NlPy4oKVxuICAgICAgaWYgKHByb21pc2UgJiYgJ2NhdGNoJyBpbiBwcm9taXNlKSB7XG4gICAgICAgIHByb21pc2UuY2F0Y2goKCkgPT4gbnVsbClcbiAgICAgIH1cbiAgICAgIHNldFZpc2libGUoZmFsc2UpXG4gICAgfVxuICAgIGRpc2Nsb3N1cmVSZWYuY3VycmVudD8uZm9jdXMoKVxuICB9LCBbZGlzY2xvc3VyZVJlZiwgb25CZWZvcmVDbG9zZSwgb25DbG9zZV0pXG5cbiAgY29uc3QgaGFuZGxlVG9nZ2xlID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIHNldFZpc2libGUoY3VycmVudCA9PiAhY3VycmVudClcbiAgfSwgW10pXG5cbiAgY29uc3QgZmluYWxJZCA9IGlkID8/IGNvbnRyb2xJZFxuICBjb25zdCBmaW5hbFNpemUgPSBzaXplID8/IHdpZHRoXG5cbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAge2Rpc2Nsb3N1cmUgPyAoXG4gICAgICAgIDxEaXNjbG9zdXJlXG4gICAgICAgICAgaWQ9e2ZpbmFsSWR9XG4gICAgICAgICAgaGFuZGxlT3Blbj17aGFuZGxlT3Blbn1cbiAgICAgICAgICBkaXNjbG9zdXJlPXtkaXNjbG9zdXJlfVxuICAgICAgICAgIGhhbmRsZUNsb3NlPXtoYW5kbGVDbG9zZX1cbiAgICAgICAgICB2aXNpYmxlPXt2aXNpYmxlfVxuICAgICAgICAgIHRvZ2dsZT17aGFuZGxlVG9nZ2xlfVxuICAgICAgICAgIGRpc2Nsb3N1cmVSZWY9e2Rpc2Nsb3N1cmVSZWZ9XG4gICAgICAgIC8+XG4gICAgICApIDogbnVsbH1cbiAgICAgIDxEaWFsb2dcbiAgICAgICAgb3Blbj17dmlzaWJsZSB8fCBvcGVuIHx8IG9wZW5lZH1cbiAgICAgICAgcGxhY2VtZW50PXtwbGFjZW1lbnR9XG4gICAgICAgIHNpemU9e2ZpbmFsU2l6ZX1cbiAgICAgICAgYXJpYUxhYmVsPXthcmlhTGFiZWx9XG4gICAgICAgIGhpZGVPbkNsaWNrT3V0c2lkZT17aGlkZU9uQ2xpY2tPdXRzaWRlfVxuICAgICAgICBoaWRlT25Fc2M9e2hpZGVPbkVzY31cbiAgICAgICAgcHJldmVudEJvZHlTY3JvbGw9e3ByZXZlbnRCb2R5U2Nyb2xsfVxuICAgICAgICBvbkNsb3NlPXtoYW5kbGVDbG9zZX1cbiAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgIGJhY2tkcm9wQ2xhc3NOYW1lPXtiYWNrZHJvcENsYXNzTmFtZX1cbiAgICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgICAgIGlkPXtmaW5hbElkfVxuICAgICAgICBkaWFsb2dDc3M9e2N1c3RvbURpYWxvZ1N0eWxlc31cbiAgICAgICAgYmFja2Ryb3BDc3M9e2N1c3RvbURpYWxvZ0JhY2tkcm9wU3R5bGVzfVxuICAgICAgPlxuICAgICAgICA8PlxuICAgICAgICAgIHt0eXBlb2YgY2hpbGRyZW4gPT09ICdmdW5jdGlvbidcbiAgICAgICAgICAgID8gY2hpbGRyZW4oe1xuICAgICAgICAgICAgICAgIHZpc2libGUsXG4gICAgICAgICAgICAgICAgb25DbG9zZTogaGFuZGxlQ2xvc2UsXG4gICAgICAgICAgICAgICAgb25PcGVuOiBoYW5kbGVPcGVuLFxuICAgICAgICAgICAgICAgIHRvZ2dsZTogaGFuZGxlVG9nZ2xlLFxuICAgICAgICAgICAgICAgIG1vZGFsSWQ6IGZpbmFsSWQsXG4gICAgICAgICAgICAgICAgaGlkZTogaGFuZGxlQ2xvc2UsXG4gICAgICAgICAgICAgICAgY2xvc2U6IGhhbmRsZUNsb3NlLFxuICAgICAgICAgICAgICAgIHNob3c6IGhhbmRsZU9wZW4sXG4gICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICA6IGNoaWxkcmVufVxuICAgICAgICAgIDxTdHlsZWRDb250YWluZXI+XG4gICAgICAgICAgICB7aXNDbG9zYWJsZSA/IChcbiAgICAgICAgICAgICAgPEJ1dHRvblxuICAgICAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtcbiAgICAgICAgICAgICAgICAgIGRhdGFUZXN0SWQgPyBgJHtkYXRhVGVzdElkfS1jbG9zZS1idXR0b25gIDogdW5kZWZpbmVkXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIG9uQ2xpY2s9e2hhbmRsZUNsb3NlfVxuICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJnaG9zdFwiXG4gICAgICAgICAgICAgICAgc2l6ZT1cInNtYWxsXCJcbiAgICAgICAgICAgICAgICBpY29uPVwiY2xvc2VcIlxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgIGFyaWEtbGFiZWw9XCJjbG9zZVwiXG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICAgICAgPC8+XG4gICAgICA8L0RpYWxvZz5cbiAgICA8Lz5cbiAgKVxufVxuIl19 */"));
17
17
  const Modal = ({
18
18
  ariaLabel = "modal",
19
19
  id,
@@ -38,6 +38,7 @@ const Modal = ({
38
38
  }) => {
39
39
  const [visible, setVisible] = useState(false);
40
40
  const controlId = useId();
41
+ const disclosureRef = useRef(null);
41
42
  const handleOpen = useCallback(() => {
42
43
  setVisible(true);
43
44
  }, []);
@@ -51,14 +52,15 @@ const Modal = ({
51
52
  }
52
53
  setVisible(false);
53
54
  }
54
- }, [onBeforeClose, onClose]);
55
+ disclosureRef.current?.focus();
56
+ }, [disclosureRef, onBeforeClose, onClose]);
55
57
  const handleToggle = useCallback(() => {
56
58
  setVisible((current) => !current);
57
59
  }, []);
58
60
  const finalId = id ?? controlId;
59
61
  const finalSize = size ?? width;
60
62
  return /* @__PURE__ */ jsxs(Fragment, { children: [
61
- disclosure ? /* @__PURE__ */ jsx(Disclosure, { id: finalId, handleOpen, disclosure, handleClose, visible, toggle: handleToggle }) : null,
63
+ disclosure ? /* @__PURE__ */ jsx(Disclosure, { id: finalId, handleOpen, disclosure, handleClose, visible, toggle: handleToggle, disclosureRef }) : null,
62
64
  /* @__PURE__ */ jsx(Dialog, { open: visible || open || opened, placement, size: finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, onClose: handleClose, className, backdropClassName, "data-testid": dataTestId, id: finalId, dialogCss: customDialogStyles, backdropCss: customDialogBackdropStyles, children: /* @__PURE__ */ jsxs(Fragment, { children: [
63
65
  typeof children === "function" ? children({
64
66
  visible,
@@ -28,6 +28,7 @@ export type DisclosureProps = {
28
28
  visible: ModalState['visible'];
29
29
  toggle: ModalState['toggle'];
30
30
  id: string;
31
+ disclosureRef: React.RefObject<HTMLElement>;
31
32
  };
32
33
  export type DialogProps = {
33
34
  ariaLabel?: string;
@@ -3,9 +3,9 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const jsxRuntime = require("@emotion/react/jsx-runtime");
4
4
  const _styled = require("@emotion/styled/base");
5
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");
6
+ const index = require("../Stack/index.cjs");
7
+ const index$1 = require("../Text/index.cjs");
8
+ const index$2 = require("../Tooltip/index.cjs");
9
9
  const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
10
10
  const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
11
11
  function _EMOTION_STRINGIFIED_CSS_ERROR__() {
@@ -13,17 +13,23 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__() {
13
13
  }
14
14
  const SIZE = 24;
15
15
  const InnerCircleRing = /* @__PURE__ */ _styled__default.default("circle", process.env.NODE_ENV === "production" ? {
16
- target: "ehkrmld6"
16
+ target: "ehkrmld7"
17
17
  } : {
18
- target: "ehkrmld6",
18
+ target: "ehkrmld7",
19
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"]} */");
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\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
21
21
  const RadioMark = /* @__PURE__ */ _styled__default.default("circle", process.env.NODE_ENV === "production" ? {
22
+ target: "ehkrmld6"
23
+ } : {
24
+ target: "ehkrmld6",
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\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
27
+ const RadioStack = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
22
28
  target: "ehkrmld5"
23
29
  } : {
24
30
  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"]} */");
31
+ label: "RadioStack"
32
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAYuC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */");
27
33
  const RadioMarkedIcon = () => /* @__PURE__ */ jsxRuntime.jsxs("g", { children: [
28
34
  /* @__PURE__ */ jsxRuntime.jsx("circle", { cx: "12", cy: "12", r: "10", strokeWidth: "2" }),
29
35
  /* @__PURE__ */ jsxRuntime.jsx(InnerCircleRing, { cx: "12", cy: "12", r: "8" }),
@@ -40,7 +46,7 @@ const Ring = /* @__PURE__ */ _styled__default.default("svg", process.env.NODE_EN
40
46
  theme
41
47
  }) => theme.colors.neutral.border, ";", InnerCircleRing, "{fill:", ({
42
48
  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"]} */"));
49
+ }) => theme.colors.neutral.background, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAsBuB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
44
50
  const RadioInput = /* @__PURE__ */ _styled__default.default("input", process.env.NODE_ENV === "production" ? {
45
51
  target: "ehkrmld3"
46
52
  } : {
@@ -48,7 +54,9 @@ const RadioInput = /* @__PURE__ */ _styled__default.default("input", process.env
48
54
  label: "RadioInput"
49
55
  })("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
56
  theme
51
- }) => theme.colors.primary.backgroundStrong, ";}&[aria-invalid='true']:not([aria-disabled='true'])+", Ring, "{fill:", ({
57
+ }) => theme.colors.primary.backgroundStrong, ";}&:checked[aria-disabled='true'][aria-invalid='false']+", Ring, "{fill:", ({
58
+ theme
59
+ }) => theme.colors.primary.borderDisabled, ";}&[aria-invalid='true']:not([aria-disabled='true'])+", Ring, "{fill:", ({
52
60
  theme
53
61
  }) => theme.colors.danger.backgroundStrong, ";}&[aria-disabled='false']:active+", Ring, "{background-color:#5e127e40;fill:", ({
54
62
  theme
@@ -58,7 +66,7 @@ const RadioInput = /* @__PURE__ */ _styled__default.default("input", process.env
58
66
  theme
59
67
  }) => theme.colors.danger.backgroundStrong, ";", InnerCircleRing, "{fill:", ({
60
68
  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"]} */"));
69
+ }) => theme.colors.danger.background, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAkC+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
62
70
  const RadioContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
63
71
  target: "ehkrmld2"
64
72
  } : {
@@ -80,7 +88,7 @@ const RadioContainer = /* @__PURE__ */ _styled__default.default("div", process.e
80
88
  theme
81
89
  }) => theme.colors.neutral.borderDisabled, ";cursor:not-allowed;", InnerCircleRing, "{fill:", ({
82
90
  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"]} */"));
91
+ }) => theme.colors.neutral.backgroundDisabled, ";}}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx"],"names":[],"mappings":"AAyFiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
84
92
  const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.env.NODE_ENV === "production" ? {
85
93
  target: "ehkrmld1"
86
94
  } : {
@@ -92,17 +100,17 @@ const StyledLabel = /* @__PURE__ */ _styled__default.default("label", process.en
92
100
  } : {
93
101
  name: "82a6rk",
94
102
  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"]} */",
103
+ 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":"AA4IgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */",
96
104
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
97
105
  });
98
- const MargedText = /* @__PURE__ */ _styled__default.default(index.Text, process.env.NODE_ENV === "production" ? {
106
+ const MargedText = /* @__PURE__ */ _styled__default.default(index$1.Text, process.env.NODE_ENV === "production" ? {
99
107
  target: "ehkrmld0"
100
108
  } : {
101
109
  target: "ehkrmld0",
102
110
  label: "MargedText"
103
111
  })("margin-left:", ({
104
112
  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"]} */"));
113
+ }) => 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":"AAgJ+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Radio/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport type { ForwardedRef, InputHTMLAttributes, ReactNode } from 'react'\nimport { forwardRef, useId } from 'react'\nimport { Stack } from '../Stack'\nimport { Text } from '../Text'\nimport { Tooltip } from '../Tooltip'\n\nconst SIZE = 24\n\nconst InnerCircleRing = styled.circle``\nconst RadioMark = styled.circle``\n\nexport const RadioStack = styled(Stack)``\n\nconst RadioMarkedIcon = () => (\n  <g>\n    <circle cx=\"12\" cy=\"12\" r=\"10\" strokeWidth=\"2\" />\n    <InnerCircleRing cx=\"12\" cy=\"12\" r=\"8\" />\n    <RadioMark cx=\"12\" cy=\"12\" r=\"5\" />\n  </g>\n)\n\nconst Ring = styled.svg`\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  min-width: ${SIZE}px;\n  min-height: ${SIZE}px;\n  border-radius: ${({ theme }) => theme.radii.circle};\n  fill: ${({ theme }) => theme.colors.neutral.border};\n  ${InnerCircleRing} {\n    fill: ${({ theme }) => theme.colors.neutral.background};\n  }\n`\n\nconst RadioInput = styled.input`\n  cursor: pointer;\n  position: absolute;\n  height: ${SIZE}px;\n  width: ${SIZE}px;\n  opacity: 0;\n  white-space: nowrap;\n  border-width: 0;\n  & + ${Ring} {\n    ${RadioMark} {\n      transform-origin: center;\n      transition: 200ms transform ease-in-out;\n      transform: scale(0);\n    }\n  }\n\n  &:checked + svg {\n    ${RadioMark} {\n      transform: scale(1);\n    }\n  }\n\n  &:checked[aria-disabled='false'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n  }\n\n  &:checked[aria-disabled='true'][aria-invalid='false'] + ${Ring} {\n    fill: ${({ theme }) => theme.colors.primary.borderDisabled};\n  }\n\n  &[aria-invalid='true']:not([aria-disabled='true']) + ${Ring} {\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n  }\n\n  &[aria-disabled='false']:active + ${Ring} {\n    background-color: #5e127e40;\n    fill: ${({ theme }) => theme.colors.primary.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.primary.background};\n    }\n  }\n\n  &[aria-disabled='false']:focus-visible + ${Ring} {\n    outline: -webkit-focus-ring-color auto 1px;\n  }\n\n  &[aria-invalid='true']:focus + ${Ring} {\n    background-color: #f91b6c40;\n    fill: ${({ theme }) => theme.colors.danger.backgroundStrong};\n    ${InnerCircleRing} {\n      fill: ${({ theme }) => theme.colors.danger.background};\n    }\n  }\n`\n\nconst RadioContainer = styled.div`\n  position: relative;\n  display: flex;\n  flex: 1;\n  align-items: flex-start;\n  gap: ${({ theme }) => theme.space['1']};\n\n  &[aria-disabled='false'],\n  &[aria-disabled='false'] > label {\n    cursor: pointer;\n  }\n\n  &[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      \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        <RadioStack gap={0.5}>\n          <RadioContainer\n            aria-disabled={disabled}\n            className={className}\n            data-checked={checked}\n            data-error={error}\n            data-testid={dataTestId}\n          >\n            <RadioInput\n              type=\"radio\"\n              aria-invalid={!!error}\n              aria-disabled={disabled}\n              aria-label={ariaLabel}\n              checked={checked}\n              id={`${computedName}-${value}`}\n              onChange={onChange}\n              onFocus={onFocus}\n              onKeyDown={onKeyDown}\n              onBlur={onBlur}\n              value={value}\n              disabled={disabled}\n              name={computedName}\n              autoFocus={autoFocus}\n              ref={ref}\n            />\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        </RadioStack>\n      </Tooltip>\n    )\n  },\n)\n"]} */"));
106
114
  const Radio = React.forwardRef(({
107
115
  checked = false,
108
116
  onChange,
@@ -123,7 +131,7 @@ const Radio = React.forwardRef(({
123
131
  }, ref) => {
124
132
  const id = React.useId();
125
133
  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: [
134
+ return /* @__PURE__ */ jsxRuntime.jsx(index$2.Tooltip, { text: tooltip, children: /* @__PURE__ */ jsxRuntime.jsxs(RadioStack, { gap: 0.5, children: [
127
135
  /* @__PURE__ */ jsxRuntime.jsxs(RadioContainer, { "aria-disabled": disabled, className, "data-checked": checked, "data-error": error, "data-testid": dataTestId, children: [
128
136
  /* @__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
137
  /* @__PURE__ */ jsxRuntime.jsx(Ring, { viewBox: "0 0 24 24", children: /* @__PURE__ */ jsxRuntime.jsx(RadioMarkedIcon, {}) }),
@@ -133,3 +141,4 @@ const Radio = React.forwardRef(({
133
141
  ] }) });
134
142
  });
135
143
  exports.Radio = Radio;
144
+ exports.RadioStack = RadioStack;
@@ -1,4 +1,21 @@
1
1
  import type { InputHTMLAttributes, ReactNode } from 'react';
2
+ export declare const RadioStack: import("@emotion/styled").StyledComponent<{
3
+ theme?: import("@emotion/react").Theme;
4
+ as?: import("react").ElementType;
5
+ } & {
6
+ gap?: keyof import("../..").UltravioletUITheme["space"] | number;
7
+ direction?: "row" | "column";
8
+ alignItems?: import("react").CSSProperties["alignItems"];
9
+ justifyContent?: import("react").CSSProperties["justifyContent"];
10
+ wrap?: boolean | import("react").CSSProperties["flexWrap"];
11
+ width?: import("react").CSSProperties["width"];
12
+ flex?: import("react").CSSProperties["flex"];
13
+ className?: string;
14
+ children: ReactNode;
15
+ 'data-testid'?: string;
16
+ } & import("react").ClassAttributes<HTMLDivElement> & import("react").HTMLAttributes<HTMLDivElement> & {
17
+ theme?: import("@emotion/react").Theme;
18
+ }, {}, {}>;
2
19
  type RadioProps = {
3
20
  error?: ReactNode;
4
21
  checked?: boolean;