@reitwagen/design-components 0.3.0 → 0.4.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 (282) hide show
  1. package/dist/components/Button/Button.d.ts +15 -5
  2. package/dist/components/Button/Button.d.ts.map +1 -1
  3. package/dist/components/Button/Button.js +12 -2
  4. package/dist/components/Checkbox/Checkbox.d.ts +30 -3
  5. package/dist/components/Checkbox/Checkbox.d.ts.map +1 -1
  6. package/dist/components/Checkbox/Checkbox.js +28 -0
  7. package/dist/components/Checkbox/Checkbox.stories.js +1 -1
  8. package/dist/components/Chip/Chip.d.ts +12 -2
  9. package/dist/components/Chip/Chip.d.ts.map +1 -1
  10. package/dist/components/Chip/Chip.js +11 -0
  11. package/dist/components/Icons/IconAlarmOff.d.ts +1 -0
  12. package/dist/components/Icons/IconAlarmOff.d.ts.map +1 -1
  13. package/dist/components/Icons/IconAlarmOff.js +2 -0
  14. package/dist/components/Icons/IconAlarmOn.d.ts +1 -0
  15. package/dist/components/Icons/IconAlarmOn.d.ts.map +1 -1
  16. package/dist/components/Icons/IconAlarmOn.js +2 -0
  17. package/dist/components/Icons/IconAppleDefault.d.ts +1 -0
  18. package/dist/components/Icons/IconAppleDefault.d.ts.map +1 -1
  19. package/dist/components/Icons/IconAppleDefault.js +2 -0
  20. package/dist/components/Icons/IconArrowDown.d.ts +1 -0
  21. package/dist/components/Icons/IconArrowDown.d.ts.map +1 -1
  22. package/dist/components/Icons/IconArrowDown.js +2 -0
  23. package/dist/components/Icons/IconArrowLeft.d.ts +1 -0
  24. package/dist/components/Icons/IconArrowLeft.d.ts.map +1 -1
  25. package/dist/components/Icons/IconArrowLeft.js +2 -0
  26. package/dist/components/Icons/IconArrowRight.d.ts +1 -0
  27. package/dist/components/Icons/IconArrowRight.d.ts.map +1 -1
  28. package/dist/components/Icons/IconArrowRight.js +2 -0
  29. package/dist/components/Icons/IconArrowUp.d.ts +1 -0
  30. package/dist/components/Icons/IconArrowUp.d.ts.map +1 -1
  31. package/dist/components/Icons/IconArrowUp.js +2 -0
  32. package/dist/components/Icons/IconBikeDefault.d.ts +1 -0
  33. package/dist/components/Icons/IconBikeDefault.d.ts.map +1 -1
  34. package/dist/components/Icons/IconBikeDefault.js +2 -0
  35. package/dist/components/Icons/IconBookmarkOff.d.ts +1 -0
  36. package/dist/components/Icons/IconBookmarkOff.d.ts.map +1 -1
  37. package/dist/components/Icons/IconBookmarkOff.js +2 -0
  38. package/dist/components/Icons/IconBookmarkOn.d.ts +1 -0
  39. package/dist/components/Icons/IconBookmarkOn.d.ts.map +1 -1
  40. package/dist/components/Icons/IconBookmarkOn.js +2 -0
  41. package/dist/components/Icons/IconCafeDefault.d.ts +1 -0
  42. package/dist/components/Icons/IconCafeDefault.d.ts.map +1 -1
  43. package/dist/components/Icons/IconCafeDefault.js +2 -0
  44. package/dist/components/Icons/IconCalendarDefault.d.ts +1 -0
  45. package/dist/components/Icons/IconCalendarDefault.d.ts.map +1 -1
  46. package/dist/components/Icons/IconCalendarDefault.js +2 -0
  47. package/dist/components/Icons/IconCallDefault.d.ts +1 -0
  48. package/dist/components/Icons/IconCallDefault.d.ts.map +1 -1
  49. package/dist/components/Icons/IconCallDefault.js +2 -0
  50. package/dist/components/Icons/IconCameraDefault.d.ts +1 -0
  51. package/dist/components/Icons/IconCameraDefault.d.ts.map +1 -1
  52. package/dist/components/Icons/IconCameraDefault.js +2 -0
  53. package/dist/components/Icons/IconChatDefault.d.ts +1 -0
  54. package/dist/components/Icons/IconChatDefault.d.ts.map +1 -1
  55. package/dist/components/Icons/IconChatDefault.js +2 -0
  56. package/dist/components/Icons/IconCheckDefault.d.ts +1 -0
  57. package/dist/components/Icons/IconCheckDefault.d.ts.map +1 -1
  58. package/dist/components/Icons/IconCheckDefault.js +2 -0
  59. package/dist/components/Icons/IconChevronDown.d.ts +1 -0
  60. package/dist/components/Icons/IconChevronDown.d.ts.map +1 -1
  61. package/dist/components/Icons/IconChevronDown.js +2 -0
  62. package/dist/components/Icons/IconChevronLeft.d.ts +1 -0
  63. package/dist/components/Icons/IconChevronLeft.d.ts.map +1 -1
  64. package/dist/components/Icons/IconChevronLeft.js +2 -0
  65. package/dist/components/Icons/IconChevronRight.d.ts +1 -0
  66. package/dist/components/Icons/IconChevronRight.d.ts.map +1 -1
  67. package/dist/components/Icons/IconChevronRight.js +2 -0
  68. package/dist/components/Icons/IconChevronUp.d.ts +1 -0
  69. package/dist/components/Icons/IconChevronUp.d.ts.map +1 -1
  70. package/dist/components/Icons/IconChevronUp.js +2 -0
  71. package/dist/components/Icons/IconCloseCircle.d.ts +1 -0
  72. package/dist/components/Icons/IconCloseCircle.d.ts.map +1 -1
  73. package/dist/components/Icons/IconCloseCircle.js +2 -0
  74. package/dist/components/Icons/IconCloseDefault.d.ts +1 -0
  75. package/dist/components/Icons/IconCloseDefault.d.ts.map +1 -1
  76. package/dist/components/Icons/IconCloseDefault.js +2 -0
  77. package/dist/components/Icons/IconCloseSmall.d.ts +1 -0
  78. package/dist/components/Icons/IconCloseSmall.d.ts.map +1 -1
  79. package/dist/components/Icons/IconCloseSmall.js +2 -0
  80. package/dist/components/Icons/IconCommentOff.d.ts +1 -0
  81. package/dist/components/Icons/IconCommentOff.d.ts.map +1 -1
  82. package/dist/components/Icons/IconCommentOff.js +2 -0
  83. package/dist/components/Icons/IconCommentOn.d.ts +1 -0
  84. package/dist/components/Icons/IconCommentOn.d.ts.map +1 -1
  85. package/dist/components/Icons/IconCommentOn.js +2 -0
  86. package/dist/components/Icons/IconCommunityDefault.d.ts +1 -0
  87. package/dist/components/Icons/IconCommunityDefault.d.ts.map +1 -1
  88. package/dist/components/Icons/IconCommunityDefault.js +2 -0
  89. package/dist/components/Icons/IconCopyDefault.d.ts +1 -0
  90. package/dist/components/Icons/IconCopyDefault.d.ts.map +1 -1
  91. package/dist/components/Icons/IconCopyDefault.js +2 -0
  92. package/dist/components/Icons/IconCouponDefault.d.ts +1 -0
  93. package/dist/components/Icons/IconCouponDefault.d.ts.map +1 -1
  94. package/dist/components/Icons/IconCouponDefault.js +2 -0
  95. package/dist/components/Icons/IconEditDefault.d.ts +1 -0
  96. package/dist/components/Icons/IconEditDefault.d.ts.map +1 -1
  97. package/dist/components/Icons/IconEditDefault.js +2 -0
  98. package/dist/components/Icons/IconEyeOff.d.ts +1 -0
  99. package/dist/components/Icons/IconEyeOff.d.ts.map +1 -1
  100. package/dist/components/Icons/IconEyeOff.js +2 -0
  101. package/dist/components/Icons/IconEyeOn.d.ts +1 -0
  102. package/dist/components/Icons/IconEyeOn.d.ts.map +1 -1
  103. package/dist/components/Icons/IconEyeOn.js +2 -0
  104. package/dist/components/Icons/IconFilterDefault.d.ts +1 -0
  105. package/dist/components/Icons/IconFilterDefault.d.ts.map +1 -1
  106. package/dist/components/Icons/IconFilterDefault.js +2 -0
  107. package/dist/components/Icons/IconFireDefault.d.ts +1 -0
  108. package/dist/components/Icons/IconFireDefault.d.ts.map +1 -1
  109. package/dist/components/Icons/IconFireDefault.js +2 -0
  110. package/dist/components/Icons/IconFlagDefault.d.ts +1 -0
  111. package/dist/components/Icons/IconFlagDefault.d.ts.map +1 -1
  112. package/dist/components/Icons/IconFlagDefault.js +2 -0
  113. package/dist/components/Icons/IconFunDefault.d.ts +1 -0
  114. package/dist/components/Icons/IconFunDefault.d.ts.map +1 -1
  115. package/dist/components/Icons/IconFunDefault.js +2 -0
  116. package/dist/components/Icons/IconHeartDefault.d.ts +1 -0
  117. package/dist/components/Icons/IconHeartDefault.d.ts.map +1 -1
  118. package/dist/components/Icons/IconHeartDefault.js +2 -0
  119. package/dist/components/Icons/IconHeartOff.d.ts +1 -0
  120. package/dist/components/Icons/IconHeartOff.d.ts.map +1 -1
  121. package/dist/components/Icons/IconHeartOff.js +2 -0
  122. package/dist/components/Icons/IconHeartOn.d.ts +1 -0
  123. package/dist/components/Icons/IconHeartOn.d.ts.map +1 -1
  124. package/dist/components/Icons/IconHeartOn.js +2 -0
  125. package/dist/components/Icons/IconHelmetDefault.d.ts +1 -0
  126. package/dist/components/Icons/IconHelmetDefault.d.ts.map +1 -1
  127. package/dist/components/Icons/IconHelmetDefault.js +2 -0
  128. package/dist/components/Icons/IconHomeDefault.d.ts +1 -0
  129. package/dist/components/Icons/IconHomeDefault.d.ts.map +1 -1
  130. package/dist/components/Icons/IconHomeDefault.js +2 -0
  131. package/dist/components/Icons/IconHomeLine.d.ts +1 -0
  132. package/dist/components/Icons/IconHomeLine.d.ts.map +1 -1
  133. package/dist/components/Icons/IconHomeLine.js +2 -0
  134. package/dist/components/Icons/IconImageDefault.d.ts +1 -0
  135. package/dist/components/Icons/IconImageDefault.d.ts.map +1 -1
  136. package/dist/components/Icons/IconImageDefault.js +2 -0
  137. package/dist/components/Icons/IconInfoDefault.d.ts +1 -0
  138. package/dist/components/Icons/IconInfoDefault.d.ts.map +1 -1
  139. package/dist/components/Icons/IconInfoDefault.js +2 -0
  140. package/dist/components/Icons/IconInformationDefault.d.ts +1 -0
  141. package/dist/components/Icons/IconInformationDefault.d.ts.map +1 -1
  142. package/dist/components/Icons/IconInformationDefault.js +2 -0
  143. package/dist/components/Icons/IconInstagramDefault.d.ts +1 -0
  144. package/dist/components/Icons/IconInstagramDefault.d.ts.map +1 -1
  145. package/dist/components/Icons/IconInstagramDefault.js +2 -0
  146. package/dist/components/Icons/IconKakaotalkDefault.d.ts +1 -0
  147. package/dist/components/Icons/IconKakaotalkDefault.d.ts.map +1 -1
  148. package/dist/components/Icons/IconKakaotalkDefault.js +2 -0
  149. package/dist/components/Icons/IconLike.d.ts +1 -0
  150. package/dist/components/Icons/IconLike.d.ts.map +1 -1
  151. package/dist/components/Icons/IconLike.js +2 -0
  152. package/dist/components/Icons/IconLikeOff.d.ts +1 -0
  153. package/dist/components/Icons/IconLikeOff.d.ts.map +1 -1
  154. package/dist/components/Icons/IconLikeOff.js +2 -0
  155. package/dist/components/Icons/IconLikeOn.d.ts +1 -0
  156. package/dist/components/Icons/IconLikeOn.d.ts.map +1 -1
  157. package/dist/components/Icons/IconLikeOn.js +2 -0
  158. package/dist/components/Icons/IconLocateDefault.d.ts +1 -0
  159. package/dist/components/Icons/IconLocateDefault.d.ts.map +1 -1
  160. package/dist/components/Icons/IconLocateDefault.js +2 -0
  161. package/dist/components/Icons/IconMYDefault.d.ts +1 -0
  162. package/dist/components/Icons/IconMYDefault.d.ts.map +1 -1
  163. package/dist/components/Icons/IconMYDefault.js +2 -0
  164. package/dist/components/Icons/IconMYLine.d.ts +1 -0
  165. package/dist/components/Icons/IconMYLine.d.ts.map +1 -1
  166. package/dist/components/Icons/IconMYLine.js +2 -0
  167. package/dist/components/Icons/IconMedal.d.ts +1 -0
  168. package/dist/components/Icons/IconMedal.d.ts.map +1 -1
  169. package/dist/components/Icons/IconMedal.js +2 -0
  170. package/dist/components/Icons/IconMenuDefault.d.ts +1 -0
  171. package/dist/components/Icons/IconMenuDefault.d.ts.map +1 -1
  172. package/dist/components/Icons/IconMenuDefault.js +2 -0
  173. package/dist/components/Icons/IconMessage.d.ts +1 -0
  174. package/dist/components/Icons/IconMessage.d.ts.map +1 -1
  175. package/dist/components/Icons/IconMessage.js +2 -0
  176. package/dist/components/Icons/IconMessageDefault.d.ts +1 -0
  177. package/dist/components/Icons/IconMessageDefault.d.ts.map +1 -1
  178. package/dist/components/Icons/IconMessageDefault.js +2 -0
  179. package/dist/components/Icons/IconMinusDefault.d.ts +1 -0
  180. package/dist/components/Icons/IconMinusDefault.d.ts.map +1 -1
  181. package/dist/components/Icons/IconMinusDefault.js +2 -0
  182. package/dist/components/Icons/IconMoreDefault.d.ts +1 -0
  183. package/dist/components/Icons/IconMoreDefault.d.ts.map +1 -1
  184. package/dist/components/Icons/IconMoreDefault.js +2 -0
  185. package/dist/components/Icons/IconNaviDefault.d.ts +1 -0
  186. package/dist/components/Icons/IconNaviDefault.d.ts.map +1 -1
  187. package/dist/components/Icons/IconNaviDefault.js +2 -0
  188. package/dist/components/Icons/IconNaviLine.d.ts +1 -0
  189. package/dist/components/Icons/IconNaviLine.d.ts.map +1 -1
  190. package/dist/components/Icons/IconNaviLine.js +2 -0
  191. package/dist/components/Icons/IconNull.d.ts +1 -0
  192. package/dist/components/Icons/IconNull.d.ts.map +1 -1
  193. package/dist/components/Icons/IconNull.js +2 -0
  194. package/dist/components/Icons/IconOilDefault.d.ts +1 -0
  195. package/dist/components/Icons/IconOilDefault.d.ts.map +1 -1
  196. package/dist/components/Icons/IconOilDefault.js +2 -0
  197. package/dist/components/Icons/IconPlaceDefault.d.ts +1 -0
  198. package/dist/components/Icons/IconPlaceDefault.d.ts.map +1 -1
  199. package/dist/components/Icons/IconPlaceDefault.js +2 -0
  200. package/dist/components/Icons/IconPlaceLine.d.ts +1 -0
  201. package/dist/components/Icons/IconPlaceLine.d.ts.map +1 -1
  202. package/dist/components/Icons/IconPlaceLine.js +2 -0
  203. package/dist/components/Icons/IconPlusDefault.d.ts +1 -0
  204. package/dist/components/Icons/IconPlusDefault.d.ts.map +1 -1
  205. package/dist/components/Icons/IconPlusDefault.js +2 -0
  206. package/dist/components/Icons/IconReceiptDefault.d.ts +1 -0
  207. package/dist/components/Icons/IconReceiptDefault.d.ts.map +1 -1
  208. package/dist/components/Icons/IconReceiptDefault.js +2 -0
  209. package/dist/components/Icons/IconRepairDefault.d.ts +1 -0
  210. package/dist/components/Icons/IconRepairDefault.d.ts.map +1 -1
  211. package/dist/components/Icons/IconRepairDefault.js +2 -0
  212. package/dist/components/Icons/IconResetDefault.d.ts +1 -0
  213. package/dist/components/Icons/IconResetDefault.d.ts.map +1 -1
  214. package/dist/components/Icons/IconResetDefault.js +2 -0
  215. package/dist/components/Icons/IconRevolvingLightDefault.d.ts +1 -0
  216. package/dist/components/Icons/IconRevolvingLightDefault.d.ts.map +1 -1
  217. package/dist/components/Icons/IconRevolvingLightDefault.js +2 -0
  218. package/dist/components/Icons/IconSadDefault.d.ts +1 -0
  219. package/dist/components/Icons/IconSadDefault.d.ts.map +1 -1
  220. package/dist/components/Icons/IconSadDefault.js +2 -0
  221. package/dist/components/Icons/IconSafe.d.ts +1 -0
  222. package/dist/components/Icons/IconSafe.d.ts.map +1 -1
  223. package/dist/components/Icons/IconSafe.js +2 -0
  224. package/dist/components/Icons/IconSearchDefault.d.ts +1 -0
  225. package/dist/components/Icons/IconSearchDefault.d.ts.map +1 -1
  226. package/dist/components/Icons/IconSearchDefault.js +2 -0
  227. package/dist/components/Icons/IconSettingDefault.d.ts +1 -0
  228. package/dist/components/Icons/IconSettingDefault.d.ts.map +1 -1
  229. package/dist/components/Icons/IconSettingDefault.js +2 -0
  230. package/dist/components/Icons/IconShareDefault.d.ts +1 -0
  231. package/dist/components/Icons/IconShareDefault.d.ts.map +1 -1
  232. package/dist/components/Icons/IconShareDefault.js +2 -0
  233. package/dist/components/Icons/IconShopDefault.d.ts +1 -0
  234. package/dist/components/Icons/IconShopDefault.d.ts.map +1 -1
  235. package/dist/components/Icons/IconShopDefault.js +2 -0
  236. package/dist/components/Icons/IconSmileDefault.d.ts +1 -0
  237. package/dist/components/Icons/IconSmileDefault.d.ts.map +1 -1
  238. package/dist/components/Icons/IconSmileDefault.js +2 -0
  239. package/dist/components/Icons/IconStarOff.d.ts +1 -0
  240. package/dist/components/Icons/IconStarOff.d.ts.map +1 -1
  241. package/dist/components/Icons/IconStarOff.js +2 -0
  242. package/dist/components/Icons/IconStarOn.d.ts +1 -0
  243. package/dist/components/Icons/IconStarOn.d.ts.map +1 -1
  244. package/dist/components/Icons/IconStarOn.js +2 -0
  245. package/dist/components/Icons/IconThumbDefault.d.ts +1 -0
  246. package/dist/components/Icons/IconThumbDefault.d.ts.map +1 -1
  247. package/dist/components/Icons/IconThumbDefault.js +2 -0
  248. package/dist/components/Icons/IconThunder.d.ts +1 -0
  249. package/dist/components/Icons/IconThunder.d.ts.map +1 -1
  250. package/dist/components/Icons/IconThunder.js +2 -0
  251. package/dist/components/Icons/IconTimeDefault.d.ts +1 -0
  252. package/dist/components/Icons/IconTimeDefault.d.ts.map +1 -1
  253. package/dist/components/Icons/IconTimeDefault.js +2 -0
  254. package/dist/components/Icons/IconVoteDefault.d.ts +1 -0
  255. package/dist/components/Icons/IconVoteDefault.d.ts.map +1 -1
  256. package/dist/components/Icons/IconVoteDefault.js +2 -0
  257. package/dist/components/Icons/IconYoutubeDefault.d.ts +1 -0
  258. package/dist/components/Icons/IconYoutubeDefault.d.ts.map +1 -1
  259. package/dist/components/Icons/IconYoutubeDefault.js +2 -0
  260. package/dist/components/Radio/Radio.d.ts +34 -0
  261. package/dist/components/Radio/Radio.d.ts.map +1 -0
  262. package/dist/components/Radio/Radio.js +45 -0
  263. package/dist/components/Radio/Radio.stories.d.ts +33 -0
  264. package/dist/components/Radio/Radio.stories.d.ts.map +1 -0
  265. package/dist/components/Radio/Radio.stories.js +118 -0
  266. package/dist/components/Radio/Radio.styles.d.ts +9 -0
  267. package/dist/components/Radio/Radio.styles.d.ts.map +1 -0
  268. package/dist/components/Radio/Radio.styles.js +70 -0
  269. package/dist/components/Radio/index.d.ts +2 -0
  270. package/dist/components/Radio/index.d.ts.map +1 -0
  271. package/dist/components/Radio/index.js +5 -0
  272. package/dist/components/Toggle/Toggle.d.ts +15 -12
  273. package/dist/components/Toggle/Toggle.d.ts.map +1 -1
  274. package/dist/components/Toggle/Toggle.js +8 -8
  275. package/dist/components/Toggle/Toggle.stories.d.ts.map +1 -1
  276. package/dist/index.css +31 -0
  277. package/dist/index.d.ts +1 -0
  278. package/dist/index.d.ts.map +1 -1
  279. package/dist/index.js +1 -0
  280. package/dist/types/props.d.ts +6 -2
  281. package/dist/types/props.d.ts.map +1 -1
  282. package/package.json +3 -3
@@ -6,6 +6,7 @@ interface Props extends SVGProps<SVGSVGElement> {
6
6
  }
7
7
  /**
8
8
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
9
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
9
10
  * @example
10
11
  * ```tsx
11
12
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -1 +1 @@
1
- {"version":3,"file":"IconThumbDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconThumbDefault.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;GAOG;AACH,iBAAS,gBAAgB,CAAC,EACxB,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CA4BP;AAED,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"IconThumbDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconThumbDefault.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;;GAQG;AACH,iBAAS,gBAAgB,CAAC,EACxB,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CA4BP;AAED,eAAe,gBAAgB,CAAC"}
@@ -1,8 +1,10 @@
1
+ "use client";
1
2
  "use strict";
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  const jsx_runtime_1 = require("react/jsx-runtime");
4
5
  /**
5
6
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
7
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
6
8
  * @example
7
9
  * ```tsx
8
10
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -6,6 +6,7 @@ interface Props extends SVGProps<SVGSVGElement> {
6
6
  }
7
7
  /**
8
8
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
9
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
9
10
  * @example
10
11
  * ```tsx
11
12
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -1 +1 @@
1
- {"version":3,"file":"IconThunder.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconThunder.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;GAOG;AACH,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,KAAU,EAAE,MAAW,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,2CAmB3E;AAED,eAAe,WAAW,CAAC"}
1
+ {"version":3,"file":"IconThunder.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconThunder.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;;GAQG;AACH,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,KAAU,EAAE,MAAW,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,2CAmB3E;AAED,eAAe,WAAW,CAAC"}
@@ -1,8 +1,10 @@
1
+ "use client";
1
2
  "use strict";
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  const jsx_runtime_1 = require("react/jsx-runtime");
4
5
  /**
5
6
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
7
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
6
8
  * @example
7
9
  * ```tsx
8
10
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -6,6 +6,7 @@ interface Props extends SVGProps<SVGSVGElement> {
6
6
  }
7
7
  /**
8
8
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
9
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
9
10
  * @example
10
11
  * ```tsx
11
12
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -1 +1 @@
1
- {"version":3,"file":"IconTimeDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconTimeDefault.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;GAOG;AACH,iBAAS,eAAe,CAAC,EACvB,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CA4BP;AAED,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"IconTimeDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconTimeDefault.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;;GAQG;AACH,iBAAS,eAAe,CAAC,EACvB,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CA4BP;AAED,eAAe,eAAe,CAAC"}
@@ -1,8 +1,10 @@
1
+ "use client";
1
2
  "use strict";
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  const jsx_runtime_1 = require("react/jsx-runtime");
4
5
  /**
5
6
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
7
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
6
8
  * @example
7
9
  * ```tsx
8
10
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -6,6 +6,7 @@ interface Props extends SVGProps<SVGSVGElement> {
6
6
  }
7
7
  /**
8
8
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
9
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
9
10
  * @example
10
11
  * ```tsx
11
12
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -1 +1 @@
1
- {"version":3,"file":"IconVoteDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconVoteDefault.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;GAOG;AACH,iBAAS,eAAe,CAAC,EACvB,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CAiBP;AAED,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"IconVoteDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconVoteDefault.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;;GAQG;AACH,iBAAS,eAAe,CAAC,EACvB,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CAiBP;AAED,eAAe,eAAe,CAAC"}
@@ -1,8 +1,10 @@
1
+ "use client";
1
2
  "use strict";
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  const jsx_runtime_1 = require("react/jsx-runtime");
4
5
  /**
5
6
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
7
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
6
8
  * @example
7
9
  * ```tsx
8
10
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -6,6 +6,7 @@ interface Props extends SVGProps<SVGSVGElement> {
6
6
  }
7
7
  /**
8
8
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
9
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
9
10
  * @example
10
11
  * ```tsx
11
12
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -1 +1 @@
1
- {"version":3,"file":"IconYoutubeDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconYoutubeDefault.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;GAOG;AACH,iBAAS,kBAAkB,CAAC,EAC1B,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CAmBP;AAED,eAAe,kBAAkB,CAAC"}
1
+ {"version":3,"file":"IconYoutubeDefault.d.ts","sourceRoot":"","sources":["../../../src/components/Icons/IconYoutubeDefault.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEtC,UAAU,KAAM,SAAQ,QAAQ,CAAC,aAAa,CAAC;IAC7C,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED;;;;;;;;GAQG;AACH,iBAAS,kBAAkB,CAAC,EAC1B,SAAS,EACT,KAAU,EACV,MAAW,EACX,GAAG,KAAK,EACT,EAAE,KAAK,2CAmBP;AAED,eAAe,kBAAkB,CAAC"}
@@ -1,8 +1,10 @@
1
+ "use client";
1
2
  "use strict";
2
3
  Object.defineProperty(exports, "__esModule", { value: true });
3
4
  const jsx_runtime_1 = require("react/jsx-runtime");
4
5
  /**
5
6
  * `Icon-` 컴포넌트의 기본 사이즈는 24px을 기준으로 합니다. className 속성으로 text color를 지정하여 색상을 변경할 수 있습니다.
7
+ * @see [RDS Storybook: Icon](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-icons--docs)
6
8
  * @example
7
9
  * ```tsx
8
10
  * <Icon width={24} height={24} className="text-gray-500" />
@@ -0,0 +1,34 @@
1
+ import { ComponentPropsWithRef } from "react";
2
+ import { VariantProps } from "class-variance-authority";
3
+ import { ChildrenProps } from "../../types/props";
4
+ import { radioVariants } from "./Radio.styles";
5
+ export type RadioProps = ComponentPropsWithRef<"input"> & ChildrenProps & VariantProps<typeof radioVariants> & {
6
+ /**
7
+ * 라디오의 선택 상태가 변경될 때 호출되는 이벤트 핸들러
8
+ */
9
+ onCheckedChange?: (checked: boolean) => void;
10
+ };
11
+ /**
12
+ * `Radio`: 그룹 내 단일 선택만 가능한 요소로, 상호 배타적 옵션을 나타냅니다.
13
+ * @see [RDS Storybook: Radio](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-radio--docs)
14
+ * @example
15
+ * ```tsx
16
+ * const [selected, setSelected] = useState(false)
17
+ *
18
+ * // Controlled
19
+ * <Radio
20
+ * checked={selected}
21
+ * onCheckedChange={setSelected}
22
+ * >
23
+ * Option
24
+ * </Radio>
25
+ *
26
+ * // Uncontrolled
27
+ * <Radio defaultChecked>Option</Radio>
28
+ * ```
29
+ */
30
+ export declare function Radio({ id: idProp, checked: controlledChecked, defaultChecked, disabled, className, onCheckedChange, children, ...props }: RadioProps): import("react/jsx-runtime").JSX.Element;
31
+ export declare namespace Radio {
32
+ var displayName: string;
33
+ }
34
+ //# sourceMappingURL=Radio.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Radio.d.ts","sourceRoot":"","sources":["../../../src/components/Radio/Radio.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAmB,MAAM,OAAO,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAoB,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAEjE,MAAM,MAAM,UAAU,GAAG,qBAAqB,CAAC,OAAO,CAAC,GACrD,aAAa,GACb,YAAY,CAAC,OAAO,aAAa,CAAC,GAAG;IACnC;;OAEG;IACH,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAC9C,CAAC;AAEJ;;;;;;;;;;;;;;;;;;GAkBG;AAEH,wBAAgB,KAAK,CAAC,EACpB,EAAE,EAAE,MAAM,EACV,OAAO,EAAE,iBAAiB,EAC1B,cAAc,EACd,QAAQ,EACR,SAAS,EACT,eAAe,EACf,QAAQ,EACR,GAAG,KAAK,EACT,EAAE,UAAU,2CAwDZ;yBAjEe,KAAK"}
@@ -0,0 +1,45 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.Radio = Radio;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const style_1 = require("../../utils/style");
8
+ const Radio_styles_1 = require("./Radio.styles");
9
+ /**
10
+ * `Radio`: 그룹 내 단일 선택만 가능한 요소로, 상호 배타적 옵션을 나타냅니다.
11
+ * @see [RDS Storybook: Radio](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-radio--docs)
12
+ * @example
13
+ * ```tsx
14
+ * const [selected, setSelected] = useState(false)
15
+ *
16
+ * // Controlled
17
+ * <Radio
18
+ * checked={selected}
19
+ * onCheckedChange={setSelected}
20
+ * >
21
+ * Option
22
+ * </Radio>
23
+ *
24
+ * // Uncontrolled
25
+ * <Radio defaultChecked>Option</Radio>
26
+ * ```
27
+ */
28
+ function Radio({ id: idProp, checked: controlledChecked, defaultChecked, disabled, className, onCheckedChange, children, ...props }) {
29
+ const [uncontrolledChecked, setUncontrolledChecked] = (0, react_1.useState)(defaultChecked);
30
+ const uniqId = (0, react_1.useId)();
31
+ const id = idProp || uniqId;
32
+ const isChecked = controlledChecked ?? uncontrolledChecked;
33
+ const handleChange = () => {
34
+ if (disabled)
35
+ return;
36
+ if (controlledChecked === undefined) {
37
+ setUncontrolledChecked(true);
38
+ }
39
+ onCheckedChange?.(true);
40
+ };
41
+ return ((0, jsx_runtime_1.jsxs)("label", { htmlFor: id, className: (0, style_1.cn)("ui:flex ui:items-center ui:gap-2 ui:cursor-pointer ui:select-none", disabled && "ui:cursor-default ui:pointer-events-none"), children: [(0, jsx_runtime_1.jsx)("input", { id: id, type: "radio", checked: isChecked, defaultChecked: defaultChecked, disabled: disabled || undefined, onChange: handleChange, className: "ui:sr-only", ...props }), (0, jsx_runtime_1.jsx)("div", { className: (0, Radio_styles_1.radioVariants)({ checked: isChecked, disabled, className }), children: (0, jsx_runtime_1.jsx)("div", { className: (0, Radio_styles_1.radioDotVariants)({ checked: isChecked, disabled }) }) }), children && ((0, jsx_runtime_1.jsx)("span", { className: (0, style_1.cn)("ui:text-body5", disabled
42
+ ? "ui:text-gray-400 ui:pointer-events-none"
43
+ : "ui:cursor-pointer"), children: children }))] }));
44
+ }
45
+ Radio.displayName = "Radio";
@@ -0,0 +1,33 @@
1
+ import type { StoryObj } from "@storybook/react";
2
+ import { Radio } from "./Radio";
3
+ declare const meta: {
4
+ title: string;
5
+ component: typeof Radio;
6
+ tags: string[];
7
+ parameters: {
8
+ docs: {
9
+ description: {
10
+ component: string;
11
+ };
12
+ };
13
+ };
14
+ argTypes: {
15
+ checked: {
16
+ control: {
17
+ type: "boolean";
18
+ };
19
+ };
20
+ disabled: {
21
+ control: {
22
+ type: "boolean";
23
+ };
24
+ };
25
+ };
26
+ };
27
+ export default meta;
28
+ type Story = StoryObj<typeof meta>;
29
+ export declare const Controlled: Story;
30
+ export declare const ControlledWithLabel: Story;
31
+ export declare const UnControlled: Story;
32
+ export declare const UnControlledWithLabel: Story;
33
+ //# sourceMappingURL=Radio.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Radio.stories.d.ts","sourceRoot":"","sources":["../../../src/components/Radio/Radio.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,KAAK,EAAc,MAAM,SAAS,CAAC;AAG5C,QAAA,MAAM,IAAI;;;;;;;;;;;;;;;;;;;;;;;CAqBoB,CAAC;AAE/B,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,UAAU,EAAE,KA+BxB,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,KA2BjC,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KAmB1B,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,KASnC,CAAC"}
@@ -0,0 +1,118 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UnControlledWithLabel = exports.UnControlled = exports.ControlledWithLabel = exports.Controlled = void 0;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const Radio_1 = require("./Radio");
6
+ const meta = {
7
+ title: "Components/Radio",
8
+ component: Radio_1.Radio,
9
+ tags: ["autodocs"],
10
+ parameters: {
11
+ docs: {
12
+ description: {
13
+ component: `
14
+ 그룹 내 단일 선택만 가능한 요소로, 상호 배타적 옵션을 나타냅니다. 라벨과 함께 사용하거나 단독으로 사용할 수 있습니다.
15
+ `,
16
+ },
17
+ },
18
+ },
19
+ argTypes: {
20
+ checked: {
21
+ control: { type: "boolean" },
22
+ },
23
+ disabled: {
24
+ control: { type: "boolean" },
25
+ },
26
+ },
27
+ };
28
+ exports.default = meta;
29
+ exports.Controlled = {
30
+ parameters: {
31
+ docs: {
32
+ description: {
33
+ story: `
34
+ ### 상태를 외부에서 관리하는 방식
35
+
36
+ Radio의 상태를 외부에서 관리하려면 \`checked\`와 \`onCheckedChange\` 속성을 함께 사용하세요.
37
+ `,
38
+ },
39
+ source: {
40
+ code: `
41
+ function Controlled() {
42
+ const [checked, setChecked] = useState(true);
43
+
44
+ return (
45
+ <Radio
46
+ checked={checked}
47
+ onCheckedChange={() => setChecked(!checked)}
48
+ />
49
+ );
50
+ }
51
+ `.trim(),
52
+ },
53
+ },
54
+ },
55
+ render: (props) => (0, jsx_runtime_1.jsx)(Radio_1.Radio, { ...props }),
56
+ args: {
57
+ checked: true,
58
+ disabled: false,
59
+ },
60
+ };
61
+ exports.ControlledWithLabel = {
62
+ parameters: {
63
+ docs: {
64
+ source: {
65
+ code: `
66
+ function ControlledWithLabel() {
67
+ const [checked, setChecked] = useState(false);
68
+
69
+ return (
70
+ <Radio
71
+ checked={checked}
72
+ onCheckedChange={() => setChecked(!checked)}
73
+ >
74
+ Action Text
75
+ </Radio>
76
+ );
77
+ }
78
+ `.trim(),
79
+ },
80
+ },
81
+ },
82
+ render: (props) => (0, jsx_runtime_1.jsx)(Radio_1.Radio, { ...props }),
83
+ args: {
84
+ children: "Action Text",
85
+ checked: false,
86
+ disabled: false,
87
+ },
88
+ };
89
+ exports.UnControlled = {
90
+ parameters: {
91
+ docs: {
92
+ description: {
93
+ story: `
94
+ ### 상태를 내부에서 관리하는 방식
95
+
96
+ Radio상태를 내부에서 자동으로 관리하려면 <code>defaultChecked</code> 속성을 사용하세요. 이 속성은 Checkbox이 처음 화면에 표시될 때 선택 상태를 정해주고, 그 후에는 컴포넌트가 스스로 상태를 관리해요. 상태 변화를 추적하지 않아도 될 때 유용해요.
97
+ `,
98
+ },
99
+ },
100
+ },
101
+ render: (props) => (0, jsx_runtime_1.jsx)(Radio_1.Radio, { ...props }),
102
+ args: {
103
+ defaultChecked: true,
104
+ },
105
+ argTypes: {
106
+ defaultChecked: { control: "boolean" },
107
+ },
108
+ };
109
+ exports.UnControlledWithLabel = {
110
+ render: (props) => (0, jsx_runtime_1.jsx)(Radio_1.Radio, { ...props, children: props.children }),
111
+ args: {
112
+ children: "Action Text",
113
+ defaultChecked: true,
114
+ },
115
+ argTypes: {
116
+ defaultChecked: { control: "boolean" },
117
+ },
118
+ };
@@ -0,0 +1,9 @@
1
+ export declare const radioVariants: (props?: ({
2
+ checked?: boolean | null | undefined;
3
+ disabled?: boolean | null | undefined;
4
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
5
+ export declare const radioDotVariants: (props?: ({
6
+ checked?: boolean | null | undefined;
7
+ disabled?: boolean | null | undefined;
8
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
9
+ //# sourceMappingURL=Radio.styles.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Radio.styles.d.ts","sourceRoot":"","sources":["../../../src/components/Radio/Radio.styles.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,aAAa;;;8EAyCzB,CAAC;AAEF,eAAO,MAAM,gBAAgB;;;8EA8B5B,CAAC"}
@@ -0,0 +1,70 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.radioDotVariants = exports.radioVariants = void 0;
4
+ const class_variance_authority_1 = require("class-variance-authority");
5
+ exports.radioVariants = (0, class_variance_authority_1.cva)("ui:w-[22px] ui:h-[22px] ui:flex ui:items-center ui:justify-center ui:rounded-full ui:border-[1.5px] ui:duration-100 ui:transition-colors", {
6
+ variants: {
7
+ checked: {
8
+ true: "",
9
+ false: "",
10
+ },
11
+ disabled: {
12
+ true: "",
13
+ false: "",
14
+ },
15
+ },
16
+ compoundVariants: [
17
+ {
18
+ checked: true,
19
+ disabled: false,
20
+ className: "ui:bg-white ui:border-blue-700 ui:active:border-blue-800",
21
+ },
22
+ {
23
+ checked: false,
24
+ disabled: false,
25
+ className: "ui:bg-white ui:border-gray-200 ui:active:bg-gray-100 ui:active:border-gray-300",
26
+ },
27
+ {
28
+ checked: true,
29
+ disabled: true,
30
+ className: "ui:bg-white ui:border-blue-300",
31
+ },
32
+ {
33
+ checked: false,
34
+ disabled: true,
35
+ className: "ui:bg-white ui:border-gray-100",
36
+ },
37
+ ],
38
+ defaultVariants: {
39
+ checked: false,
40
+ disabled: false,
41
+ },
42
+ });
43
+ exports.radioDotVariants = (0, class_variance_authority_1.cva)("ui:w-3 ui:h-3 ui:rounded-full ui:transition-colors ui:duration-300", {
44
+ variants: {
45
+ checked: {
46
+ true: "ui:opacity-100",
47
+ false: "ui:opacity-0",
48
+ },
49
+ disabled: {
50
+ true: "",
51
+ false: "",
52
+ },
53
+ },
54
+ compoundVariants: [
55
+ {
56
+ checked: true,
57
+ disabled: false,
58
+ className: "ui:bg-blue-700 ui:active:bg-blue-800",
59
+ },
60
+ {
61
+ checked: true,
62
+ disabled: true,
63
+ className: "ui:bg-blue-300",
64
+ },
65
+ ],
66
+ defaultVariants: {
67
+ checked: false,
68
+ disabled: false,
69
+ },
70
+ });
@@ -0,0 +1,2 @@
1
+ export { Radio } from "./Radio";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Radio/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC"}
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Radio = void 0;
4
+ var Radio_1 = require("./Radio");
5
+ Object.defineProperty(exports, "Radio", { enumerable: true, get: function () { return Radio_1.Radio; } });
@@ -1,29 +1,32 @@
1
- import { ButtonHTMLAttributes } from "react";
1
+ import { ElementType } from "react";
2
2
  import { type VariantProps } from "class-variance-authority";
3
3
  import { toggleVariants } from "./Toggle.styles";
4
- export interface ToggleProps extends Omit<ButtonHTMLAttributes<HTMLButtonElement>, "disabled">, VariantProps<typeof toggleVariants> {
4
+ import { PolymorphicComponentWithRef } from "../../types/props";
5
+ type ToggleOwnProps = VariantProps<typeof toggleVariants> & {
5
6
  /**
6
7
  * 토글 상태가 변경될 때 호출되는 이벤트 핸들러
7
8
  */
8
9
  onCheckedChange?: (checked: boolean) => void;
9
- }
10
+ };
11
+ export type ToggleProps<C extends ElementType> = PolymorphicComponentWithRef<C, ToggleOwnProps>;
10
12
  /**
11
- * `Toggle` 컴포넌트는 즉각적인 상태 전환(켜기/끄기)을 위한 요소로, 활성화/비활성화 기능을 나타냅니다.
13
+ * `Toggle`: 즉각적인 상태 전환(켜기/끄기)을 위한 요소로, 활성화/비활성화 기능을 나타냅니다.
14
+ * @see [RDS Storybook: Toggle](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-toggle--docs)
12
15
  * @example
13
16
  * ```tsx
14
17
  * const [checked, setChecked] = useState(false)
15
18
  * // Controlled
16
- * <Toggle
17
- * checked={checked}
18
- * onCheckedChange={setChecked}
19
- * />
20
- * // UnControlled
21
- * <Toggle defaultChecked={true}
22
- * />
19
+ * <Toggle
20
+ * checked={checked}
21
+ * onCheckedChange={setChecked}
22
+ * />
23
+ * // UnControlled
24
+ * <Toggle defaultChecked={true} />
23
25
  * ```
24
26
  */
25
- export declare function Toggle({ checked: controlledChecked, defaultChecked, disabled, onCheckedChange, ...props }: ToggleProps): import("react/jsx-runtime").JSX.Element;
27
+ export declare function Toggle<C extends ElementType = "button">({ checked: controlledChecked, defaultChecked, disabled, onCheckedChange, ...props }: ToggleProps<C>): import("react/jsx-runtime").JSX.Element;
26
28
  export declare namespace Toggle {
27
29
  var displayName: string;
28
30
  }
31
+ export {};
29
32
  //# sourceMappingURL=Toggle.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Toggle.d.ts","sourceRoot":"","sources":["../../../src/components/Toggle/Toggle.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAY,MAAM,OAAO,CAAC;AACvD,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAE7D,OAAO,EAAiB,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAEhE,MAAM,WAAW,WACf,SAAQ,IAAI,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,EAAE,UAAU,CAAC,EAC/D,YAAY,CAAC,OAAO,cAAc,CAAC;IACrC;;OAEG;IACH,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAC9C;AAED;;;;;;;;;;;;;;GAcG;AAEH,wBAAgB,MAAM,CAAC,EACrB,OAAO,EAAE,iBAAiB,EAC1B,cAAc,EACd,QAAQ,EACR,eAAe,EACf,GAAG,KAAK,EACT,EAAE,WAAW,2CAmCb;yBAzCe,MAAM"}
1
+ {"version":3,"file":"Toggle.d.ts","sourceRoot":"","sources":["../../../src/components/Toggle/Toggle.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,WAAW,EAAY,MAAM,OAAO,CAAC;AAC9C,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAE7D,OAAO,EAAiB,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAChE,OAAO,EAAE,2BAA2B,EAAE,MAAM,mBAAmB,CAAC;AAEhE,KAAK,cAAc,GAAG,YAAY,CAAC,OAAO,cAAc,CAAC,GAAG;IAC1D;;OAEG;IACH,eAAe,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CAC9C,CAAC;AAEF,MAAM,MAAM,WAAW,CAAC,CAAC,SAAS,WAAW,IAAI,2BAA2B,CAC1E,CAAC,EACD,cAAc,CACf,CAAC;AAEF;;;;;;;;;;;;;;GAcG;AAEH,wBAAgB,MAAM,CAAC,CAAC,SAAS,WAAW,GAAG,QAAQ,EAAE,EACvD,OAAO,EAAE,iBAAiB,EAC1B,cAAc,EACd,QAAQ,EACR,eAAe,EACf,GAAG,KAAK,EACT,EAAE,WAAW,CAAC,CAAC,CAAC,2CAmChB;yBAzCe,MAAM"}
@@ -7,18 +7,18 @@ const react_1 = require("react");
7
7
  const style_1 = require("../../utils/style");
8
8
  const Toggle_styles_1 = require("./Toggle.styles");
9
9
  /**
10
- * `Toggle` 컴포넌트는 즉각적인 상태 전환(켜기/끄기)을 위한 요소로, 활성화/비활성화 기능을 나타냅니다.
10
+ * `Toggle`: 즉각적인 상태 전환(켜기/끄기)을 위한 요소로, 활성화/비활성화 기능을 나타냅니다.
11
+ * @see [RDS Storybook: Toggle](https://main--691ac7d6da1eb0c0acb5f3e2.chromatic.com/?path=/docs/components-toggle--docs)
11
12
  * @example
12
13
  * ```tsx
13
14
  * const [checked, setChecked] = useState(false)
14
15
  * // Controlled
15
- * <Toggle
16
- * checked={checked}
17
- * onCheckedChange={setChecked}
18
- * />
19
- * // UnControlled
20
- * <Toggle defaultChecked={true}
21
- * />
16
+ * <Toggle
17
+ * checked={checked}
18
+ * onCheckedChange={setChecked}
19
+ * />
20
+ * // UnControlled
21
+ * <Toggle defaultChecked={true} />
22
22
  * ```
23
23
  */
24
24
  function Toggle({ checked: controlledChecked, defaultChecked, disabled, onCheckedChange, ...props }) {
@@ -1 +1 @@
1
- {"version":3,"file":"Toggle.stories.d.ts","sourceRoot":"","sources":["../../../src/components/Toggle/Toggle.stories.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,MAAM,EAAe,MAAM,UAAU,CAAC;AAE/C,QAAA,MAAM,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;CAwBqB,CAAC;AAEhC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAcnC,eAAO,MAAM,UAAU,EAAE,KA8CxB,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KA2B1B,CAAC"}
1
+ {"version":3,"file":"Toggle.stories.d.ts","sourceRoot":"","sources":["../../../src/components/Toggle/Toggle.stories.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAQ,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,MAAM,EAAe,MAAM,UAAU,CAAC;AAE/C,QAAA,MAAM,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;CAwBqB,CAAC;AAEhC,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAgBnC,eAAO,MAAM,UAAU,EAAE,KA8CxB,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KA2B1B,CAAC"}
package/dist/index.css CHANGED
@@ -268,6 +268,17 @@
268
268
  .ui\:pointer-events-none {
269
269
  pointer-events: none;
270
270
  }
271
+ .ui\:sr-only {
272
+ position: absolute;
273
+ width: 1px;
274
+ height: 1px;
275
+ padding: 0;
276
+ margin: -1px;
277
+ overflow: hidden;
278
+ clip-path: inset(50%);
279
+ white-space: nowrap;
280
+ border-width: 0;
281
+ }
271
282
  .ui\:my-3 {
272
283
  margin-block: calc(var(--ui-spacing) * 3);
273
284
  }
@@ -280,6 +291,9 @@
280
291
  .ui\:inline-flex {
281
292
  display: inline-flex;
282
293
  }
294
+ .ui\:h-3 {
295
+ height: calc(var(--ui-spacing) * 3);
296
+ }
283
297
  .ui\:h-6 {
284
298
  height: calc(var(--ui-spacing) * 6);
285
299
  }
@@ -316,6 +330,9 @@
316
330
  .ui\:h-px {
317
331
  height: 1px;
318
332
  }
333
+ .ui\:w-3 {
334
+ width: calc(var(--ui-spacing) * 3);
335
+ }
319
336
  .ui\:w-6 {
320
337
  width: calc(var(--ui-spacing) * 6);
321
338
  }
@@ -638,6 +655,9 @@
638
655
  .ui\:text-gray-300 {
639
656
  color: var(--ui-color-gray-300);
640
657
  }
658
+ .ui\:text-gray-400 {
659
+ color: var(--ui-color-gray-400);
660
+ }
641
661
  .ui\:text-gray-500 {
642
662
  color: var(--ui-color-gray-500);
643
663
  }
@@ -653,6 +673,12 @@
653
673
  .ui\:text-white {
654
674
  color: var(--ui-color-white);
655
675
  }
676
+ .ui\:opacity-0 {
677
+ opacity: 0%;
678
+ }
679
+ .ui\:opacity-100 {
680
+ opacity: 100%;
681
+ }
656
682
  .ui\:ring-0 {
657
683
  --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
658
684
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
@@ -685,6 +711,11 @@
685
711
  box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
686
712
  }
687
713
  }
714
+ .ui\:active\:border-blue-800 {
715
+ &:active {
716
+ border-color: var(--ui-color-blue-800);
717
+ }
718
+ }
688
719
  .ui\:active\:border-gray-100 {
689
720
  &:active {
690
721
  border-color: var(--ui-color-gray-100);
package/dist/index.d.ts CHANGED
@@ -2,5 +2,6 @@ export * from "./components/Button";
2
2
  export * from "./components/Chip";
3
3
  export * from "./components/Toggle";
4
4
  export * from "./components/Checkbox";
5
+ export * from "./components/Radio";
5
6
  export * from "./components/Icons";
6
7
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,qBAAqB,CAAC;AACpC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,uBAAuB,CAAC;AAGtC,cAAc,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,qBAAqB,CAAC;AACpC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oBAAoB,CAAC;AAGnC,cAAc,oBAAoB,CAAC"}