@cssui/react 1.0.0 → 1.0.2

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 (544) hide show
  1. package/dist/adapter-react/components/breadcrumb/Breadcrumb.d.ts +8 -0
  2. package/dist/adapter-react/components/breadcrumb/Breadcrumb.d.ts.map +1 -0
  3. package/dist/adapter-react/components/breadcrumb/Breadcrumb.js +170 -0
  4. package/dist/adapter-react/components/breadcrumb/Breadcrumb.js.map +1 -0
  5. package/dist/adapter-react/components/breadcrumb/index.d.ts +2 -0
  6. package/dist/adapter-react/components/breadcrumb/index.d.ts.map +1 -0
  7. package/dist/adapter-react/components/button/Button.d.ts +10 -0
  8. package/dist/adapter-react/components/button/Button.d.ts.map +1 -0
  9. package/dist/adapter-react/components/button/Button.js +49 -0
  10. package/dist/adapter-react/components/button/Button.js.map +1 -0
  11. package/dist/adapter-react/components/button/index.d.ts +3 -0
  12. package/dist/adapter-react/components/button/index.d.ts.map +1 -0
  13. package/dist/adapter-react/components/carousel/Carousel.d.ts +12 -0
  14. package/dist/adapter-react/components/carousel/Carousel.d.ts.map +1 -0
  15. package/dist/adapter-react/components/carousel/Carousel.js +155 -0
  16. package/dist/adapter-react/components/carousel/Carousel.js.map +1 -0
  17. package/dist/adapter-react/components/carousel/index.d.ts +3 -0
  18. package/dist/adapter-react/components/carousel/index.d.ts.map +1 -0
  19. package/dist/adapter-react/components/checkbox/Checkbox.d.ts +11 -0
  20. package/dist/adapter-react/components/checkbox/Checkbox.d.ts.map +1 -0
  21. package/dist/adapter-react/components/checkbox/Checkbox.js +69 -0
  22. package/dist/adapter-react/components/checkbox/Checkbox.js.map +1 -0
  23. package/dist/adapter-react/components/checkbox/CheckboxGroup.d.ts +22 -0
  24. package/dist/adapter-react/components/checkbox/CheckboxGroup.d.ts.map +1 -0
  25. package/dist/adapter-react/components/checkbox/CheckboxGroup.js +86 -0
  26. package/dist/adapter-react/components/checkbox/CheckboxGroup.js.map +1 -0
  27. package/dist/adapter-react/components/checkbox/index.d.ts +5 -0
  28. package/dist/adapter-react/components/checkbox/index.d.ts.map +1 -0
  29. package/dist/adapter-react/components/date-picker/DatePicker.d.ts +8 -0
  30. package/dist/adapter-react/components/date-picker/DatePicker.d.ts.map +1 -0
  31. package/dist/adapter-react/components/date-picker/DatePicker.js +438 -0
  32. package/dist/adapter-react/components/date-picker/DatePicker.js.map +1 -0
  33. package/dist/adapter-react/components/date-picker/index.d.ts +2 -0
  34. package/dist/adapter-react/components/date-picker/index.d.ts.map +1 -0
  35. package/dist/adapter-react/components/divider/Divider.d.ts +13 -0
  36. package/dist/adapter-react/components/divider/Divider.d.ts.map +1 -0
  37. package/dist/adapter-react/components/divider/Divider.js +31 -0
  38. package/dist/adapter-react/components/divider/Divider.js.map +1 -0
  39. package/dist/adapter-react/components/divider/index.d.ts +3 -0
  40. package/dist/adapter-react/components/divider/index.d.ts.map +1 -0
  41. package/dist/adapter-react/components/float-button/FloatButton.d.ts +17 -0
  42. package/dist/adapter-react/components/float-button/FloatButton.d.ts.map +1 -0
  43. package/dist/adapter-react/components/float-button/FloatButton.js +97 -0
  44. package/dist/adapter-react/components/float-button/FloatButton.js.map +1 -0
  45. package/dist/adapter-react/components/float-button/FloatButtonGroup.d.ts +9 -0
  46. package/dist/adapter-react/components/float-button/FloatButtonGroup.d.ts.map +1 -0
  47. package/dist/adapter-react/components/float-button/FloatButtonGroup.js +61 -0
  48. package/dist/adapter-react/components/float-button/FloatButtonGroup.js.map +1 -0
  49. package/dist/adapter-react/components/float-button/context.d.ts +3 -0
  50. package/dist/adapter-react/components/float-button/context.d.ts.map +1 -0
  51. package/dist/adapter-react/components/float-button/context.js +6 -0
  52. package/dist/adapter-react/components/float-button/context.js.map +1 -0
  53. package/dist/adapter-react/components/float-button/index.d.ts +5 -0
  54. package/dist/adapter-react/components/float-button/index.d.ts.map +1 -0
  55. package/dist/adapter-react/components/form/Form.d.ts +13 -0
  56. package/dist/adapter-react/components/form/Form.d.ts.map +1 -0
  57. package/dist/adapter-react/components/form/Form.js +355 -0
  58. package/dist/adapter-react/components/form/Form.js.map +1 -0
  59. package/dist/adapter-react/components/form/index.d.ts +4 -0
  60. package/dist/adapter-react/components/form/index.d.ts.map +1 -0
  61. package/dist/adapter-react/components/grid/Grid.d.ts +8 -0
  62. package/dist/adapter-react/components/grid/Grid.d.ts.map +1 -0
  63. package/dist/adapter-react/components/grid/Grid.js +51 -0
  64. package/dist/adapter-react/components/grid/Grid.js.map +1 -0
  65. package/dist/adapter-react/components/grid/GridItem.d.ts +8 -0
  66. package/dist/adapter-react/components/grid/GridItem.d.ts.map +1 -0
  67. package/dist/adapter-react/components/grid/GridItem.js +31 -0
  68. package/dist/adapter-react/components/grid/GridItem.js.map +1 -0
  69. package/dist/adapter-react/components/grid/index.d.ts +6 -0
  70. package/dist/adapter-react/components/grid/index.d.ts.map +1 -0
  71. package/dist/adapter-react/components/icon/Icon.d.ts +18 -0
  72. package/dist/adapter-react/components/icon/Icon.d.ts.map +1 -0
  73. package/dist/adapter-react/components/icon/Icon.js +51 -0
  74. package/dist/adapter-react/components/icon/Icon.js.map +1 -0
  75. package/dist/adapter-react/components/icon/index.d.ts +3 -0
  76. package/dist/adapter-react/components/icon/index.d.ts.map +1 -0
  77. package/dist/adapter-react/components/input/Input.d.ts +10 -0
  78. package/dist/adapter-react/components/input/Input.d.ts.map +1 -0
  79. package/dist/adapter-react/components/input/Input.js +79 -0
  80. package/dist/adapter-react/components/input/Input.js.map +1 -0
  81. package/dist/adapter-react/components/input/index.d.ts +3 -0
  82. package/dist/adapter-react/components/input/index.d.ts.map +1 -0
  83. package/dist/adapter-react/components/input-bar/InputBar.d.ts +9 -0
  84. package/dist/adapter-react/components/input-bar/InputBar.d.ts.map +1 -0
  85. package/dist/adapter-react/components/input-bar/InputBar.js +136 -0
  86. package/dist/adapter-react/components/input-bar/InputBar.js.map +1 -0
  87. package/dist/adapter-react/components/input-bar/index.d.ts +3 -0
  88. package/dist/adapter-react/components/input-bar/index.d.ts.map +1 -0
  89. package/dist/adapter-react/components/input-number/InputNumber.d.ts +9 -0
  90. package/dist/adapter-react/components/input-number/InputNumber.d.ts.map +1 -0
  91. package/dist/adapter-react/components/input-number/InputNumber.js +135 -0
  92. package/dist/adapter-react/components/input-number/InputNumber.js.map +1 -0
  93. package/dist/adapter-react/components/input-number/index.d.ts +2 -0
  94. package/dist/adapter-react/components/input-number/index.d.ts.map +1 -0
  95. package/dist/adapter-react/components/modal/Modal.d.ts +18 -0
  96. package/dist/adapter-react/components/modal/Modal.d.ts.map +1 -0
  97. package/dist/adapter-react/components/modal/Modal.js +108 -0
  98. package/dist/adapter-react/components/modal/Modal.js.map +1 -0
  99. package/dist/adapter-react/components/modal/index.d.ts +6 -0
  100. package/dist/adapter-react/components/modal/index.d.ts.map +1 -0
  101. package/dist/adapter-react/components/nav-menu/NavMenu.d.ts +11 -0
  102. package/dist/adapter-react/components/nav-menu/NavMenu.d.ts.map +1 -0
  103. package/dist/adapter-react/components/nav-menu/NavMenu.js +197 -0
  104. package/dist/adapter-react/components/nav-menu/NavMenu.js.map +1 -0
  105. package/dist/adapter-react/components/nav-menu/index.d.ts +3 -0
  106. package/dist/adapter-react/components/nav-menu/index.d.ts.map +1 -0
  107. package/dist/adapter-react/components/pagination/Pagination.d.ts +11 -0
  108. package/dist/adapter-react/components/pagination/Pagination.d.ts.map +1 -0
  109. package/dist/adapter-react/components/pagination/Pagination.js +128 -0
  110. package/dist/adapter-react/components/pagination/Pagination.js.map +1 -0
  111. package/dist/adapter-react/components/pagination/index.d.ts +3 -0
  112. package/dist/adapter-react/components/pagination/index.d.ts.map +1 -0
  113. package/dist/adapter-react/components/radio/Radio.d.ts +12 -0
  114. package/dist/adapter-react/components/radio/Radio.d.ts.map +1 -0
  115. package/dist/adapter-react/components/radio/Radio.js +83 -0
  116. package/dist/adapter-react/components/radio/Radio.js.map +1 -0
  117. package/dist/adapter-react/components/radio/RadioGroup.d.ts +24 -0
  118. package/dist/adapter-react/components/radio/RadioGroup.d.ts.map +1 -0
  119. package/dist/adapter-react/components/radio/RadioGroup.js +97 -0
  120. package/dist/adapter-react/components/radio/RadioGroup.js.map +1 -0
  121. package/dist/adapter-react/components/radio/index.d.ts +7 -0
  122. package/dist/adapter-react/components/radio/index.d.ts.map +1 -0
  123. package/dist/adapter-react/components/select/Select.d.ts +9 -0
  124. package/dist/adapter-react/components/select/Select.d.ts.map +1 -0
  125. package/dist/adapter-react/components/select/Select.js +189 -0
  126. package/dist/adapter-react/components/select/Select.js.map +1 -0
  127. package/dist/adapter-react/components/select/index.d.ts +3 -0
  128. package/dist/adapter-react/components/select/index.d.ts.map +1 -0
  129. package/dist/adapter-react/components/sidebar/Sidebar.d.ts +13 -0
  130. package/dist/adapter-react/components/sidebar/Sidebar.d.ts.map +1 -0
  131. package/dist/adapter-react/components/sidebar/Sidebar.js +242 -0
  132. package/dist/adapter-react/components/sidebar/Sidebar.js.map +1 -0
  133. package/dist/adapter-react/components/sidebar/index.d.ts +3 -0
  134. package/dist/adapter-react/components/sidebar/index.d.ts.map +1 -0
  135. package/dist/adapter-react/components/slider/Slider.d.ts +9 -0
  136. package/dist/adapter-react/components/slider/Slider.d.ts.map +1 -0
  137. package/dist/adapter-react/components/slider/Slider.js +150 -0
  138. package/dist/adapter-react/components/slider/Slider.js.map +1 -0
  139. package/dist/adapter-react/components/slider/index.d.ts +3 -0
  140. package/dist/adapter-react/components/slider/index.d.ts.map +1 -0
  141. package/dist/adapter-react/components/steps/Steps.d.ts +11 -0
  142. package/dist/adapter-react/components/steps/Steps.d.ts.map +1 -0
  143. package/dist/adapter-react/components/steps/Steps.js +172 -0
  144. package/dist/adapter-react/components/steps/Steps.js.map +1 -0
  145. package/dist/adapter-react/components/steps/index.d.ts +3 -0
  146. package/dist/adapter-react/components/steps/index.d.ts.map +1 -0
  147. package/dist/adapter-react/components/switch/Switch.d.ts +11 -0
  148. package/dist/adapter-react/components/switch/Switch.d.ts.map +1 -0
  149. package/dist/adapter-react/components/switch/Switch.js +98 -0
  150. package/dist/adapter-react/components/switch/Switch.js.map +1 -0
  151. package/dist/adapter-react/components/switch/index.d.ts +2 -0
  152. package/dist/adapter-react/components/switch/index.d.ts.map +1 -0
  153. package/dist/adapter-react/components/table/Table.d.ts +15 -0
  154. package/dist/adapter-react/components/table/Table.d.ts.map +1 -0
  155. package/dist/adapter-react/components/table/Table.js +211 -0
  156. package/dist/adapter-react/components/table/Table.js.map +1 -0
  157. package/dist/adapter-react/components/table/index.d.ts +3 -0
  158. package/dist/adapter-react/components/table/index.d.ts.map +1 -0
  159. package/dist/adapter-react/components/tabs/Tabs.d.ts +9 -0
  160. package/dist/adapter-react/components/tabs/Tabs.d.ts.map +1 -0
  161. package/dist/adapter-react/components/tabs/Tabs.js +62 -0
  162. package/dist/adapter-react/components/tabs/Tabs.js.map +1 -0
  163. package/dist/adapter-react/components/tabs/index.d.ts +2 -0
  164. package/dist/adapter-react/components/tabs/index.d.ts.map +1 -0
  165. package/dist/adapter-react/components/time-picker/TimePicker.d.ts +9 -0
  166. package/dist/adapter-react/components/time-picker/TimePicker.d.ts.map +1 -0
  167. package/dist/adapter-react/components/time-picker/TimePicker.js +271 -0
  168. package/dist/adapter-react/components/time-picker/TimePicker.js.map +1 -0
  169. package/dist/adapter-react/components/time-picker/index.d.ts +2 -0
  170. package/dist/adapter-react/components/time-picker/index.d.ts.map +1 -0
  171. package/dist/adapter-react/components/toast/Toast.d.ts +25 -0
  172. package/dist/adapter-react/components/toast/Toast.d.ts.map +1 -0
  173. package/dist/adapter-react/components/toast/Toast.js +223 -0
  174. package/dist/adapter-react/components/toast/Toast.js.map +1 -0
  175. package/dist/adapter-react/components/toast/index.d.ts +3 -0
  176. package/dist/adapter-react/components/toast/index.d.ts.map +1 -0
  177. package/dist/adapter-react/components/toolbars/Toolbar.d.ts +11 -0
  178. package/dist/adapter-react/components/toolbars/Toolbar.d.ts.map +1 -0
  179. package/dist/adapter-react/components/toolbars/Toolbar.js +66 -0
  180. package/dist/adapter-react/components/toolbars/Toolbar.js.map +1 -0
  181. package/dist/adapter-react/components/toolbars/index.d.ts +3 -0
  182. package/dist/adapter-react/components/toolbars/index.d.ts.map +1 -0
  183. package/dist/adapter-react/components/tooltip/Tooltip.d.ts +9 -0
  184. package/dist/adapter-react/components/tooltip/Tooltip.d.ts.map +1 -0
  185. package/dist/adapter-react/components/tooltip/Tooltip.js +141 -0
  186. package/dist/adapter-react/components/tooltip/Tooltip.js.map +1 -0
  187. package/dist/adapter-react/components/tooltip/index.d.ts +2 -0
  188. package/dist/adapter-react/components/tooltip/index.d.ts.map +1 -0
  189. package/dist/adapter-react/hooks/index.d.ts +12 -0
  190. package/dist/adapter-react/hooks/index.d.ts.map +1 -0
  191. package/dist/adapter-react/hooks/index.js +43 -0
  192. package/dist/adapter-react/hooks/index.js.map +1 -0
  193. package/dist/adapter-react/hooks/useControlled.d.ts +7 -0
  194. package/dist/adapter-react/hooks/useControlled.d.ts.map +1 -0
  195. package/dist/adapter-react/hooks/useControlled.js +21 -0
  196. package/dist/adapter-react/hooks/useControlled.js.map +1 -0
  197. package/dist/adapter-react/hooks/useEvent.d.ts +2 -0
  198. package/dist/adapter-react/hooks/useEvent.d.ts.map +1 -0
  199. package/dist/adapter-react/hooks/useMergedState.d.ts +4 -0
  200. package/dist/adapter-react/hooks/useMergedState.d.ts.map +1 -0
  201. package/dist/adapter-react/hooks/useMergedState.js +15 -0
  202. package/dist/adapter-react/hooks/useMergedState.js.map +1 -0
  203. package/dist/adapter-react/index.d.ts +37 -0
  204. package/dist/adapter-react/index.d.ts.map +1 -0
  205. package/dist/adapter-react/runtime/createComponent.d.ts +3 -0
  206. package/dist/adapter-react/runtime/createComponent.d.ts.map +1 -0
  207. package/dist/adapter-react/runtime/createComponent.js +6 -0
  208. package/dist/adapter-react/runtime/createComponent.js.map +1 -0
  209. package/dist/adapter-react/runtime/createProps.d.ts +2 -0
  210. package/dist/adapter-react/runtime/createProps.d.ts.map +1 -0
  211. package/dist/adapter-react/runtime/forwardRef.d.ts +3 -0
  212. package/dist/adapter-react/runtime/forwardRef.d.ts.map +1 -0
  213. package/dist/adapter-react/runtime/forwardRef.js +6 -0
  214. package/dist/adapter-react/runtime/forwardRef.js.map +1 -0
  215. package/dist/adapter-react/runtime/index.d.ts +5 -0
  216. package/dist/adapter-react/runtime/index.d.ts.map +1 -0
  217. package/dist/adapter-react/runtime/withInstall.d.ts +3 -0
  218. package/dist/adapter-react/runtime/withInstall.d.ts.map +1 -0
  219. package/dist/adapter-react/runtime/withInstall.js +6 -0
  220. package/dist/adapter-react/runtime/withInstall.js.map +1 -0
  221. package/dist/adapter-react/style/index.d.ts +2 -0
  222. package/dist/adapter-react/style/index.d.ts.map +1 -0
  223. package/dist/adapter-react/style/injectStyle.d.ts +2 -0
  224. package/dist/adapter-react/style/injectStyle.d.ts.map +1 -0
  225. package/dist/adapter-react/types.d.ts +6 -0
  226. package/dist/adapter-react/types.d.ts.map +1 -0
  227. package/dist/breadcrumb/index.d.ts +2 -2
  228. package/dist/breadcrumb/index.js +34 -1
  229. package/dist/breadcrumb/index.js.map +1 -0
  230. package/dist/breadcrumb/style.css +219 -1
  231. package/dist/button/index.d.ts +2 -2
  232. package/dist/button/index.js +34 -1
  233. package/dist/button/index.js.map +1 -0
  234. package/dist/button/style.css +151 -1
  235. package/dist/carousel/index.d.ts +2 -2
  236. package/dist/carousel/index.js +34 -1
  237. package/dist/carousel/index.js.map +1 -0
  238. package/dist/carousel/style.css +196 -1
  239. package/dist/checkbox/index.d.ts +3 -3
  240. package/dist/checkbox/index.js +34 -2
  241. package/dist/checkbox/index.js.map +1 -0
  242. package/dist/checkbox/style.css +135 -1
  243. package/dist/components/breadcrumb/index.d.ts +61 -0
  244. package/dist/components/breadcrumb/index.d.ts.map +1 -0
  245. package/dist/components/breadcrumb/index.js +49 -0
  246. package/dist/components/breadcrumb/index.js.map +1 -0
  247. package/dist/components/breadcrumb/style.css +219 -0
  248. package/dist/components/button/index.d.ts +15 -0
  249. package/dist/components/button/index.d.ts.map +1 -0
  250. package/dist/components/button/index.js +11 -0
  251. package/dist/components/button/index.js.map +1 -0
  252. package/dist/components/button/style.css +151 -0
  253. package/dist/components/carousel/index.d.ts +38 -0
  254. package/dist/components/carousel/index.d.ts.map +1 -0
  255. package/dist/components/carousel/index.js +33 -0
  256. package/dist/components/carousel/index.js.map +1 -0
  257. package/dist/components/carousel/style.css +196 -0
  258. package/dist/components/checkbox/index.d.ts +36 -0
  259. package/dist/components/checkbox/index.d.ts.map +1 -0
  260. package/dist/components/checkbox/index.js +34 -0
  261. package/dist/components/checkbox/index.js.map +1 -0
  262. package/dist/components/checkbox/style.css +135 -0
  263. package/dist/components/date-picker/index.d.ts +53 -0
  264. package/dist/components/date-picker/index.d.ts.map +1 -0
  265. package/dist/components/date-picker/index.js +105 -0
  266. package/dist/components/date-picker/index.js.map +1 -0
  267. package/dist/components/date-picker/style.css +491 -0
  268. package/dist/components/divider/index.d.ts +12 -0
  269. package/dist/components/divider/index.d.ts.map +1 -0
  270. package/dist/components/divider/index.js +23 -0
  271. package/dist/components/divider/index.js.map +1 -0
  272. package/dist/components/divider/style.css +100 -0
  273. package/dist/components/float-button/index.d.ts +32 -0
  274. package/dist/components/float-button/index.d.ts.map +1 -0
  275. package/dist/components/float-button/index.js +23 -0
  276. package/dist/components/float-button/index.js.map +1 -0
  277. package/dist/components/float-button/style.css +176 -0
  278. package/dist/components/form/index.d.ts +79 -0
  279. package/dist/components/form/index.d.ts.map +1 -0
  280. package/dist/components/form/index.js +144 -0
  281. package/dist/components/form/index.js.map +1 -0
  282. package/dist/components/form/style.css +79 -0
  283. package/dist/components/grid/index.d.ts +34 -0
  284. package/dist/components/grid/index.d.ts.map +1 -0
  285. package/dist/components/grid/index.js +109 -0
  286. package/dist/components/grid/index.js.map +1 -0
  287. package/dist/components/grid/style.css +189 -0
  288. package/dist/components/icon/index.d.ts +35 -0
  289. package/dist/components/icon/index.d.ts.map +1 -0
  290. package/dist/components/icon/index.js +16 -0
  291. package/dist/components/icon/index.js.map +1 -0
  292. package/dist/components/icon/style.css +28 -0
  293. package/dist/components/input/index.d.ts +29 -0
  294. package/dist/components/input/index.d.ts.map +1 -0
  295. package/dist/components/input/index.js +19 -0
  296. package/dist/components/input/index.js.map +1 -0
  297. package/dist/components/input/style.css +110 -0
  298. package/dist/components/input-bar/index.d.ts +31 -0
  299. package/dist/components/input-bar/index.d.ts.map +1 -0
  300. package/dist/components/input-bar/index.js +18 -0
  301. package/dist/components/input-bar/index.js.map +1 -0
  302. package/dist/components/input-bar/style.css +180 -0
  303. package/dist/components/input-number/index.d.ts +28 -0
  304. package/dist/components/input-number/index.d.ts.map +1 -0
  305. package/dist/components/input-number/index.js +21 -0
  306. package/dist/components/input-number/index.js.map +1 -0
  307. package/dist/components/input-number/style.css +109 -0
  308. package/dist/components/modal/index.d.ts +17 -0
  309. package/dist/components/modal/index.d.ts.map +1 -0
  310. package/dist/components/modal/index.js +10 -0
  311. package/dist/components/modal/index.js.map +1 -0
  312. package/dist/components/modal/style.css +150 -0
  313. package/dist/components/nav-menu/index.d.ts +35 -0
  314. package/dist/components/nav-menu/index.d.ts.map +1 -0
  315. package/dist/components/nav-menu/index.js +47 -0
  316. package/dist/components/nav-menu/index.js.map +1 -0
  317. package/dist/components/nav-menu/style.css +241 -0
  318. package/dist/components/pagination/index.d.ts +32 -0
  319. package/dist/components/pagination/index.d.ts.map +1 -0
  320. package/dist/components/pagination/index.js +35 -0
  321. package/dist/components/pagination/index.js.map +1 -0
  322. package/dist/components/pagination/style.css +150 -0
  323. package/dist/components/radio/index.d.ts +45 -0
  324. package/dist/components/radio/index.d.ts.map +1 -0
  325. package/dist/components/radio/index.js +48 -0
  326. package/dist/components/radio/index.js.map +1 -0
  327. package/dist/components/radio/style.css +294 -0
  328. package/dist/components/select/index.d.ts +30 -0
  329. package/dist/components/select/index.d.ts.map +1 -0
  330. package/dist/components/select/index.js +16 -0
  331. package/dist/components/select/index.js.map +1 -0
  332. package/dist/components/select/style.css +255 -0
  333. package/dist/components/sidebar/index.d.ts +19 -0
  334. package/dist/components/sidebar/index.d.ts.map +1 -0
  335. package/dist/components/sidebar/index.js +23 -0
  336. package/dist/components/sidebar/index.js.map +1 -0
  337. package/dist/components/sidebar/style.css +270 -0
  338. package/dist/components/slider/index.d.ts +29 -0
  339. package/dist/components/slider/index.d.ts.map +1 -0
  340. package/dist/components/slider/index.js +24 -0
  341. package/dist/components/slider/index.js.map +1 -0
  342. package/dist/components/slider/style.css +206 -0
  343. package/dist/components/src/index.d.ts +28 -0
  344. package/dist/components/src/index.d.ts.map +1 -0
  345. package/dist/components/steps/index.d.ts +41 -0
  346. package/dist/components/steps/index.d.ts.map +1 -0
  347. package/dist/components/steps/index.js +32 -0
  348. package/dist/components/steps/index.js.map +1 -0
  349. package/dist/components/steps/style.css +286 -0
  350. package/dist/components/switch/index.d.ts +16 -0
  351. package/dist/components/switch/index.d.ts.map +1 -0
  352. package/dist/components/switch/index.js +17 -0
  353. package/dist/components/switch/index.js.map +1 -0
  354. package/dist/components/switch/style.css +160 -0
  355. package/dist/components/table/index.d.ts +49 -0
  356. package/dist/components/table/index.d.ts.map +1 -0
  357. package/dist/components/table/index.js +74 -0
  358. package/dist/components/table/index.js.map +1 -0
  359. package/dist/components/table/style.css +131 -0
  360. package/dist/components/tabs/index.d.ts +34 -0
  361. package/dist/components/tabs/index.d.ts.map +1 -0
  362. package/dist/components/tabs/index.js +21 -0
  363. package/dist/components/tabs/index.js.map +1 -0
  364. package/dist/components/tabs/style.css +146 -0
  365. package/dist/components/time-picker/index.d.ts +56 -0
  366. package/dist/components/time-picker/index.d.ts.map +1 -0
  367. package/dist/components/time-picker/index.js +84 -0
  368. package/dist/components/time-picker/index.js.map +1 -0
  369. package/dist/components/time-picker/style.css +258 -0
  370. package/dist/components/toast/index.d.ts +41 -0
  371. package/dist/components/toast/index.d.ts.map +1 -0
  372. package/dist/components/toast/index.js +24 -0
  373. package/dist/components/toast/index.js.map +1 -0
  374. package/dist/components/toast/style.css +117 -0
  375. package/dist/components/toolbars/index.d.ts +31 -0
  376. package/dist/components/toolbars/index.d.ts.map +1 -0
  377. package/dist/components/toolbars/index.js +32 -0
  378. package/dist/components/toolbars/index.js.map +1 -0
  379. package/dist/components/toolbars/style.css +220 -0
  380. package/dist/components/tooltip/index.d.ts +31 -0
  381. package/dist/components/tooltip/index.d.ts.map +1 -0
  382. package/dist/components/tooltip/index.js +17 -0
  383. package/dist/components/tooltip/index.js.map +1 -0
  384. package/dist/components/tooltip/style.css +138 -0
  385. package/dist/date-picker/index.d.ts +2 -2
  386. package/dist/date-picker/index.js +34 -1
  387. package/dist/date-picker/index.js.map +1 -0
  388. package/dist/date-picker/style.css +491 -1
  389. package/dist/divider/index.d.ts +2 -2
  390. package/dist/divider/index.js +34 -1
  391. package/dist/divider/index.js.map +1 -0
  392. package/dist/divider/style.css +100 -1
  393. package/dist/float-button/index.d.ts +2 -2
  394. package/dist/float-button/index.js +34 -1
  395. package/dist/float-button/index.js.map +1 -0
  396. package/dist/float-button/style.css +176 -1
  397. package/dist/form/index.d.ts +2 -2
  398. package/dist/form/index.js +34 -1
  399. package/dist/form/index.js.map +1 -0
  400. package/dist/form/style.css +79 -1
  401. package/dist/grid/index.d.ts +2 -2
  402. package/dist/grid/index.js +34 -1
  403. package/dist/grid/index.js.map +1 -0
  404. package/dist/grid/style.css +189 -1
  405. package/dist/icon/index.d.ts +2 -2
  406. package/dist/icon/index.js +34 -1
  407. package/dist/icon/index.js.map +1 -0
  408. package/dist/icon/style.css +28 -1
  409. package/dist/icons/react/add_circle.js +30 -0
  410. package/dist/icons/react/add_circle.js.map +1 -0
  411. package/dist/icons/react/arrow_back.js +24 -0
  412. package/dist/icons/react/arrow_back.js.map +1 -0
  413. package/dist/icons/react/arrow_drop_down.js +26 -0
  414. package/dist/icons/react/arrow_drop_down.js.map +1 -0
  415. package/dist/icons/react/arrow_forward.js +26 -0
  416. package/dist/icons/react/arrow_forward.js.map +1 -0
  417. package/dist/icons/react/calendar_month.js +26 -0
  418. package/dist/icons/react/calendar_month.js.map +1 -0
  419. package/dist/icons/react/check.js +24 -0
  420. package/dist/icons/react/check.js.map +1 -0
  421. package/dist/icons/react/chevron_right.js +26 -0
  422. package/dist/icons/react/chevron_right.js.map +1 -0
  423. package/dist/icons/react/close.js +24 -0
  424. package/dist/icons/react/close.js.map +1 -0
  425. package/dist/icons/react/config.js +32 -0
  426. package/dist/icons/react/config.js.map +1 -0
  427. package/dist/icons/react/dark_mode.js +24 -0
  428. package/dist/icons/react/dark_mode.js.map +1 -0
  429. package/dist/icons/react/do_not_disturb_on.js +32 -0
  430. package/dist/icons/react/do_not_disturb_on.js.map +1 -0
  431. package/dist/icons/react/error.js +24 -0
  432. package/dist/icons/react/error.js.map +1 -0
  433. package/dist/icons/react/home.js +27 -0
  434. package/dist/icons/react/home.js.map +1 -0
  435. package/dist/icons/react/index.js +27 -0
  436. package/dist/icons/react/index.js.map +1 -0
  437. package/dist/icons/react/info.js +30 -0
  438. package/dist/icons/react/info.js.map +1 -0
  439. package/dist/icons/react/logo_Block.js +30 -0
  440. package/dist/icons/react/logo_Block.js.map +1 -0
  441. package/dist/icons/react/logo_Horizontal.js +32 -0
  442. package/dist/icons/react/logo_Horizontal.js.map +1 -0
  443. package/dist/icons/react/looks_3.js +24 -0
  444. package/dist/icons/react/looks_3.js.map +1 -0
  445. package/dist/icons/react/looks_one.js +30 -0
  446. package/dist/icons/react/looks_one.js.map +1 -0
  447. package/dist/icons/react/looks_two.js +24 -0
  448. package/dist/icons/react/looks_two.js.map +1 -0
  449. package/dist/icons/react/menu.js +24 -0
  450. package/dist/icons/react/menu.js.map +1 -0
  451. package/dist/icons/react/menu_open.js +24 -0
  452. package/dist/icons/react/menu_open.js.map +1 -0
  453. package/dist/icons/react/more_horiz.js +27 -0
  454. package/dist/icons/react/more_horiz.js.map +1 -0
  455. package/dist/icons/react/schedule.js +24 -0
  456. package/dist/icons/react/schedule.js.map +1 -0
  457. package/dist/icons/react/search.js +30 -0
  458. package/dist/icons/react/search.js.map +1 -0
  459. package/dist/icons/react/sunny.js +24 -0
  460. package/dist/icons/react/sunny.js.map +1 -0
  461. package/dist/icons/react/warning.js +30 -0
  462. package/dist/icons/react/warning.js.map +1 -0
  463. package/dist/index.css +5214 -0
  464. package/dist/index.css.map +1 -0
  465. package/dist/input/index.d.ts +2 -2
  466. package/dist/input/index.js +34 -1
  467. package/dist/input/index.js.map +1 -0
  468. package/dist/input/style.css +110 -1
  469. package/dist/input-bar/index.d.ts +2 -2
  470. package/dist/input-bar/index.js +34 -1
  471. package/dist/input-bar/index.js.map +1 -0
  472. package/dist/input-bar/style.css +180 -1
  473. package/dist/input-number/index.d.ts +1 -1
  474. package/dist/input-number/index.js +34 -1
  475. package/dist/input-number/index.js.map +1 -0
  476. package/dist/input-number/style.css +109 -1
  477. package/dist/modal/index.d.ts +2 -2
  478. package/dist/modal/index.js +34 -1
  479. package/dist/modal/index.js.map +1 -0
  480. package/dist/modal/style.css +150 -1
  481. package/dist/nav-menu/index.d.ts +2 -2
  482. package/dist/nav-menu/index.js +34 -1
  483. package/dist/nav-menu/index.js.map +1 -0
  484. package/dist/nav-menu/style.css +241 -1
  485. package/dist/pagination/index.d.ts +1 -1
  486. package/dist/pagination/index.js +34 -1
  487. package/dist/pagination/index.js.map +1 -0
  488. package/dist/pagination/style.css +150 -1
  489. package/dist/radio/index.d.ts +3 -3
  490. package/dist/radio/index.js +34 -2
  491. package/dist/radio/index.js.map +1 -0
  492. package/dist/radio/style.css +294 -1
  493. package/dist/select/index.d.ts +2 -2
  494. package/dist/select/index.js +34 -1
  495. package/dist/select/index.js.map +1 -0
  496. package/dist/select/style.css +255 -1
  497. package/dist/sidebar/index.d.ts +2 -2
  498. package/dist/sidebar/index.js +34 -1
  499. package/dist/sidebar/index.js.map +1 -0
  500. package/dist/sidebar/style.css +270 -1
  501. package/dist/slider/index.d.ts +2 -2
  502. package/dist/slider/index.js +34 -1
  503. package/dist/slider/index.js.map +1 -0
  504. package/dist/slider/style.css +206 -1
  505. package/dist/src/index.js +33 -31
  506. package/dist/src/index.js.map +1 -0
  507. package/dist/steps/index.d.ts +1 -1
  508. package/dist/steps/index.js +34 -1
  509. package/dist/steps/index.js.map +1 -0
  510. package/dist/steps/style.css +286 -1
  511. package/dist/style.css +2 -0
  512. package/dist/switch/index.d.ts +2 -2
  513. package/dist/switch/index.js +34 -1
  514. package/dist/switch/index.js.map +1 -0
  515. package/dist/switch/style.css +160 -1
  516. package/dist/table/index.d.ts +1 -1
  517. package/dist/table/index.js +34 -1
  518. package/dist/table/index.js.map +1 -0
  519. package/dist/table/style.css +131 -1
  520. package/dist/tabs/index.d.ts +2 -2
  521. package/dist/tabs/index.js +34 -1
  522. package/dist/tabs/index.js.map +1 -0
  523. package/dist/tabs/style.css +146 -1
  524. package/dist/theme.css +183 -0
  525. package/dist/time-picker/index.d.ts +2 -2
  526. package/dist/time-picker/index.js +34 -1
  527. package/dist/time-picker/index.js.map +1 -0
  528. package/dist/time-picker/style.css +258 -1
  529. package/dist/toast/index.d.ts +4 -4
  530. package/dist/toast/index.js +38 -3
  531. package/dist/toast/index.js.map +1 -0
  532. package/dist/toast/style.css +117 -1
  533. package/dist/toolbars/index.d.ts +3 -3
  534. package/dist/toolbars/index.js +34 -1
  535. package/dist/toolbars/index.js.map +1 -0
  536. package/dist/toolbars/style.css +220 -1
  537. package/dist/tooltip/index.d.ts +1 -1
  538. package/dist/tooltip/index.js +34 -1
  539. package/dist/tooltip/index.js.map +1 -0
  540. package/dist/tooltip/style.css +138 -1
  541. package/dist/utils/src/index.js +6 -0
  542. package/dist/utils/src/index.js.map +1 -0
  543. package/package.json +9 -7
  544. package/dist/tsconfig.tsbuildinfo +0 -1
@@ -0,0 +1,11 @@
1
+ import { type HTMLAttributes, type MouseEvent } from 'react';
2
+ import { type NavMenuItem, type NavMenuProps as BaseNavMenuProps, type NavMenuValue } from '../../../components/nav-menu/index';
3
+ import '../../../components/nav-menu/style.css';
4
+ export interface NavMenuProps extends Omit<BaseNavMenuProps, 'className'>, Omit<HTMLAttributes<HTMLElement>, 'onChange'> {
5
+ value?: NavMenuValue;
6
+ defaultValue?: NavMenuValue;
7
+ onChange?: (value: NavMenuValue, item: NavMenuItem, event: MouseEvent<HTMLElement>) => void;
8
+ }
9
+ export declare const NavMenu: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<NavMenuProps & import("react").RefAttributes<HTMLElement>>>;
10
+ export default NavMenu;
11
+ //# sourceMappingURL=NavMenu.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NavMenu.d.ts","sourceRoot":"","sources":["../../../components/nav-menu/NavMenu.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EACnB,KAAK,UAAU,EAMhB,MAAM,OAAO,CAAA;AACd,OAAO,EAKL,KAAK,WAAW,EAChB,KAAK,YAAY,IAAI,gBAAgB,EACrC,KAAK,YAAY,EAClB,MAAM,4BAA4B,CAAA;AAMnC,OAAO,sCAAsC,CAAA;AAE7C,MAAM,WAAW,YACf,SAAQ,IAAI,CAAC,gBAAgB,EAAE,WAAW,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,UAAU,CAAC;IAC1F,KAAK,CAAC,EAAE,YAAY,CAAA;IACpB,YAAY,CAAC,EAAE,YAAY,CAAA;IAC3B,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,UAAU,CAAC,WAAW,CAAC,KAAK,IAAI,CAAA;CAC5F;AA8PD,eAAO,MAAM,OAAO,4IAAgC,CAAA;AAEpD,eAAe,OAAO,CAAA"}
@@ -0,0 +1,197 @@
1
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
2
+ import { useMemo, useState, useRef, useEffect } from 'react';
3
+ import { findNavMenuItemPath, hasNavMenuChildren, getNavMenuClassNames, getNavMenuItemClassNames } from '../../../components/nav-menu/index.js';
4
+ import { cn } from '../../../utils/src/index.js';
5
+ import { useMergedState } from '../../hooks/useMergedState.js';
6
+ import { createComponent } from '../../runtime/createComponent.js';
7
+ import { withInstall } from '../../runtime/withInstall.js';
8
+ import { forwardRef } from '../../runtime/forwardRef.js';
9
+ import IconComponent from '../icon/Icon.js';
10
+
11
+ const NavMenuComponent = createComponent(
12
+ forwardRef((props, ref) => {
13
+ const {
14
+ items = [],
15
+ value,
16
+ defaultValue,
17
+ theme = "light",
18
+ className,
19
+ onChange,
20
+ ...restProps
21
+ } = props;
22
+ const [currentValue, setCurrentValue] = useMergedState(defaultValue, {
23
+ value
24
+ });
25
+ const selectedPath = useMemo(
26
+ () => findNavMenuItemPath(items, currentValue),
27
+ [items, currentValue]
28
+ );
29
+ const selectedRootValue = selectedPath[0]?.value;
30
+ const selectedValues = useMemo(
31
+ () => new Set(selectedPath.map((item) => item.value)),
32
+ [selectedPath]
33
+ );
34
+ const [openRootValue, setOpenRootValue] = useState(void 0);
35
+ const rootRef = useRef(null);
36
+ const setRootRef = (node) => {
37
+ rootRef.current = node;
38
+ if (typeof ref === "function") {
39
+ ref(node);
40
+ return;
41
+ }
42
+ if (ref) {
43
+ ref.current = node;
44
+ }
45
+ };
46
+ useEffect(() => {
47
+ if (openRootValue === void 0) {
48
+ return;
49
+ }
50
+ if (!items.some((item) => item.value === openRootValue)) {
51
+ setOpenRootValue(void 0);
52
+ }
53
+ }, [items, openRootValue]);
54
+ useEffect(() => {
55
+ if (openRootValue === void 0) {
56
+ return;
57
+ }
58
+ const handlePointerDown = (event) => {
59
+ const target = event.target;
60
+ if (!target || !rootRef.current || rootRef.current.contains(target)) {
61
+ return;
62
+ }
63
+ setOpenRootValue(void 0);
64
+ };
65
+ document.addEventListener("pointerdown", handlePointerDown);
66
+ return () => {
67
+ document.removeEventListener("pointerdown", handlePointerDown);
68
+ };
69
+ }, [openRootValue]);
70
+ const handleSelect = (item, event, closePanel = true) => {
71
+ if (item.disabled) {
72
+ event.preventDefault();
73
+ return;
74
+ }
75
+ setCurrentValue(item.value);
76
+ if (closePanel) {
77
+ setOpenRootValue(void 0);
78
+ }
79
+ onChange?.(item.value, item, event);
80
+ };
81
+ const handleRootClick = (item, event) => {
82
+ if (item.disabled) {
83
+ return;
84
+ }
85
+ if (hasNavMenuChildren(item)) {
86
+ setOpenRootValue((prev) => prev === item.value ? void 0 : item.value);
87
+ return;
88
+ }
89
+ handleSelect(item, event, false);
90
+ setOpenRootValue(void 0);
91
+ };
92
+ const renderItemContent = (item, iconSize) => /* @__PURE__ */ jsxs("span", { className: "css-nav-menu__item-main", children: [
93
+ item.icon && /* @__PURE__ */ jsx("span", { className: "css-nav-menu__item-icon", children: /* @__PURE__ */ jsx(IconComponent, { name: item.icon, size: iconSize }) }),
94
+ /* @__PURE__ */ jsx("span", { className: "css-nav-menu__item-label", children: item.label })
95
+ ] });
96
+ const renderRootAction = (item) => {
97
+ const active = openRootValue === item.value || selectedRootValue === item.value;
98
+ const classes = getNavMenuItemClassNames({
99
+ active,
100
+ expanded: openRootValue === item.value,
101
+ disabled: item.disabled});
102
+ return /* @__PURE__ */ jsx(
103
+ "button",
104
+ {
105
+ type: "button",
106
+ className: classes,
107
+ "aria-expanded": hasNavMenuChildren(item) ? openRootValue === item.value : void 0,
108
+ onClick: (event) => handleRootClick(item, event),
109
+ children: renderItemContent(item, 16)
110
+ }
111
+ );
112
+ };
113
+ const renderPanelLink = (item, nested = false) => {
114
+ const classes = cn(
115
+ "css-nav-menu__panel-link",
116
+ currentValue === item.value && "css-nav-menu__panel-link--active",
117
+ item.disabled && "css-nav-menu__panel-link--disabled",
118
+ nested && "css-nav-menu__panel-link--nested"
119
+ );
120
+ if (item.href) {
121
+ return /* @__PURE__ */ jsx(
122
+ "a",
123
+ {
124
+ href: item.disabled ? void 0 : item.href,
125
+ className: classes,
126
+ "aria-disabled": item.disabled || void 0,
127
+ onClick: (event) => handleSelect(item, event),
128
+ children: renderItemContent(item, 14)
129
+ }
130
+ );
131
+ }
132
+ return /* @__PURE__ */ jsx(
133
+ "button",
134
+ {
135
+ type: "button",
136
+ className: classes,
137
+ disabled: item.disabled,
138
+ onClick: (event) => handleSelect(item, event),
139
+ children: renderItemContent(item, 14)
140
+ }
141
+ );
142
+ };
143
+ const renderPanelTitle = (item) => {
144
+ const classes = cn(
145
+ "css-nav-menu__panel-title",
146
+ selectedValues.has(item.value) && !hasNavMenuChildren(item) && "css-nav-menu__panel-link--active"
147
+ );
148
+ return /* @__PURE__ */ jsx(
149
+ "button",
150
+ {
151
+ type: "button",
152
+ className: classes,
153
+ disabled: item.disabled,
154
+ onClick: (event) => handleSelect(item, event),
155
+ children: renderItemContent(item, 16)
156
+ }
157
+ );
158
+ };
159
+ const renderPanelNode = (item, nested = false) => {
160
+ if (!hasNavMenuChildren(item)) {
161
+ return /* @__PURE__ */ jsx("li", { className: "css-nav-menu__panel-link-item", children: renderPanelLink(item, nested) }, item.value);
162
+ }
163
+ return /* @__PURE__ */ jsxs("li", { className: "css-nav-menu__panel-group", children: [
164
+ renderPanelTitle(item),
165
+ /* @__PURE__ */ jsx(
166
+ "ul",
167
+ {
168
+ className: cn("css-nav-menu__panel-list", nested && "css-nav-menu__panel-list--nested"),
169
+ children: item.children?.map((child) => renderPanelNode(child, true))
170
+ }
171
+ )
172
+ ] }, item.value);
173
+ };
174
+ const openRootItem = items.find((item) => item.value === openRootValue);
175
+ return /* @__PURE__ */ jsxs(
176
+ "nav",
177
+ {
178
+ ref: setRootRef,
179
+ className: cn(getNavMenuClassNames({ theme }), className),
180
+ "aria-label": "\u5BFC\u822A\u83DC\u5355",
181
+ ...restProps,
182
+ children: [
183
+ /* @__PURE__ */ jsx("ul", { className: "css-nav-menu__root", children: items.map((item) => /* @__PURE__ */ jsx("li", { children: renderRootAction(item) }, item.value)) }),
184
+ openRootItem && hasNavMenuChildren(openRootItem) ? /* @__PURE__ */ jsx("div", { className: "css-nav-menu__panel", children: /* @__PURE__ */ jsx("ul", { className: "css-nav-menu__panel-grid", children: openRootItem.children?.map((item) => /* @__PURE__ */ jsx("li", { className: "css-nav-menu__panel-column", children: hasNavMenuChildren(item) ? /* @__PURE__ */ jsxs(Fragment, { children: [
185
+ renderPanelTitle(item),
186
+ /* @__PURE__ */ jsx("ul", { className: "css-nav-menu__panel-list", children: item.children?.map((child) => renderPanelNode(child, true)) })
187
+ ] }) : renderPanelLink(item) }, item.value)) }) }) : null
188
+ ]
189
+ }
190
+ );
191
+ })
192
+ );
193
+ NavMenuComponent.displayName = "CssNavMenu";
194
+ const NavMenu = withInstall(NavMenuComponent);
195
+
196
+ export { NavMenu };
197
+ //# sourceMappingURL=NavMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NavMenu.js","sources":["../../../../../adapter-react/components/nav-menu/NavMenu.tsx"],"sourcesContent":["import {\r\n type HTMLAttributes,\r\n type MouseEvent,\r\n type MutableRefObject,\r\n useEffect,\r\n useMemo,\r\n useRef,\r\n useState,\r\n} from 'react'\r\nimport {\r\n findNavMenuItemPath,\r\n getNavMenuClassNames,\r\n getNavMenuItemClassNames,\r\n hasNavMenuChildren,\r\n type NavMenuItem,\r\n type NavMenuProps as BaseNavMenuProps,\r\n type NavMenuValue,\r\n} from '@cssui/components/nav-menu'\r\nimport { cn } from '@cssui/utils'\r\nimport { useMergedState } from '../../hooks'\r\nimport { createComponent, forwardRef, withInstall } from '../../runtime'\r\nimport Icon from '../icon/Icon'\r\n\r\nimport '@cssui/components/nav-menu/style.css'\r\n\r\nexport interface NavMenuProps\r\n extends Omit<BaseNavMenuProps, 'className'>, Omit<HTMLAttributes<HTMLElement>, 'onChange'> {\r\n value?: NavMenuValue\r\n defaultValue?: NavMenuValue\r\n onChange?: (value: NavMenuValue, item: NavMenuItem, event: MouseEvent<HTMLElement>) => void\r\n}\r\n\r\nconst NavMenuComponent = createComponent(\r\n forwardRef<HTMLElement, NavMenuProps>((props, ref) => {\r\n const {\r\n items = [],\r\n value,\r\n defaultValue,\r\n theme = 'light',\r\n className,\r\n onChange,\r\n ...restProps\r\n } = props\r\n\r\n const [currentValue, setCurrentValue] = useMergedState<NavMenuValue | undefined>(defaultValue, {\r\n value,\r\n })\r\n const selectedPath = useMemo(\r\n () => findNavMenuItemPath(items, currentValue),\r\n [items, currentValue]\r\n )\r\n const selectedRootValue = selectedPath[0]?.value\r\n const selectedValues = useMemo(\r\n () => new Set<NavMenuValue>(selectedPath.map(item => item.value)),\r\n [selectedPath]\r\n )\r\n const [openRootValue, setOpenRootValue] = useState<NavMenuValue | undefined>(undefined)\r\n const rootRef = useRef<HTMLElement | null>(null)\r\n\r\n const setRootRef = (node: HTMLElement | null) => {\r\n rootRef.current = node\r\n\r\n if (typeof ref === 'function') {\r\n ref(node)\r\n return\r\n }\r\n\r\n if (ref) {\r\n ;(ref as MutableRefObject<HTMLElement | null>).current = node\r\n }\r\n }\r\n\r\n useEffect(() => {\r\n if (openRootValue === undefined) {\r\n return\r\n }\r\n\r\n if (!items.some(item => item.value === openRootValue)) {\r\n setOpenRootValue(undefined)\r\n }\r\n }, [items, openRootValue])\r\n\r\n useEffect(() => {\r\n if (openRootValue === undefined) {\r\n return\r\n }\r\n\r\n const handlePointerDown = (event: PointerEvent) => {\r\n const target = event.target as Node | null\r\n\r\n if (!target || !rootRef.current || rootRef.current.contains(target)) {\r\n return\r\n }\r\n\r\n setOpenRootValue(undefined)\r\n }\r\n\r\n document.addEventListener('pointerdown', handlePointerDown)\r\n\r\n return () => {\r\n document.removeEventListener('pointerdown', handlePointerDown)\r\n }\r\n }, [openRootValue])\r\n\r\n const handleSelect = (\r\n item: NavMenuItem,\r\n event: MouseEvent<HTMLButtonElement | HTMLAnchorElement>,\r\n closePanel = true\r\n ) => {\r\n if (item.disabled) {\r\n event.preventDefault()\r\n return\r\n }\r\n\r\n setCurrentValue(item.value)\r\n\r\n if (closePanel) {\r\n setOpenRootValue(undefined)\r\n }\r\n\r\n onChange?.(item.value, item, event as MouseEvent<HTMLElement>)\r\n }\r\n\r\n const handleRootClick = (item: NavMenuItem, event: MouseEvent<HTMLButtonElement>) => {\r\n if (item.disabled) {\r\n return\r\n }\r\n\r\n if (hasNavMenuChildren(item)) {\r\n setOpenRootValue(prev => (prev === item.value ? undefined : item.value))\r\n return\r\n }\r\n\r\n handleSelect(item, event, false)\r\n setOpenRootValue(undefined)\r\n }\r\n\r\n const renderItemContent = (item: NavMenuItem, iconSize: number) => (\r\n <span className=\"css-nav-menu__item-main\">\r\n {item.icon && (\r\n <span className=\"css-nav-menu__item-icon\">\r\n <Icon name={item.icon as any} size={iconSize} />\r\n </span>\r\n )}\r\n <span className=\"css-nav-menu__item-label\">{item.label}</span>\r\n </span>\r\n )\r\n\r\n const renderRootAction = (item: NavMenuItem) => {\r\n const active = openRootValue === item.value || selectedRootValue === item.value\r\n const classes = getNavMenuItemClassNames({\r\n active,\r\n expanded: openRootValue === item.value,\r\n disabled: item.disabled,\r\n root: true,\r\n })\r\n\r\n return (\r\n <button\r\n type=\"button\"\r\n className={classes}\r\n aria-expanded={hasNavMenuChildren(item) ? openRootValue === item.value : undefined}\r\n onClick={event => handleRootClick(item, event)}\r\n >\r\n {renderItemContent(item, 16)}\r\n </button>\r\n )\r\n }\r\n\r\n const renderPanelLink = (item: NavMenuItem, nested = false) => {\r\n const classes = cn(\r\n 'css-nav-menu__panel-link',\r\n currentValue === item.value && 'css-nav-menu__panel-link--active',\r\n item.disabled && 'css-nav-menu__panel-link--disabled',\r\n nested && 'css-nav-menu__panel-link--nested'\r\n )\r\n\r\n if (item.href) {\r\n return (\r\n <a\r\n href={item.disabled ? undefined : item.href}\r\n className={classes}\r\n aria-disabled={item.disabled || undefined}\r\n onClick={event => handleSelect(item, event)}\r\n >\r\n {renderItemContent(item, 14)}\r\n </a>\r\n )\r\n }\r\n\r\n return (\r\n <button\r\n type=\"button\"\r\n className={classes}\r\n disabled={item.disabled}\r\n onClick={event => handleSelect(item, event)}\r\n >\r\n {renderItemContent(item, 14)}\r\n </button>\r\n )\r\n }\r\n\r\n const renderPanelTitle = (item: NavMenuItem) => {\r\n const classes = cn(\r\n 'css-nav-menu__panel-title',\r\n selectedValues.has(item.value) &&\r\n !hasNavMenuChildren(item) &&\r\n 'css-nav-menu__panel-link--active'\r\n )\r\n\r\n return (\r\n <button\r\n type=\"button\"\r\n className={classes}\r\n disabled={item.disabled}\r\n onClick={event => handleSelect(item, event)}\r\n >\r\n {renderItemContent(item, 16)}\r\n </button>\r\n )\r\n }\r\n\r\n const renderPanelNode = (item: NavMenuItem, nested = false): JSX.Element => {\r\n if (!hasNavMenuChildren(item)) {\r\n return (\r\n <li key={item.value} className=\"css-nav-menu__panel-link-item\">\r\n {renderPanelLink(item, nested)}\r\n </li>\r\n )\r\n }\r\n\r\n return (\r\n <li key={item.value} className=\"css-nav-menu__panel-group\">\r\n {renderPanelTitle(item)}\r\n <ul\r\n className={cn('css-nav-menu__panel-list', nested && 'css-nav-menu__panel-list--nested')}\r\n >\r\n {item.children?.map(child => renderPanelNode(child, true))}\r\n </ul>\r\n </li>\r\n )\r\n }\r\n\r\n const openRootItem = items.find(item => item.value === openRootValue)\r\n\r\n return (\r\n <nav\r\n ref={setRootRef}\r\n className={cn(getNavMenuClassNames({ theme }), className)}\r\n aria-label=\"导航菜单\"\r\n {...restProps}\r\n >\r\n <ul className=\"css-nav-menu__root\">\r\n {items.map(item => (\r\n <li key={item.value}>{renderRootAction(item)}</li>\r\n ))}\r\n </ul>\r\n {openRootItem && hasNavMenuChildren(openRootItem) ? (\r\n <div className=\"css-nav-menu__panel\">\r\n <ul className=\"css-nav-menu__panel-grid\">\r\n {openRootItem.children?.map(item => (\r\n <li key={item.value} className=\"css-nav-menu__panel-column\">\r\n {hasNavMenuChildren(item) ? (\r\n <>\r\n {renderPanelTitle(item)}\r\n <ul className=\"css-nav-menu__panel-list\">\r\n {item.children?.map(child => renderPanelNode(child, true))}\r\n </ul>\r\n </>\r\n ) : (\r\n renderPanelLink(item)\r\n )}\r\n </li>\r\n ))}\r\n </ul>\r\n </div>\r\n ) : null}\r\n </nav>\r\n )\r\n })\r\n)\r\n\r\nNavMenuComponent.displayName = 'CssNavMenu'\r\n\r\nexport const NavMenu = withInstall(NavMenuComponent)\r\n\r\nexport default NavMenu\r\n"],"names":["Icon"],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export { NavMenu } from './NavMenu';
2
+ export type { NavMenuProps } from './NavMenu';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/nav-menu/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AACnC,YAAY,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA"}
@@ -0,0 +1,11 @@
1
+ import { type HTMLAttributes } from 'react';
2
+ import { type PaginationProps as BasePaginationProps } from '../../../components/pagination/index';
3
+ import '../../../components/pagination/style.css';
4
+ export interface PaginationProps extends Omit<BasePaginationProps, 'onChange'>, Omit<HTMLAttributes<HTMLDivElement>, 'children' | 'onChange'> {
5
+ /** 非受控默认页码 */
6
+ defaultCurrent?: number;
7
+ onChange?: (page: number) => void;
8
+ }
9
+ export declare const Pagination: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<PaginationProps & import("react").RefAttributes<HTMLDivElement>>>;
10
+ export default Pagination;
11
+ //# sourceMappingURL=Pagination.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Pagination.d.ts","sourceRoot":"","sources":["../../../components/pagination/Pagination.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6C,KAAK,cAAc,EAAE,MAAM,OAAO,CAAA;AACtF,OAAO,EAKL,KAAK,eAAe,IAAI,mBAAmB,EAC5C,MAAM,8BAA8B,CAAA;AAMrC,OAAO,wCAAwC,CAAA;AAE/C,MAAM,WAAW,eACf,SACE,IAAI,CAAC,mBAAmB,EAAE,UAAU,CAAC,EACrC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,GAAG,UAAU,CAAC;IAC/D,cAAc;IACd,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;CAClC;AA0HD,eAAO,MAAM,UAAU,kJAAmC,CAAA;AAE1D,eAAe,UAAU,CAAA"}
@@ -0,0 +1,128 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useMemo, useState, useEffect, useCallback } from 'react';
3
+ import { getPaginationPageCount, clampPaginationPage, getPaginationRecordRange, getPaginationClassNames } from '../../../components/pagination/index.js';
4
+ import { cn } from '../../../utils/src/index.js';
5
+ import { createComponent } from '../../runtime/createComponent.js';
6
+ import { withInstall } from '../../runtime/withInstall.js';
7
+ import { forwardRef } from '../../runtime/forwardRef.js';
8
+ import IconComponent from '../icon/Icon.js';
9
+ import { Select } from '../select/Select.js';
10
+
11
+ const PaginationComponent = createComponent(
12
+ forwardRef((props, ref) => {
13
+ const {
14
+ current,
15
+ defaultCurrent = 1,
16
+ total = 0,
17
+ pageSize = 15,
18
+ align = "end",
19
+ showTotal = false,
20
+ className,
21
+ onChange,
22
+ ...restProps
23
+ } = props;
24
+ const totalPages = useMemo(() => getPaginationPageCount({ total, pageSize }), [pageSize, total]);
25
+ const [innerCurrent, setInnerCurrent] = useState(current ?? defaultCurrent);
26
+ const isControlled = current !== void 0;
27
+ useEffect(() => {
28
+ if (!isControlled) {
29
+ setInnerCurrent((previous) => clampPaginationPage(previous, totalPages));
30
+ }
31
+ }, [isControlled, totalPages]);
32
+ const currentPage = clampPaginationPage(
33
+ isControlled ? current ?? 1 : innerCurrent,
34
+ totalPages
35
+ );
36
+ const recordRange = useMemo(
37
+ () => getPaginationRecordRange({ current: currentPage, total, pageSize }),
38
+ [currentPage, pageSize, total]
39
+ );
40
+ const pageOptions = useMemo(
41
+ () => Array.from({ length: totalPages }, (_, index) => index + 1),
42
+ [totalPages]
43
+ );
44
+ const pageSelectOptions = useMemo(
45
+ () => pageOptions.map((page) => ({
46
+ label: String(page),
47
+ value: String(page)
48
+ })),
49
+ [pageOptions]
50
+ );
51
+ const classNames = cn(getPaginationClassNames({ align, showTotal }), className);
52
+ const handlePageChange = useCallback(
53
+ (nextPage) => {
54
+ const normalizedPage = clampPaginationPage(nextPage, totalPages);
55
+ if (normalizedPage === currentPage) {
56
+ return;
57
+ }
58
+ if (!isControlled) {
59
+ setInnerCurrent(normalizedPage);
60
+ }
61
+ onChange?.(normalizedPage);
62
+ },
63
+ [currentPage, isControlled, onChange, totalPages]
64
+ );
65
+ return /* @__PURE__ */ jsxs("div", { ref, className: classNames, ...restProps, children: [
66
+ showTotal ? /* @__PURE__ */ jsxs("div", { className: "css-pagination__summary", "aria-live": "polite", children: [
67
+ /* @__PURE__ */ jsxs("p", { className: "css-pagination__summary-line", children: [
68
+ "Total Records: ",
69
+ /* @__PURE__ */ jsx("strong", { children: total })
70
+ ] }),
71
+ /* @__PURE__ */ jsxs("p", { className: "css-pagination__summary-line", children: [
72
+ "Now Showing records: ",
73
+ recordRange.start,
74
+ "-",
75
+ recordRange.end
76
+ ] })
77
+ ] }) : null,
78
+ /* @__PURE__ */ jsxs("div", { className: "css-pagination__controls", children: [
79
+ /* @__PURE__ */ jsx(
80
+ "button",
81
+ {
82
+ type: "button",
83
+ className: "css-pagination__arrow",
84
+ onClick: () => handlePageChange(currentPage - 1),
85
+ disabled: currentPage <= 1,
86
+ "aria-label": "\u4E0A\u4E00\u9875",
87
+ children: /* @__PURE__ */ jsx(IconComponent, { name: "ChevronRight", size: 20, rotate: 180 })
88
+ }
89
+ ),
90
+ /* @__PURE__ */ jsxs("div", { className: "css-pagination__selector", children: [
91
+ /* @__PURE__ */ jsx("span", { className: "css-pagination__sr-only", children: "\u9009\u62E9\u9875\u7801" }),
92
+ /* @__PURE__ */ jsx(
93
+ Select,
94
+ {
95
+ value: String(currentPage),
96
+ options: pageSelectOptions,
97
+ onChange: (value) => {
98
+ if (typeof value === "string") {
99
+ handlePageChange(Number(value));
100
+ }
101
+ }
102
+ }
103
+ )
104
+ ] }),
105
+ showTotal ? /* @__PURE__ */ jsxs("span", { className: "css-pagination__page-count", children: [
106
+ "of ",
107
+ totalPages
108
+ ] }) : null,
109
+ /* @__PURE__ */ jsx(
110
+ "button",
111
+ {
112
+ type: "button",
113
+ className: "css-pagination__arrow",
114
+ onClick: () => handlePageChange(currentPage + 1),
115
+ disabled: currentPage >= totalPages,
116
+ "aria-label": "\u4E0B\u4E00\u9875",
117
+ children: /* @__PURE__ */ jsx(IconComponent, { name: "ChevronRight", size: 20 })
118
+ }
119
+ )
120
+ ] })
121
+ ] });
122
+ })
123
+ );
124
+ PaginationComponent.displayName = "CssPagination";
125
+ const Pagination = withInstall(PaginationComponent);
126
+
127
+ export { Pagination, Pagination as default };
128
+ //# sourceMappingURL=Pagination.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Pagination.js","sources":["../../../../../adapter-react/components/pagination/Pagination.tsx"],"sourcesContent":["import { useCallback, useEffect, useMemo, useState, type HTMLAttributes } from 'react'\nimport {\n clampPaginationPage,\n getPaginationClassNames,\n getPaginationPageCount,\n getPaginationRecordRange,\n type PaginationProps as BasePaginationProps,\n} from '@cssui/components/pagination'\nimport { cn } from '@cssui/utils'\nimport { createComponent, forwardRef, withInstall } from '../../runtime'\nimport Icon from '../icon/Icon'\nimport Select from '../select/Select'\n\nimport '@cssui/components/pagination/style.css'\n\nexport interface PaginationProps\n extends\n Omit<BasePaginationProps, 'onChange'>,\n Omit<HTMLAttributes<HTMLDivElement>, 'children' | 'onChange'> {\n /** 非受控默认页码 */\n defaultCurrent?: number\n onChange?: (page: number) => void\n}\n\nconst PaginationComponent = createComponent(\n forwardRef<HTMLDivElement, PaginationProps>((props, ref) => {\n const {\n current,\n defaultCurrent = 1,\n total = 0,\n pageSize = 15,\n align = 'end',\n showTotal = false,\n className,\n onChange,\n ...restProps\n } = props\n\n const totalPages = useMemo(() => getPaginationPageCount({ total, pageSize }), [pageSize, total])\n const [innerCurrent, setInnerCurrent] = useState(current ?? defaultCurrent)\n const isControlled = current !== undefined\n\n useEffect(() => {\n if (!isControlled) {\n setInnerCurrent(previous => clampPaginationPage(previous, totalPages))\n }\n }, [isControlled, totalPages])\n\n const currentPage = clampPaginationPage(\n isControlled ? (current ?? 1) : innerCurrent,\n totalPages\n )\n const recordRange = useMemo(\n () => getPaginationRecordRange({ current: currentPage, total, pageSize }),\n [currentPage, pageSize, total]\n )\n const pageOptions = useMemo(\n () => Array.from({ length: totalPages }, (_, index) => index + 1),\n [totalPages]\n )\n const pageSelectOptions = useMemo(\n () =>\n pageOptions.map(page => ({\n label: String(page),\n value: String(page),\n })),\n [pageOptions]\n )\n\n const classNames = cn(getPaginationClassNames({ align, showTotal }), className)\n\n const handlePageChange = useCallback(\n (nextPage: number) => {\n const normalizedPage = clampPaginationPage(nextPage, totalPages)\n\n if (normalizedPage === currentPage) {\n return\n }\n\n if (!isControlled) {\n setInnerCurrent(normalizedPage)\n }\n\n onChange?.(normalizedPage)\n },\n [currentPage, isControlled, onChange, totalPages]\n )\n\n return (\n <div ref={ref} className={classNames} {...restProps}>\n {showTotal ? (\n <div className=\"css-pagination__summary\" aria-live=\"polite\">\n <p className=\"css-pagination__summary-line\">\n Total Records: <strong>{total}</strong>\n </p>\n <p className=\"css-pagination__summary-line\">\n Now Showing records: {recordRange.start}-{recordRange.end}\n </p>\n </div>\n ) : null}\n\n <div className=\"css-pagination__controls\">\n <button\n type=\"button\"\n className=\"css-pagination__arrow\"\n onClick={() => handlePageChange(currentPage - 1)}\n disabled={currentPage <= 1}\n aria-label=\"上一页\"\n >\n <Icon name=\"ChevronRight\" size={20} rotate={180} />\n </button>\n\n <div className=\"css-pagination__selector\">\n <span className=\"css-pagination__sr-only\">选择页码</span>\n <Select\n value={String(currentPage)}\n options={pageSelectOptions}\n onChange={value => {\n if (typeof value === 'string') {\n handlePageChange(Number(value))\n }\n }}\n />\n </div>\n\n {showTotal ? <span className=\"css-pagination__page-count\">of {totalPages}</span> : null}\n\n <button\n type=\"button\"\n className=\"css-pagination__arrow\"\n onClick={() => handlePageChange(currentPage + 1)}\n disabled={currentPage >= totalPages}\n aria-label=\"下一页\"\n >\n <Icon name=\"ChevronRight\" size={20} />\n </button>\n </div>\n </div>\n )\n })\n)\n\nPaginationComponent.displayName = 'CssPagination'\n\nexport const Pagination = withInstall(PaginationComponent)\n\nexport default Pagination\n"],"names":["Icon"],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export { Pagination, default } from './Pagination';
2
+ export type { PaginationProps } from './Pagination';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../components/pagination/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAClD,YAAY,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA"}
@@ -0,0 +1,12 @@
1
+ import type { ChangeEvent } from 'react';
2
+ import { type RadioProps as BaseRadioProps } from '../../../components/radio/index';
3
+ import '../../../components/radio/style.css';
4
+ export interface RadioProps extends Omit<BaseRadioProps, 'onChange'> {
5
+ defaultChecked?: boolean;
6
+ icon?: React.ReactNode | string;
7
+ onChange?: (checked: boolean, event: ChangeEvent<HTMLInputElement>) => void;
8
+ [key: string]: any;
9
+ }
10
+ export declare const Radio: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<Omit<RadioProps, "ref"> & import("react").RefAttributes<HTMLInputElement>>>;
11
+ export default Radio;
12
+ //# sourceMappingURL=Radio.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Radio.d.ts","sourceRoot":"","sources":["../../../components/radio/Radio.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AACxC,OAAO,EAEL,KAAK,UAAU,IAAI,cAAc,EAElC,MAAM,yBAAyB,CAAA;AAKhC,OAAO,mCAAmC,CAAA;AAE1C,MAAM,WAAW,UAAW,SAAQ,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC;IAClE,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,IAAI,CAAC,EAAE,KAAK,CAAC,SAAS,GAAG,MAAM,CAAA;IAC/B,QAAQ,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAA;IAC3E,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CACnB;AA2FD,eAAO,MAAM,KAAK,4JAA8B,CAAA;AAEhD,eAAe,KAAK,CAAA"}
@@ -0,0 +1,83 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { getRadioClassNames } from '../../../components/radio/index.js';
3
+ import { createComponent } from '../../runtime/createComponent.js';
4
+ import { withInstall } from '../../runtime/withInstall.js';
5
+ import { forwardRef } from '../../runtime/forwardRef.js';
6
+ import IconComponent from '../icon/Icon.js';
7
+ import { useRadioGroupContext } from './RadioGroup.js';
8
+
9
+ const RadioComponent = createComponent(
10
+ forwardRef((props, ref) => {
11
+ const {
12
+ checked,
13
+ defaultChecked,
14
+ disabled,
15
+ error,
16
+ label,
17
+ children,
18
+ className,
19
+ onChange,
20
+ value,
21
+ variant,
22
+ icon,
23
+ iconOnly,
24
+ name,
25
+ ...restProps
26
+ } = props;
27
+ const groupContext = useRadioGroupContext();
28
+ const mergedDisabled = groupContext?.disabled || disabled;
29
+ const mergedError = groupContext?.error || error;
30
+ const mergedVariant = variant ?? groupContext?.variant ?? "default";
31
+ const mergedIconOnly = iconOnly ?? groupContext?.iconOnly ?? false;
32
+ const mergedName = name ?? groupContext?.name;
33
+ const groupChecked = groupContext && value !== void 0 ? groupContext.value === value : void 0;
34
+ const mergedChecked = groupChecked ?? checked;
35
+ const radioClassName = getRadioClassNames({
36
+ disabled: mergedDisabled,
37
+ error: mergedError,
38
+ className,
39
+ variant: mergedVariant,
40
+ iconOnly: mergedIconOnly
41
+ });
42
+ const handleChange = (event) => {
43
+ if (mergedDisabled) {
44
+ return;
45
+ }
46
+ if (groupContext && value !== void 0) {
47
+ groupContext.onChange?.(value, event);
48
+ }
49
+ onChange?.(event.target.checked, event);
50
+ };
51
+ const renderedIcon = typeof icon === "string" ? /* @__PURE__ */ jsx(IconComponent, { name: icon, size: 20, className: "css-radio__icon" }) : icon;
52
+ return /* @__PURE__ */ jsxs("label", { className: radioClassName, children: [
53
+ /* @__PURE__ */ jsx(
54
+ "input",
55
+ {
56
+ ref,
57
+ type: "radio",
58
+ className: "css-radio__input",
59
+ checked: mergedChecked,
60
+ defaultChecked,
61
+ disabled: mergedDisabled,
62
+ name: mergedName,
63
+ value,
64
+ onChange: handleChange,
65
+ ...restProps
66
+ }
67
+ ),
68
+ /* @__PURE__ */ jsx("span", { className: "css-radio__indicator" }),
69
+ (renderedIcon || label || children) && /* @__PURE__ */ jsxs("span", { className: "css-radio__content", children: [
70
+ renderedIcon ? /* @__PURE__ */ jsx("span", { className: "css-radio__icon", children: renderedIcon }) : null,
71
+ (label || children) && /* @__PURE__ */ jsxs("span", { className: "css-radio__label", children: [
72
+ label,
73
+ children
74
+ ] })
75
+ ] })
76
+ ] });
77
+ })
78
+ );
79
+ RadioComponent.displayName = "CssRadio";
80
+ const Radio = withInstall(RadioComponent);
81
+
82
+ export { Radio, Radio as default };
83
+ //# sourceMappingURL=Radio.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Radio.js","sources":["../../../../../adapter-react/components/radio/Radio.tsx"],"sourcesContent":["import type { ChangeEvent } from 'react'\nimport {\n getRadioClassNames,\n type RadioProps as BaseRadioProps,\n type RadioValue,\n} from '@cssui/components/radio'\nimport { createComponent, forwardRef, withInstall } from '../../runtime'\nimport Icon from '../icon/Icon'\nimport { useRadioGroupContext } from './RadioGroup'\n\nimport '@cssui/components/radio/style.css'\n\nexport interface RadioProps extends Omit<BaseRadioProps, 'onChange'> {\n defaultChecked?: boolean\n icon?: React.ReactNode | string\n onChange?: (checked: boolean, event: ChangeEvent<HTMLInputElement>) => void\n [key: string]: any\n}\n\nconst RadioComponent = createComponent(\n forwardRef<HTMLInputElement, RadioProps>((props, ref) => {\n const {\n checked,\n defaultChecked,\n disabled,\n error,\n label,\n children,\n className,\n onChange,\n value,\n variant,\n icon,\n iconOnly,\n name,\n ...restProps\n } = props\n\n const groupContext = useRadioGroupContext()\n const mergedDisabled = groupContext?.disabled || disabled\n const mergedError = groupContext?.error || error\n const mergedVariant = variant ?? groupContext?.variant ?? 'default'\n const mergedIconOnly = iconOnly ?? groupContext?.iconOnly ?? false\n const mergedName = name ?? groupContext?.name\n const groupChecked =\n groupContext && value !== undefined ? groupContext.value === (value as RadioValue) : undefined\n const mergedChecked = groupChecked ?? checked\n\n const radioClassName = getRadioClassNames({\n disabled: mergedDisabled,\n error: mergedError,\n className,\n variant: mergedVariant,\n iconOnly: mergedIconOnly,\n })\n\n const handleChange = (event: ChangeEvent<HTMLInputElement>) => {\n if (mergedDisabled) {\n return\n }\n\n if (groupContext && value !== undefined) {\n groupContext.onChange?.(value as RadioValue, event)\n }\n\n onChange?.(event.target.checked, event)\n }\n\n const renderedIcon =\n typeof icon === 'string' ? (\n <Icon name={icon as any} size={20} className=\"css-radio__icon\" />\n ) : (\n icon\n )\n\n return (\n <label className={radioClassName}>\n <input\n ref={ref}\n type=\"radio\"\n className=\"css-radio__input\"\n checked={mergedChecked}\n defaultChecked={defaultChecked}\n disabled={mergedDisabled}\n name={mergedName}\n value={value as string | number | readonly string[] | undefined}\n onChange={handleChange}\n {...restProps}\n />\n <span className=\"css-radio__indicator\" />\n {(renderedIcon || label || children) && (\n <span className=\"css-radio__content\">\n {renderedIcon ? <span className=\"css-radio__icon\">{renderedIcon}</span> : null}\n {(label || children) && (\n <span className=\"css-radio__label\">\n {label}\n {children}\n </span>\n )}\n </span>\n )}\n </label>\n )\n })\n)\n\nRadioComponent.displayName = 'CssRadio'\n\nexport const Radio = withInstall(RadioComponent)\n\nexport default Radio\n"],"names":["Icon"],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ import { type ChangeEvent, type ReactNode } from 'react';
2
+ import { type RadioGroupOption as BaseRadioGroupOption, type RadioGroupProps as BaseRadioGroupProps, type RadioValue, type RadioVariant, type RadioDirection } from '../../../components/radio/index';
3
+ export interface RadioGroupOption extends Omit<BaseRadioGroupOption, 'icon'> {
4
+ icon?: string | ReactNode;
5
+ }
6
+ export interface RadioGroupProps extends Omit<BaseRadioGroupProps, 'onChange' | 'options'> {
7
+ options?: RadioGroupOption[];
8
+ direction?: RadioDirection;
9
+ onChange?: (value: RadioValue, event?: ChangeEvent<HTMLInputElement>) => void;
10
+ }
11
+ export interface RadioGroupContextValue {
12
+ name?: string;
13
+ value?: RadioValue;
14
+ disabled?: boolean;
15
+ error?: boolean;
16
+ variant?: RadioVariant;
17
+ iconOnly?: boolean;
18
+ onChange?: (value: RadioValue, event: ChangeEvent<HTMLInputElement>) => void;
19
+ }
20
+ export declare const RadioGroupContext: import("react").Context<RadioGroupContextValue | null>;
21
+ export declare function useRadioGroupContext(): RadioGroupContextValue | null;
22
+ export declare const RadioGroup: import("../..").ComponentWithInstall<import("react").ForwardRefExoticComponent<RadioGroupProps & import("react").RefAttributes<HTMLDivElement>>>;
23
+ export default RadioGroup;
24
+ //# sourceMappingURL=RadioGroup.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioGroup.d.ts","sourceRoot":"","sources":["../../../components/radio/RadioGroup.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA6C,KAAK,WAAW,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AACnG,OAAO,EAEL,KAAK,gBAAgB,IAAI,oBAAoB,EAC7C,KAAK,eAAe,IAAI,mBAAmB,EAC3C,KAAK,UAAU,EACf,KAAK,YAAY,EACjB,KAAK,cAAc,EACpB,MAAM,yBAAyB,CAAA;AAMhC,MAAM,WAAW,gBAAiB,SAAQ,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC;IAC1E,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAAA;CAC1B;AAED,MAAM,WAAW,eAAgB,SAAQ,IAAI,CAAC,mBAAmB,EAAE,UAAU,GAAG,SAAS,CAAC;IACxF,OAAO,CAAC,EAAE,gBAAgB,EAAE,CAAA;IAC5B,SAAS,CAAC,EAAE,cAAc,CAAA;IAC1B,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,CAAC,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAA;CAC9E;AAED,MAAM,WAAW,sBAAsB;IACrC,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,UAAU,CAAA;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,OAAO,CAAC,EAAE,YAAY,CAAA;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,CAAC,gBAAgB,CAAC,KAAK,IAAI,CAAA;CAC7E;AAED,eAAO,MAAM,iBAAiB,wDAAqD,CAAA;AAEnF,wBAAgB,oBAAoB,kCAEnC;AA+FD,eAAO,MAAM,UAAU,kJAAmC,CAAA;AAE1D,eAAe,UAAU,CAAA"}