@mdigital_ui/ui 0.4.0 → 0.4.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 (576) hide show
  1. package/dist/accordion/index.d.ts +6 -0
  2. package/dist/accordion/index.d.ts.map +1 -0
  3. package/dist/accordion/index.js +5 -0
  4. package/dist/accordion/index.js.map +1 -0
  5. package/dist/accordion/types.d.ts +126 -0
  6. package/dist/accordion/types.d.ts.map +1 -0
  7. package/dist/avatar/index.d.ts +14 -0
  8. package/dist/avatar/index.d.ts.map +1 -0
  9. package/dist/avatar/index.js +4 -0
  10. package/dist/avatar/index.js.map +1 -0
  11. package/dist/avatar/types.d.ts +147 -0
  12. package/dist/avatar/types.d.ts.map +1 -0
  13. package/dist/badge/index.d.ts +28 -0
  14. package/dist/badge/index.d.ts.map +1 -0
  15. package/dist/badge/index.js +5 -0
  16. package/dist/badge/index.js.map +1 -0
  17. package/dist/badge/types.d.ts +97 -0
  18. package/dist/badge/types.d.ts.map +1 -0
  19. package/dist/breadcrumbs/index.d.ts +13 -0
  20. package/dist/breadcrumbs/index.d.ts.map +1 -0
  21. package/dist/breadcrumbs/index.js +8 -0
  22. package/dist/breadcrumbs/index.js.map +1 -0
  23. package/dist/breadcrumbs/types.d.ts +118 -0
  24. package/dist/breadcrumbs/types.d.ts.map +1 -0
  25. package/dist/button/index.d.ts +15 -0
  26. package/dist/button/index.d.ts.map +1 -0
  27. package/dist/button/index.js +7 -0
  28. package/dist/button/index.js.map +1 -0
  29. package/dist/button/types.d.ts +103 -0
  30. package/dist/button/types.d.ts.map +1 -0
  31. package/dist/button-group/index.d.ts +34 -0
  32. package/dist/button-group/index.d.ts.map +1 -0
  33. package/dist/button-group/index.js +4 -0
  34. package/dist/button-group/index.js.map +1 -0
  35. package/dist/button-group/types.d.ts +75 -0
  36. package/dist/button-group/types.d.ts.map +1 -0
  37. package/dist/card/index.d.ts +71 -0
  38. package/dist/card/index.d.ts.map +1 -0
  39. package/dist/card/index.js +5 -0
  40. package/dist/card/index.js.map +1 -0
  41. package/dist/card/types.d.ts +136 -0
  42. package/dist/card/types.d.ts.map +1 -0
  43. package/dist/carousel/carousel-navigation.d.ts +9 -0
  44. package/dist/carousel/carousel-navigation.d.ts.map +1 -0
  45. package/dist/carousel/index.d.ts +50 -0
  46. package/dist/carousel/index.d.ts.map +1 -0
  47. package/dist/carousel/index.js +4 -0
  48. package/dist/carousel/index.js.map +1 -0
  49. package/dist/cascader/index.d.ts +27 -0
  50. package/dist/cascader/index.d.ts.map +1 -0
  51. package/dist/cascader/index.js +5 -0
  52. package/dist/cascader/index.js.map +1 -0
  53. package/dist/cascader/types.d.ts +220 -0
  54. package/dist/cascader/types.d.ts.map +1 -0
  55. package/dist/checkbox/index.d.ts +6 -0
  56. package/dist/checkbox/index.d.ts.map +1 -0
  57. package/dist/checkbox/index.js +5 -0
  58. package/dist/checkbox/index.js.map +1 -0
  59. package/dist/checkbox/types.d.ts +21 -0
  60. package/dist/checkbox/types.d.ts.map +1 -0
  61. package/dist/checkbox-group/index.d.ts +6 -0
  62. package/dist/checkbox-group/index.d.ts.map +1 -0
  63. package/dist/checkbox-group/index.js +4 -0
  64. package/dist/checkbox-group/index.js.map +1 -0
  65. package/dist/checkbox-group/types.d.ts +43 -0
  66. package/dist/checkbox-group/types.d.ts.map +1 -0
  67. package/dist/chunk-2PNLIQYM.js +76 -0
  68. package/dist/chunk-2PNLIQYM.js.map +1 -0
  69. package/dist/chunk-2TLOWZE4.js +689 -0
  70. package/dist/chunk-2TLOWZE4.js.map +1 -0
  71. package/dist/chunk-2WZVD7P3.js +145 -0
  72. package/dist/chunk-2WZVD7P3.js.map +1 -0
  73. package/dist/chunk-3BIV3QE2.js +353 -0
  74. package/dist/chunk-3BIV3QE2.js.map +1 -0
  75. package/dist/chunk-3BZE6BBJ.js +758 -0
  76. package/dist/chunk-3BZE6BBJ.js.map +1 -0
  77. package/dist/chunk-3PWILVOE.js +182 -0
  78. package/dist/chunk-3PWILVOE.js.map +1 -0
  79. package/dist/chunk-4FFVNUTK.js +35 -0
  80. package/dist/chunk-4FFVNUTK.js.map +1 -0
  81. package/dist/chunk-5PUATOLR.js +127 -0
  82. package/dist/chunk-5PUATOLR.js.map +1 -0
  83. package/dist/chunk-64NHVOZS.js +272 -0
  84. package/dist/chunk-64NHVOZS.js.map +1 -0
  85. package/dist/chunk-674JC24S.js +414 -0
  86. package/dist/chunk-674JC24S.js.map +1 -0
  87. package/dist/chunk-6BAP6QUT.js +72 -0
  88. package/dist/chunk-6BAP6QUT.js.map +1 -0
  89. package/dist/chunk-6G3BMY4N.js +349 -0
  90. package/dist/chunk-6G3BMY4N.js.map +1 -0
  91. package/dist/chunk-6HGUDHHE.js +86 -0
  92. package/dist/chunk-6HGUDHHE.js.map +1 -0
  93. package/dist/chunk-6JGNJI5T.js +174 -0
  94. package/dist/chunk-6JGNJI5T.js.map +1 -0
  95. package/dist/chunk-6LYRMQOI.js +328 -0
  96. package/dist/chunk-6LYRMQOI.js.map +1 -0
  97. package/dist/chunk-6YOOKE6C.js +138 -0
  98. package/dist/chunk-6YOOKE6C.js.map +1 -0
  99. package/dist/chunk-764UKE6X.js +359 -0
  100. package/dist/chunk-764UKE6X.js.map +1 -0
  101. package/dist/chunk-7UCNBMCV.js +261 -0
  102. package/dist/chunk-7UCNBMCV.js.map +1 -0
  103. package/dist/chunk-BPRCBPVJ.js +253 -0
  104. package/dist/chunk-BPRCBPVJ.js.map +1 -0
  105. package/dist/chunk-BVO2BNFG.js +437 -0
  106. package/dist/chunk-BVO2BNFG.js.map +1 -0
  107. package/dist/chunk-C5IGZLIT.js +107 -0
  108. package/dist/chunk-C5IGZLIT.js.map +1 -0
  109. package/dist/chunk-CN74CNAN.js +75 -0
  110. package/dist/chunk-CN74CNAN.js.map +1 -0
  111. package/dist/chunk-D4SUSZDN.js +360 -0
  112. package/dist/chunk-D4SUSZDN.js.map +1 -0
  113. package/dist/chunk-DUIL5BYS.js +293 -0
  114. package/dist/chunk-DUIL5BYS.js.map +1 -0
  115. package/dist/chunk-EHWXPH76.js +42 -0
  116. package/dist/chunk-EHWXPH76.js.map +1 -0
  117. package/dist/chunk-ERRZ2CSG.js +192 -0
  118. package/dist/chunk-ERRZ2CSG.js.map +1 -0
  119. package/dist/chunk-EZGK67T6.js +383 -0
  120. package/dist/chunk-EZGK67T6.js.map +1 -0
  121. package/dist/chunk-FZSCLZF6.js +552 -0
  122. package/dist/chunk-FZSCLZF6.js.map +1 -0
  123. package/dist/chunk-G6NVGBYZ.js +334 -0
  124. package/dist/chunk-G6NVGBYZ.js.map +1 -0
  125. package/dist/chunk-GJPZOMFE.js +407 -0
  126. package/dist/chunk-GJPZOMFE.js.map +1 -0
  127. package/dist/chunk-GOLARX5K.js +310 -0
  128. package/dist/chunk-GOLARX5K.js.map +1 -0
  129. package/dist/chunk-GVVP5TZM.js +506 -0
  130. package/dist/chunk-GVVP5TZM.js.map +1 -0
  131. package/dist/chunk-H6G4BUPA.js +586 -0
  132. package/dist/chunk-H6G4BUPA.js.map +1 -0
  133. package/dist/chunk-HCOTO5WX.js +77 -0
  134. package/dist/chunk-HCOTO5WX.js.map +1 -0
  135. package/dist/chunk-HECAAILV.js +94 -0
  136. package/dist/chunk-HECAAILV.js.map +1 -0
  137. package/dist/chunk-HUXODBIO.js +424 -0
  138. package/dist/chunk-HUXODBIO.js.map +1 -0
  139. package/dist/chunk-I32ZQUYY.js +184 -0
  140. package/dist/chunk-I32ZQUYY.js.map +1 -0
  141. package/dist/chunk-JWTWPZ32.js +355 -0
  142. package/dist/chunk-JWTWPZ32.js.map +1 -0
  143. package/dist/chunk-KH577UDI.js +218 -0
  144. package/dist/chunk-KH577UDI.js.map +1 -0
  145. package/dist/chunk-KJTMZJ7V.js +239 -0
  146. package/dist/chunk-KJTMZJ7V.js.map +1 -0
  147. package/dist/chunk-L5UYN5LX.js +787 -0
  148. package/dist/chunk-L5UYN5LX.js.map +1 -0
  149. package/dist/chunk-LOYLJRCF.js +485 -0
  150. package/dist/chunk-LOYLJRCF.js.map +1 -0
  151. package/dist/chunk-LX4FDH4J.js +299 -0
  152. package/dist/chunk-LX4FDH4J.js.map +1 -0
  153. package/dist/chunk-N2WHJ3FI.js +130 -0
  154. package/dist/chunk-N2WHJ3FI.js.map +1 -0
  155. package/dist/chunk-NGYLRX6F.js +42 -0
  156. package/dist/chunk-NGYLRX6F.js.map +1 -0
  157. package/dist/chunk-O3V3BTIJ.js +419 -0
  158. package/dist/chunk-O3V3BTIJ.js.map +1 -0
  159. package/dist/chunk-OFUPJH35.js +74 -0
  160. package/dist/chunk-OFUPJH35.js.map +1 -0
  161. package/dist/chunk-OLTQAMV2.js +210 -0
  162. package/dist/chunk-OLTQAMV2.js.map +1 -0
  163. package/dist/chunk-ON2CMF6J.js +503 -0
  164. package/dist/chunk-ON2CMF6J.js.map +1 -0
  165. package/dist/chunk-ONGJXAYQ.js +144 -0
  166. package/dist/chunk-ONGJXAYQ.js.map +1 -0
  167. package/dist/chunk-OQFYIKWR.js +1264 -0
  168. package/dist/chunk-OQFYIKWR.js.map +1 -0
  169. package/dist/chunk-POLVJ36Y.js +210 -0
  170. package/dist/chunk-POLVJ36Y.js.map +1 -0
  171. package/dist/chunk-POXI7JJ4.js +351 -0
  172. package/dist/chunk-POXI7JJ4.js.map +1 -0
  173. package/dist/chunk-R3TLU26W.js +110 -0
  174. package/dist/chunk-R3TLU26W.js.map +1 -0
  175. package/dist/chunk-RFHTC6AH.js +250 -0
  176. package/dist/chunk-RFHTC6AH.js.map +1 -0
  177. package/dist/chunk-ROA7BYGB.js +123 -0
  178. package/dist/chunk-ROA7BYGB.js.map +1 -0
  179. package/dist/chunk-SGRACNBP.js +60 -0
  180. package/dist/chunk-SGRACNBP.js.map +1 -0
  181. package/dist/chunk-TLNHWOQQ.js +1026 -0
  182. package/dist/chunk-TLNHWOQQ.js.map +1 -0
  183. package/dist/chunk-UTWQ2FZK.js +337 -0
  184. package/dist/chunk-UTWQ2FZK.js.map +1 -0
  185. package/dist/chunk-VOODO2ZE.js +180 -0
  186. package/dist/chunk-VOODO2ZE.js.map +1 -0
  187. package/dist/chunk-WRSG7WU5.js +278 -0
  188. package/dist/chunk-WRSG7WU5.js.map +1 -0
  189. package/dist/chunk-X3YNHX77.js +109 -0
  190. package/dist/chunk-X3YNHX77.js.map +1 -0
  191. package/dist/chunk-Y4XAXZHB.js +42 -0
  192. package/dist/chunk-Y4XAXZHB.js.map +1 -0
  193. package/dist/chunk-YJOLLSHH.js +132 -0
  194. package/dist/chunk-YJOLLSHH.js.map +1 -0
  195. package/dist/chunk-YS5AIY4A.js +43 -0
  196. package/dist/chunk-YS5AIY4A.js.map +1 -0
  197. package/dist/chunk-YXLIGJTN.js +336 -0
  198. package/dist/chunk-YXLIGJTN.js.map +1 -0
  199. package/dist/chunk-ZIYA7TGX.js +141 -0
  200. package/dist/chunk-ZIYA7TGX.js.map +1 -0
  201. package/dist/chunk-ZJNGZCRB.js +440 -0
  202. package/dist/chunk-ZJNGZCRB.js.map +1 -0
  203. package/dist/clipboard/index.d.ts +6 -0
  204. package/dist/clipboard/index.d.ts.map +1 -0
  205. package/dist/clipboard/index.js +6 -0
  206. package/dist/clipboard/index.js.map +1 -0
  207. package/dist/clipboard/types.d.ts +65 -0
  208. package/dist/clipboard/types.d.ts.map +1 -0
  209. package/dist/collapse/index.d.ts +6 -0
  210. package/dist/collapse/index.d.ts.map +1 -0
  211. package/dist/collapse/index.js +5 -0
  212. package/dist/collapse/index.js.map +1 -0
  213. package/dist/collapse/types.d.ts +60 -0
  214. package/dist/collapse/types.d.ts.map +1 -0
  215. package/dist/command/index.d.ts +74 -0
  216. package/dist/command/index.d.ts.map +1 -0
  217. package/dist/command/index.js +5 -0
  218. package/dist/command/index.js.map +1 -0
  219. package/dist/command/types.d.ts +24 -0
  220. package/dist/command/types.d.ts.map +1 -0
  221. package/dist/context-menu/index.d.ts +63 -0
  222. package/dist/context-menu/index.d.ts.map +1 -0
  223. package/dist/context-menu/index.js +5 -0
  224. package/dist/context-menu/index.js.map +1 -0
  225. package/dist/context-menu/types.d.ts +109 -0
  226. package/dist/context-menu/types.d.ts.map +1 -0
  227. package/dist/date-picker/index.d.ts +12 -0
  228. package/dist/date-picker/index.d.ts.map +1 -0
  229. package/dist/date-picker/index.js +6 -0
  230. package/dist/date-picker/index.js.map +1 -0
  231. package/dist/date-picker/types.d.ts +64 -0
  232. package/dist/date-picker/types.d.ts.map +1 -0
  233. package/dist/date-picker/utils.d.ts +10 -0
  234. package/dist/date-picker/utils.d.ts.map +1 -0
  235. package/dist/descriptions/index.d.ts +6 -0
  236. package/dist/descriptions/index.d.ts.map +1 -0
  237. package/dist/descriptions/index.js +4 -0
  238. package/dist/descriptions/index.js.map +1 -0
  239. package/dist/descriptions/types.d.ts +34 -0
  240. package/dist/descriptions/types.d.ts.map +1 -0
  241. package/dist/divider/index.d.ts +39 -0
  242. package/dist/divider/index.d.ts.map +1 -0
  243. package/dist/divider/index.js +4 -0
  244. package/dist/divider/index.js.map +1 -0
  245. package/dist/divider/types.d.ts +63 -0
  246. package/dist/divider/types.d.ts.map +1 -0
  247. package/dist/drawer/index.d.ts +23 -0
  248. package/dist/drawer/index.d.ts.map +1 -0
  249. package/dist/drawer/index.js +4 -0
  250. package/dist/drawer/index.js.map +1 -0
  251. package/dist/drawer/types.d.ts +309 -0
  252. package/dist/drawer/types.d.ts.map +1 -0
  253. package/dist/dropdown/index.d.ts +6 -0
  254. package/dist/dropdown/index.d.ts.map +1 -0
  255. package/dist/dropdown/index.js +7 -0
  256. package/dist/dropdown/index.js.map +1 -0
  257. package/dist/dropdown/types.d.ts +116 -0
  258. package/dist/dropdown/types.d.ts.map +1 -0
  259. package/dist/empty/index.d.ts +6 -0
  260. package/dist/empty/index.d.ts.map +1 -0
  261. package/dist/empty/index.js +4 -0
  262. package/dist/empty/index.js.map +1 -0
  263. package/dist/empty/types.d.ts +62 -0
  264. package/dist/empty/types.d.ts.map +1 -0
  265. package/dist/fetching-overlay/index.d.ts +10 -0
  266. package/dist/fetching-overlay/index.d.ts.map +1 -0
  267. package/dist/fetching-overlay/index.js +6 -0
  268. package/dist/fetching-overlay/index.js.map +1 -0
  269. package/dist/float-input/index.d.ts +6 -0
  270. package/dist/float-input/index.d.ts.map +1 -0
  271. package/dist/float-input/index.js +6 -0
  272. package/dist/float-input/index.js.map +1 -0
  273. package/dist/float-input/types.d.ts +23 -0
  274. package/dist/float-input/types.d.ts.map +1 -0
  275. package/dist/grid/index.d.ts +6 -0
  276. package/dist/grid/index.d.ts.map +1 -0
  277. package/dist/grid/index.js +4 -0
  278. package/dist/grid/index.js.map +1 -0
  279. package/dist/grid/types.d.ts +21 -0
  280. package/dist/grid/types.d.ts.map +1 -0
  281. package/dist/hooks/index.d.ts +6 -0
  282. package/dist/hooks/index.d.ts.map +1 -0
  283. package/dist/hooks/useControllable.d.ts +6 -0
  284. package/dist/hooks/useControllable.d.ts.map +1 -0
  285. package/dist/hooks/useDebounce.d.ts +2 -0
  286. package/dist/hooks/useDebounce.d.ts.map +1 -0
  287. package/dist/hooks/useMediaQuery.d.ts +2 -0
  288. package/dist/hooks/useMediaQuery.d.ts.map +1 -0
  289. package/dist/hooks/useRipple.d.ts +29 -0
  290. package/dist/hooks/useRipple.d.ts.map +1 -0
  291. package/dist/hooks/useThrottle.d.ts +2 -0
  292. package/dist/hooks/useThrottle.d.ts.map +1 -0
  293. package/dist/image/index.d.ts +6 -0
  294. package/dist/image/index.d.ts.map +1 -0
  295. package/dist/image/index.js +4 -0
  296. package/dist/image/index.js.map +1 -0
  297. package/dist/image/types.d.ts +57 -0
  298. package/dist/image/types.d.ts.map +1 -0
  299. package/dist/index.d.ts +142 -0
  300. package/dist/index.d.ts.map +1 -0
  301. package/dist/index.js +133 -0
  302. package/dist/index.js.map +1 -0
  303. package/dist/input/index.d.ts +6 -0
  304. package/dist/input/index.d.ts.map +1 -0
  305. package/dist/input/index.js +6 -0
  306. package/dist/input/index.js.map +1 -0
  307. package/dist/input/types.d.ts +28 -0
  308. package/dist/input/types.d.ts.map +1 -0
  309. package/dist/input-group/index.d.ts +9 -0
  310. package/dist/input-group/index.d.ts.map +1 -0
  311. package/dist/input-group/index.js +4 -0
  312. package/dist/input-group/index.js.map +1 -0
  313. package/dist/input-group/types.d.ts +68 -0
  314. package/dist/input-group/types.d.ts.map +1 -0
  315. package/dist/input-otp/index.d.ts +7 -0
  316. package/dist/input-otp/index.d.ts.map +1 -0
  317. package/dist/input-otp/index.js +4 -0
  318. package/dist/input-otp/index.js.map +1 -0
  319. package/dist/input-otp/types.d.ts +111 -0
  320. package/dist/input-otp/types.d.ts.map +1 -0
  321. package/dist/input-password/index.d.ts +6 -0
  322. package/dist/input-password/index.d.ts.map +1 -0
  323. package/dist/input-password/index.js +7 -0
  324. package/dist/input-password/index.js.map +1 -0
  325. package/dist/input-password/types.d.ts +16 -0
  326. package/dist/input-password/types.d.ts.map +1 -0
  327. package/dist/kbd/index.d.ts +6 -0
  328. package/dist/kbd/index.d.ts.map +1 -0
  329. package/dist/kbd/index.js +5 -0
  330. package/dist/kbd/index.js.map +1 -0
  331. package/dist/kbd/types.d.ts +26 -0
  332. package/dist/kbd/types.d.ts.map +1 -0
  333. package/dist/link/index.d.ts +9 -0
  334. package/dist/link/index.d.ts.map +1 -0
  335. package/dist/link/index.js +4 -0
  336. package/dist/link/index.js.map +1 -0
  337. package/dist/link/types.d.ts +30 -0
  338. package/dist/link/types.d.ts.map +1 -0
  339. package/dist/menubar/index.d.ts +6 -0
  340. package/dist/menubar/index.d.ts.map +1 -0
  341. package/dist/menubar/index.js +6 -0
  342. package/dist/menubar/index.js.map +1 -0
  343. package/dist/menubar/types.d.ts +40 -0
  344. package/dist/menubar/types.d.ts.map +1 -0
  345. package/dist/modal/index.d.ts +39 -0
  346. package/dist/modal/index.d.ts.map +1 -0
  347. package/dist/modal/index.js +4 -0
  348. package/dist/modal/index.js.map +1 -0
  349. package/dist/modal/types.d.ts +77 -0
  350. package/dist/modal/types.d.ts.map +1 -0
  351. package/dist/multi-select/index.d.ts +6 -0
  352. package/dist/multi-select/index.d.ts.map +1 -0
  353. package/dist/multi-select/index.js +8 -0
  354. package/dist/multi-select/index.js.map +1 -0
  355. package/dist/multi-select/types.d.ts +81 -0
  356. package/dist/multi-select/types.d.ts.map +1 -0
  357. package/dist/multi-select/utils.d.ts +12 -0
  358. package/dist/multi-select/utils.d.ts.map +1 -0
  359. package/dist/navigation-menu/index.d.ts +5 -0
  360. package/dist/navigation-menu/index.d.ts.map +1 -0
  361. package/dist/navigation-menu/index.js +4 -0
  362. package/dist/navigation-menu/index.js.map +1 -0
  363. package/dist/navigation-menu/types.d.ts +37 -0
  364. package/dist/navigation-menu/types.d.ts.map +1 -0
  365. package/dist/notification/index.d.ts +6 -0
  366. package/dist/notification/index.d.ts.map +1 -0
  367. package/dist/notification/index.js +5 -0
  368. package/dist/notification/index.js.map +1 -0
  369. package/dist/notification/types.d.ts +90 -0
  370. package/dist/notification/types.d.ts.map +1 -0
  371. package/dist/number-input/index.d.ts +6 -0
  372. package/dist/number-input/index.d.ts.map +1 -0
  373. package/dist/number-input/index.js +7 -0
  374. package/dist/number-input/index.js.map +1 -0
  375. package/dist/number-input/types.d.ts +28 -0
  376. package/dist/number-input/types.d.ts.map +1 -0
  377. package/dist/pagination/index.d.ts +6 -0
  378. package/dist/pagination/index.d.ts.map +1 -0
  379. package/dist/pagination/index.js +5 -0
  380. package/dist/pagination/index.js.map +1 -0
  381. package/dist/pagination/types.d.ts +87 -0
  382. package/dist/pagination/types.d.ts.map +1 -0
  383. package/dist/popover/index.d.ts +19 -0
  384. package/dist/popover/index.d.ts.map +1 -0
  385. package/dist/popover/index.js +5 -0
  386. package/dist/popover/index.js.map +1 -0
  387. package/dist/popover/types.d.ts +31 -0
  388. package/dist/popover/types.d.ts.map +1 -0
  389. package/dist/progress/index.d.ts +6 -0
  390. package/dist/progress/index.d.ts.map +1 -0
  391. package/dist/progress/index.js +4 -0
  392. package/dist/progress/index.js.map +1 -0
  393. package/dist/progress/styles.d.ts +39 -0
  394. package/dist/progress/styles.d.ts.map +1 -0
  395. package/dist/progress/types.d.ts +100 -0
  396. package/dist/progress/types.d.ts.map +1 -0
  397. package/dist/radio/index.d.ts +6 -0
  398. package/dist/radio/index.d.ts.map +1 -0
  399. package/dist/radio/index.js +5 -0
  400. package/dist/radio/index.js.map +1 -0
  401. package/dist/radio/types.d.ts +20 -0
  402. package/dist/radio/types.d.ts.map +1 -0
  403. package/dist/radio-group/index.d.ts +6 -0
  404. package/dist/radio-group/index.d.ts.map +1 -0
  405. package/dist/radio-group/index.js +4 -0
  406. package/dist/radio-group/index.js.map +1 -0
  407. package/dist/radio-group/types.d.ts +43 -0
  408. package/dist/radio-group/types.d.ts.map +1 -0
  409. package/dist/rating/index.d.ts +6 -0
  410. package/dist/rating/index.d.ts.map +1 -0
  411. package/dist/rating/index.js +4 -0
  412. package/dist/rating/index.js.map +1 -0
  413. package/dist/rating/types.d.ts +64 -0
  414. package/dist/rating/types.d.ts.map +1 -0
  415. package/dist/scroll-area/index.d.ts +10 -0
  416. package/dist/scroll-area/index.d.ts.map +1 -0
  417. package/dist/scroll-area/index.js +4 -0
  418. package/dist/scroll-area/index.js.map +1 -0
  419. package/dist/scroll-area/types.d.ts +24 -0
  420. package/dist/scroll-area/types.d.ts.map +1 -0
  421. package/dist/select/index.d.ts +6 -0
  422. package/dist/select/index.d.ts.map +1 -0
  423. package/dist/select/index.js +8 -0
  424. package/dist/select/index.js.map +1 -0
  425. package/dist/select/types.d.ts +34 -0
  426. package/dist/select/types.d.ts.map +1 -0
  427. package/dist/shared/useSelectBase.d.ts +56 -0
  428. package/dist/shared/useSelectBase.d.ts.map +1 -0
  429. package/dist/skeleton/index.d.ts +6 -0
  430. package/dist/skeleton/index.d.ts.map +1 -0
  431. package/dist/skeleton/index.js +5 -0
  432. package/dist/skeleton/index.js.map +1 -0
  433. package/dist/skeleton/types.d.ts +10 -0
  434. package/dist/skeleton/types.d.ts.map +1 -0
  435. package/dist/slider/index.d.ts +6 -0
  436. package/dist/slider/index.d.ts.map +1 -0
  437. package/dist/slider/index.js +4 -0
  438. package/dist/slider/index.js.map +1 -0
  439. package/dist/slider/types.d.ts +76 -0
  440. package/dist/slider/types.d.ts.map +1 -0
  441. package/dist/spinner/index.d.ts +6 -0
  442. package/dist/spinner/index.d.ts.map +1 -0
  443. package/dist/spinner/index.js +5 -0
  444. package/dist/spinner/index.js.map +1 -0
  445. package/dist/spinner/types.d.ts +10 -0
  446. package/dist/spinner/types.d.ts.map +1 -0
  447. package/dist/stepper/index.d.ts +6 -0
  448. package/dist/stepper/index.d.ts.map +1 -0
  449. package/dist/stepper/index.js +4 -0
  450. package/dist/stepper/index.js.map +1 -0
  451. package/dist/stepper/types.d.ts +86 -0
  452. package/dist/stepper/types.d.ts.map +1 -0
  453. package/dist/styles/themes/index.d.ts +9 -0
  454. package/dist/styles/themes/index.d.ts.map +1 -0
  455. package/dist/styles/themes/presets/index.d.ts +21 -0
  456. package/dist/styles/themes/presets/index.d.ts.map +1 -0
  457. package/dist/styles/tokens.d.ts +428 -0
  458. package/dist/styles/tokens.d.ts.map +1 -0
  459. package/dist/switch/index.d.ts +6 -0
  460. package/dist/switch/index.d.ts.map +1 -0
  461. package/dist/switch/index.js +5 -0
  462. package/dist/switch/index.js.map +1 -0
  463. package/dist/switch/types.d.ts +80 -0
  464. package/dist/switch/types.d.ts.map +1 -0
  465. package/dist/table/EditableCell.d.ts +13 -0
  466. package/dist/table/EditableCell.d.ts.map +1 -0
  467. package/dist/table/TableActions.d.ts +21 -0
  468. package/dist/table/TableActions.d.ts.map +1 -0
  469. package/dist/table/TableCell.d.ts +12 -0
  470. package/dist/table/TableCell.d.ts.map +1 -0
  471. package/dist/table/TableHeaderCell.d.ts +16 -0
  472. package/dist/table/TableHeaderCell.d.ts.map +1 -0
  473. package/dist/table/TableRow.d.ts +16 -0
  474. package/dist/table/TableRow.d.ts.map +1 -0
  475. package/dist/table/TableSkeleton.d.ts +13 -0
  476. package/dist/table/TableSkeleton.d.ts.map +1 -0
  477. package/dist/table/index.d.ts +15 -0
  478. package/dist/table/index.d.ts.map +1 -0
  479. package/dist/table/index.js +13 -0
  480. package/dist/table/index.js.map +1 -0
  481. package/dist/table/types.d.ts +110 -0
  482. package/dist/table/types.d.ts.map +1 -0
  483. package/dist/table/variants.d.ts +4 -0
  484. package/dist/table/variants.d.ts.map +1 -0
  485. package/dist/tabs/index.d.ts +7 -0
  486. package/dist/tabs/index.d.ts.map +1 -0
  487. package/dist/tabs/index.js +5 -0
  488. package/dist/tabs/index.js.map +1 -0
  489. package/dist/tabs/types.d.ts +90 -0
  490. package/dist/tabs/types.d.ts.map +1 -0
  491. package/dist/tag/index.d.ts +49 -0
  492. package/dist/tag/index.d.ts.map +1 -0
  493. package/dist/tag/index.js +5 -0
  494. package/dist/tag/index.js.map +1 -0
  495. package/dist/tag/types.d.ts +23 -0
  496. package/dist/tag/types.d.ts.map +1 -0
  497. package/dist/textarea/index.d.ts +6 -0
  498. package/dist/textarea/index.d.ts.map +1 -0
  499. package/dist/textarea/index.js +4 -0
  500. package/dist/textarea/index.js.map +1 -0
  501. package/dist/textarea/types.d.ts +84 -0
  502. package/dist/textarea/types.d.ts.map +1 -0
  503. package/dist/theme/ThemeProvider.d.ts +44 -0
  504. package/dist/theme/ThemeProvider.d.ts.map +1 -0
  505. package/dist/theme/index.d.ts +7 -0
  506. package/dist/theme/index.d.ts.map +1 -0
  507. package/dist/theme/index.js +3 -0
  508. package/dist/theme/index.js.map +1 -0
  509. package/dist/theme/types.d.ts +47 -0
  510. package/dist/theme/types.d.ts.map +1 -0
  511. package/dist/timeline/index.d.ts +6 -0
  512. package/dist/timeline/index.d.ts.map +1 -0
  513. package/dist/timeline/index.js +4 -0
  514. package/dist/timeline/index.js.map +1 -0
  515. package/dist/timeline/types.d.ts +27 -0
  516. package/dist/timeline/types.d.ts.map +1 -0
  517. package/dist/toast/index.d.ts +12 -0
  518. package/dist/toast/index.d.ts.map +1 -0
  519. package/dist/toast/index.js +5 -0
  520. package/dist/toast/index.js.map +1 -0
  521. package/dist/toast/types.d.ts +49 -0
  522. package/dist/toast/types.d.ts.map +1 -0
  523. package/dist/toggle/index.d.ts +6 -0
  524. package/dist/toggle/index.d.ts.map +1 -0
  525. package/dist/toggle/index.js +5 -0
  526. package/dist/toggle/index.js.map +1 -0
  527. package/dist/toggle/types.d.ts +57 -0
  528. package/dist/toggle/types.d.ts.map +1 -0
  529. package/dist/toggle-group/index.d.ts +6 -0
  530. package/dist/toggle-group/index.d.ts.map +1 -0
  531. package/dist/toggle-group/index.js +5 -0
  532. package/dist/toggle-group/index.js.map +1 -0
  533. package/dist/toggle-group/types.d.ts +80 -0
  534. package/dist/toggle-group/types.d.ts.map +1 -0
  535. package/dist/tooltip/index.d.ts +9 -0
  536. package/dist/tooltip/index.d.ts.map +1 -0
  537. package/dist/tooltip/index.js +5 -0
  538. package/dist/tooltip/index.js.map +1 -0
  539. package/dist/tooltip/types.d.ts +72 -0
  540. package/dist/tooltip/types.d.ts.map +1 -0
  541. package/dist/transfer/index.d.ts +5 -0
  542. package/dist/transfer/index.d.ts.map +1 -0
  543. package/dist/transfer/index.js +6 -0
  544. package/dist/transfer/index.js.map +1 -0
  545. package/dist/transfer/types.d.ts +83 -0
  546. package/dist/transfer/types.d.ts.map +1 -0
  547. package/dist/transfer/utils.d.ts +13 -0
  548. package/dist/transfer/utils.d.ts.map +1 -0
  549. package/dist/tree/index.d.ts +6 -0
  550. package/dist/tree/index.d.ts.map +1 -0
  551. package/dist/tree/index.js +4 -0
  552. package/dist/tree/index.js.map +1 -0
  553. package/dist/tree/types.d.ts +143 -0
  554. package/dist/tree/types.d.ts.map +1 -0
  555. package/dist/tree-select/index.d.ts +6 -0
  556. package/dist/tree-select/index.d.ts.map +1 -0
  557. package/dist/tree-select/index.js +7 -0
  558. package/dist/tree-select/index.js.map +1 -0
  559. package/dist/tree-select/types.d.ts +147 -0
  560. package/dist/tree-select/types.d.ts.map +1 -0
  561. package/dist/types.d.ts +53 -0
  562. package/dist/types.d.ts.map +1 -0
  563. package/dist/upload/index.d.ts +7 -0
  564. package/dist/upload/index.d.ts.map +1 -0
  565. package/dist/upload/index.js +5 -0
  566. package/dist/upload/index.js.map +1 -0
  567. package/dist/upload/types.d.ts +94 -0
  568. package/dist/upload/types.d.ts.map +1 -0
  569. package/dist/upload/utils.d.ts +26 -0
  570. package/dist/upload/utils.d.ts.map +1 -0
  571. package/dist/utils.d.ts +63 -0
  572. package/dist/utils.d.ts.map +1 -0
  573. package/dist/variants.d.ts +315 -0
  574. package/dist/variants.d.ts.map +1 -0
  575. package/package.json +1 -1
  576. package/styles/global.css +179 -245
@@ -0,0 +1,1026 @@
1
+ import { toggle_group_default } from './chunk-ERRZ2CSG.js';
2
+ import { pagination_default } from './chunk-HUXODBIO.js';
3
+ import { input_default } from './chunk-KH577UDI.js';
4
+ import { checkbox_default } from './chunk-I32ZQUYY.js';
5
+ import { Popover, PopoverTrigger, PopoverContent } from './chunk-C5IGZLIT.js';
6
+ import { button_default } from './chunk-RFHTC6AH.js';
7
+ import { iconSizes, cn } from './chunk-NGYLRX6F.js';
8
+ import { useReactTable, getGroupedRowModel, getExpandedRowModel, getPaginationRowModel, getFilteredRowModel, getSortedRowModel, getCoreRowModel, flexRender } from '@tanstack/react-table';
9
+ import { useVirtualizer } from '@tanstack/react-virtual';
10
+ import { ChevronDown, ChevronRight, PinOff, Pin, Search, Columns3, ChevronsUpDown, Inbox } from 'lucide-react';
11
+ import React, { useState, useRef, useMemo, useEffect } from 'react';
12
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
13
+ import { cva } from 'class-variance-authority';
14
+
15
+ function EditableCell({
16
+ value,
17
+ onValueChange,
18
+ size = "md",
19
+ className
20
+ }) {
21
+ const [isEditing, setIsEditing] = useState(false);
22
+ const [editValue, setEditValue] = useState(String(value ?? ""));
23
+ const inputRef = useRef(null);
24
+ const containerRef = useRef(null);
25
+ useEffect(() => {
26
+ if (isEditing && inputRef.current) {
27
+ inputRef.current.focus();
28
+ inputRef.current.select();
29
+ }
30
+ }, [isEditing]);
31
+ useEffect(() => {
32
+ setEditValue(String(value ?? ""));
33
+ }, [value]);
34
+ const handleSave = () => {
35
+ setIsEditing(false);
36
+ if (editValue !== String(value ?? "")) {
37
+ onValueChange(editValue);
38
+ }
39
+ };
40
+ const handleKeyDown = (e) => {
41
+ if (e.key === "Enter") {
42
+ handleSave();
43
+ } else if (e.key === "Escape") {
44
+ setEditValue(String(value ?? ""));
45
+ setIsEditing(false);
46
+ }
47
+ };
48
+ const sizeClasses = {
49
+ xs: "text-xs py-0.5",
50
+ sm: "text-sm py-1",
51
+ md: "text-base py-1.5",
52
+ lg: "text-lg py-2"
53
+ };
54
+ const inputSizeMap = {
55
+ xs: "sm",
56
+ sm: "sm",
57
+ md: "md",
58
+ lg: "lg"
59
+ };
60
+ return /* @__PURE__ */ jsx(
61
+ "div",
62
+ {
63
+ ref: containerRef,
64
+ className: cn("table_editableCell relative w-full max-w-full overflow-hidden", className),
65
+ children: isEditing ? /* @__PURE__ */ jsx("div", { className: "w-full", children: /* @__PURE__ */ jsx(
66
+ input_default,
67
+ {
68
+ ref: inputRef,
69
+ type: "text",
70
+ value: editValue,
71
+ onChange: (e) => setEditValue(e.target.value),
72
+ onBlur: handleSave,
73
+ onKeyDown: handleKeyDown,
74
+ size: inputSizeMap[size],
75
+ className: "w-full min-w-0 max-w-full"
76
+ }
77
+ ) }) : /* @__PURE__ */ jsx(
78
+ "div",
79
+ {
80
+ onClick: () => setIsEditing(true),
81
+ className: cn(
82
+ "cursor-text hover:bg-surface/50 rounded transition-colors min-h-[20px] px-3 w-full overflow-hidden text-ellipsis whitespace-nowrap",
83
+ sizeClasses[size]
84
+ ),
85
+ title: "Click to edit",
86
+ children: String(value ?? "")
87
+ }
88
+ )
89
+ }
90
+ );
91
+ }
92
+ EditableCell.displayName = "EditableCell";
93
+ function TableActions({
94
+ searchValue,
95
+ onSearchChange,
96
+ visibleColumns,
97
+ allColumns,
98
+ onVisibleColumnsChange,
99
+ size,
100
+ onSizeChange,
101
+ color = "default",
102
+ className
103
+ }) {
104
+ const handleColumnToggle = (columnId) => {
105
+ if (visibleColumns.includes(columnId)) {
106
+ onVisibleColumnsChange(visibleColumns.filter((id) => id !== columnId));
107
+ } else {
108
+ onVisibleColumnsChange([...visibleColumns, columnId]);
109
+ }
110
+ };
111
+ const sizeOptions = [
112
+ { value: "sm", label: "SM" },
113
+ { value: "md", label: "MD" },
114
+ { value: "lg", label: "LG" }
115
+ ];
116
+ return /* @__PURE__ */ jsxs("div", { className: cn("table_actions flex flex-wrap items-center gap-4 rounded-md", className), children: [
117
+ /* @__PURE__ */ jsx("div", { className: "w-auto mr-auto", children: /* @__PURE__ */ jsx(
118
+ input_default,
119
+ {
120
+ type: "text",
121
+ placeholder: "Search...",
122
+ value: searchValue,
123
+ onChange: (e) => onSearchChange(e.target.value),
124
+ size: "sm",
125
+ rightIcon: /* @__PURE__ */ jsx(Search, { className: iconSizes[size] })
126
+ }
127
+ ) }),
128
+ /* @__PURE__ */ jsxs(Popover, { children: [
129
+ /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
130
+ button_default,
131
+ {
132
+ variant: "outline",
133
+ size: "sm",
134
+ leftIcon: /* @__PURE__ */ jsx(Columns3, { className: iconSizes[size] }),
135
+ children: "Columns"
136
+ }
137
+ ) }),
138
+ /* @__PURE__ */ jsx(PopoverContent, { className: "w-56 p-2", children: /* @__PURE__ */ jsx("div", { className: "space-y-1 max-h-[300px] overflow-y-auto", children: allColumns.map((col) => /* @__PURE__ */ jsxs(
139
+ "label",
140
+ {
141
+ className: "flex items-center gap-2 px-3 py-2 hover:bg-surface rounded cursor-pointer",
142
+ children: [
143
+ /* @__PURE__ */ jsx(
144
+ checkbox_default,
145
+ {
146
+ checked: visibleColumns.includes(col.id),
147
+ onChange: () => handleColumnToggle(col.id),
148
+ color: color === "default" ? "primary" : color,
149
+ size: "sm"
150
+ }
151
+ ),
152
+ /* @__PURE__ */ jsx("span", { className: "text-sm text-text-primary", children: col.label })
153
+ ]
154
+ },
155
+ col.id
156
+ )) }) })
157
+ ] }),
158
+ /* @__PURE__ */ jsx(
159
+ toggle_group_default,
160
+ {
161
+ options: sizeOptions,
162
+ value: size,
163
+ onChange: (value) => onSizeChange(value),
164
+ color,
165
+ size: "sm",
166
+ variant: "default"
167
+ }
168
+ )
169
+ ] });
170
+ }
171
+ TableActions.displayName = "TableActions";
172
+ var cellVariants = cva("text-left transition-colors", {
173
+ variants: {
174
+ size: {
175
+ xs: "px-2 py-1 text-xs",
176
+ sm: "px-3 py-2 text-sm",
177
+ md: "px-4 py-3 text-base",
178
+ lg: "px-6 py-4 text-lg"
179
+ }
180
+ },
181
+ defaultVariants: {
182
+ size: "md"
183
+ }
184
+ });
185
+ var TableCell = ({
186
+ size = "md",
187
+ bordered = false,
188
+ fixed,
189
+ className,
190
+ children,
191
+ ...props
192
+ }) => {
193
+ return /* @__PURE__ */ jsx(
194
+ "td",
195
+ {
196
+ className: cn(
197
+ "table_cell",
198
+ cellVariants({ size }),
199
+ "text-text-primary",
200
+ bordered && "border-r border-border last:border-r-0",
201
+ fixed === "left" && "sticky left-0 bg-background z-10",
202
+ fixed === "right" && "sticky right-0 bg-background z-10",
203
+ className
204
+ ),
205
+ ...props,
206
+ children
207
+ }
208
+ );
209
+ };
210
+ TableCell.displayName = "TableCell";
211
+ function TableHeaderCell({
212
+ header,
213
+ size = "md",
214
+ variant = "outline",
215
+ color = "default",
216
+ bordered = false,
217
+ enableColumnPinning = false,
218
+ className,
219
+ ...props
220
+ }) {
221
+ const isPinnedLeft = header.column.getIsPinned() === "left";
222
+ const isPinnedRight = header.column.getIsPinned() === "right";
223
+ const colorHoverClasses = {
224
+ default: "hover:bg-surface",
225
+ primary: "hover:bg-primary/10",
226
+ secondary: "hover:bg-secondary/10",
227
+ accent: "hover:bg-accent/10",
228
+ success: "hover:bg-success/10",
229
+ error: "hover:bg-error/10",
230
+ warning: "hover:bg-warning/10",
231
+ info: "hover:bg-info/10"
232
+ };
233
+ const colorIconClasses = {
234
+ default: "text-text-primary",
235
+ primary: "text-primary",
236
+ secondary: "text-secondary",
237
+ accent: "text-accent",
238
+ success: "text-success",
239
+ error: "text-error",
240
+ warning: "text-warning",
241
+ info: "text-info"
242
+ };
243
+ return /* @__PURE__ */ jsx(
244
+ "th",
245
+ {
246
+ className: cn(
247
+ "table_headerCell",
248
+ cellVariants({ size }),
249
+ "font-semibold text-text-primary border-b border-border relative group",
250
+ variant === "line" && "border-b-2",
251
+ bordered && "border-r border-border last:border-r-0",
252
+ header.column.getCanSort() && "cursor-pointer select-none hover:bg-background",
253
+ isPinnedLeft && "sticky left-0 bg-surface z-20",
254
+ isPinnedRight && "sticky right-0 bg-surface z-20",
255
+ className
256
+ ),
257
+ onClick: header.column.getToggleSortingHandler(),
258
+ ...props,
259
+ children: /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-between gap-2", children: [
260
+ /* @__PURE__ */ jsx("span", { className: "flex-1", children: header.isPlaceholder ? null : typeof header.column.columnDef.header === "function" ? header.column.columnDef.header(header.getContext()) : header.column.columnDef.header }),
261
+ /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1", children: [
262
+ header.column.getCanSort() && /* @__PURE__ */ jsx(
263
+ "button",
264
+ {
265
+ type: "button",
266
+ onClick: (e) => {
267
+ e.stopPropagation();
268
+ header.column.toggleSorting();
269
+ },
270
+ className: cn(
271
+ "p-1 rounded transition-[colors,opacity]",
272
+ header.column.getIsSorted() ? `opacity-100 ${colorHoverClasses[color]}` : `opacity-0 group-hover:opacity-100 ${colorHoverClasses[color]}`,
273
+ header.column.getIsSorted() && colorIconClasses[color]
274
+ ),
275
+ children: header.column.getIsSorted() === "asc" ? /* @__PURE__ */ jsx(ChevronDown, { className: "w-3.5 h-3.5 rotate-180" }) : header.column.getIsSorted() === "desc" ? /* @__PURE__ */ jsx(ChevronDown, { className: "w-3.5 h-3.5" }) : /* @__PURE__ */ jsx(ChevronsUpDown, { className: "w-3.5 h-3.5" })
276
+ }
277
+ ),
278
+ enableColumnPinning && header.column.getCanPin() && /* @__PURE__ */ jsx(
279
+ "button",
280
+ {
281
+ type: "button",
282
+ onClick: (e) => {
283
+ e.stopPropagation();
284
+ const isPinned = header.column.getIsPinned();
285
+ if (isPinned) {
286
+ header.column.pin(false);
287
+ } else {
288
+ header.column.pin("left");
289
+ }
290
+ },
291
+ className: cn(
292
+ "p-1 rounded transition-[colors,opacity]",
293
+ isPinnedLeft || isPinnedRight ? `opacity-100 ${colorHoverClasses[color]} ${colorIconClasses[color]}` : `opacity-0 group-hover:opacity-100 ${colorHoverClasses[color]}`
294
+ ),
295
+ children: isPinnedLeft || isPinnedRight ? /* @__PURE__ */ jsx(PinOff, { className: "w-3.5 h-3.5" }) : /* @__PURE__ */ jsx(Pin, { className: "w-3.5 h-3.5" })
296
+ }
297
+ )
298
+ ] })
299
+ ] })
300
+ }
301
+ );
302
+ }
303
+ TableHeaderCell.displayName = "TableHeaderCell";
304
+ function TableRow({
305
+ row,
306
+ index,
307
+ striped = false,
308
+ hoverable = true,
309
+ onRowClick,
310
+ isPinned = false,
311
+ isExpanded = false,
312
+ className,
313
+ children,
314
+ ...props
315
+ }) {
316
+ const handleKeyDown = (e) => {
317
+ if (onRowClick && (e.key === "Enter" || e.key === " ")) {
318
+ e.preventDefault();
319
+ onRowClick(row.original);
320
+ }
321
+ };
322
+ return /* @__PURE__ */ jsx(
323
+ "tr",
324
+ {
325
+ className: cn(
326
+ "table_row border-b border-border last:border-b-0 transition-colors duration-150",
327
+ striped && index % 2 === 1 && "bg-surface/50",
328
+ hoverable && "hover:bg-surface cursor-pointer",
329
+ onRowClick && "cursor-pointer focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary",
330
+ isPinned && "bg-primary/5 border-primary/20",
331
+ row.getIsSelected() && "bg-primary/10",
332
+ className
333
+ ),
334
+ onClick: () => onRowClick?.(row.original),
335
+ onKeyDown: handleKeyDown,
336
+ tabIndex: onRowClick ? 0 : void 0,
337
+ role: onRowClick ? "button" : void 0,
338
+ ...props,
339
+ children
340
+ }
341
+ );
342
+ }
343
+ TableRow.displayName = "TableRow";
344
+ var TableSkeleton = ({
345
+ rows = 5,
346
+ columns,
347
+ size = "md",
348
+ className
349
+ }) => {
350
+ return /* @__PURE__ */ jsx(Fragment, { children: Array.from({ length: rows }).map((_, rowIndex) => /* @__PURE__ */ jsx(
351
+ "tr",
352
+ {
353
+ className: cn("table_skeleton border-b border-border", className),
354
+ children: Array.from({ length: columns }).map((_2, colIndex) => /* @__PURE__ */ jsx(
355
+ "td",
356
+ {
357
+ className: cn(cellVariants({ size })),
358
+ children: /* @__PURE__ */ jsx("div", { className: "animate-pulse", children: /* @__PURE__ */ jsx("div", { className: "h-4 bg-surface rounded w-full" }) })
359
+ },
360
+ colIndex
361
+ ))
362
+ },
363
+ rowIndex
364
+ )) });
365
+ };
366
+ TableSkeleton.displayName = "TableSkeleton";
367
+ function TableComponent({
368
+ data,
369
+ columns,
370
+ columnGroups,
371
+ caption,
372
+ showCaption = false,
373
+ "aria-label": ariaLabel,
374
+ variant = "outline",
375
+ size: initialSize = "md",
376
+ color = "default",
377
+ striped = false,
378
+ hoverable = true,
379
+ bordered = false,
380
+ enableSorting = true,
381
+ enableFiltering = false,
382
+ enablePagination = false,
383
+ enableRowSelection = false,
384
+ enableMultiRowSelection = true,
385
+ enableRowPinning = false,
386
+ enableExpandable = false,
387
+ enableGrouping = false,
388
+ enableVirtualization = false,
389
+ enableClickToSelect = false,
390
+ enableColumnPinning = false,
391
+ enableActions = false,
392
+ paginationPosition = "bottomcenter",
393
+ expandedContent,
394
+ footer,
395
+ emptyState,
396
+ loading = false,
397
+ loadingRows = 5,
398
+ pageSize = 10,
399
+ pageSizeOptions = [5, 10, 20, 50],
400
+ onRowClick,
401
+ onSelectionChange,
402
+ onCellEdit,
403
+ pinnedRowIds = [],
404
+ onPinnedRowsChange,
405
+ className,
406
+ classNames
407
+ }) {
408
+ const [sorting, setSorting] = useState([]);
409
+ const [columnFilters, setColumnFilters] = useState([]);
410
+ const [rowSelection, setRowSelection] = useState({});
411
+ const [expanded, setExpanded] = useState({});
412
+ const [grouping, setGrouping] = useState([]);
413
+ const [pinnedRows, setPinnedRows] = useState(pinnedRowIds);
414
+ const [columnPinning, setColumnPinning] = useState({
415
+ left: [],
416
+ right: []
417
+ });
418
+ const [columnVisibility, setColumnVisibility] = useState({});
419
+ const [searchValue, setSearchValue] = useState("");
420
+ const [size, setSize] = useState(initialSize);
421
+ const tableContainerRef = useRef(null);
422
+ const prevAutoPinnedIdsRef = useRef("");
423
+ const autoPinnedIds = useMemo(() => {
424
+ if (!enableRowPinning || data.length === 0) return [];
425
+ return data.map((row, index) => ({ row, id: String(index) })).filter(({ row }) => row.pin === true).map(({ id }) => id);
426
+ }, [data, enableRowPinning]);
427
+ useEffect(() => {
428
+ if (autoPinnedIds.length > 0) {
429
+ const combinedPinnedIds = [
430
+ .../* @__PURE__ */ new Set([...pinnedRowIds, ...autoPinnedIds])
431
+ ];
432
+ const autoPinnedIdsStr = autoPinnedIds.sort().join(",");
433
+ if (autoPinnedIdsStr !== prevAutoPinnedIdsRef.current) {
434
+ prevAutoPinnedIdsRef.current = autoPinnedIdsStr;
435
+ setPinnedRows(combinedPinnedIds);
436
+ }
437
+ }
438
+ }, [autoPinnedIds, pinnedRowIds]);
439
+ useEffect(() => {
440
+ if (enableColumnPinning && columns.length > 0) {
441
+ const leftPinned = columns.filter((col) => col.pin === "left").map(
442
+ (col) => col.id || col.accessorKey
443
+ );
444
+ const rightPinned = columns.filter((col) => col.pin === "right").map(
445
+ (col) => col.id || col.accessorKey
446
+ );
447
+ if (leftPinned.length > 0 || rightPinned.length > 0) {
448
+ setColumnPinning({
449
+ left: leftPinned,
450
+ right: rightPinned
451
+ });
452
+ }
453
+ }
454
+ }, [columns, enableColumnPinning]);
455
+ const enhancedColumns = useMemo(
456
+ () => enableRowSelection ? [
457
+ {
458
+ id: "select",
459
+ header: ({ table: table2 }) => enableMultiRowSelection ? /* @__PURE__ */ jsx(
460
+ checkbox_default,
461
+ {
462
+ checked: table2.getIsAllRowsSelected(),
463
+ indeterminate: table2.getIsSomeRowsSelected(),
464
+ onChange: table2.getToggleAllRowsSelectedHandler(),
465
+ size: "sm"
466
+ }
467
+ ) : null,
468
+ cell: ({ row }) => /* @__PURE__ */ jsx(
469
+ checkbox_default,
470
+ {
471
+ checked: row.getIsSelected(),
472
+ disabled: !row.getCanSelect(),
473
+ onChange: row.getToggleSelectedHandler(),
474
+ size: "sm"
475
+ }
476
+ ),
477
+ size: 50
478
+ },
479
+ ...columns
480
+ ] : columns,
481
+ [columns, enableRowSelection, enableMultiRowSelection]
482
+ );
483
+ const finalColumns = useMemo(
484
+ () => enableExpandable ? [
485
+ {
486
+ id: "expand",
487
+ header: () => null,
488
+ cell: ({ row }) => /* @__PURE__ */ jsx(
489
+ "button",
490
+ {
491
+ onClick: (e) => {
492
+ e.stopPropagation();
493
+ row.toggleExpanded();
494
+ },
495
+ className: "text-text-secondary hover:text-text-primary transition-colors",
496
+ "aria-label": row.getIsExpanded() ? "Collapse row" : "Expand row",
497
+ "aria-expanded": row.getIsExpanded(),
498
+ children: row.getIsExpanded() ? /* @__PURE__ */ jsx(
499
+ ChevronDown,
500
+ {
501
+ className: iconSizes[size],
502
+ "aria-hidden": "true"
503
+ }
504
+ ) : /* @__PURE__ */ jsx(
505
+ ChevronRight,
506
+ {
507
+ className: iconSizes[size],
508
+ "aria-hidden": "true"
509
+ }
510
+ )
511
+ }
512
+ ),
513
+ size: 50
514
+ },
515
+ ...enhancedColumns
516
+ ] : enhancedColumns,
517
+ [enhancedColumns, enableExpandable, size]
518
+ );
519
+ const columnsWithPinning = useMemo(
520
+ () => enableRowPinning ? [
521
+ ...finalColumns,
522
+ {
523
+ id: "pin",
524
+ header: () => /* @__PURE__ */ jsx(Pin, { className: "w-4 h-4 text-text-secondary" }),
525
+ cell: ({ row }) => {
526
+ const rowId = row.id;
527
+ const isPinned = pinnedRows.includes(rowId);
528
+ return /* @__PURE__ */ jsx(
529
+ "button",
530
+ {
531
+ onClick: (e) => {
532
+ e.stopPropagation();
533
+ const newPinnedRows = isPinned ? pinnedRows.filter((id) => id !== rowId) : [...pinnedRows, rowId];
534
+ setPinnedRows(newPinnedRows);
535
+ onPinnedRowsChange?.(newPinnedRows);
536
+ },
537
+ className: cn(
538
+ "text-text-secondary hover:text-text-primary transition-colors",
539
+ isPinned && "text-primary"
540
+ ),
541
+ "aria-label": isPinned ? "Unpin row" : "Pin row",
542
+ "aria-pressed": isPinned,
543
+ children: isPinned ? /* @__PURE__ */ jsx(
544
+ PinOff,
545
+ {
546
+ className: iconSizes[size],
547
+ "aria-hidden": "true"
548
+ }
549
+ ) : /* @__PURE__ */ jsx(
550
+ Pin,
551
+ {
552
+ className: iconSizes[size],
553
+ "aria-hidden": "true"
554
+ }
555
+ )
556
+ }
557
+ );
558
+ },
559
+ size: 50
560
+ }
561
+ ] : finalColumns,
562
+ [finalColumns, enableRowPinning, pinnedRows, onPinnedRowsChange, size]
563
+ );
564
+ const columnsWithEditable = useMemo(
565
+ () => columnsWithPinning.map((col) => {
566
+ const colAny = col;
567
+ if (colAny.editable && onCellEdit) {
568
+ return {
569
+ ...col,
570
+ cell: ({ row, getValue }) => {
571
+ const value = getValue?.() ?? row.original[colAny.accessorKey];
572
+ return /* @__PURE__ */ jsx(
573
+ EditableCell,
574
+ {
575
+ value,
576
+ size,
577
+ onValueChange: (newValue) => {
578
+ onCellEdit({
579
+ rowIndex: row.index,
580
+ columnId: colAny.id || colAny.accessorKey,
581
+ value: newValue,
582
+ row: row.original
583
+ });
584
+ }
585
+ }
586
+ );
587
+ }
588
+ };
589
+ }
590
+ return col;
591
+ }),
592
+ [columnsWithPinning, onCellEdit, size]
593
+ );
594
+ const filteredData = useMemo(() => {
595
+ if (!enableActions || !searchValue.trim()) {
596
+ return data;
597
+ }
598
+ const searchLower = searchValue.toLowerCase();
599
+ return data.filter((row) => {
600
+ return Object.values(row).some(
601
+ (value) => String(value).toLowerCase().includes(searchLower)
602
+ );
603
+ });
604
+ }, [data, searchValue, enableActions]);
605
+ const allColumnsList = useMemo(() => {
606
+ return columns.map((col) => {
607
+ const colAny = col;
608
+ return {
609
+ id: col.id || colAny.accessorKey,
610
+ label: typeof colAny.header === "string" ? colAny.header : col.id || colAny.accessorKey
611
+ };
612
+ });
613
+ }, [columns]);
614
+ const visibleColumnIds = useMemo(() => {
615
+ return Object.keys(columnVisibility).length === 0 ? allColumnsList.map((c) => c.id) : allColumnsList.filter((c) => columnVisibility[c.id] !== false).map((c) => c.id);
616
+ }, [columnVisibility, allColumnsList]);
617
+ const table = useReactTable({
618
+ data: filteredData,
619
+ columns: columnsWithEditable,
620
+ getCoreRowModel: getCoreRowModel(),
621
+ getSortedRowModel: enableSorting ? getSortedRowModel() : void 0,
622
+ getFilteredRowModel: enableFiltering ? getFilteredRowModel() : void 0,
623
+ getPaginationRowModel: enablePagination && !enableVirtualization ? getPaginationRowModel() : void 0,
624
+ getExpandedRowModel: enableExpandable ? getExpandedRowModel() : void 0,
625
+ getGroupedRowModel: enableGrouping ? getGroupedRowModel() : void 0,
626
+ onSortingChange: setSorting,
627
+ onColumnFiltersChange: setColumnFilters,
628
+ onRowSelectionChange: setRowSelection,
629
+ onExpandedChange: setExpanded,
630
+ onGroupingChange: setGrouping,
631
+ onColumnPinningChange: setColumnPinning,
632
+ onColumnVisibilityChange: setColumnVisibility,
633
+ enableRowSelection,
634
+ enableMultiRowSelection,
635
+ enableGrouping,
636
+ enableColumnPinning,
637
+ getRowCanExpand: enableExpandable ? () => true : void 0,
638
+ state: {
639
+ sorting,
640
+ columnFilters,
641
+ rowSelection,
642
+ expanded,
643
+ grouping,
644
+ columnPinning,
645
+ columnVisibility
646
+ },
647
+ initialState: {
648
+ pagination: {
649
+ pageSize
650
+ }
651
+ }
652
+ });
653
+ useEffect(() => {
654
+ if (onSelectionChange) {
655
+ const selectedRows = table.getSelectedRowModel().rows.map((row) => row.original);
656
+ onSelectionChange(selectedRows);
657
+ }
658
+ }, [rowSelection, onSelectionChange]);
659
+ const rows = table.getRowModel().rows;
660
+ const allRowsOrdered = useMemo(() => {
661
+ const pinned = rows.filter((row) => pinnedRows.includes(row.id));
662
+ const unpinned = rows.filter((row) => !pinnedRows.includes(row.id));
663
+ return [...pinned, ...unpinned];
664
+ }, [rows, pinnedRows]);
665
+ const rowVirtualizer = useVirtualizer({
666
+ count: allRowsOrdered.length,
667
+ getScrollElement: () => tableContainerRef.current,
668
+ estimateSize: () => size === "sm" ? 44 : size === "lg" ? 68 : 56,
669
+ overscan: 5,
670
+ enabled: enableVirtualization
671
+ });
672
+ const handleRowClick = (row, rowData) => {
673
+ if (enableClickToSelect && enableRowSelection) {
674
+ row.toggleSelected();
675
+ }
676
+ onRowClick?.(rowData);
677
+ };
678
+ const renderColumnGroups = () => {
679
+ if (!columnGroups || columnGroups.length === 0) return null;
680
+ const headerGroups = table.getHeaderGroups()[0];
681
+ if (!headerGroups) return null;
682
+ const groupedHeaders = [];
683
+ const processedCols = /* @__PURE__ */ new Set();
684
+ headerGroups.headers.forEach((header, index) => {
685
+ const colId = header.column.id;
686
+ if (processedCols.has(colId)) return;
687
+ const group = columnGroups.find((g) => g.columns.includes(colId));
688
+ if (group) {
689
+ group.columns.forEach((c) => processedCols.add(c));
690
+ groupedHeaders.push({
691
+ header: group.header,
692
+ span: group.columns.length,
693
+ startIndex: index
694
+ });
695
+ } else {
696
+ groupedHeaders.push({
697
+ header: "",
698
+ span: 1,
699
+ startIndex: index
700
+ });
701
+ }
702
+ });
703
+ return /* @__PURE__ */ jsx("tr", { className: "border-b border-border", children: groupedHeaders.map((group, idx) => /* @__PURE__ */ jsx(
704
+ "th",
705
+ {
706
+ colSpan: group.span,
707
+ className: cn(
708
+ cellVariants({ size }),
709
+ "font-bold text-text-primary bg-surface/70 border-border text-center",
710
+ bordered && "border-r border-border last:border-r-0"
711
+ ),
712
+ children: group.header
713
+ },
714
+ idx
715
+ )) });
716
+ };
717
+ const renderRows = () => {
718
+ if (loading) {
719
+ return /* @__PURE__ */ jsx(
720
+ TableSkeleton,
721
+ {
722
+ rows: loadingRows,
723
+ columns: columnsWithPinning.length,
724
+ size,
725
+ className: classNames?.skeleton
726
+ }
727
+ );
728
+ }
729
+ if (allRowsOrdered.length === 0) {
730
+ return /* @__PURE__ */ jsx("tr", { className: "table_empty", children: /* @__PURE__ */ jsx(
731
+ "td",
732
+ {
733
+ colSpan: columnsWithPinning.length,
734
+ className: cn("px-4 py-12 text-center", classNames?.empty),
735
+ children: emptyState || /* @__PURE__ */ jsxs("div", { className: "flex flex-col items-center justify-center gap-2 text-text-secondary", children: [
736
+ /* @__PURE__ */ jsx(Inbox, { className: "w-12 h-12 opacity-20" }),
737
+ /* @__PURE__ */ jsx("p", { className: "text-sm", children: "No data available" })
738
+ ] })
739
+ }
740
+ ) });
741
+ }
742
+ if (enableVirtualization) {
743
+ const virtualRows = rowVirtualizer.getVirtualItems();
744
+ const paddingTop = virtualRows.length > 0 ? virtualRows[0]?.start || 0 : 0;
745
+ const paddingBottom = virtualRows.length > 0 ? rowVirtualizer.getTotalSize() - (virtualRows[virtualRows.length - 1]?.end || 0) : 0;
746
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
747
+ paddingTop > 0 && /* @__PURE__ */ jsx("tr", { children: /* @__PURE__ */ jsx(
748
+ "td",
749
+ {
750
+ colSpan: columnsWithPinning.length,
751
+ style: { height: `${paddingTop}px`, padding: 0, border: 0 }
752
+ }
753
+ ) }),
754
+ virtualRows.map((virtualRow) => {
755
+ const row = allRowsOrdered[virtualRow.index];
756
+ if (!row) return null;
757
+ const isLastVirtualRow = virtualRow.index === allRowsOrdered.length - 1;
758
+ return /* @__PURE__ */ jsx(
759
+ TableRow,
760
+ {
761
+ row,
762
+ index: virtualRow.index,
763
+ striped,
764
+ hoverable,
765
+ onRowClick: () => handleRowClick(row, row.original),
766
+ isPinned: pinnedRows.includes(row.id),
767
+ className: cn(isLastVirtualRow && "border-b-0", classNames?.row),
768
+ children: row.getVisibleCells().map((cell) => {
769
+ const isPinnedLeft = cell.column.getIsPinned() === "left";
770
+ const isPinnedRight = cell.column.getIsPinned() === "right";
771
+ return /* @__PURE__ */ jsx(
772
+ TableCell,
773
+ {
774
+ size,
775
+ bordered,
776
+ fixed: isPinnedLeft ? "left" : isPinnedRight ? "right" : void 0,
777
+ className: classNames?.cell,
778
+ children: cell.getIsGrouped() ? /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
779
+ /* @__PURE__ */ jsx(
780
+ "button",
781
+ {
782
+ type: "button",
783
+ onClick: (e) => {
784
+ e.stopPropagation();
785
+ row.toggleExpanded();
786
+ },
787
+ className: "text-text-secondary hover:text-text-primary",
788
+ "aria-label": row.getIsExpanded() ? "Collapse group" : "Expand group",
789
+ "aria-expanded": row.getIsExpanded(),
790
+ children: row.getIsExpanded() ? /* @__PURE__ */ jsx(ChevronDown, { className: iconSizes[size], "aria-hidden": "true" }) : /* @__PURE__ */ jsx(ChevronRight, { className: iconSizes[size], "aria-hidden": "true" })
791
+ }
792
+ ),
793
+ flexRender(
794
+ cell.column.columnDef.cell,
795
+ cell.getContext()
796
+ ),
797
+ " ",
798
+ "(",
799
+ row.subRows.length,
800
+ ")"
801
+ ] }) : cell.getIsAggregated() ? flexRender(
802
+ cell.column.columnDef.aggregatedCell ?? cell.column.columnDef.cell,
803
+ cell.getContext()
804
+ ) : cell.getIsPlaceholder() ? null : flexRender(
805
+ cell.column.columnDef.cell,
806
+ cell.getContext()
807
+ )
808
+ },
809
+ cell.id
810
+ );
811
+ })
812
+ },
813
+ row.id
814
+ );
815
+ }),
816
+ paddingBottom > 0 && /* @__PURE__ */ jsx("tr", { children: /* @__PURE__ */ jsx(
817
+ "td",
818
+ {
819
+ colSpan: columnsWithPinning.length,
820
+ style: { height: `${paddingBottom}px`, padding: 0, border: 0 }
821
+ }
822
+ ) })
823
+ ] });
824
+ }
825
+ return allRowsOrdered.map((row, index) => /* @__PURE__ */ jsxs(React.Fragment, { children: [
826
+ /* @__PURE__ */ jsx(
827
+ TableRow,
828
+ {
829
+ row,
830
+ index,
831
+ striped,
832
+ hoverable,
833
+ onRowClick: () => handleRowClick(row, row.original),
834
+ isPinned: pinnedRows.includes(row.id),
835
+ className: classNames?.row,
836
+ children: row.getVisibleCells().map((cell) => {
837
+ const isPinnedLeft = cell.column.getIsPinned() === "left";
838
+ const isPinnedRight = cell.column.getIsPinned() === "right";
839
+ return /* @__PURE__ */ jsx(
840
+ TableCell,
841
+ {
842
+ size,
843
+ bordered,
844
+ fixed: isPinnedLeft ? "left" : isPinnedRight ? "right" : void 0,
845
+ className: classNames?.cell,
846
+ children: cell.getIsGrouped() ? /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-2", children: [
847
+ /* @__PURE__ */ jsx(
848
+ "button",
849
+ {
850
+ type: "button",
851
+ onClick: (e) => {
852
+ e.stopPropagation();
853
+ row.toggleExpanded();
854
+ },
855
+ className: "text-text-secondary hover:text-text-primary",
856
+ "aria-label": row.getIsExpanded() ? "Collapse group" : "Expand group",
857
+ "aria-expanded": row.getIsExpanded(),
858
+ children: row.getIsExpanded() ? /* @__PURE__ */ jsx(ChevronDown, { className: iconSizes[size], "aria-hidden": "true" }) : /* @__PURE__ */ jsx(ChevronRight, { className: iconSizes[size], "aria-hidden": "true" })
859
+ }
860
+ ),
861
+ flexRender(cell.column.columnDef.cell, cell.getContext()),
862
+ " ",
863
+ "(",
864
+ row.subRows.length,
865
+ ")"
866
+ ] }) : cell.getIsAggregated() ? flexRender(
867
+ cell.column.columnDef.aggregatedCell ?? cell.column.columnDef.cell,
868
+ cell.getContext()
869
+ ) : cell.getIsPlaceholder() ? null : flexRender(cell.column.columnDef.cell, cell.getContext())
870
+ },
871
+ cell.id
872
+ );
873
+ })
874
+ }
875
+ ),
876
+ enableExpandable && row.getIsExpanded() && expandedContent && /* @__PURE__ */ jsx("tr", { children: /* @__PURE__ */ jsx(
877
+ "td",
878
+ {
879
+ colSpan: row.getVisibleCells().length,
880
+ className: "bg-surface/30 border-b border-border p-4",
881
+ children: expandedContent(row)
882
+ }
883
+ ) })
884
+ ] }, row.id));
885
+ };
886
+ const renderPagination = () => {
887
+ if (!enablePagination || table.getPageCount() === 0 || loading || enableVirtualization) {
888
+ return null;
889
+ }
890
+ const getPaginationPositionClasses = () => {
891
+ const positionClasses = {
892
+ topleft: "justify-start",
893
+ topcenter: "w-full justify-between",
894
+ topright: "justify-end",
895
+ bottomleft: "justify-start",
896
+ bottomcenter: "w-full justify-between",
897
+ bottomright: "justify-end"
898
+ };
899
+ return positionClasses[paginationPosition];
900
+ };
901
+ return /* @__PURE__ */ jsx(
902
+ pagination_default,
903
+ {
904
+ total: table.getFilteredRowModel().rows.length,
905
+ current: table.getState().pagination.pageIndex + 1,
906
+ pageSize: table.getState().pagination.pageSize,
907
+ onChange: (page, pageSize2) => {
908
+ table.setPageIndex(page - 1);
909
+ table.setPageSize(pageSize2);
910
+ },
911
+ showSizeChanger: true,
912
+ pageSizeOptions,
913
+ showTotal: (total, range) => /* @__PURE__ */ jsxs(Fragment, { children: [
914
+ "Showing ",
915
+ range[0],
916
+ "-",
917
+ range[1],
918
+ " of ",
919
+ total,
920
+ " rows"
921
+ ] }),
922
+ color,
923
+ size: "sm",
924
+ className: cn("table_pagination flex", getPaginationPositionClasses(), classNames?.pagination)
925
+ }
926
+ );
927
+ };
928
+ const shouldShowTopPagination = paginationPosition.startsWith("top");
929
+ const shouldShowBottomPagination = paginationPosition.startsWith("bottom");
930
+ const handleVisibleColumnsChange = (newVisibleColumns) => {
931
+ const newVisibility = {};
932
+ allColumnsList.forEach((col) => {
933
+ newVisibility[col.id] = newVisibleColumns.includes(col.id);
934
+ });
935
+ setColumnVisibility(newVisibility);
936
+ };
937
+ return /* @__PURE__ */ jsxs("div", { className: cn("table_root w-full space-y-4", classNames?.root), children: [
938
+ enableActions && /* @__PURE__ */ jsx(
939
+ TableActions,
940
+ {
941
+ searchValue,
942
+ onSearchChange: setSearchValue,
943
+ visibleColumns: visibleColumnIds,
944
+ allColumns: allColumnsList,
945
+ onVisibleColumnsChange: handleVisibleColumnsChange,
946
+ size,
947
+ onSizeChange: setSize,
948
+ color,
949
+ className: classNames?.actions
950
+ }
951
+ ),
952
+ shouldShowTopPagination && renderPagination(),
953
+ /* @__PURE__ */ jsx(
954
+ "div",
955
+ {
956
+ ref: tableContainerRef,
957
+ className: cn(
958
+ "table_wrapper overflow-auto rounded-md",
959
+ enableVirtualization && "max-h-[500px]",
960
+ variant === "outline" && "border border-border",
961
+ classNames?.wrapper
962
+ ),
963
+ children: /* @__PURE__ */ jsxs(
964
+ "table",
965
+ {
966
+ className: cn(
967
+ "w-full border-collapse",
968
+ variant === "line" && "border-0",
969
+ variant === "ghost" && "border-0",
970
+ className
971
+ ),
972
+ "aria-label": ariaLabel,
973
+ children: [
974
+ caption && /* @__PURE__ */ jsx("caption", { className: cn(!showCaption && "sr-only"), children: caption }),
975
+ /* @__PURE__ */ jsxs("thead", { className: cn("table_header bg-surface sticky top-0 z-30", classNames?.header), children: [
976
+ renderColumnGroups(),
977
+ table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx("tr", { className: cn("table_headerRow", classNames?.headerRow), children: headerGroup.headers.map((header) => /* @__PURE__ */ jsx(
978
+ TableHeaderCell,
979
+ {
980
+ header,
981
+ size,
982
+ variant,
983
+ color,
984
+ bordered,
985
+ enableColumnPinning,
986
+ className: classNames?.headerCell
987
+ },
988
+ header.id
989
+ )) }, headerGroup.id))
990
+ ] }),
991
+ /* @__PURE__ */ jsx("tbody", { className: cn("table_body", classNames?.body), children: renderRows() }),
992
+ footer && /* @__PURE__ */ jsx("tfoot", { className: cn("table_footer bg-surface border-t border-border sticky bottom-0 z-30", classNames?.footer), children: table.getFooterGroups().map((footerGroup) => /* @__PURE__ */ jsx("tr", { children: footerGroup.headers.map((header) => {
993
+ const isPinnedLeft = header.column.getIsPinned() === "left";
994
+ const isPinnedRight = header.column.getIsPinned() === "right";
995
+ return /* @__PURE__ */ jsx(
996
+ "th",
997
+ {
998
+ className: cn(
999
+ "px-4 py-3 text-left font-semibold text-text-primary",
1000
+ bordered && "border-r border-border last:border-r-0",
1001
+ isPinnedLeft && "sticky left-0 bg-surface z-20",
1002
+ isPinnedRight && "sticky right-0 bg-surface z-20"
1003
+ ),
1004
+ children: header.isPlaceholder ? null : flexRender(
1005
+ header.column.columnDef.footer,
1006
+ header.getContext()
1007
+ )
1008
+ },
1009
+ header.id
1010
+ );
1011
+ }) }, footerGroup.id)) })
1012
+ ]
1013
+ }
1014
+ )
1015
+ }
1016
+ ),
1017
+ shouldShowBottomPagination && renderPagination()
1018
+ ] });
1019
+ }
1020
+ TableComponent.displayName = "Table";
1021
+ var Table = React.memo(TableComponent);
1022
+ var table_default = Table;
1023
+
1024
+ export { EditableCell, TableActions, TableCell, TableHeaderCell, TableRow, TableSkeleton, table_default };
1025
+ //# sourceMappingURL=chunk-TLNHWOQQ.js.map
1026
+ //# sourceMappingURL=chunk-TLNHWOQQ.js.map