@causw/core 0.0.9 → 0.0.11

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 (459) hide show
  1. package/dist/_virtual/rolldown_runtime.cjs +29 -0
  2. package/dist/assets/avatar/default.cjs +11 -0
  3. package/dist/assets/avatar/default.mjs +6 -0
  4. package/dist/assets/avatar/default.mjs.map +1 -0
  5. package/dist/components/Avatar/Avatar.cjs +46 -0
  6. package/dist/components/Avatar/Avatar.d.cts +25 -0
  7. package/dist/components/Avatar/Avatar.d.cts.map +1 -0
  8. package/dist/components/Avatar/Avatar.d.mts +26 -0
  9. package/dist/components/Avatar/Avatar.d.mts.map +1 -0
  10. package/dist/components/Avatar/Avatar.mjs +45 -0
  11. package/dist/components/Avatar/Avatar.mjs.map +1 -0
  12. package/dist/components/Avatar/Avatar.styles.cjs +22 -0
  13. package/dist/components/Avatar/Avatar.styles.d.cts +75 -0
  14. package/dist/components/Avatar/Avatar.styles.d.cts.map +1 -0
  15. package/dist/components/Avatar/Avatar.styles.d.mts +75 -0
  16. package/dist/components/Avatar/Avatar.styles.d.mts.map +1 -0
  17. package/dist/components/Avatar/Avatar.styles.mjs +22 -0
  18. package/dist/components/Avatar/Avatar.styles.mjs.map +1 -0
  19. package/dist/components/Avatar/index.d.mts +2 -0
  20. package/dist/components/Box/Box.cjs +24 -0
  21. package/dist/components/Box/Box.d.cts +22 -0
  22. package/dist/components/Box/Box.d.cts.map +1 -0
  23. package/dist/components/Box/Box.d.mts +23 -0
  24. package/dist/components/Box/Box.d.mts.map +1 -0
  25. package/dist/components/Box/Box.mjs +23 -0
  26. package/dist/components/Box/Box.mjs.map +1 -0
  27. package/dist/components/Box/Box.styles.cjs +48 -0
  28. package/dist/components/Box/Box.styles.d.cts +105 -0
  29. package/dist/components/Box/Box.styles.d.cts.map +1 -0
  30. package/dist/components/Box/Box.styles.d.mts +105 -0
  31. package/dist/components/Box/Box.styles.d.mts.map +1 -0
  32. package/dist/components/Box/Box.styles.mjs +48 -0
  33. package/dist/components/Box/Box.styles.mjs.map +1 -0
  34. package/dist/components/Box/index.d.mts +2 -0
  35. package/dist/components/Button/Button.cjs +23 -0
  36. package/dist/components/Button/Button.d.cts +19 -0
  37. package/dist/components/Button/Button.d.cts.map +1 -0
  38. package/dist/components/Button/Button.d.mts +20 -0
  39. package/dist/components/Button/Button.d.mts.map +1 -0
  40. package/dist/components/Button/Button.mjs +23 -0
  41. package/dist/components/Button/Button.mjs.map +1 -0
  42. package/dist/components/Button/Button.styles.cjs +35 -0
  43. package/dist/components/Button/Button.styles.d.cts +63 -0
  44. package/dist/components/Button/Button.styles.d.cts.map +1 -0
  45. package/dist/components/Button/Button.styles.d.mts +63 -0
  46. package/dist/components/Button/Button.styles.d.mts.map +1 -0
  47. package/dist/components/Button/Button.styles.mjs +35 -0
  48. package/dist/components/Button/Button.styles.mjs.map +1 -0
  49. package/dist/components/Button/index.d.mts +1 -0
  50. package/dist/components/CTAButton/CTAButton.cjs +22 -0
  51. package/dist/components/CTAButton/CTAButton.d.cts +18 -0
  52. package/dist/components/CTAButton/CTAButton.d.cts.map +1 -0
  53. package/dist/components/CTAButton/CTAButton.d.mts +19 -0
  54. package/dist/components/CTAButton/CTAButton.d.mts.map +1 -0
  55. package/dist/components/CTAButton/CTAButton.mjs +22 -0
  56. package/dist/components/CTAButton/CTAButton.mjs.map +1 -0
  57. package/dist/components/CTAButton/CTAButton.styles.cjs +32 -0
  58. package/dist/components/CTAButton/CTAButton.styles.d.cts +57 -0
  59. package/dist/components/CTAButton/CTAButton.styles.d.cts.map +1 -0
  60. package/dist/components/CTAButton/CTAButton.styles.d.mts +57 -0
  61. package/dist/components/CTAButton/CTAButton.styles.d.mts.map +1 -0
  62. package/dist/components/CTAButton/CTAButton.styles.mjs +32 -0
  63. package/dist/components/CTAButton/CTAButton.styles.mjs.map +1 -0
  64. package/dist/components/CTAButton/index.d.mts +1 -0
  65. package/dist/components/Checkbox/Checkbox.cjs +83 -0
  66. package/dist/components/Checkbox/Checkbox.d.cts +44 -0
  67. package/dist/components/Checkbox/Checkbox.d.cts.map +1 -0
  68. package/dist/components/Checkbox/Checkbox.d.mts +46 -0
  69. package/dist/components/Checkbox/Checkbox.d.mts.map +1 -0
  70. package/dist/components/Checkbox/Checkbox.mjs +82 -0
  71. package/dist/components/Checkbox/Checkbox.mjs.map +1 -0
  72. package/dist/components/Checkbox/Checkbox.styles.cjs +31 -0
  73. package/dist/components/Checkbox/Checkbox.styles.d.cts +75 -0
  74. package/dist/components/Checkbox/Checkbox.styles.d.cts.map +1 -0
  75. package/dist/components/Checkbox/Checkbox.styles.d.mts +75 -0
  76. package/dist/components/Checkbox/Checkbox.styles.d.mts.map +1 -0
  77. package/dist/components/Checkbox/Checkbox.styles.mjs +31 -0
  78. package/dist/components/Checkbox/Checkbox.styles.mjs.map +1 -0
  79. package/dist/components/Checkbox/index.d.mts +1 -0
  80. package/dist/components/Chip/Chip.cjs +29 -0
  81. package/dist/components/Chip/Chip.d.cts +22 -0
  82. package/dist/components/Chip/Chip.d.cts.map +1 -0
  83. package/dist/components/Chip/Chip.d.mts +23 -0
  84. package/dist/components/Chip/Chip.d.mts.map +1 -0
  85. package/dist/components/Chip/Chip.mjs +28 -0
  86. package/dist/components/Chip/Chip.mjs.map +1 -0
  87. package/dist/components/Chip/Chip.styles.cjs +30 -0
  88. package/dist/components/Chip/Chip.styles.d.cts +51 -0
  89. package/dist/components/Chip/Chip.styles.d.cts.map +1 -0
  90. package/dist/components/Chip/Chip.styles.d.mts +51 -0
  91. package/dist/components/Chip/Chip.styles.d.mts.map +1 -0
  92. package/dist/components/Chip/Chip.styles.mjs +30 -0
  93. package/dist/components/Chip/Chip.styles.mjs.map +1 -0
  94. package/dist/components/Chip/index.d.mts +2 -0
  95. package/dist/components/Dialog/Dialog.cjs +59 -0
  96. package/dist/components/Dialog/Dialog.d.cts +57 -0
  97. package/dist/components/Dialog/Dialog.d.cts.map +1 -0
  98. package/dist/components/Dialog/Dialog.d.mts +58 -0
  99. package/dist/components/Dialog/Dialog.d.mts.map +1 -0
  100. package/dist/components/Dialog/Dialog.mjs +58 -0
  101. package/dist/components/Dialog/Dialog.mjs.map +1 -0
  102. package/dist/components/Dialog/Dialog.styles.cjs +35 -0
  103. package/dist/components/Dialog/Dialog.styles.d.cts +46 -0
  104. package/dist/components/Dialog/Dialog.styles.d.cts.map +1 -0
  105. package/dist/components/Dialog/Dialog.styles.d.mts +46 -0
  106. package/dist/components/Dialog/Dialog.styles.d.mts.map +1 -0
  107. package/dist/components/Dialog/Dialog.styles.mjs +33 -0
  108. package/dist/components/Dialog/Dialog.styles.mjs.map +1 -0
  109. package/dist/components/Dialog/index.d.mts +2 -0
  110. package/dist/components/Dropdown/Dropdown.cjs +39 -0
  111. package/dist/components/Dropdown/Dropdown.d.cts +36 -0
  112. package/dist/components/Dropdown/Dropdown.d.cts.map +1 -0
  113. package/dist/components/Dropdown/Dropdown.d.mts +36 -0
  114. package/dist/components/Dropdown/Dropdown.d.mts.map +1 -0
  115. package/dist/components/Dropdown/Dropdown.mjs +37 -0
  116. package/dist/components/Dropdown/Dropdown.mjs.map +1 -0
  117. package/dist/components/Dropdown/Dropdown.styles.cjs +19 -0
  118. package/dist/components/Dropdown/Dropdown.styles.d.cts +54 -0
  119. package/dist/components/Dropdown/Dropdown.styles.d.cts.map +1 -0
  120. package/dist/components/Dropdown/Dropdown.styles.d.mts +54 -0
  121. package/dist/components/Dropdown/Dropdown.styles.d.mts.map +1 -0
  122. package/dist/components/Dropdown/Dropdown.styles.mjs +19 -0
  123. package/dist/components/Dropdown/Dropdown.styles.mjs.map +1 -0
  124. package/dist/components/Dropdown/index.d.mts +2 -0
  125. package/dist/components/Field/Field.cjs +80 -0
  126. package/dist/components/Field/Field.d.cts +59 -0
  127. package/dist/components/Field/Field.d.cts.map +1 -0
  128. package/dist/components/Field/Field.d.mts +60 -0
  129. package/dist/components/Field/Field.d.mts.map +1 -0
  130. package/dist/components/Field/Field.mjs +79 -0
  131. package/dist/components/Field/Field.mjs.map +1 -0
  132. package/dist/components/Field/Field.styles.cjs +13 -0
  133. package/dist/components/Field/Field.styles.mjs +13 -0
  134. package/dist/components/Field/Field.styles.mjs.map +1 -0
  135. package/dist/components/Field/index.d.mts +1 -0
  136. package/dist/components/Flex/Flex.cjs +25 -0
  137. package/dist/components/Flex/Flex.d.cts +24 -0
  138. package/dist/components/Flex/Flex.d.cts.map +1 -0
  139. package/dist/components/Flex/Flex.d.mts +25 -0
  140. package/dist/components/Flex/Flex.d.mts.map +1 -0
  141. package/dist/components/Flex/Flex.mjs +24 -0
  142. package/dist/components/Flex/Flex.mjs.map +1 -0
  143. package/dist/components/Flex/Flex.styles.cjs +50 -0
  144. package/dist/components/Flex/Flex.styles.d.cts +16 -0
  145. package/dist/components/Flex/Flex.styles.d.cts.map +1 -0
  146. package/dist/components/Flex/Flex.styles.d.mts +16 -0
  147. package/dist/components/Flex/Flex.styles.d.mts.map +1 -0
  148. package/dist/components/Flex/Flex.styles.mjs +51 -0
  149. package/dist/components/Flex/Flex.styles.mjs.map +1 -0
  150. package/dist/components/Flex/index.d.mts +2 -0
  151. package/dist/components/Float/Float.cjs +32 -0
  152. package/dist/components/Float/Float.d.cts +25 -0
  153. package/dist/components/Float/Float.d.cts.map +1 -0
  154. package/dist/components/Float/Float.d.mts +26 -0
  155. package/dist/components/Float/Float.d.mts.map +1 -0
  156. package/dist/components/Float/Float.mjs +31 -0
  157. package/dist/components/Float/Float.mjs.map +1 -0
  158. package/dist/components/Float/Float.styles.cjs +39 -0
  159. package/dist/components/Float/Float.styles.d.cts +58 -0
  160. package/dist/components/Float/Float.styles.d.cts.map +1 -0
  161. package/dist/components/Float/Float.styles.d.mts +58 -0
  162. package/dist/components/Float/Float.styles.d.mts.map +1 -0
  163. package/dist/components/Float/Float.styles.mjs +38 -0
  164. package/dist/components/Float/Float.styles.mjs.map +1 -0
  165. package/dist/components/Float/index.d.mts +1 -0
  166. package/dist/components/FloatingActionButton/FloatingActionButton.cjs +18 -0
  167. package/dist/components/FloatingActionButton/FloatingActionButton.d.cts +16 -0
  168. package/dist/components/FloatingActionButton/FloatingActionButton.d.cts.map +1 -0
  169. package/dist/components/FloatingActionButton/FloatingActionButton.d.mts +17 -0
  170. package/dist/components/FloatingActionButton/FloatingActionButton.d.mts.map +1 -0
  171. package/dist/components/FloatingActionButton/FloatingActionButton.mjs +18 -0
  172. package/dist/components/FloatingActionButton/FloatingActionButton.mjs.map +1 -0
  173. package/dist/components/FloatingActionButton/FloatingActionButton.styles.cjs +15 -0
  174. package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.cts +24 -0
  175. package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.cts.map +1 -0
  176. package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.mts +24 -0
  177. package/dist/components/FloatingActionButton/FloatingActionButton.styles.d.mts.map +1 -0
  178. package/dist/components/FloatingActionButton/FloatingActionButton.styles.mjs +15 -0
  179. package/dist/components/FloatingActionButton/FloatingActionButton.styles.mjs.map +1 -0
  180. package/dist/components/FloatingActionButton/index.d.mts +1 -0
  181. package/dist/components/Grid/Grid.cjs +24 -0
  182. package/dist/components/Grid/Grid.d.cts +22 -0
  183. package/dist/components/Grid/Grid.d.cts.map +1 -0
  184. package/dist/components/Grid/Grid.d.mts +23 -0
  185. package/dist/components/Grid/Grid.d.mts.map +1 -0
  186. package/dist/components/Grid/Grid.mjs +23 -0
  187. package/dist/components/Grid/Grid.mjs.map +1 -0
  188. package/dist/components/Grid/Grid.styles.cjs +56 -0
  189. package/dist/components/Grid/Grid.styles.d.cts +126 -0
  190. package/dist/components/Grid/Grid.styles.d.cts.map +1 -0
  191. package/dist/components/Grid/Grid.styles.d.mts +126 -0
  192. package/dist/components/Grid/Grid.styles.d.mts.map +1 -0
  193. package/dist/components/Grid/Grid.styles.mjs +56 -0
  194. package/dist/components/Grid/Grid.styles.mjs.map +1 -0
  195. package/dist/components/Grid/index.d.mts +1 -0
  196. package/dist/components/HStack/HStack.cjs +17 -0
  197. package/dist/components/HStack/HStack.d.cts +15 -0
  198. package/dist/components/HStack/HStack.d.cts.map +1 -0
  199. package/dist/components/HStack/HStack.d.mts +16 -0
  200. package/dist/components/HStack/HStack.d.mts.map +1 -0
  201. package/dist/components/HStack/HStack.mjs +16 -0
  202. package/dist/components/HStack/HStack.mjs.map +1 -0
  203. package/dist/components/HStack/index.d.mts +1 -0
  204. package/dist/components/Modal/Modal.cjs +81 -0
  205. package/dist/components/Modal/Modal.d.cts +64 -0
  206. package/dist/components/Modal/Modal.d.cts.map +1 -0
  207. package/dist/components/Modal/Modal.d.mts +65 -0
  208. package/dist/components/Modal/Modal.d.mts.map +1 -0
  209. package/dist/components/Modal/Modal.mjs +80 -0
  210. package/dist/components/Modal/Modal.mjs.map +1 -0
  211. package/dist/components/Modal/Modal.styles.cjs +49 -0
  212. package/dist/components/Modal/Modal.styles.d.cts +108 -0
  213. package/dist/components/Modal/Modal.styles.d.cts.map +1 -0
  214. package/dist/components/Modal/Modal.styles.d.mts +108 -0
  215. package/dist/components/Modal/Modal.styles.d.mts.map +1 -0
  216. package/dist/components/Modal/Modal.styles.mjs +49 -0
  217. package/dist/components/Modal/Modal.styles.mjs.map +1 -0
  218. package/dist/components/Modal/index.d.mts +2 -0
  219. package/dist/components/Primitive/Primitive.cjs +35 -0
  220. package/dist/components/Primitive/Primitive.d.cts +77 -0
  221. package/dist/components/Primitive/Primitive.d.cts.map +1 -0
  222. package/dist/components/Primitive/Primitive.d.mts +77 -0
  223. package/dist/components/Primitive/Primitive.d.mts.map +1 -0
  224. package/dist/components/Primitive/Primitive.mjs +34 -0
  225. package/dist/components/Primitive/Primitive.mjs.map +1 -0
  226. package/dist/components/Primitive/index.d.mts +1 -0
  227. package/dist/components/Radio/Radio.cjs +97 -0
  228. package/dist/components/Radio/Radio.d.cts +48 -0
  229. package/dist/components/Radio/Radio.d.cts.map +1 -0
  230. package/dist/components/Radio/Radio.d.mts +49 -0
  231. package/dist/components/Radio/Radio.d.mts.map +1 -0
  232. package/dist/components/Radio/Radio.mjs +94 -0
  233. package/dist/components/Radio/Radio.mjs.map +1 -0
  234. package/dist/components/Radio/Radio.styles.cjs +32 -0
  235. package/dist/components/Radio/Radio.styles.mjs +32 -0
  236. package/dist/components/Radio/Radio.styles.mjs.map +1 -0
  237. package/dist/components/Radio/index.d.mts +1 -0
  238. package/dist/components/RatioChart/RatioChart.cjs +182 -0
  239. package/dist/components/RatioChart/RatioChart.d.cts +66 -0
  240. package/dist/components/RatioChart/RatioChart.d.cts.map +1 -0
  241. package/dist/components/RatioChart/RatioChart.d.mts +66 -0
  242. package/dist/components/RatioChart/RatioChart.d.mts.map +1 -0
  243. package/dist/components/RatioChart/RatioChart.mjs +181 -0
  244. package/dist/components/RatioChart/RatioChart.mjs.map +1 -0
  245. package/dist/components/RatioChart/RatioChart.styles.cjs +42 -0
  246. package/dist/components/RatioChart/RatioChart.styles.mjs +42 -0
  247. package/dist/components/RatioChart/RatioChart.styles.mjs.map +1 -0
  248. package/dist/components/RatioChart/RatioChartEditor.cjs +121 -0
  249. package/dist/components/RatioChart/RatioChartEditor.d.cts +44 -0
  250. package/dist/components/RatioChart/RatioChartEditor.d.cts.map +1 -0
  251. package/dist/components/RatioChart/RatioChartEditor.d.mts +44 -0
  252. package/dist/components/RatioChart/RatioChartEditor.d.mts.map +1 -0
  253. package/dist/components/RatioChart/RatioChartEditor.mjs +120 -0
  254. package/dist/components/RatioChart/RatioChartEditor.mjs.map +1 -0
  255. package/dist/components/RatioChart/RatioChartEditor.styles.cjs +23 -0
  256. package/dist/components/RatioChart/RatioChartEditor.styles.mjs +23 -0
  257. package/dist/components/RatioChart/RatioChartEditor.styles.mjs.map +1 -0
  258. package/dist/components/RatioChart/index.d.mts +2 -0
  259. package/dist/components/Select/Select.cjs +84 -0
  260. package/dist/components/Select/Select.d.cts +60 -0
  261. package/dist/components/Select/Select.d.cts.map +1 -0
  262. package/dist/components/Select/Select.d.mts +60 -0
  263. package/dist/components/Select/Select.d.mts.map +1 -0
  264. package/dist/components/Select/Select.mjs +82 -0
  265. package/dist/components/Select/Select.mjs.map +1 -0
  266. package/dist/components/Select/Select.styles.cjs +44 -0
  267. package/dist/components/Select/Select.styles.d.cts +72 -0
  268. package/dist/components/Select/Select.styles.d.cts.map +1 -0
  269. package/dist/components/Select/Select.styles.d.mts +72 -0
  270. package/dist/components/Select/Select.styles.d.mts.map +1 -0
  271. package/dist/components/Select/Select.styles.mjs +44 -0
  272. package/dist/components/Select/Select.styles.mjs.map +1 -0
  273. package/dist/components/Select/index.d.mts +2 -0
  274. package/dist/components/Separator/Separator.cjs +21 -0
  275. package/dist/components/Separator/Separator.d.cts +18 -0
  276. package/dist/components/Separator/Separator.d.cts.map +1 -0
  277. package/dist/components/Separator/Separator.d.mts +19 -0
  278. package/dist/components/Separator/Separator.d.mts.map +1 -0
  279. package/dist/components/Separator/Separator.mjs +20 -0
  280. package/dist/components/Separator/Separator.mjs.map +1 -0
  281. package/dist/components/Separator/Separator.styles.cjs +15 -0
  282. package/dist/components/Separator/Separator.styles.d.cts +24 -0
  283. package/dist/components/Separator/Separator.styles.d.cts.map +1 -0
  284. package/dist/components/Separator/Separator.styles.d.mts +24 -0
  285. package/dist/components/Separator/Separator.styles.d.mts.map +1 -0
  286. package/dist/components/Separator/Separator.styles.mjs +15 -0
  287. package/dist/components/Separator/Separator.styles.mjs.map +1 -0
  288. package/dist/components/Separator/index.d.mts +2 -0
  289. package/dist/components/Spacer/Spacer.cjs +20 -0
  290. package/dist/components/Spacer/Spacer.d.cts +18 -0
  291. package/dist/components/Spacer/Spacer.d.cts.map +1 -0
  292. package/dist/components/Spacer/Spacer.d.mts +19 -0
  293. package/dist/components/Spacer/Spacer.d.mts.map +1 -0
  294. package/dist/components/Spacer/Spacer.mjs +19 -0
  295. package/dist/components/Spacer/Spacer.mjs.map +1 -0
  296. package/dist/components/Spacer/Spacer.styles.cjs +24 -0
  297. package/dist/components/Spacer/Spacer.styles.d.cts +51 -0
  298. package/dist/components/Spacer/Spacer.styles.d.cts.map +1 -0
  299. package/dist/components/Spacer/Spacer.styles.d.mts +51 -0
  300. package/dist/components/Spacer/Spacer.styles.d.mts.map +1 -0
  301. package/dist/components/Spacer/Spacer.styles.mjs +24 -0
  302. package/dist/components/Spacer/Spacer.styles.mjs.map +1 -0
  303. package/dist/components/Spacer/index.d.mts +2 -0
  304. package/dist/components/Stack/Stack.cjs +28 -0
  305. package/dist/components/Stack/Stack.d.cts +26 -0
  306. package/dist/components/Stack/Stack.d.cts.map +1 -0
  307. package/dist/components/Stack/Stack.d.mts +27 -0
  308. package/dist/components/Stack/Stack.d.mts.map +1 -0
  309. package/dist/components/Stack/Stack.mjs +27 -0
  310. package/dist/components/Stack/Stack.mjs.map +1 -0
  311. package/dist/components/Stack/Stack.styles.cjs +42 -0
  312. package/dist/components/Stack/Stack.styles.d.cts +84 -0
  313. package/dist/components/Stack/Stack.styles.d.cts.map +1 -0
  314. package/dist/components/Stack/Stack.styles.d.mts +84 -0
  315. package/dist/components/Stack/Stack.styles.d.mts.map +1 -0
  316. package/dist/components/Stack/Stack.styles.mjs +42 -0
  317. package/dist/components/Stack/Stack.styles.mjs.map +1 -0
  318. package/dist/components/Stack/index.d.mts +2 -0
  319. package/dist/components/Tab/Tab.cjs +103 -0
  320. package/dist/components/Tab/Tab.d.cts +84 -0
  321. package/dist/components/Tab/Tab.d.cts.map +1 -0
  322. package/dist/components/Tab/Tab.d.mts +85 -0
  323. package/dist/components/Tab/Tab.d.mts.map +1 -0
  324. package/dist/components/Tab/Tab.mjs +102 -0
  325. package/dist/components/Tab/Tab.mjs.map +1 -0
  326. package/dist/components/Tab/Tab.styles.cjs +35 -0
  327. package/dist/components/Tab/Tab.styles.d.cts +51 -0
  328. package/dist/components/Tab/Tab.styles.d.cts.map +1 -0
  329. package/dist/components/Tab/Tab.styles.d.mts +51 -0
  330. package/dist/components/Tab/Tab.styles.d.mts.map +1 -0
  331. package/dist/components/Tab/Tab.styles.mjs +35 -0
  332. package/dist/components/Tab/Tab.styles.mjs.map +1 -0
  333. package/dist/components/Tab/index.d.mts +2 -0
  334. package/dist/components/Text/Text.cjs +20 -0
  335. package/dist/components/Text/Text.d.cts +24 -0
  336. package/dist/components/Text/Text.d.cts.map +1 -0
  337. package/dist/components/Text/Text.d.mts +25 -0
  338. package/dist/components/Text/Text.d.mts.map +1 -0
  339. package/dist/components/Text/Text.mjs +20 -0
  340. package/dist/components/Text/Text.mjs.map +1 -0
  341. package/dist/components/Text/Text.styles.cjs +58 -0
  342. package/dist/components/Text/Text.styles.d.cts +150 -0
  343. package/dist/components/Text/Text.styles.d.cts.map +1 -0
  344. package/dist/components/Text/Text.styles.d.mts +150 -0
  345. package/dist/components/Text/Text.styles.d.mts.map +1 -0
  346. package/dist/components/Text/Text.styles.mjs +58 -0
  347. package/dist/components/Text/Text.styles.mjs.map +1 -0
  348. package/dist/components/Text/index.d.mts +2 -0
  349. package/dist/components/TextArea/TextArea.cjs +52 -0
  350. package/dist/components/TextArea/TextArea.d.cts +42 -0
  351. package/dist/components/TextArea/TextArea.d.cts.map +1 -0
  352. package/dist/components/TextArea/TextArea.d.mts +43 -0
  353. package/dist/components/TextArea/TextArea.d.mts.map +1 -0
  354. package/dist/components/TextArea/TextArea.mjs +51 -0
  355. package/dist/components/TextArea/TextArea.mjs.map +1 -0
  356. package/dist/components/TextArea/TextArea.styles.cjs +33 -0
  357. package/dist/components/TextArea/TextArea.styles.d.cts +84 -0
  358. package/dist/components/TextArea/TextArea.styles.d.cts.map +1 -0
  359. package/dist/components/TextArea/TextArea.styles.d.mts +84 -0
  360. package/dist/components/TextArea/TextArea.styles.d.mts.map +1 -0
  361. package/dist/components/TextArea/TextArea.styles.mjs +33 -0
  362. package/dist/components/TextArea/TextArea.styles.mjs.map +1 -0
  363. package/dist/components/TextArea/index.d.mts +1 -0
  364. package/dist/components/TextInput/TextInput.cjs +48 -0
  365. package/dist/components/TextInput/TextInput.d.cts +32 -0
  366. package/dist/components/TextInput/TextInput.d.cts.map +1 -0
  367. package/dist/components/TextInput/TextInput.d.mts +33 -0
  368. package/dist/components/TextInput/TextInput.d.mts.map +1 -0
  369. package/dist/components/TextInput/TextInput.mjs +47 -0
  370. package/dist/components/TextInput/TextInput.mjs.map +1 -0
  371. package/dist/components/TextInput/TextInput.styles.cjs +43 -0
  372. package/dist/components/TextInput/TextInput.styles.d.cts +81 -0
  373. package/dist/components/TextInput/TextInput.styles.d.cts.map +1 -0
  374. package/dist/components/TextInput/TextInput.styles.d.mts +81 -0
  375. package/dist/components/TextInput/TextInput.styles.d.mts.map +1 -0
  376. package/dist/components/TextInput/TextInput.styles.mjs +43 -0
  377. package/dist/components/TextInput/TextInput.styles.mjs.map +1 -0
  378. package/dist/components/TextInput/index.d.mts +2 -0
  379. package/dist/components/Toast/Toast.cjs +42 -0
  380. package/dist/components/Toast/Toast.d.cts +27 -0
  381. package/dist/components/Toast/Toast.d.cts.map +1 -0
  382. package/dist/components/Toast/Toast.d.mts +27 -0
  383. package/dist/components/Toast/Toast.d.mts.map +1 -0
  384. package/dist/components/Toast/Toast.mjs +39 -0
  385. package/dist/components/Toast/Toast.mjs.map +1 -0
  386. package/dist/components/Toast/Toast.styles.cjs +20 -0
  387. package/dist/components/Toast/Toast.styles.d.cts +36 -0
  388. package/dist/components/Toast/Toast.styles.d.cts.map +1 -0
  389. package/dist/components/Toast/Toast.styles.d.mts +36 -0
  390. package/dist/components/Toast/Toast.styles.d.mts.map +1 -0
  391. package/dist/components/Toast/Toast.styles.mjs +20 -0
  392. package/dist/components/Toast/Toast.styles.mjs.map +1 -0
  393. package/dist/components/Toast/index.d.mts +2 -0
  394. package/dist/components/Toggle/Toggle.cjs +71 -0
  395. package/dist/components/Toggle/Toggle.d.cts +44 -0
  396. package/dist/components/Toggle/Toggle.d.cts.map +1 -0
  397. package/dist/components/Toggle/Toggle.d.mts +46 -0
  398. package/dist/components/Toggle/Toggle.d.mts.map +1 -0
  399. package/dist/components/Toggle/Toggle.mjs +70 -0
  400. package/dist/components/Toggle/Toggle.mjs.map +1 -0
  401. package/dist/components/Toggle/Toggle.styles.cjs +31 -0
  402. package/dist/components/Toggle/Toggle.styles.d.cts +75 -0
  403. package/dist/components/Toggle/Toggle.styles.d.cts.map +1 -0
  404. package/dist/components/Toggle/Toggle.styles.d.mts +75 -0
  405. package/dist/components/Toggle/Toggle.styles.d.mts.map +1 -0
  406. package/dist/components/Toggle/Toggle.styles.mjs +31 -0
  407. package/dist/components/Toggle/Toggle.styles.mjs.map +1 -0
  408. package/dist/components/Toggle/index.d.mts +1 -0
  409. package/dist/components/VStack/VStack.cjs +17 -0
  410. package/dist/components/VStack/VStack.d.cts +15 -0
  411. package/dist/components/VStack/VStack.d.cts.map +1 -0
  412. package/dist/components/VStack/VStack.d.mts +16 -0
  413. package/dist/components/VStack/VStack.d.mts.map +1 -0
  414. package/dist/components/VStack/VStack.mjs +16 -0
  415. package/dist/components/VStack/VStack.mjs.map +1 -0
  416. package/dist/components/VStack/index.d.mts +1 -0
  417. package/dist/components/index.d.mts +74 -0
  418. package/dist/hooks/field/useFieldContext.cjs +18 -0
  419. package/dist/hooks/field/useFieldContext.mjs +17 -0
  420. package/dist/hooks/field/useFieldContext.mjs.map +1 -0
  421. package/dist/hooks/ratioChart/useRatioChartContext.cjs +14 -0
  422. package/dist/hooks/ratioChart/useRatioChartContext.mjs +13 -0
  423. package/dist/hooks/ratioChart/useRatioChartContext.mjs.map +1 -0
  424. package/dist/index.cjs +73 -0
  425. package/dist/index.d.cts +50 -0
  426. package/dist/index.d.mts +52 -207
  427. package/dist/index.mjs +35 -658
  428. package/dist/utils/converter/converter.cjs +9 -0
  429. package/dist/utils/converter/converter.d.cts +5 -0
  430. package/dist/utils/converter/converter.d.cts.map +1 -0
  431. package/dist/utils/converter/converter.d.mts +5 -0
  432. package/dist/utils/converter/converter.d.mts.map +1 -0
  433. package/dist/utils/converter/converter.mjs +9 -0
  434. package/dist/utils/converter/converter.mjs.map +1 -0
  435. package/dist/utils/index.d.mts +6 -0
  436. package/dist/utils/mergeStyles/index.d.mts +1 -0
  437. package/dist/utils/mergeStyles/mergeStyles.cjs +18 -0
  438. package/dist/utils/mergeStyles/mergeStyles.d.cts +14 -0
  439. package/dist/utils/mergeStyles/mergeStyles.d.cts.map +1 -0
  440. package/dist/utils/mergeStyles/mergeStyles.d.mts +14 -0
  441. package/dist/utils/mergeStyles/mergeStyles.d.mts.map +1 -0
  442. package/dist/utils/mergeStyles/mergeStyles.mjs +18 -0
  443. package/dist/utils/mergeStyles/mergeStyles.mjs.map +1 -0
  444. package/dist/utils/polymorphic/index.d.mts +1 -0
  445. package/dist/utils/polymorphic/polymorphic.d.cts +24 -0
  446. package/dist/utils/polymorphic/polymorphic.d.cts.map +1 -0
  447. package/dist/utils/polymorphic/polymorphic.d.mts +24 -0
  448. package/dist/utils/polymorphic/polymorphic.d.mts.map +1 -0
  449. package/dist/utils/splitter/splitter.cjs +12 -0
  450. package/dist/utils/splitter/splitter.d.cts +5 -0
  451. package/dist/utils/splitter/splitter.d.cts.map +1 -0
  452. package/dist/utils/splitter/splitter.d.mts +5 -0
  453. package/dist/utils/splitter/splitter.d.mts.map +1 -0
  454. package/dist/utils/splitter/splitter.mjs +12 -0
  455. package/dist/utils/splitter/splitter.mjs.map +1 -0
  456. package/package.json +22 -10
  457. package/src/styles/global.css +162 -79
  458. package/dist/index.d.ts +0 -207
  459. package/dist/index.js +0 -674
@@ -0,0 +1,66 @@
1
+ import React from "react";
2
+ import * as react_jsx_runtime25 from "react/jsx-runtime";
3
+
4
+ //#region src/components/RatioChart/RatioChart.d.ts
5
+ interface RatioChartRootSingleProps extends Omit<React.ComponentProps<'div'>, 'defaultValue'> {
6
+ mode?: 'single';
7
+ value?: string;
8
+ defaultValue?: string;
9
+ onValueChange?: (value: string) => void;
10
+ disabled?: boolean;
11
+ }
12
+ interface RatioChartRootMultipleProps extends Omit<React.ComponentProps<'div'>, 'defaultValue'> {
13
+ mode: 'multiple';
14
+ value?: string[];
15
+ defaultValue?: string[];
16
+ onValueChange?: (value: string[]) => void;
17
+ disabled?: boolean;
18
+ }
19
+ type RatioChartRootProps = RatioChartRootSingleProps | RatioChartRootMultipleProps;
20
+ interface RatioChartItemProps extends Omit<React.ComponentProps<'button'>, 'value'> {
21
+ value: string;
22
+ label: string;
23
+ count?: number;
24
+ ratio?: number;
25
+ disabled?: boolean;
26
+ }
27
+ interface RatioChartFooterProps extends React.ComponentProps<'div'> {
28
+ endDate?: Date;
29
+ endTime?: string;
30
+ hideParticipantCount?: boolean;
31
+ }
32
+ declare const RatioChart: {
33
+ (props: RatioChartRootProps): react_jsx_runtime25.JSX.Element;
34
+ displayName: string;
35
+ } & {
36
+ Root: {
37
+ (props: RatioChartRootProps): react_jsx_runtime25.JSX.Element;
38
+ displayName: string;
39
+ };
40
+ Item: {
41
+ ({
42
+ value,
43
+ label,
44
+ count,
45
+ ratio,
46
+ disabled: itemDisabled,
47
+ className,
48
+ ...props
49
+ }: RatioChartItemProps): react_jsx_runtime25.JSX.Element;
50
+ displayName: string;
51
+ };
52
+ Footer: {
53
+ ({
54
+ endDate,
55
+ endTime,
56
+ hideParticipantCount,
57
+ className,
58
+ children,
59
+ ...props
60
+ }: RatioChartFooterProps): react_jsx_runtime25.JSX.Element;
61
+ displayName: string;
62
+ };
63
+ };
64
+ //#endregion
65
+ export { RatioChart, RatioChartFooterProps, RatioChartItemProps, RatioChartRootProps };
66
+ //# sourceMappingURL=RatioChart.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RatioChart.d.mts","names":[],"sources":["../../../src/components/RatioChart/RatioChart.tsx"],"mappings":";;;;UAUU,yBAAA,SAAkC,IAAA,CAC1C,KAAA,CAAM,cAAA;EAGN,IAAA;EACA,KAAA;EACA,YAAA;EACA,aAAA,IAAiB,KAAA;EACjB,QAAA;AAAA;AAAA,UAIQ,2BAAA,SAAoC,IAAA,CAC5C,KAAA,CAAM,cAAA;EAGN,IAAA;EACA,KAAA;EACA,YAAA;EACA,aAAA,IAAiB,KAAA;EACjB,QAAA;AAAA;AAAA,KAGU,mBAAA,GACR,yBAAA,GACA,2BAAA;AAAA,UAmIa,mBAAA,SAA4B,IAAA,CAC3C,KAAA,CAAM,cAAA;EAGN,KAAA;EACA,KAAA;EACA,KAAA;EACA,KAAA;EACA,QAAA;AAAA;AAAA,UAuGe,qBAAA,SAA8B,KAAA,CAAM,cAAA;EACnD,OAAA,GAAU,IAAA;EACV,OAAA;EACA,oBAAA;AAAA;AAAA,cA8DW,UAAA;EAAA,QAjTkB,mBAAA,GAAmB,mBAAA,CAAA,GAAA,CAAA,OAAA;;;;YAAnB,mBAAA,GAAmB,mBAAA,CAAA,GAAA,CAAA,OAAA;;;;;;;;;;;;OAoJ/C,mBAAA,GAAmB,mBAAA,CAAA,GAAA,CAAA,OAAA;;;;;;;;;;;OAiInB,qBAAA,GAAqB,mBAAA,CAAA,GAAA,CAAA,OAAA"}
@@ -0,0 +1,181 @@
1
+ import { RatioChartContext, useRatioChartContext } from "../../hooks/ratioChart/useRatioChartContext.mjs";
2
+ import { mergeStyles } from "../../utils/mergeStyles/mergeStyles.mjs";
3
+ import { ratioChart } from "./RatioChart.styles.mjs";
4
+ import React, { useCallback, useEffect, useMemo, useState } from "react";
5
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
6
+
7
+ //#region src/components/RatioChart/RatioChart.tsx
8
+ const RatioChartRoot = (props) => {
9
+ const { mode = "single", value: valueProp, defaultValue, onValueChange, disabled, children, className, ...rest } = props;
10
+ const [internalSingleValue, setInternalSingleValue] = useState(() => mode === "single" && typeof defaultValue === "string" ? defaultValue : "");
11
+ const [internalMultipleValue, setInternalMultipleValue] = useState(() => mode === "multiple" && Array.isArray(defaultValue) ? defaultValue : []);
12
+ const [counts, setCounts] = useState(/* @__PURE__ */ new Map());
13
+ const isControlled = valueProp !== void 0;
14
+ const currentValue = mode === "single" ? isControlled ? valueProp : internalSingleValue : isControlled ? valueProp : internalMultipleValue;
15
+ const isSelected = useCallback((itemValue) => {
16
+ if (mode === "single") return currentValue === itemValue;
17
+ return currentValue.includes(itemValue);
18
+ }, [mode, currentValue]);
19
+ const onSelect = useCallback((itemValue) => {
20
+ if (disabled) return;
21
+ if (mode === "single") {
22
+ if (!isControlled) setInternalSingleValue(itemValue);
23
+ onValueChange?.(itemValue);
24
+ } else {
25
+ const currentArray = currentValue;
26
+ const newValue = currentArray.includes(itemValue) ? currentArray.filter((v) => v !== itemValue) : [...currentArray, itemValue];
27
+ if (!isControlled) setInternalMultipleValue(newValue);
28
+ onValueChange?.(newValue);
29
+ }
30
+ }, [
31
+ mode,
32
+ disabled,
33
+ isControlled,
34
+ currentValue,
35
+ onValueChange
36
+ ]);
37
+ const registerCount = useCallback((itemValue, count) => {
38
+ setCounts((prev) => new Map(prev).set(itemValue, count));
39
+ }, []);
40
+ const unregisterCount = useCallback((itemValue) => {
41
+ setCounts((prev) => {
42
+ const next = new Map(prev);
43
+ next.delete(itemValue);
44
+ return next;
45
+ });
46
+ }, []);
47
+ const totalCount = useMemo(() => {
48
+ let total = 0;
49
+ counts.forEach((c) => total += c);
50
+ return total;
51
+ }, [counts]);
52
+ const getRatio = useCallback((itemValue) => {
53
+ const count = counts.get(itemValue) ?? 0;
54
+ return totalCount > 0 ? Math.round(count / totalCount * 100) : 0;
55
+ }, [counts, totalCount]);
56
+ const styles = ratioChart({ disabled });
57
+ return /* @__PURE__ */ jsx(RatioChartContext.Provider, {
58
+ value: {
59
+ value: currentValue,
60
+ mode,
61
+ disabled,
62
+ onSelect,
63
+ isSelected,
64
+ counts,
65
+ registerCount,
66
+ unregisterCount,
67
+ totalCount,
68
+ getRatio
69
+ },
70
+ children: /* @__PURE__ */ jsx("div", {
71
+ role: "group",
72
+ className: mergeStyles(styles.root(), className),
73
+ ...rest,
74
+ children
75
+ })
76
+ });
77
+ };
78
+ const RatioChartItem = ({ value, label, count, ratio, disabled: itemDisabled, className, ...props }) => {
79
+ const { disabled: rootDisabled, onSelect, isSelected, registerCount, unregisterCount, getRatio } = useRatioChartContext();
80
+ const disabled = itemDisabled || rootDisabled;
81
+ const selected = isSelected(value);
82
+ useEffect(() => {
83
+ if (count !== void 0) {
84
+ registerCount(value, count);
85
+ return () => unregisterCount(value);
86
+ }
87
+ }, [
88
+ count,
89
+ value,
90
+ registerCount,
91
+ unregisterCount
92
+ ]);
93
+ const handleClick = () => {
94
+ if (!disabled) onSelect(value);
95
+ };
96
+ const handleKeyDown = (e) => {
97
+ if ((e.key === "Enter" || e.key === " ") && !disabled) {
98
+ e.preventDefault();
99
+ onSelect(value);
100
+ }
101
+ };
102
+ const displayRatio = count !== void 0 ? getRatio(value) : ratio ?? 0;
103
+ const showRatio = count !== void 0 || ratio !== void 0;
104
+ const styles = ratioChart({
105
+ disabled,
106
+ selected
107
+ });
108
+ const lightContent = ratioChart({ contentVariant: "light" });
109
+ const darkContent = ratioChart({ contentVariant: "dark" });
110
+ const contentElement = /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx("span", {
111
+ className: styles.label(),
112
+ children: label
113
+ }), showRatio && /* @__PURE__ */ jsxs("span", {
114
+ className: styles.ratio(),
115
+ children: [displayRatio, "%"]
116
+ })] });
117
+ return /* @__PURE__ */ jsxs("button", {
118
+ type: "button",
119
+ role: "option",
120
+ "aria-selected": selected,
121
+ disabled,
122
+ onClick: handleClick,
123
+ onKeyDown: handleKeyDown,
124
+ className: mergeStyles(styles.item(), className),
125
+ style: { minWidth: 0 },
126
+ ...props,
127
+ children: [/* @__PURE__ */ jsx("span", {
128
+ className: styles.fill(),
129
+ style: { width: `${displayRatio}%` }
130
+ }), selected ? /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx("span", {
131
+ className: lightContent.content(),
132
+ style: { clipPath: `inset(0 ${100 - displayRatio}% 0 0)` },
133
+ children: contentElement
134
+ }), /* @__PURE__ */ jsx("span", {
135
+ className: darkContent.content(),
136
+ style: { clipPath: `inset(0 0 0 ${displayRatio}%)` },
137
+ children: contentElement
138
+ })] }) : /* @__PURE__ */ jsx("span", {
139
+ className: darkContent.content(),
140
+ children: contentElement
141
+ })]
142
+ });
143
+ };
144
+ function formatTimeRemaining(endDate) {
145
+ const now = /* @__PURE__ */ new Date();
146
+ const diff = endDate.getTime() - now.getTime();
147
+ if (diff <= 0) return "종료됨";
148
+ const totalHours = diff / (1e3 * 60 * 60);
149
+ const totalMinutes = diff / (1e3 * 60);
150
+ if (totalHours >= 24) return `${Math.round(totalHours / 24)}일 후 종료`;
151
+ if (totalHours >= 1) return `${Math.floor(totalHours)}시간 후 종료`;
152
+ return `${Math.floor(totalMinutes)}분 후 종료`;
153
+ }
154
+ const RatioChartFooter = ({ endDate, endTime, hideParticipantCount, className, children, ...props }) => {
155
+ const { totalCount } = useRatioChartContext();
156
+ const displayEndTime = endDate ? formatTimeRemaining(endDate) : endTime;
157
+ const styles = ratioChart();
158
+ return /* @__PURE__ */ jsx("div", {
159
+ className: mergeStyles(styles.footer(), className),
160
+ ...props,
161
+ children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [!hideParticipantCount && /* @__PURE__ */ jsxs("span", {
162
+ className: styles.footerText(),
163
+ children: [totalCount, "명 참여"]
164
+ }), displayEndTime && /* @__PURE__ */ jsx("span", {
165
+ className: styles.footerText(),
166
+ children: displayEndTime
167
+ })] })
168
+ });
169
+ };
170
+ RatioChartRoot.displayName = "RatioChart.Root";
171
+ RatioChartItem.displayName = "RatioChart.Item";
172
+ RatioChartFooter.displayName = "RatioChart.Footer";
173
+ const RatioChart = Object.assign(RatioChartRoot, {
174
+ Root: RatioChartRoot,
175
+ Item: RatioChartItem,
176
+ Footer: RatioChartFooter
177
+ });
178
+
179
+ //#endregion
180
+ export { RatioChart };
181
+ //# sourceMappingURL=RatioChart.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RatioChart.mjs","names":[],"sources":["../../../src/components/RatioChart/RatioChart.tsx"],"sourcesContent":["import React, { useState, useCallback, useMemo, useEffect } from 'react';\nimport { mergeStyles } from '../../utils';\nimport { RatioChartContext } from '../../hooks/ratioChart/useRatioChartContext';\nimport {\n useRatioChartContext,\n type RatioChartSelectionMode,\n} from '../../hooks/ratioChart';\nimport { ratioChart } from './RatioChart.styles';\n\n// Root Props - 단일 선택\ninterface RatioChartRootSingleProps extends Omit<\n React.ComponentProps<'div'>,\n 'defaultValue'\n> {\n mode?: 'single';\n value?: string;\n defaultValue?: string;\n onValueChange?: (value: string) => void;\n disabled?: boolean;\n}\n\n// Root Props - 다중 선택\ninterface RatioChartRootMultipleProps extends Omit<\n React.ComponentProps<'div'>,\n 'defaultValue'\n> {\n mode: 'multiple';\n value?: string[];\n defaultValue?: string[];\n onValueChange?: (value: string[]) => void;\n disabled?: boolean;\n}\n\nexport type RatioChartRootProps =\n | RatioChartRootSingleProps\n | RatioChartRootMultipleProps;\n\nconst RatioChartRoot = (props: RatioChartRootProps) => {\n const {\n mode = 'single',\n value: valueProp,\n defaultValue,\n onValueChange,\n disabled,\n children,\n className,\n ...rest\n } = props;\n\n // 단일 선택 내부 상태\n const [internalSingleValue, setInternalSingleValue] = useState<string>(() =>\n mode === 'single' && typeof defaultValue === 'string' ? defaultValue : '',\n );\n\n // 다중 선택 내부 상태\n const [internalMultipleValue, setInternalMultipleValue] = useState<string[]>(\n () =>\n mode === 'multiple' && Array.isArray(defaultValue) ? defaultValue : [],\n );\n\n // count 기반 자동 비율 계산을 위한 state\n const [counts, setCounts] = useState<Map<string, number>>(new Map());\n\n const isControlled = valueProp !== undefined;\n\n const currentValue =\n mode === 'single'\n ? isControlled\n ? (valueProp as string)\n : internalSingleValue\n : isControlled\n ? (valueProp as string[])\n : internalMultipleValue;\n\n const isSelected = useCallback(\n (itemValue: string) => {\n if (mode === 'single') {\n return currentValue === itemValue;\n }\n return (currentValue as string[]).includes(itemValue);\n },\n [mode, currentValue],\n );\n\n const onSelect = useCallback(\n (itemValue: string) => {\n if (disabled) return;\n\n if (mode === 'single') {\n if (!isControlled) {\n setInternalSingleValue(itemValue);\n }\n (onValueChange as ((value: string) => void) | undefined)?.(itemValue);\n } else {\n const currentArray = currentValue as string[];\n const newValue = currentArray.includes(itemValue)\n ? currentArray.filter((v) => v !== itemValue)\n : [...currentArray, itemValue];\n\n if (!isControlled) {\n setInternalMultipleValue(newValue);\n }\n (onValueChange as ((value: string[]) => void) | undefined)?.(newValue);\n }\n },\n [mode, disabled, isControlled, currentValue, onValueChange],\n );\n\n // count 등록/해제 함수\n const registerCount = useCallback((itemValue: string, count: number) => {\n setCounts((prev) => new Map(prev).set(itemValue, count));\n }, []);\n\n const unregisterCount = useCallback((itemValue: string) => {\n setCounts((prev) => {\n const next = new Map(prev);\n next.delete(itemValue);\n return next;\n });\n }, []);\n\n // 전체 count 합계\n const totalCount = useMemo(() => {\n let total = 0;\n counts.forEach((c) => (total += c));\n return total;\n }, [counts]);\n\n // 항목의 비율 계산\n const getRatio = useCallback(\n (itemValue: string) => {\n const count = counts.get(itemValue) ?? 0;\n return totalCount > 0 ? Math.round((count / totalCount) * 100) : 0;\n },\n [counts, totalCount],\n );\n\n const styles = ratioChart({ disabled });\n\n return (\n <RatioChartContext.Provider\n value={{\n value: currentValue,\n mode: mode as RatioChartSelectionMode,\n disabled,\n onSelect,\n isSelected,\n counts,\n registerCount,\n unregisterCount,\n totalCount,\n getRatio,\n }}\n >\n <div\n role=\"group\"\n className={mergeStyles(styles.root(), className)}\n {...rest}\n >\n {children}\n </div>\n </RatioChartContext.Provider>\n );\n};\n\n// Item Props\nexport interface RatioChartItemProps extends Omit<\n React.ComponentProps<'button'>,\n 'value'\n> {\n value: string;\n label: string;\n count?: number; // count만 전달하면 자동으로 비율 계산\n ratio?: number; // 0-100, 직접 비율 지정 (count사용 시 count 우선)\n disabled?: boolean;\n}\n\nconst RatioChartItem = ({\n value,\n label,\n count,\n ratio,\n disabled: itemDisabled,\n className,\n ...props\n}: RatioChartItemProps) => {\n const {\n disabled: rootDisabled,\n onSelect,\n isSelected,\n registerCount,\n unregisterCount,\n getRatio,\n } = useRatioChartContext();\n const disabled = itemDisabled || rootDisabled;\n const selected = isSelected(value);\n\n // count가 있으면 등록\n useEffect(() => {\n if (count !== undefined) {\n registerCount(value, count);\n return () => unregisterCount(value);\n }\n }, [count, value, registerCount, unregisterCount]);\n\n const handleClick = () => {\n if (!disabled) {\n onSelect(value);\n }\n };\n\n const handleKeyDown = (e: React.KeyboardEvent<HTMLButtonElement>) => {\n if ((e.key === 'Enter' || e.key === ' ') && !disabled) {\n e.preventDefault();\n onSelect(value);\n }\n };\n\n // count가 있으면 자동 계산, 없으면 ratio prop 사용, 둘 다 없으면 0\n const displayRatio = count !== undefined ? getRatio(value) : (ratio ?? 0);\n // ratio 표시 여부: count가 있거나 ratio가 명시적으로 지정된 경우\n const showRatio = count !== undefined || ratio !== undefined;\n\n const styles = ratioChart({ disabled, selected });\n const lightContent = ratioChart({ contentVariant: 'light' });\n const darkContent = ratioChart({ contentVariant: 'dark' });\n\n // 텍스트 컨텐츠\n const contentElement = (\n <>\n <span className={styles.label()}>{label}</span>\n {showRatio && <span className={styles.ratio()}>{displayRatio}%</span>}\n </>\n );\n\n return (\n <button\n type=\"button\"\n role=\"option\"\n aria-selected={selected}\n disabled={disabled}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n className={mergeStyles(styles.item(), className)}\n style={{ minWidth: 0 }}\n {...props}\n >\n {/* 비율 배경 */}\n <span className={styles.fill()} style={{ width: `${displayRatio}%` }} />\n\n {selected ? (\n <>\n {/* selected: 흰색 텍스트 (fill 영역에서만 보임) */}\n <span\n className={lightContent.content()}\n style={{ clipPath: `inset(0 ${100 - displayRatio}% 0 0)` }}\n >\n {contentElement}\n </span>\n\n {/* selected: 검은색 텍스트 (fill 밖에서만 보임) */}\n <span\n className={darkContent.content()}\n style={{ clipPath: `inset(0 0 0 ${displayRatio}%)` }}\n >\n {contentElement}\n </span>\n </>\n ) : (\n /* unselected: 검은색 텍스트 하나만 */\n <span className={darkContent.content()}>{contentElement}</span>\n )}\n </button>\n );\n};\n\n// Footer Props\nexport interface RatioChartFooterProps extends React.ComponentProps<'div'> {\n endDate?: Date; // 종료 시간 자동 계산\n endTime?: string; // 직접 문자열 지정\n hideParticipantCount?: boolean;\n}\n\n// 남은 시간 계산\nfunction formatTimeRemaining(endDate: Date): string {\n const now = new Date();\n const diff = endDate.getTime() - now.getTime();\n\n if (diff <= 0) return '종료됨';\n\n const totalHours = diff / (1000 * 60 * 60);\n const totalMinutes = diff / (1000 * 60);\n\n // 24시간 이상이면 일 단위 (12시간 기준 반올림/내림)\n if (totalHours >= 24) {\n return `${Math.round(totalHours / 24)}일 후 종료`;\n }\n\n // 1시간 이상이면 시간 단위 (내림)\n if (totalHours >= 1) {\n return `${Math.floor(totalHours)}시간 후 종료`;\n }\n\n // 그 외 분 단위 (내림)\n return `${Math.floor(totalMinutes)}분 후 종료`;\n}\n\nconst RatioChartFooter = ({\n endDate,\n endTime,\n hideParticipantCount,\n className,\n children,\n ...props\n}: RatioChartFooterProps) => {\n const { totalCount } = useRatioChartContext();\n\n // endDate가 있으면 자동 계산, 없으면 endTime 사용\n const displayEndTime = endDate ? formatTimeRemaining(endDate) : endTime;\n\n const styles = ratioChart();\n\n return (\n <div className={mergeStyles(styles.footer(), className)} {...props}>\n {children ?? (\n <>\n {!hideParticipantCount && (\n <span className={styles.footerText()}>{totalCount}명 참여</span>\n )}\n {displayEndTime && (\n <span className={styles.footerText()}>{displayEndTime}</span>\n )}\n </>\n )}\n </div>\n );\n};\n\nRatioChartRoot.displayName = 'RatioChart.Root';\nRatioChartItem.displayName = 'RatioChart.Item';\nRatioChartFooter.displayName = 'RatioChart.Footer';\n\nexport const RatioChart = Object.assign(RatioChartRoot, {\n Root: RatioChartRoot,\n Item: RatioChartItem,\n Footer: RatioChartFooter,\n});\n"],"mappings":"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"}
@@ -0,0 +1,42 @@
1
+ const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
+ let tailwind_variants = require("tailwind-variants");
3
+
4
+ //#region src/components/RatioChart/RatioChart.styles.ts
5
+ const ratioChart = (0, tailwind_variants.tv)({
6
+ slots: {
7
+ root: "flex flex-col gap-[0.75rem] pb-[0.5rem] min-w-[20rem] max-h-[16.25rem] overflow-y-auto",
8
+ item: "relative flex items-center px-[1rem] h-[3.5rem] flex-shrink-0 rounded-[0.75rem] border border-gray-200 overflow-hidden transition-all duration-200",
9
+ fill: "absolute inset-y-0 left-0 rounded-l-[0.75rem] transition-all duration-300",
10
+ content: "absolute inset-0 z-10 flex items-center justify-between px-[1rem] gap-[0.5rem] typo-body1-md-point",
11
+ label: "truncate",
12
+ ratio: "flex-shrink-0",
13
+ footer: "flex items-end justify-between px-[0.25rem]",
14
+ footerText: "typo-body-14 text-gray-400"
15
+ },
16
+ variants: {
17
+ disabled: {
18
+ true: {
19
+ root: "opacity-50 cursor-not-allowed",
20
+ item: "cursor-not-allowed"
21
+ },
22
+ false: { item: "cursor-pointer focus:outline-none focus-visible:ring-2 focus-visible:ring-gray-900 focus-visible:ring-inset" }
23
+ },
24
+ selected: {
25
+ true: { fill: "bg-gray-900" },
26
+ false: { fill: "bg-gray-200" }
27
+ },
28
+ contentVariant: {
29
+ light: { content: "text-white font-bold" },
30
+ dark: { content: "text-gray-800 font-medium" }
31
+ }
32
+ },
33
+ defaultVariants: {
34
+ disabled: false,
35
+ selected: false,
36
+ contentVariant: "dark"
37
+ }
38
+ });
39
+ const ratioChartKeys = ratioChart.variantKeys;
40
+
41
+ //#endregion
42
+ exports.ratioChart = ratioChart;
@@ -0,0 +1,42 @@
1
+ import { tv } from "tailwind-variants";
2
+
3
+ //#region src/components/RatioChart/RatioChart.styles.ts
4
+ const ratioChart = tv({
5
+ slots: {
6
+ root: "flex flex-col gap-[0.75rem] pb-[0.5rem] min-w-[20rem] max-h-[16.25rem] overflow-y-auto",
7
+ item: "relative flex items-center px-[1rem] h-[3.5rem] flex-shrink-0 rounded-[0.75rem] border border-gray-200 overflow-hidden transition-all duration-200",
8
+ fill: "absolute inset-y-0 left-0 rounded-l-[0.75rem] transition-all duration-300",
9
+ content: "absolute inset-0 z-10 flex items-center justify-between px-[1rem] gap-[0.5rem] typo-body1-md-point",
10
+ label: "truncate",
11
+ ratio: "flex-shrink-0",
12
+ footer: "flex items-end justify-between px-[0.25rem]",
13
+ footerText: "typo-body-14 text-gray-400"
14
+ },
15
+ variants: {
16
+ disabled: {
17
+ true: {
18
+ root: "opacity-50 cursor-not-allowed",
19
+ item: "cursor-not-allowed"
20
+ },
21
+ false: { item: "cursor-pointer focus:outline-none focus-visible:ring-2 focus-visible:ring-gray-900 focus-visible:ring-inset" }
22
+ },
23
+ selected: {
24
+ true: { fill: "bg-gray-900" },
25
+ false: { fill: "bg-gray-200" }
26
+ },
27
+ contentVariant: {
28
+ light: { content: "text-white font-bold" },
29
+ dark: { content: "text-gray-800 font-medium" }
30
+ }
31
+ },
32
+ defaultVariants: {
33
+ disabled: false,
34
+ selected: false,
35
+ contentVariant: "dark"
36
+ }
37
+ });
38
+ const ratioChartKeys = ratioChart.variantKeys;
39
+
40
+ //#endregion
41
+ export { ratioChart };
42
+ //# sourceMappingURL=RatioChart.styles.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RatioChart.styles.mjs","names":[],"sources":["../../../src/components/RatioChart/RatioChart.styles.ts"],"sourcesContent":["import { tv, type VariantProps } from 'tailwind-variants';\n\nexport const ratioChart = tv({\n slots: {\n root: 'flex flex-col gap-[0.75rem] pb-[0.5rem] min-w-[20rem] max-h-[16.25rem] overflow-y-auto', // 컨테이너 (5개부터 스크롤)\n item: 'relative flex items-center px-[1rem] h-[3.5rem] flex-shrink-0 rounded-[0.75rem] border border-gray-200 overflow-hidden transition-all duration-200', // 개별 항목 버튼 (크기 고정)\n fill: 'absolute inset-y-0 left-0 rounded-l-[0.75rem] transition-all duration-300', // 비율 배경\n content:\n 'absolute inset-0 z-10 flex items-center justify-between px-[1rem] gap-[0.5rem] typo-body1-md-point', // 텍스트 오버레이\n label: 'truncate', // 라벨 텍스트\n ratio: 'flex-shrink-0', // 퍼센트 텍스트\n footer: 'flex items-end justify-between px-[0.25rem]', // 푸터 컨테이너\n footerText: 'typo-body-14 text-gray-400', // 푸터 텍스트\n },\n variants: {\n disabled: {\n true: {\n root: 'opacity-50 cursor-not-allowed',\n item: 'cursor-not-allowed',\n },\n false: {\n item: 'cursor-pointer focus:outline-none focus-visible:ring-2 focus-visible:ring-gray-900 focus-visible:ring-inset',\n },\n },\n selected: {\n true: {\n fill: 'bg-gray-900',\n },\n false: {\n fill: 'bg-gray-200',\n },\n },\n contentVariant: {\n light: {\n content: 'text-white font-bold',\n },\n dark: {\n content: 'text-gray-800 font-medium',\n },\n },\n },\n defaultVariants: {\n disabled: false,\n selected: false,\n contentVariant: 'dark',\n },\n});\n\nexport type RatioChartVariants = VariantProps<typeof ratioChart>;\nexport const ratioChartKeys = ratioChart.variantKeys;\n"],"mappings":";;;AAEA,MAAa,aAAa,GAAG;CAC3B,OAAO;EACL,MAAM;EACN,MAAM;EACN,MAAM;EACN,SACE;EACF,OAAO;EACP,OAAO;EACP,QAAQ;EACR,YAAY;EACb;CACD,UAAU;EACR,UAAU;GACR,MAAM;IACJ,MAAM;IACN,MAAM;IACP;GACD,OAAO,EACL,MAAM,+GACP;GACF;EACD,UAAU;GACR,MAAM,EACJ,MAAM,eACP;GACD,OAAO,EACL,MAAM,eACP;GACF;EACD,gBAAgB;GACd,OAAO,EACL,SAAS,wBACV;GACD,MAAM,EACJ,SAAS,6BACV;GACF;EACF;CACD,iBAAiB;EACf,UAAU;EACV,UAAU;EACV,gBAAgB;EACjB;CACF,CAAC;AAGF,MAAa,iBAAiB,WAAW"}
@@ -0,0 +1,121 @@
1
+ const require_rolldown_runtime = require('../../_virtual/rolldown_runtime.cjs');
2
+ const require_Checkbox = require('../Checkbox/Checkbox.cjs');
3
+ const require_mergeStyles = require('../../utils/mergeStyles/mergeStyles.cjs');
4
+ const require_RatioChartEditor_styles = require('./RatioChartEditor.styles.cjs');
5
+ let react = require("react");
6
+ react = require_rolldown_runtime.__toESM(react);
7
+ let react_jsx_runtime = require("react/jsx-runtime");
8
+ let _causw_icons = require("@causw/icons");
9
+
10
+ //#region src/components/RatioChart/RatioChartEditor.tsx
11
+ const RatioChartEditor = ({ options: optionsProp, onOptionsChange, allowMultiple: allowMultipleProp, onAllowMultipleChange, onDelete, minOptions = 2, placeholder = "내용을 입력해주세요", disabled, className, ...props }) => {
12
+ const baseId = (0, react.useId)();
13
+ const [internalOptions, setInternalOptions] = (0, react.useState)(() => {
14
+ const initial = [];
15
+ for (let i = 0; i < minOptions; i++) initial.push({
16
+ id: `${baseId}-${i}`,
17
+ value: ""
18
+ });
19
+ return initial;
20
+ });
21
+ const [internalAllowMultiple, setInternalAllowMultiple] = (0, react.useState)(false);
22
+ const isOptionsControlled = optionsProp !== void 0;
23
+ const isAllowMultipleControlled = allowMultipleProp !== void 0;
24
+ const options = isOptionsControlled ? optionsProp : internalOptions;
25
+ const allowMultiple = isAllowMultipleControlled ? allowMultipleProp : internalAllowMultiple;
26
+ const handleOptionChange = (0, react.useCallback)((id, value) => {
27
+ const newOptions = options.map((opt) => opt.id === id ? {
28
+ ...opt,
29
+ value
30
+ } : opt);
31
+ if (!isOptionsControlled) setInternalOptions(newOptions);
32
+ onOptionsChange?.(newOptions);
33
+ }, [
34
+ options,
35
+ isOptionsControlled,
36
+ onOptionsChange
37
+ ]);
38
+ const handleAddOption = (0, react.useCallback)(() => {
39
+ const newOption = {
40
+ id: `${baseId}-${Date.now()}`,
41
+ value: ""
42
+ };
43
+ const newOptions = [...options, newOption];
44
+ if (!isOptionsControlled) setInternalOptions(newOptions);
45
+ onOptionsChange?.(newOptions);
46
+ }, [
47
+ options,
48
+ isOptionsControlled,
49
+ onOptionsChange,
50
+ baseId
51
+ ]);
52
+ const handleRemoveOption = (0, react.useCallback)((id) => {
53
+ if (options.length <= minOptions) return;
54
+ const newOptions = options.filter((opt) => opt.id !== id);
55
+ if (!isOptionsControlled) setInternalOptions(newOptions);
56
+ onOptionsChange?.(newOptions);
57
+ }, [
58
+ options,
59
+ minOptions,
60
+ isOptionsControlled,
61
+ onOptionsChange
62
+ ]);
63
+ const handleAllowMultipleChange = (0, react.useCallback)((checked) => {
64
+ if (!isAllowMultipleControlled) setInternalAllowMultiple(checked);
65
+ onAllowMultipleChange?.(checked);
66
+ }, [isAllowMultipleControlled, onAllowMultipleChange]);
67
+ const canRemove = options.length > minOptions;
68
+ const styles = require_RatioChartEditor_styles.ratioChartEditor({ disabled });
69
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
70
+ className: require_mergeStyles.mergeStyles(styles.root(), className),
71
+ ...props,
72
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
73
+ className: styles.fields(),
74
+ children: [options.map((option) => /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
75
+ className: styles.input(),
76
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)("input", {
77
+ type: "text",
78
+ value: option.value,
79
+ onChange: (e) => handleOptionChange(option.id, e.target.value),
80
+ placeholder,
81
+ disabled,
82
+ className: styles.textInput()
83
+ }), canRemove && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
84
+ type: "button",
85
+ onClick: () => handleRemoveOption(option.id),
86
+ disabled,
87
+ className: styles.removeButton(),
88
+ "aria-label": "옵션 삭제",
89
+ children: /* @__PURE__ */ (0, react_jsx_runtime.jsx)(_causw_icons.CloseFilled, { size: 20 })
90
+ })]
91
+ }, option.id)), /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("button", {
92
+ type: "button",
93
+ onClick: handleAddOption,
94
+ disabled,
95
+ className: styles.addButton(),
96
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(_causw_icons.Plus, { size: 20 }), /* @__PURE__ */ (0, react_jsx_runtime.jsx)("span", {
97
+ className: styles.addButtonText(),
98
+ children: "다른 선택 항목 추가"
99
+ })]
100
+ })]
101
+ }), /* @__PURE__ */ (0, react_jsx_runtime.jsxs)("div", {
102
+ className: styles.footer(),
103
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsxs)(require_Checkbox.Checkbox, {
104
+ checked: allowMultiple,
105
+ onCheckedChange: handleAllowMultipleChange,
106
+ disabled,
107
+ children: [/* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Checkbox.Checkbox.Indicator, {}), /* @__PURE__ */ (0, react_jsx_runtime.jsx)(require_Checkbox.Checkbox.Label, { children: "복수 선택 허용" })]
108
+ }), onDelete && /* @__PURE__ */ (0, react_jsx_runtime.jsx)("button", {
109
+ type: "button",
110
+ onClick: onDelete,
111
+ disabled,
112
+ className: styles.deleteButton(),
113
+ children: "투표 삭제"
114
+ })]
115
+ })]
116
+ });
117
+ };
118
+ RatioChartEditor.displayName = "RatioChartEditor";
119
+
120
+ //#endregion
121
+ exports.RatioChartEditor = RatioChartEditor;
@@ -0,0 +1,44 @@
1
+ import React from "react";
2
+ import * as react_jsx_runtime35 from "react/jsx-runtime";
3
+
4
+ //#region src/components/RatioChart/RatioChartEditor.d.ts
5
+ interface RatioChartEditorOption {
6
+ id: string;
7
+ value: string;
8
+ }
9
+ interface RatioChartEditorProps extends Omit<React.ComponentProps<'div'>, 'onChange'> {
10
+ /** 옵션 목록 */
11
+ options?: RatioChartEditorOption[];
12
+ /** 옵션 변경 콜백 */
13
+ onOptionsChange?: (options: RatioChartEditorOption[]) => void;
14
+ /** 복수 선택 허용 여부 */
15
+ allowMultiple?: boolean;
16
+ /** 복수 선택 변경 콜백 */
17
+ onAllowMultipleChange?: (allowMultiple: boolean) => void;
18
+ /** 투표 삭제 콜백 */
19
+ onDelete?: () => void;
20
+ /** 최소 옵션 수 (기본: 2) */
21
+ minOptions?: number;
22
+ /** 플레이스홀더 텍스트 */
23
+ placeholder?: string;
24
+ /** 비활성화 */
25
+ disabled?: boolean;
26
+ }
27
+ declare const RatioChartEditor: {
28
+ ({
29
+ options: optionsProp,
30
+ onOptionsChange,
31
+ allowMultiple: allowMultipleProp,
32
+ onAllowMultipleChange,
33
+ onDelete,
34
+ minOptions,
35
+ placeholder,
36
+ disabled,
37
+ className,
38
+ ...props
39
+ }: RatioChartEditorProps): react_jsx_runtime35.JSX.Element;
40
+ displayName: string;
41
+ };
42
+ //#endregion
43
+ export { RatioChartEditor, RatioChartEditorOption, RatioChartEditorProps };
44
+ //# sourceMappingURL=RatioChartEditor.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RatioChartEditor.d.cts","names":[],"sources":["../../../src/components/RatioChart/RatioChartEditor.tsx"],"mappings":";;;;UAMiB,sBAAA;EACf,EAAA;EACA,KAAA;AAAA;AAAA,UAGe,qBAAA,SAA8B,IAAA,CAC7C,KAAA,CAAM,cAAA;;EAIN,OAAA,GAAU,sBAAA;EARL;EAUL,eAAA,IAAmB,OAAA,EAAS,sBAAA;EAPS;EASrC,aAAA;EARA;EAUA,qBAAA,IAAyB,aAAA;EAJG;EAM5B,QAAA;EAbiD;EAejD,UAAA;EAf6C;EAiB7C,WAAA;EAhBM;EAkBN,QAAA;AAAA;AAAA,cAGW,gBAAA;EAAA;;;;;;;;;;;KAWV,qBAAA,GAAqB,mBAAA,CAAA,GAAA,CAAA,OAAA"}
@@ -0,0 +1,44 @@
1
+ import React from "react";
2
+ import * as react_jsx_runtime24 from "react/jsx-runtime";
3
+
4
+ //#region src/components/RatioChart/RatioChartEditor.d.ts
5
+ interface RatioChartEditorOption {
6
+ id: string;
7
+ value: string;
8
+ }
9
+ interface RatioChartEditorProps extends Omit<React.ComponentProps<'div'>, 'onChange'> {
10
+ /** 옵션 목록 */
11
+ options?: RatioChartEditorOption[];
12
+ /** 옵션 변경 콜백 */
13
+ onOptionsChange?: (options: RatioChartEditorOption[]) => void;
14
+ /** 복수 선택 허용 여부 */
15
+ allowMultiple?: boolean;
16
+ /** 복수 선택 변경 콜백 */
17
+ onAllowMultipleChange?: (allowMultiple: boolean) => void;
18
+ /** 투표 삭제 콜백 */
19
+ onDelete?: () => void;
20
+ /** 최소 옵션 수 (기본: 2) */
21
+ minOptions?: number;
22
+ /** 플레이스홀더 텍스트 */
23
+ placeholder?: string;
24
+ /** 비활성화 */
25
+ disabled?: boolean;
26
+ }
27
+ declare const RatioChartEditor: {
28
+ ({
29
+ options: optionsProp,
30
+ onOptionsChange,
31
+ allowMultiple: allowMultipleProp,
32
+ onAllowMultipleChange,
33
+ onDelete,
34
+ minOptions,
35
+ placeholder,
36
+ disabled,
37
+ className,
38
+ ...props
39
+ }: RatioChartEditorProps): react_jsx_runtime24.JSX.Element;
40
+ displayName: string;
41
+ };
42
+ //#endregion
43
+ export { RatioChartEditor, RatioChartEditorOption, RatioChartEditorProps };
44
+ //# sourceMappingURL=RatioChartEditor.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RatioChartEditor.d.mts","names":[],"sources":["../../../src/components/RatioChart/RatioChartEditor.tsx"],"mappings":";;;;UAMiB,sBAAA;EACf,EAAA;EACA,KAAA;AAAA;AAAA,UAGe,qBAAA,SAA8B,IAAA,CAC7C,KAAA,CAAM,cAAA;;EAIN,OAAA,GAAU,sBAAA;EARL;EAUL,eAAA,IAAmB,OAAA,EAAS,sBAAA;EAPS;EASrC,aAAA;EARA;EAUA,qBAAA,IAAyB,aAAA;EAJG;EAM5B,QAAA;EAbiD;EAejD,UAAA;EAf6C;EAiB7C,WAAA;EAhBM;EAkBN,QAAA;AAAA;AAAA,cAGW,gBAAA;EAAA;;;;;;;;;;;KAWV,qBAAA,GAAqB,mBAAA,CAAA,GAAA,CAAA,OAAA"}