shad-m 1.0.2 → 1.0.3

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 (613) hide show
  1. package/dist/assets/Animation/index.js +180 -0
  2. package/dist/assets/Animation/index.js.map +1 -0
  3. package/dist/assets/Animation/index.mjs +79 -0
  4. package/dist/assets/Animation/index.mjs.map +1 -0
  5. package/dist/assets/Icon/index.js +2102 -0
  6. package/dist/assets/Icon/index.js.map +1 -0
  7. package/dist/assets/Icon/index.mjs +421 -0
  8. package/dist/assets/Icon/index.mjs.map +1 -0
  9. package/dist/assets/Image/index.js +755 -0
  10. package/dist/assets/Image/index.js.map +1 -0
  11. package/dist/assets/Image/index.mjs +150 -0
  12. package/dist/assets/Image/index.mjs.map +1 -0
  13. package/dist/common/display/countdown.js +68 -0
  14. package/dist/common/display/countdown.js.map +1 -0
  15. package/dist/common/display/countdown.mjs +46 -0
  16. package/dist/common/display/countdown.mjs.map +1 -0
  17. package/dist/common/display/display-field-group.js +91 -0
  18. package/dist/common/display/display-field-group.js.map +1 -0
  19. package/dist/common/display/display-field-group.mjs +89 -0
  20. package/dist/common/display/display-field-group.mjs.map +1 -0
  21. package/dist/common/display/display-field.js +46 -0
  22. package/dist/common/display/display-field.js.map +1 -0
  23. package/dist/common/display/display-field.mjs +40 -0
  24. package/dist/common/display/display-field.mjs.map +1 -0
  25. package/dist/common/display/display-html-string.js +52 -0
  26. package/dist/common/display/display-html-string.js.map +1 -0
  27. package/dist/common/display/display-html-string.mjs +30 -0
  28. package/dist/common/display/display-html-string.mjs.map +1 -0
  29. package/dist/common/display/index.js +59 -0
  30. package/dist/common/display/index.js.map +1 -0
  31. package/dist/common/display/index.mjs +10 -0
  32. package/dist/common/display/index.mjs.map +1 -0
  33. package/dist/common/display/page-breadcrumb.js +43 -0
  34. package/dist/common/display/page-breadcrumb.js.map +1 -0
  35. package/dist/common/display/page-breadcrumb.mjs +37 -0
  36. package/dist/common/display/page-breadcrumb.mjs.map +1 -0
  37. package/dist/common/display/page-v2.js +58 -0
  38. package/dist/common/display/page-v2.js.map +1 -0
  39. package/dist/common/display/page-v2.mjs +20 -0
  40. package/dist/common/display/page-v2.mjs.map +1 -0
  41. package/dist/common/display/page.js +155 -0
  42. package/dist/common/display/page.js.map +1 -0
  43. package/dist/common/display/page.mjs +138 -0
  44. package/dist/common/display/page.mjs.map +1 -0
  45. package/dist/common/display/score-meter.js +161 -0
  46. package/dist/common/display/score-meter.js.map +1 -0
  47. package/dist/common/display/score-meter.mjs +140 -0
  48. package/dist/common/display/score-meter.mjs.map +1 -0
  49. package/dist/common/display/sidebar/app-sidebar.js +114 -0
  50. package/dist/common/display/sidebar/app-sidebar.js.map +1 -0
  51. package/dist/common/display/sidebar/app-sidebar.mjs +92 -0
  52. package/dist/common/display/sidebar/app-sidebar.mjs.map +1 -0
  53. package/dist/common/display/sidebar/index.js +89 -0
  54. package/dist/common/display/sidebar/index.js.map +1 -0
  55. package/dist/common/display/sidebar/index.mjs +81 -0
  56. package/dist/common/display/sidebar/index.mjs.map +1 -0
  57. package/dist/common/display/sidebar/nav-main.js +406 -0
  58. package/dist/common/display/sidebar/nav-main.js.map +1 -0
  59. package/dist/common/display/sidebar/nav-main.mjs +400 -0
  60. package/dist/common/display/sidebar/nav-main.mjs.map +1 -0
  61. package/dist/common/display/sidebar/sidebar-sheet.js +140 -0
  62. package/dist/common/display/sidebar/sidebar-sheet.js.map +1 -0
  63. package/dist/common/display/sidebar/sidebar-sheet.mjs +118 -0
  64. package/dist/common/display/sidebar/sidebar-sheet.mjs.map +1 -0
  65. package/dist/common/display/sidebar/types.js +4 -0
  66. package/dist/common/display/sidebar/types.js.map +1 -0
  67. package/dist/common/display/sidebar/types.mjs +3 -0
  68. package/dist/common/display/sidebar/types.mjs.map +1 -0
  69. package/dist/common/display/status-state.js +97 -0
  70. package/dist/common/display/status-state.js.map +1 -0
  71. package/dist/common/display/status-state.mjs +88 -0
  72. package/dist/common/display/status-state.mjs.map +1 -0
  73. package/dist/common/forms/auto-form.js +101 -0
  74. package/dist/common/forms/auto-form.js.map +1 -0
  75. package/dist/common/forms/auto-form.mjs +78 -0
  76. package/dist/common/forms/auto-form.mjs.map +1 -0
  77. package/dist/common/forms/form-field.js +58 -0
  78. package/dist/common/forms/form-field.js.map +1 -0
  79. package/dist/common/forms/form-field.mjs +56 -0
  80. package/dist/common/forms/form-field.mjs.map +1 -0
  81. package/dist/common/forms/form-input-field.js +64 -0
  82. package/dist/common/forms/form-input-field.js.map +1 -0
  83. package/dist/common/forms/form-input-field.mjs +62 -0
  84. package/dist/common/forms/form-input-field.mjs.map +1 -0
  85. package/dist/common/forms/index.js +22 -0
  86. package/dist/common/forms/index.js.map +1 -0
  87. package/dist/common/forms/index.mjs +5 -0
  88. package/dist/common/forms/index.mjs.map +1 -0
  89. package/dist/common/forms/switch-field.js +106 -0
  90. package/dist/common/forms/switch-field.js.map +1 -0
  91. package/dist/common/forms/switch-field.mjs +104 -0
  92. package/dist/common/forms/switch-field.mjs.map +1 -0
  93. package/dist/common/interactive/alert-dialog-wrapper.js +141 -0
  94. package/dist/common/interactive/alert-dialog-wrapper.js.map +1 -0
  95. package/dist/common/interactive/alert-dialog-wrapper.mjs +119 -0
  96. package/dist/common/interactive/alert-dialog-wrapper.mjs.map +1 -0
  97. package/dist/common/interactive/autocomplete.js +178 -0
  98. package/dist/common/interactive/autocomplete.js.map +1 -0
  99. package/dist/common/interactive/autocomplete.mjs +157 -0
  100. package/dist/common/interactive/autocomplete.mjs.map +1 -0
  101. package/dist/common/interactive/copy-tooltip.js +152 -0
  102. package/dist/common/interactive/copy-tooltip.js.map +1 -0
  103. package/dist/common/interactive/copy-tooltip.mjs +143 -0
  104. package/dist/common/interactive/copy-tooltip.mjs.map +1 -0
  105. package/dist/common/interactive/date-field.js +303 -0
  106. package/dist/common/interactive/date-field.js.map +1 -0
  107. package/dist/common/interactive/date-field.mjs +281 -0
  108. package/dist/common/interactive/date-field.mjs.map +1 -0
  109. package/dist/common/interactive/date-input/date-input.js +68 -0
  110. package/dist/common/interactive/date-input/date-input.js.map +1 -0
  111. package/dist/common/interactive/date-input/date-input.mjs +62 -0
  112. package/dist/common/interactive/date-input/date-input.mjs.map +1 -0
  113. package/dist/common/interactive/date-input/index.js +17 -0
  114. package/dist/common/interactive/date-input/index.js.map +1 -0
  115. package/dist/common/interactive/date-input/index.mjs +4 -0
  116. package/dist/common/interactive/date-input/index.mjs.map +1 -0
  117. package/dist/common/interactive/date-input/types.js +4 -0
  118. package/dist/common/interactive/date-input/types.js.map +1 -0
  119. package/dist/common/interactive/date-input/types.mjs +3 -0
  120. package/dist/common/interactive/date-input/types.mjs.map +1 -0
  121. package/dist/common/interactive/date-input/use-typed-date.js +478 -0
  122. package/dist/common/interactive/date-input/use-typed-date.js.map +1 -0
  123. package/dist/common/interactive/date-input/use-typed-date.mjs +476 -0
  124. package/dist/common/interactive/date-input/use-typed-date.mjs.map +1 -0
  125. package/dist/common/interactive/date-input/utils.js +34 -0
  126. package/dist/common/interactive/date-input/utils.js.map +1 -0
  127. package/dist/common/interactive/date-input/utils.mjs +29 -0
  128. package/dist/common/interactive/date-input/utils.mjs.map +1 -0
  129. package/dist/common/interactive/date-picker.js +616 -0
  130. package/dist/common/interactive/date-picker.js.map +1 -0
  131. package/dist/common/interactive/date-picker.mjs +594 -0
  132. package/dist/common/interactive/date-picker.mjs.map +1 -0
  133. package/dist/common/interactive/date-range-input/date-range-input.js +82 -0
  134. package/dist/common/interactive/date-range-input/date-range-input.js.map +1 -0
  135. package/dist/common/interactive/date-range-input/date-range-input.mjs +76 -0
  136. package/dist/common/interactive/date-range-input/date-range-input.mjs.map +1 -0
  137. package/dist/common/interactive/date-range-input/index.js +12 -0
  138. package/dist/common/interactive/date-range-input/index.js.map +1 -0
  139. package/dist/common/interactive/date-range-input/index.mjs +3 -0
  140. package/dist/common/interactive/date-range-input/index.mjs.map +1 -0
  141. package/dist/common/interactive/date-range-input/types.js +4 -0
  142. package/dist/common/interactive/date-range-input/types.js.map +1 -0
  143. package/dist/common/interactive/date-range-input/types.mjs +3 -0
  144. package/dist/common/interactive/date-range-input/types.mjs.map +1 -0
  145. package/dist/common/interactive/date-range-input/use-typed-date-range.js +602 -0
  146. package/dist/common/interactive/date-range-input/use-typed-date-range.js.map +1 -0
  147. package/dist/common/interactive/date-range-input/use-typed-date-range.mjs +600 -0
  148. package/dist/common/interactive/date-range-input/use-typed-date-range.mjs.map +1 -0
  149. package/dist/common/interactive/date-time-picker.js +215 -0
  150. package/dist/common/interactive/date-time-picker.js.map +1 -0
  151. package/dist/common/interactive/date-time-picker.mjs +213 -0
  152. package/dist/common/interactive/date-time-picker.mjs.map +1 -0
  153. package/dist/common/interactive/dialog-wrapper.js +124 -0
  154. package/dist/common/interactive/dialog-wrapper.js.map +1 -0
  155. package/dist/common/interactive/dialog-wrapper.mjs +102 -0
  156. package/dist/common/interactive/dialog-wrapper.mjs.map +1 -0
  157. package/dist/common/interactive/filter.js +287 -0
  158. package/dist/common/interactive/filter.js.map +1 -0
  159. package/dist/common/interactive/filter.mjs +280 -0
  160. package/dist/common/interactive/filter.mjs.map +1 -0
  161. package/dist/common/interactive/index.js +235 -0
  162. package/dist/common/interactive/index.js.map +1 -0
  163. package/dist/common/interactive/index.mjs +24 -0
  164. package/dist/common/interactive/index.mjs.map +1 -0
  165. package/dist/common/interactive/list.js +160 -0
  166. package/dist/common/interactive/list.js.map +1 -0
  167. package/dist/common/interactive/list.mjs +134 -0
  168. package/dist/common/interactive/list.mjs.map +1 -0
  169. package/dist/common/interactive/otp-dialog/index.js +35 -0
  170. package/dist/common/interactive/otp-dialog/index.js.map +1 -0
  171. package/dist/common/interactive/otp-dialog/index.mjs +6 -0
  172. package/dist/common/interactive/otp-dialog/index.mjs.map +1 -0
  173. package/dist/common/interactive/otp-dialog/otp-dialog.js +325 -0
  174. package/dist/common/interactive/otp-dialog/otp-dialog.js.map +1 -0
  175. package/dist/common/interactive/otp-dialog/otp-dialog.mjs +303 -0
  176. package/dist/common/interactive/otp-dialog/otp-dialog.mjs.map +1 -0
  177. package/dist/common/interactive/otp-dialog/reducer.js +40 -0
  178. package/dist/common/interactive/otp-dialog/reducer.js.map +1 -0
  179. package/dist/common/interactive/otp-dialog/reducer.mjs +37 -0
  180. package/dist/common/interactive/otp-dialog/reducer.mjs.map +1 -0
  181. package/dist/common/interactive/otp-dialog/types.js +15 -0
  182. package/dist/common/interactive/otp-dialog/types.js.map +1 -0
  183. package/dist/common/interactive/otp-dialog/types.mjs +13 -0
  184. package/dist/common/interactive/otp-dialog/types.mjs.map +1 -0
  185. package/dist/common/interactive/otp-dialog/utils.js +24 -0
  186. package/dist/common/interactive/otp-dialog/utils.js.map +1 -0
  187. package/dist/common/interactive/otp-dialog/utils.mjs +21 -0
  188. package/dist/common/interactive/otp-dialog/utils.mjs.map +1 -0
  189. package/dist/common/interactive/pagination/PaginationSkeleton.js +51 -0
  190. package/dist/common/interactive/pagination/PaginationSkeleton.js.map +1 -0
  191. package/dist/common/interactive/pagination/PaginationSkeleton.mjs +49 -0
  192. package/dist/common/interactive/pagination/PaginationSkeleton.mjs.map +1 -0
  193. package/dist/common/interactive/pagination/index.js +235 -0
  194. package/dist/common/interactive/pagination/index.js.map +1 -0
  195. package/dist/common/interactive/pagination/index.mjs +223 -0
  196. package/dist/common/interactive/pagination/index.mjs.map +1 -0
  197. package/dist/common/interactive/pagination/usePagination.js +28 -0
  198. package/dist/common/interactive/pagination/usePagination.js.map +1 -0
  199. package/dist/common/interactive/pagination/usePagination.mjs +25 -0
  200. package/dist/common/interactive/pagination/usePagination.mjs.map +1 -0
  201. package/dist/common/interactive/popover-wrapper.js +138 -0
  202. package/dist/common/interactive/popover-wrapper.js.map +1 -0
  203. package/dist/common/interactive/popover-wrapper.mjs +116 -0
  204. package/dist/common/interactive/popover-wrapper.mjs.map +1 -0
  205. package/dist/common/interactive/pressable.js +84 -0
  206. package/dist/common/interactive/pressable.js.map +1 -0
  207. package/dist/common/interactive/pressable.mjs +62 -0
  208. package/dist/common/interactive/pressable.mjs.map +1 -0
  209. package/dist/common/interactive/select/context.js +38 -0
  210. package/dist/common/interactive/select/context.js.map +1 -0
  211. package/dist/common/interactive/select/context.mjs +14 -0
  212. package/dist/common/interactive/select/context.mjs.map +1 -0
  213. package/dist/common/interactive/select/index.js +123 -0
  214. package/dist/common/interactive/select/index.js.map +1 -0
  215. package/dist/common/interactive/select/index.mjs +18 -0
  216. package/dist/common/interactive/select/index.mjs.map +1 -0
  217. package/dist/common/interactive/select/select-body.js +89 -0
  218. package/dist/common/interactive/select/select-body.js.map +1 -0
  219. package/dist/common/interactive/select/select-body.mjs +67 -0
  220. package/dist/common/interactive/select/select-body.mjs.map +1 -0
  221. package/dist/common/interactive/select/select-close.js +38 -0
  222. package/dist/common/interactive/select/select-close.js.map +1 -0
  223. package/dist/common/interactive/select/select-close.mjs +16 -0
  224. package/dist/common/interactive/select/select-close.mjs.map +1 -0
  225. package/dist/common/interactive/select/select-content-auto-layout.js +221 -0
  226. package/dist/common/interactive/select/select-content-auto-layout.js.map +1 -0
  227. package/dist/common/interactive/select/select-content-auto-layout.mjs +199 -0
  228. package/dist/common/interactive/select/select-content-auto-layout.mjs.map +1 -0
  229. package/dist/common/interactive/select/select-content-group-auto-layout.js +411 -0
  230. package/dist/common/interactive/select/select-content-group-auto-layout.js.map +1 -0
  231. package/dist/common/interactive/select/select-content-group-auto-layout.mjs +389 -0
  232. package/dist/common/interactive/select/select-content-group-auto-layout.mjs.map +1 -0
  233. package/dist/common/interactive/select/select-content.js +187 -0
  234. package/dist/common/interactive/select/select-content.js.map +1 -0
  235. package/dist/common/interactive/select/select-content.mjs +165 -0
  236. package/dist/common/interactive/select/select-content.mjs.map +1 -0
  237. package/dist/common/interactive/select/select-footer.js +82 -0
  238. package/dist/common/interactive/select/select-footer.js.map +1 -0
  239. package/dist/common/interactive/select/select-footer.mjs +60 -0
  240. package/dist/common/interactive/select/select-footer.mjs.map +1 -0
  241. package/dist/common/interactive/select/select-item.js +214 -0
  242. package/dist/common/interactive/select/select-item.js.map +1 -0
  243. package/dist/common/interactive/select/select-item.mjs +191 -0
  244. package/dist/common/interactive/select/select-item.mjs.map +1 -0
  245. package/dist/common/interactive/select/select-layout.js +66 -0
  246. package/dist/common/interactive/select/select-layout.js.map +1 -0
  247. package/dist/common/interactive/select/select-layout.mjs +41 -0
  248. package/dist/common/interactive/select/select-layout.mjs.map +1 -0
  249. package/dist/common/interactive/select/select-search.js +55 -0
  250. package/dist/common/interactive/select/select-search.js.map +1 -0
  251. package/dist/common/interactive/select/select-search.mjs +33 -0
  252. package/dist/common/interactive/select/select-search.mjs.map +1 -0
  253. package/dist/common/interactive/select/select-states.js +57 -0
  254. package/dist/common/interactive/select/select-states.js.map +1 -0
  255. package/dist/common/interactive/select/select-states.mjs +34 -0
  256. package/dist/common/interactive/select/select-states.mjs.map +1 -0
  257. package/dist/common/interactive/select/select-trigger.js +310 -0
  258. package/dist/common/interactive/select/select-trigger.js.map +1 -0
  259. package/dist/common/interactive/select/select-trigger.mjs +286 -0
  260. package/dist/common/interactive/select/select-trigger.mjs.map +1 -0
  261. package/dist/common/interactive/select/select-value.js +52 -0
  262. package/dist/common/interactive/select/select-value.js.map +1 -0
  263. package/dist/common/interactive/select/select-value.mjs +30 -0
  264. package/dist/common/interactive/select/select-value.mjs.map +1 -0
  265. package/dist/common/interactive/select/select.js +184 -0
  266. package/dist/common/interactive/select/select.js.map +1 -0
  267. package/dist/common/interactive/select/select.mjs +162 -0
  268. package/dist/common/interactive/select/select.mjs.map +1 -0
  269. package/dist/common/interactive/select/types.js +4 -0
  270. package/dist/common/interactive/select/types.js.map +1 -0
  271. package/dist/common/interactive/select/types.mjs +3 -0
  272. package/dist/common/interactive/select/types.mjs.map +1 -0
  273. package/dist/common/interactive/select/utils.js +31 -0
  274. package/dist/common/interactive/select/utils.js.map +1 -0
  275. package/dist/common/interactive/select/utils.mjs +28 -0
  276. package/dist/common/interactive/select/utils.mjs.map +1 -0
  277. package/dist/common/interactive/select/variants.js +27 -0
  278. package/dist/common/interactive/select/variants.js.map +1 -0
  279. package/dist/common/interactive/select/variants.mjs +25 -0
  280. package/dist/common/interactive/select/variants.mjs.map +1 -0
  281. package/dist/common/interactive/select-chip.js +76 -0
  282. package/dist/common/interactive/select-chip.js.map +1 -0
  283. package/dist/common/interactive/select-chip.mjs +74 -0
  284. package/dist/common/interactive/select-chip.mjs.map +1 -0
  285. package/dist/common/interactive/select-level.js +236 -0
  286. package/dist/common/interactive/select-level.js.map +1 -0
  287. package/dist/common/interactive/select-level.mjs +230 -0
  288. package/dist/common/interactive/select-level.mjs.map +1 -0
  289. package/dist/common/interactive/select-range.js +211 -0
  290. package/dist/common/interactive/select-range.js.map +1 -0
  291. package/dist/common/interactive/select-range.mjs +209 -0
  292. package/dist/common/interactive/select-range.mjs.map +1 -0
  293. package/dist/common/interactive/select-with-api.js +767 -0
  294. package/dist/common/interactive/select-with-api.js.map +1 -0
  295. package/dist/common/interactive/select-with-api.mjs +758 -0
  296. package/dist/common/interactive/select-with-api.mjs.map +1 -0
  297. package/dist/common/interactive/select.js +15 -0
  298. package/dist/common/interactive/select.js.map +1 -0
  299. package/dist/common/interactive/select.mjs +4 -0
  300. package/dist/common/interactive/select.mjs.map +1 -0
  301. package/dist/common/interactive/sheet-wrapper.js +105 -0
  302. package/dist/common/interactive/sheet-wrapper.js.map +1 -0
  303. package/dist/common/interactive/sheet-wrapper.mjs +83 -0
  304. package/dist/common/interactive/sheet-wrapper.mjs.map +1 -0
  305. package/dist/common/interactive/table/enhanced-table.js +390 -0
  306. package/dist/common/interactive/table/enhanced-table.js.map +1 -0
  307. package/dist/common/interactive/table/enhanced-table.mjs +388 -0
  308. package/dist/common/interactive/table/enhanced-table.mjs.map +1 -0
  309. package/dist/common/interactive/table/index.js +83 -0
  310. package/dist/common/interactive/table/index.js.map +1 -0
  311. package/dist/common/interactive/table/index.mjs +68 -0
  312. package/dist/common/interactive/table/index.mjs.map +1 -0
  313. package/dist/common/interactive/table/table-pagination.js +12 -0
  314. package/dist/common/interactive/table/table-pagination.js.map +1 -0
  315. package/dist/common/interactive/table/table-pagination.mjs +10 -0
  316. package/dist/common/interactive/table/table-pagination.mjs.map +1 -0
  317. package/dist/common/interactive/table/types.js +4 -0
  318. package/dist/common/interactive/table/types.js.map +1 -0
  319. package/dist/common/interactive/table/types.mjs +3 -0
  320. package/dist/common/interactive/table/types.mjs.map +1 -0
  321. package/dist/common/interactive/time-picker.js +313 -0
  322. package/dist/common/interactive/time-picker.js.map +1 -0
  323. package/dist/common/interactive/time-picker.mjs +307 -0
  324. package/dist/common/interactive/time-picker.mjs.map +1 -0
  325. package/dist/common/interactive/types.js +4 -0
  326. package/dist/common/interactive/types.js.map +1 -0
  327. package/dist/common/interactive/types.mjs +3 -0
  328. package/dist/common/interactive/types.mjs.map +1 -0
  329. package/dist/common/pages/page-404.js +16 -0
  330. package/dist/common/pages/page-404.js.map +1 -0
  331. package/dist/common/pages/page-404.mjs +11 -0
  332. package/dist/common/pages/page-404.mjs.map +1 -0
  333. package/dist/common/pages/page-500.js +30 -0
  334. package/dist/common/pages/page-500.js.map +1 -0
  335. package/dist/common/pages/page-500.mjs +25 -0
  336. package/dist/common/pages/page-500.mjs.map +1 -0
  337. package/dist/components/accordion.js +65 -0
  338. package/dist/components/accordion.js.map +1 -0
  339. package/dist/components/accordion.mjs +39 -0
  340. package/dist/components/accordion.mjs.map +1 -0
  341. package/dist/components/alert-dialog.js +231 -0
  342. package/dist/components/alert-dialog.js.map +1 -0
  343. package/dist/components/alert-dialog.mjs +197 -0
  344. package/dist/components/alert-dialog.mjs.map +1 -0
  345. package/dist/components/alert.js +97 -0
  346. package/dist/components/alert.js.map +1 -0
  347. package/dist/components/alert.mjs +72 -0
  348. package/dist/components/alert.mjs.map +1 -0
  349. package/dist/components/aspect-ratio.js +29 -0
  350. package/dist/components/aspect-ratio.js.map +1 -0
  351. package/dist/components/aspect-ratio.mjs +7 -0
  352. package/dist/components/aspect-ratio.mjs.map +1 -0
  353. package/dist/components/avatar.js +64 -0
  354. package/dist/components/avatar.js.map +1 -0
  355. package/dist/components/avatar.mjs +39 -0
  356. package/dist/components/avatar.mjs.map +1 -0
  357. package/dist/components/badge.js +72 -0
  358. package/dist/components/badge.js.map +1 -0
  359. package/dist/components/badge.mjs +69 -0
  360. package/dist/components/badge.mjs.map +1 -0
  361. package/dist/components/breadcrumb.js +109 -0
  362. package/dist/components/breadcrumb.js.map +1 -0
  363. package/dist/components/breadcrumb.mjs +81 -0
  364. package/dist/components/breadcrumb.mjs.map +1 -0
  365. package/dist/components/button.js +250 -0
  366. package/dist/components/button.js.map +1 -0
  367. package/dist/components/button.mjs +226 -0
  368. package/dist/components/button.mjs.map +1 -0
  369. package/dist/components/calendar.js +681 -0
  370. package/dist/components/calendar.js.map +1 -0
  371. package/dist/components/calendar.mjs +659 -0
  372. package/dist/components/calendar.mjs.map +1 -0
  373. package/dist/components/card.js +98 -0
  374. package/dist/components/card.js.map +1 -0
  375. package/dist/components/card.mjs +71 -0
  376. package/dist/components/card.mjs.map +1 -0
  377. package/dist/components/carousel.js +237 -0
  378. package/dist/components/carousel.js.map +1 -0
  379. package/dist/components/carousel.mjs +208 -0
  380. package/dist/components/carousel.mjs.map +1 -0
  381. package/dist/components/chart.js +252 -0
  382. package/dist/components/chart.js.map +1 -0
  383. package/dist/components/chart.mjs +224 -0
  384. package/dist/components/chart.mjs.map +1 -0
  385. package/dist/components/checkbox.js +97 -0
  386. package/dist/components/checkbox.js.map +1 -0
  387. package/dist/components/checkbox.mjs +74 -0
  388. package/dist/components/checkbox.mjs.map +1 -0
  389. package/dist/components/chip.js +88 -0
  390. package/dist/components/chip.js.map +1 -0
  391. package/dist/components/chip.mjs +82 -0
  392. package/dist/components/chip.mjs.map +1 -0
  393. package/dist/components/collapsible.js +33 -0
  394. package/dist/components/collapsible.js.map +1 -0
  395. package/dist/components/collapsible.mjs +9 -0
  396. package/dist/components/collapsible.mjs.map +1 -0
  397. package/dist/components/command.js +125 -0
  398. package/dist/components/command.js.map +1 -0
  399. package/dist/components/command.mjs +95 -0
  400. package/dist/components/command.mjs.map +1 -0
  401. package/dist/components/context-menu.js +168 -0
  402. package/dist/components/context-menu.js.map +1 -0
  403. package/dist/components/context-menu.mjs +131 -0
  404. package/dist/components/context-menu.mjs.map +1 -0
  405. package/dist/components/dialog.js +192 -0
  406. package/dist/components/dialog.js.map +1 -0
  407. package/dist/components/dialog.mjs +159 -0
  408. package/dist/components/dialog.mjs.map +1 -0
  409. package/dist/components/drawer.js +98 -0
  410. package/dist/components/drawer.js.map +1 -0
  411. package/dist/components/drawer.mjs +67 -0
  412. package/dist/components/drawer.mjs.map +1 -0
  413. package/dist/components/dropdown-menu.js +163 -0
  414. package/dist/components/dropdown-menu.js.map +1 -0
  415. package/dist/components/dropdown-menu.mjs +126 -0
  416. package/dist/components/dropdown-menu.mjs.map +1 -0
  417. package/dist/components/form.js +123 -0
  418. package/dist/components/form.js.map +1 -0
  419. package/dist/components/form.mjs +94 -0
  420. package/dist/components/form.mjs.map +1 -0
  421. package/dist/components/hover-card.js +50 -0
  422. package/dist/components/hover-card.js.map +1 -0
  423. package/dist/components/hover-card.mjs +25 -0
  424. package/dist/components/hover-card.mjs.map +1 -0
  425. package/dist/components/input-otp.js +84 -0
  426. package/dist/components/input-otp.js.map +1 -0
  427. package/dist/components/input-otp.mjs +59 -0
  428. package/dist/components/input-otp.mjs.map +1 -0
  429. package/dist/components/input.js +858 -0
  430. package/dist/components/input.js.map +1 -0
  431. package/dist/components/input.mjs +831 -0
  432. package/dist/components/input.mjs.map +1 -0
  433. package/dist/components/label.js +38 -0
  434. package/dist/components/label.js.map +1 -0
  435. package/dist/components/label.mjs +15 -0
  436. package/dist/components/label.mjs.map +1 -0
  437. package/dist/components/lottie.js +59 -0
  438. package/dist/components/lottie.js.map +1 -0
  439. package/dist/components/lottie.mjs +49 -0
  440. package/dist/components/lottie.mjs.map +1 -0
  441. package/dist/components/menubar.js +195 -0
  442. package/dist/components/menubar.js.map +1 -0
  443. package/dist/components/menubar.mjs +157 -0
  444. package/dist/components/menubar.mjs.map +1 -0
  445. package/dist/components/navigation-menu.js +126 -0
  446. package/dist/components/navigation-menu.js.map +1 -0
  447. package/dist/components/navigation-menu.mjs +95 -0
  448. package/dist/components/navigation-menu.mjs.map +1 -0
  449. package/dist/components/pagination.js +112 -0
  450. package/dist/components/pagination.js.map +1 -0
  451. package/dist/components/pagination.mjs +84 -0
  452. package/dist/components/pagination.mjs.map +1 -0
  453. package/dist/components/popover.js +63 -0
  454. package/dist/components/popover.js.map +1 -0
  455. package/dist/components/popover.mjs +38 -0
  456. package/dist/components/popover.mjs.map +1 -0
  457. package/dist/components/progress.js +50 -0
  458. package/dist/components/progress.js.map +1 -0
  459. package/dist/components/progress.mjs +27 -0
  460. package/dist/components/progress.mjs.map +1 -0
  461. package/dist/components/radio-group.js +91 -0
  462. package/dist/components/radio-group.js.map +1 -0
  463. package/dist/components/radio-group.mjs +67 -0
  464. package/dist/components/radio-group.mjs.map +1 -0
  465. package/dist/components/resizable.js +59 -0
  466. package/dist/components/resizable.js.map +1 -0
  467. package/dist/components/resizable.mjs +35 -0
  468. package/dist/components/resizable.mjs.map +1 -0
  469. package/dist/components/responsive-popover.js +74 -0
  470. package/dist/components/responsive-popover.js.map +1 -0
  471. package/dist/components/responsive-popover.mjs +50 -0
  472. package/dist/components/responsive-popover.mjs.map +1 -0
  473. package/dist/components/scroll-area.js +63 -0
  474. package/dist/components/scroll-area.js.map +1 -0
  475. package/dist/components/scroll-area.mjs +39 -0
  476. package/dist/components/scroll-area.mjs.map +1 -0
  477. package/dist/components/separator.js +47 -0
  478. package/dist/components/separator.js.map +1 -0
  479. package/dist/components/separator.mjs +24 -0
  480. package/dist/components/separator.mjs.map +1 -0
  481. package/dist/components/sheet.js +239 -0
  482. package/dist/components/sheet.js.map +1 -0
  483. package/dist/components/sheet.mjs +206 -0
  484. package/dist/components/sheet.mjs.map +1 -0
  485. package/dist/components/sidebar.js +888 -0
  486. package/dist/components/sidebar.js.map +1 -0
  487. package/dist/components/sidebar.mjs +842 -0
  488. package/dist/components/sidebar.mjs.map +1 -0
  489. package/dist/components/skeleton.js +153 -0
  490. package/dist/components/skeleton.js.map +1 -0
  491. package/dist/components/skeleton.mjs +127 -0
  492. package/dist/components/skeleton.mjs.map +1 -0
  493. package/dist/components/slider.js +45 -0
  494. package/dist/components/slider.js.map +1 -0
  495. package/dist/components/slider.mjs +22 -0
  496. package/dist/components/slider.mjs.map +1 -0
  497. package/dist/components/sonner.js +76 -0
  498. package/dist/components/sonner.js.map +1 -0
  499. package/dist/components/sonner.mjs +71 -0
  500. package/dist/components/sonner.mjs.map +1 -0
  501. package/dist/components/spinner.js +59 -0
  502. package/dist/components/spinner.js.map +1 -0
  503. package/dist/components/spinner.mjs +36 -0
  504. package/dist/components/spinner.mjs.map +1 -0
  505. package/dist/components/stepper.js +726 -0
  506. package/dist/components/stepper.js.map +1 -0
  507. package/dist/components/stepper.mjs +702 -0
  508. package/dist/components/stepper.mjs.map +1 -0
  509. package/dist/components/switch.js +85 -0
  510. package/dist/components/switch.js.map +1 -0
  511. package/dist/components/switch.mjs +62 -0
  512. package/dist/components/switch.mjs.map +1 -0
  513. package/dist/components/table.js +91 -0
  514. package/dist/components/table.js.map +1 -0
  515. package/dist/components/table.mjs +62 -0
  516. package/dist/components/table.mjs.map +1 -0
  517. package/dist/components/tabs.js +287 -0
  518. package/dist/components/tabs.js.map +1 -0
  519. package/dist/components/tabs.mjs +261 -0
  520. package/dist/components/tabs.mjs.map +1 -0
  521. package/dist/components/textarea.js +200 -0
  522. package/dist/components/textarea.js.map +1 -0
  523. package/dist/components/textarea.mjs +174 -0
  524. package/dist/components/textarea.mjs.map +1 -0
  525. package/dist/components/toggle-group.js +67 -0
  526. package/dist/components/toggle-group.js.map +1 -0
  527. package/dist/components/toggle-group.mjs +43 -0
  528. package/dist/components/toggle-group.mjs.map +1 -0
  529. package/dist/components/toggle.js +63 -0
  530. package/dist/components/toggle.js.map +1 -0
  531. package/dist/components/toggle.mjs +39 -0
  532. package/dist/components/toggle.mjs.map +1 -0
  533. package/dist/components/tooltip.js +172 -0
  534. package/dist/components/tooltip.js.map +1 -0
  535. package/dist/components/tooltip.mjs +145 -0
  536. package/dist/components/tooltip.mjs.map +1 -0
  537. package/dist/hooks/index.js +27 -0
  538. package/dist/hooks/index.js.map +1 -0
  539. package/dist/hooks/index.mjs +6 -0
  540. package/dist/hooks/index.mjs.map +1 -0
  541. package/dist/hooks/useCopyToClipboard.js +59 -0
  542. package/dist/hooks/useCopyToClipboard.js.map +1 -0
  543. package/dist/hooks/useCopyToClipboard.mjs +57 -0
  544. package/dist/hooks/useCopyToClipboard.mjs.map +1 -0
  545. package/dist/hooks/useDevice.js +20 -0
  546. package/dist/hooks/useDevice.js.map +1 -0
  547. package/dist/hooks/useDevice.mjs +14 -0
  548. package/dist/hooks/useDevice.mjs.map +1 -0
  549. package/dist/hooks/useDialogTracking.js +113 -0
  550. package/dist/hooks/useDialogTracking.js.map +1 -0
  551. package/dist/hooks/useDialogTracking.mjs +91 -0
  552. package/dist/hooks/useDialogTracking.mjs.map +1 -0
  553. package/dist/hooks/useIsMounted.js +15 -0
  554. package/dist/hooks/useIsMounted.js.map +1 -0
  555. package/dist/hooks/useIsMounted.mjs +13 -0
  556. package/dist/hooks/useIsMounted.mjs.map +1 -0
  557. package/dist/hooks/usePathname.js +85 -0
  558. package/dist/hooks/usePathname.js.map +1 -0
  559. package/dist/hooks/usePathname.mjs +83 -0
  560. package/dist/hooks/usePathname.mjs.map +1 -0
  561. package/dist/icons.js +14 -0
  562. package/dist/icons.js.map +1 -0
  563. package/dist/icons.mjs +3 -0
  564. package/dist/icons.mjs.map +1 -0
  565. package/dist/index.d.ts +4 -0
  566. package/dist/index.d.ts.map +1 -1
  567. package/dist/index.js +403 -8151
  568. package/dist/index.js.map +1 -1
  569. package/dist/index.mjs +62 -7844
  570. package/dist/index.mjs.map +1 -1
  571. package/dist/lib/formatCurrency.js +187 -0
  572. package/dist/lib/formatCurrency.js.map +1 -0
  573. package/dist/lib/formatCurrency.mjs +185 -0
  574. package/dist/lib/formatCurrency.mjs.map +1 -0
  575. package/dist/lib/helpers.js +171 -0
  576. package/dist/lib/helpers.js.map +1 -0
  577. package/dist/lib/helpers.mjs +157 -0
  578. package/dist/lib/helpers.mjs.map +1 -0
  579. package/dist/lib/index.js +33 -0
  580. package/dist/lib/index.js.map +1 -0
  581. package/dist/lib/index.mjs +6 -0
  582. package/dist/lib/index.mjs.map +1 -0
  583. package/dist/lib/types.js +11 -0
  584. package/dist/lib/types.js.map +1 -0
  585. package/dist/lib/types.mjs +9 -0
  586. package/dist/lib/types.mjs.map +1 -0
  587. package/dist/lib/utils.js +24 -0
  588. package/dist/lib/utils.js.map +1 -0
  589. package/dist/lib/utils.mjs +19 -0
  590. package/dist/lib/utils.mjs.map +1 -0
  591. package/dist/providers/DeviceSizeWatcher/index.js +72 -0
  592. package/dist/providers/DeviceSizeWatcher/index.js.map +1 -0
  593. package/dist/providers/DeviceSizeWatcher/index.mjs +47 -0
  594. package/dist/providers/DeviceSizeWatcher/index.mjs.map +1 -0
  595. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js +22 -0
  596. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.js.map +1 -0
  597. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs +20 -0
  598. package/dist/providers/DeviceSizeWatcher/useDeviceSizeStore.mjs.map +1 -0
  599. package/dist/providers/UISystemProvider.js +197 -0
  600. package/dist/providers/UISystemProvider.js.map +1 -0
  601. package/dist/providers/UISystemProvider.mjs +188 -0
  602. package/dist/providers/UISystemProvider.mjs.map +1 -0
  603. package/dist/providers/index.js +24 -0
  604. package/dist/providers/index.js.map +1 -0
  605. package/dist/providers/index.mjs +3 -0
  606. package/dist/providers/index.mjs.map +1 -0
  607. package/dist/theme.js +333 -0
  608. package/dist/theme.js.map +1 -0
  609. package/dist/theme.mjs +327 -0
  610. package/dist/theme.mjs.map +1 -0
  611. package/package.json +1 -1
  612. package/dist/index.css +0 -43
  613. package/dist/index.css.map +0 -1
@@ -0,0 +1,388 @@
1
+ import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
2
+ import { ArrowUpDown, ArrowUp, ArrowDown } from 'lucide-react';
3
+ import { useState, useMemo, useCallback } from 'react';
4
+ import { MinusIcon16 } from '../../../assets/Icon';
5
+ import { Button } from '../../../components/button';
6
+ import { Checkbox } from '../../../components/checkbox';
7
+ import { Skeleton } from '../../../components/skeleton';
8
+ import { Table, TableHeader, TableBody, TableRow, TableHead, TableCell } from '../../../components/table';
9
+ import { cn } from '../../../lib/utils';
10
+ import { StatusState } from '../../display/status-state';
11
+ import { TablePagination } from './table-pagination';
12
+
13
+ function getValueByPath(obj, path) {
14
+ if (!path) return "";
15
+ if (!path.includes(".")) {
16
+ return obj[path];
17
+ }
18
+ const keys = path.split(".");
19
+ let current = obj;
20
+ for (const key of keys) {
21
+ if (current === null || current === void 0) {
22
+ return "";
23
+ }
24
+ current = current[key];
25
+ }
26
+ return current;
27
+ }
28
+ function EnhancedTable({
29
+ dataSource,
30
+ columns,
31
+ loading = false,
32
+ rowKey,
33
+ rowSelection,
34
+ pagination,
35
+ onChange,
36
+ scroll,
37
+ hasRefreshDataSource,
38
+ className,
39
+ tableClassName,
40
+ headerClassName,
41
+ bodyClassName,
42
+ rowClassName,
43
+ onRowClick,
44
+ emptyStateProps
45
+ }) {
46
+ const [sort, setSort] = useState({});
47
+ const { leftOffsets, rightOffsets, totalColumnWidth } = useMemo(() => {
48
+ const left = {};
49
+ const right = {};
50
+ let totalWidth = 0;
51
+ let currentLeft = 0;
52
+ let currentRight = 0;
53
+ if (rowSelection) {
54
+ const selectionWidth = 50;
55
+ currentLeft += selectionWidth;
56
+ totalWidth += selectionWidth;
57
+ }
58
+ columns.forEach((col) => {
59
+ const key = String(col.key || col.dataIndex);
60
+ const colWidth = Number(col.width) || 150;
61
+ totalWidth += colWidth;
62
+ if (col.fixed === "left") {
63
+ left[key] = currentLeft;
64
+ currentLeft += colWidth;
65
+ }
66
+ });
67
+ [...columns].reverse().forEach((col) => {
68
+ const key = String(col.key || col.dataIndex);
69
+ if (col.fixed === "right") {
70
+ const colWidth = Number(col.width) || 150;
71
+ right[key] = currentRight;
72
+ currentRight += colWidth;
73
+ }
74
+ });
75
+ return { leftOffsets: left, rightOffsets: right, totalColumnWidth: totalWidth };
76
+ }, [columns, rowSelection]);
77
+ const tableStyle = useMemo(() => {
78
+ if (scroll?.x !== void 0) {
79
+ if (scroll.x === 0 || scroll.x === "auto" || scroll.x === "100%") {
80
+ return { minWidth: `${totalColumnWidth}px` };
81
+ }
82
+ return { minWidth: typeof scroll.x === "number" ? `${scroll.x}px` : scroll.x };
83
+ }
84
+ return {};
85
+ }, [scroll, totalColumnWidth]);
86
+ const getRowKey = useCallback(
87
+ (record) => {
88
+ if (typeof rowKey === "function") {
89
+ return rowKey(record);
90
+ }
91
+ return record[rowKey];
92
+ },
93
+ [rowKey]
94
+ );
95
+ const handleSort = (column) => {
96
+ const columnKey = column.key || column.dataIndex;
97
+ let newOrder = "ascend";
98
+ if (sort.columnKey === columnKey && sort.order === "ascend") {
99
+ newOrder = "descend";
100
+ } else if (sort.columnKey === columnKey && sort.order === "descend") {
101
+ newOrder = void 0;
102
+ }
103
+ const newSorter = { columnKey, order: newOrder, column };
104
+ setSort(newSorter);
105
+ if (onChange && pagination) {
106
+ onChange({ current: pagination.current, pageSize: pagination.pageSize }, newSorter);
107
+ }
108
+ };
109
+ const handleSelectAll = (checked) => {
110
+ if (rowSelection) {
111
+ const allRowKeysOnPage = processedData.filter((row) => !rowSelection.isDisable?.(row)).map(getRowKey);
112
+ if (checked) {
113
+ const newSelectedKeys = [
114
+ .../* @__PURE__ */ new Set([...rowSelection.selectedRowKeys, ...allRowKeysOnPage])
115
+ ];
116
+ const newSelectedRows = dataSource.filter((r) => newSelectedKeys.includes(getRowKey(r)));
117
+ rowSelection.onChange?.(newSelectedKeys, newSelectedRows);
118
+ } else {
119
+ const newSelectedKeys = rowSelection.selectedRowKeys.filter(
120
+ (k) => !allRowKeysOnPage.includes(k)
121
+ );
122
+ const newSelectedRows = dataSource.filter((r) => newSelectedKeys.includes(getRowKey(r)));
123
+ rowSelection.onChange?.(newSelectedKeys, newSelectedRows);
124
+ }
125
+ }
126
+ };
127
+ const handleSelectRow = (record, checked) => {
128
+ if (rowSelection) {
129
+ const key = getRowKey(record);
130
+ const currentSelected = rowSelection.selectedRowKeys;
131
+ const newSelectedKeys = checked ? [...currentSelected, key] : currentSelected.filter((k) => k !== key);
132
+ const newSelectedRows = dataSource.filter((r) => newSelectedKeys.includes(getRowKey(r)));
133
+ rowSelection.onChange?.(newSelectedKeys, newSelectedRows);
134
+ }
135
+ };
136
+ const processedData = useMemo(() => {
137
+ let data = [...dataSource];
138
+ const { column, order } = sort;
139
+ if (column && order && column.sorter) {
140
+ data.sort((a, b) => {
141
+ if (typeof column.sorter === "function") {
142
+ return order === "ascend" ? column.sorter(a, b) : -column.sorter(a, b);
143
+ }
144
+ const valA = a[column.dataIndex];
145
+ const valB = b[column.dataIndex];
146
+ if (valA < valB) return order === "ascend" ? -1 : 1;
147
+ if (valA > valB) return order === "ascend" ? 1 : -1;
148
+ return 0;
149
+ });
150
+ }
151
+ if (pagination && !hasRefreshDataSource) {
152
+ const { current, pageSize } = pagination;
153
+ const startIndex = (current - 1) * pageSize;
154
+ data = data.slice(startIndex, startIndex + pageSize);
155
+ }
156
+ return data;
157
+ }, [dataSource, sort, pagination]);
158
+ const getStickyStyles = (col, baseZIndex) => {
159
+ const key = String(col.key || col.dataIndex);
160
+ const styles = {
161
+ minWidth: `${col.width}px`
162
+ };
163
+ if (col.fixed === "left") {
164
+ styles.position = "sticky";
165
+ styles.left = leftOffsets[key] ?? 0;
166
+ styles.zIndex = baseZIndex + 1;
167
+ styles.boxShadow = "10px 0 5px -2px #888";
168
+ styles.width = `${col.width}px`;
169
+ styles.maxWidth = `${col.width}px`;
170
+ styles.boxSizing = "border-box";
171
+ }
172
+ if (col.fixed === "right") {
173
+ styles.position = "sticky";
174
+ styles.right = rightOffsets[key] ?? 0;
175
+ styles.zIndex = baseZIndex + 1;
176
+ styles.boxShadow = "-10px 0px 10px 1px #aaaaaa";
177
+ styles.width = `${col.width}px`;
178
+ styles.maxWidth = `${col.width}px`;
179
+ styles.boxSizing = "border-box";
180
+ }
181
+ return styles;
182
+ };
183
+ const renderHeader = () => {
184
+ const enabledRows = processedData.filter((row) => !rowSelection?.isDisable?.(row));
185
+ const selectedEnabledRowsCount = enabledRows.filter(
186
+ (row) => rowSelection?.selectedRowKeys.includes(getRowKey(row))
187
+ ).length;
188
+ const isAllSelected = enabledRows.length > 0 && selectedEnabledRowsCount === enabledRows.length;
189
+ const isIndeterminate = selectedEnabledRowsCount > 0 && selectedEnabledRowsCount < enabledRows.length;
190
+ return /* @__PURE__ */ jsxs(TableRow, { className: cn("", typeof rowClassName === "string" ? rowClassName : ""), children: [
191
+ rowSelection && /* @__PURE__ */ jsx(
192
+ TableHead,
193
+ {
194
+ style: { width: 50, minWidth: 50, maxWidth: 50, maxHeight: 40 },
195
+ className: cn("bg-muted text-t14m sticky left-0 h-10"),
196
+ children: /* @__PURE__ */ jsx(
197
+ Checkbox,
198
+ {
199
+ checked: isAllSelected || isIndeterminate,
200
+ disabled: (
201
+ // Disable nếu không có row nào, hoặc tất cả row trên page đều bị disable
202
+ processedData.length === 0 || processedData.every((row) => rowSelection.isDisable?.(row))
203
+ ),
204
+ onCheckedChange: handleSelectAll,
205
+ className: "border-border bg-background",
206
+ indicator: isIndeterminate ? /* @__PURE__ */ jsx(MinusIcon16, { className: "ic-white h-4 w-4" }) : void 0
207
+ }
208
+ )
209
+ }
210
+ ),
211
+ columns.map((col) => {
212
+ const styles = getStickyStyles(col, 10);
213
+ return /* @__PURE__ */ jsx(
214
+ TableHead,
215
+ {
216
+ style: {
217
+ ...styles
218
+ },
219
+ className: cn(
220
+ "text-t14m text-foreground bg-muted h-10 px-4 py-2 font-medium",
221
+ col.fixed === "right" && `after:absolute after:inset-0 after:size-full after:shadow-[-8px_0_30px_-10px_rgba(0,0,0,0.2)] after:content-['']`,
222
+ col.fixed === "left" && `after:absolute after:inset-0 after:size-full after:shadow-[10px_0_30px_-15px_rgba(0,0,0,0.2)] after:content-['']`
223
+ ),
224
+ children: col.sorter ? /* @__PURE__ */ jsxs(
225
+ Button,
226
+ {
227
+ size: "sm",
228
+ variant: "ghost",
229
+ onClick: () => handleSort(col),
230
+ className: "text-t14m -ml-4",
231
+ children: [
232
+ col.title,
233
+ sort.columnKey !== (col.key || col.dataIndex) && /* @__PURE__ */ jsx(ArrowUpDown, { className: "ml-2 size-4" }),
234
+ sort.columnKey === (col.key || col.dataIndex) && sort.order === "ascend" && /* @__PURE__ */ jsx(ArrowUp, { className: "ml-2 size-4" }),
235
+ sort.columnKey === (col.key || col.dataIndex) && sort.order === "descend" && /* @__PURE__ */ jsx(ArrowDown, { className: "ml-2 size-4" })
236
+ ]
237
+ }
238
+ ) : col.title
239
+ },
240
+ col.key || col.dataIndex
241
+ );
242
+ })
243
+ ] });
244
+ };
245
+ const handleRowClick = (record) => () => {
246
+ onRowClick?.(record);
247
+ };
248
+ const renderBody = () => {
249
+ if (loading && !processedData?.length) {
250
+ const skeletonRows = Array.from({ length: 5 }, (_, rowIndex) => /* @__PURE__ */ jsxs(TableRow, { className: "text-t14m", children: [
251
+ rowSelection && /* @__PURE__ */ jsx(
252
+ TableCell,
253
+ {
254
+ style: { width: 50, minWidth: 50, maxWidth: 50 },
255
+ className: "sticky left-0 h-12 px-4 py-2",
256
+ children: /* @__PURE__ */ jsx(Skeleton, { className: "h-4 w-4 rounded" })
257
+ }
258
+ ),
259
+ columns.map((col) => {
260
+ const styles = getStickyStyles(col, 10);
261
+ const colKey = String(col.key || col.dataIndex);
262
+ return /* @__PURE__ */ jsx(
263
+ TableCell,
264
+ {
265
+ style: styles,
266
+ className: cn(
267
+ "h-12 px-4 py-2",
268
+ col.fixed === "right" && `after:absolute after:inset-0 after:size-full after:shadow-[-8px_0_30px_-10px_rgba(0,0,0,0.2)] after:content-['']`,
269
+ col.fixed === "left" && `after:absolute after:inset-0 after:size-full after:shadow-[10px_0_30px_-15px_rgba(0,0,0,0.2)] after:content-['']`
270
+ ),
271
+ children: /* @__PURE__ */ jsx(Skeleton, { className: "h-4 w-full" })
272
+ },
273
+ `skeleton-${rowIndex}-${colKey}`
274
+ );
275
+ })
276
+ ] }, `skeleton-row-${rowIndex}`));
277
+ return /* @__PURE__ */ jsx(Fragment, { children: skeletonRows });
278
+ }
279
+ if (processedData.length === 0) {
280
+ return /* @__PURE__ */ jsx(TableRow, { children: /* @__PURE__ */ jsx(
281
+ TableCell,
282
+ {
283
+ colSpan: columns.length + (rowSelection ? 1 : 0),
284
+ className: "text-muted-foreground text-t16m h-24 text-center",
285
+ children: /* @__PURE__ */ jsx(StatusState, { type: "noData", ...emptyStateProps })
286
+ }
287
+ ) });
288
+ }
289
+ return processedData.map((record, index) => {
290
+ const dynamicRowClassName = typeof rowClassName === "function" ? rowClassName(record, index) : typeof rowClassName === "string" ? rowClassName : "";
291
+ return /* @__PURE__ */ jsxs(
292
+ TableRow,
293
+ {
294
+ className: cn("text-t14m group", dynamicRowClassName),
295
+ "data-state": rowSelection?.selectedRowKeys.includes(getRowKey(record)) && "selected",
296
+ onClick: handleRowClick(record),
297
+ children: [
298
+ rowSelection && /* @__PURE__ */ jsx(
299
+ TableCell,
300
+ {
301
+ style: { width: 50, minWidth: 50, maxWidth: 50 },
302
+ className: cn(
303
+ "group-hover:bg-accent sticky left-0 h-12 px-4 py-2 transition duration-300",
304
+ rowSelection.selectedRowKeys.includes(getRowKey(record)) ? "bg-primary/10" : "bg-background"
305
+ ),
306
+ children: /* @__PURE__ */ jsx(
307
+ Checkbox,
308
+ {
309
+ checked: rowSelection.selectedRowKeys.includes(getRowKey(record)),
310
+ onCheckedChange: (checked) => handleSelectRow(record, !!checked),
311
+ className: cn("border-border bg-background"),
312
+ disabled: rowSelection?.isDisable?.(record)
313
+ }
314
+ )
315
+ }
316
+ ),
317
+ columns.map((col) => {
318
+ const styles = getStickyStyles(col, 10);
319
+ if (scroll?.y) {
320
+ styles.position = "sticky";
321
+ styles.top = 0;
322
+ styles.zIndex = styles.zIndex || 20;
323
+ }
324
+ return /* @__PURE__ */ jsx(
325
+ TableCell,
326
+ {
327
+ style: {
328
+ ...styles,
329
+ wordBreak: "break-word"
330
+ },
331
+ className: cn(
332
+ "text-t14m text-foreground group-hover:bg-accent bg-background h-12 px-4 py-2 !pr-4 transition duration-300",
333
+ col.fixed === "right" && `after:absolute after:inset-0 after:size-full after:shadow-[-8px_0_30px_-10px_rgba(0,0,0,0.2)] after:content-['']`,
334
+ col.fixed === "left" && `after:absolute after:inset-0 after:size-full after:shadow-[10px_0_30px_-15px_rgba(0,0,0,0.2)] after:content-['']`,
335
+ rowSelection && rowSelection.selectedRowKeys.includes(getRowKey(record)) && "bg-primary/10"
336
+ ),
337
+ children: col.render ? col.render(getValueByPath(record, col.dataIndex), record, index) : String(getValueByPath(record, col.dataIndex) ?? "")
338
+ },
339
+ col.key || col.dataIndex
340
+ );
341
+ })
342
+ ]
343
+ },
344
+ getRowKey(record)
345
+ );
346
+ });
347
+ };
348
+ return /* @__PURE__ */ jsxs(
349
+ "div",
350
+ {
351
+ className: cn(
352
+ "flex flex-col overflow-hidden rounded-bl-md rounded-br-md bg-white",
353
+ className
354
+ ),
355
+ children: [
356
+ /* @__PURE__ */ jsx("div", { className: "relative", children: /* @__PURE__ */ jsx(
357
+ "div",
358
+ {
359
+ className: "relative overflow-auto",
360
+ style: {
361
+ maxHeight: scroll?.y,
362
+ overflowY: scroll?.y ? "auto" : "hidden",
363
+ overflowX: scroll?.x ? "auto" : "hidden"
364
+ },
365
+ children: /* @__PURE__ */ jsxs(Table, { style: tableStyle, className: tableClassName, children: [
366
+ /* @__PURE__ */ jsx(TableHeader, { className: cn("bg-muted h-14", headerClassName), children: renderHeader() }),
367
+ /* @__PURE__ */ jsx(TableBody, { className: bodyClassName, children: renderBody() })
368
+ ] })
369
+ }
370
+ ) }),
371
+ pagination && /* @__PURE__ */ jsx(
372
+ TablePagination,
373
+ {
374
+ config: {
375
+ ...pagination,
376
+ total: isNaN(pagination?.total) ? dataSource.length : pagination?.total,
377
+ loading
378
+ }
379
+ }
380
+ )
381
+ ]
382
+ }
383
+ );
384
+ }
385
+
386
+ export { EnhancedTable };
387
+ //# sourceMappingURL=enhanced-table.mjs.map
388
+ //# sourceMappingURL=enhanced-table.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/common/interactive/table/enhanced-table.tsx"],"names":[],"mappings":"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","file":"enhanced-table.mjs","sourcesContent":["import { ArrowDown, ArrowUp, ArrowUpDown } from 'lucide-react';\nimport { useCallback, useMemo, useState } from 'react';\nimport { MinusIcon16 } from '../../../assets/Icon';\nimport { Button } from '../../../components/button';\nimport { Checkbox } from '../../../components/checkbox';\nimport { Skeleton } from '../../../components/skeleton';\nimport {\n Table,\n TableBody,\n TableCell,\n TableHead,\n TableHeader,\n TableRow,\n} from '../../../components/table';\nimport { cn } from '../../../lib/utils';\nimport { StatusState } from '../../display/status-state';\nimport { TablePagination } from './table-pagination';\nimport { ColumnType, EnhancedTableProps, SorterInfo } from './types';\n\n// Modified function to get value from nested objects using dot notation\nfunction getValueByPath(obj: any, path: string): any {\n if (!path) return '';\n\n // Handle regular dataIndex (no dots)\n if (!path.includes('.')) {\n return obj[path];\n }\n\n // Handle nested paths with dot notation\n const keys = path.split('.');\n let current = obj;\n\n for (const key of keys) {\n if (current === null || current === undefined) {\n return '';\n }\n current = current[key];\n }\n\n return current;\n}\n\nexport function EnhancedTable<T extends { [key: string]: any }>({\n dataSource,\n columns,\n loading = false,\n rowKey,\n rowSelection,\n pagination,\n onChange,\n scroll,\n hasRefreshDataSource,\n className,\n tableClassName,\n headerClassName,\n bodyClassName,\n rowClassName,\n onRowClick,\n emptyStateProps,\n}: EnhancedTableProps<T>) {\n const [sort, setSort] = useState<SorterInfo<T>>({});\n\n const { leftOffsets, rightOffsets, totalColumnWidth } = useMemo(() => {\n const left: { [key: string]: number } = {};\n const right: { [key: string]: number } = {};\n let totalWidth = 0;\n let currentLeft = 0;\n let currentRight = 0;\n\n if (rowSelection) {\n const selectionWidth = 50; // Chiều rộng cho cột checkbox\n currentLeft += selectionWidth;\n totalWidth += selectionWidth;\n }\n\n columns.forEach((col) => {\n const key = String(col.key || col.dataIndex);\n const colWidth = Number(col.width) || 150; // Default width nếu không được cung cấp\n totalWidth += colWidth;\n if (col.fixed === 'left') {\n left[key] = currentLeft;\n currentLeft += colWidth;\n }\n });\n\n [...columns].reverse().forEach((col) => {\n const key = String(col.key || col.dataIndex);\n if (col.fixed === 'right') {\n const colWidth = Number(col.width) || 150;\n right[key] = currentRight;\n currentRight += colWidth;\n }\n });\n\n return { leftOffsets: left, rightOffsets: right, totalColumnWidth: totalWidth };\n }, [columns, rowSelection]);\n\n const tableStyle = useMemo((): React.CSSProperties => {\n if (scroll?.x !== undefined) {\n if (scroll.x === 0 || scroll.x === 'auto' || scroll.x === '100%') {\n return { minWidth: `${totalColumnWidth}px` };\n }\n return { minWidth: typeof scroll.x === 'number' ? `${scroll.x}px` : scroll.x };\n }\n return {};\n }, [scroll, totalColumnWidth]);\n\n const getRowKey = useCallback(\n (record: T): React.Key => {\n if (typeof rowKey === 'function') {\n return rowKey(record);\n }\n return record[rowKey];\n },\n [rowKey],\n );\n\n const handleSort = (column: ColumnType<T>) => {\n const columnKey = column.key || (column.dataIndex as React.Key);\n let newOrder: 'ascend' | 'descend' | undefined = 'ascend';\n\n if (sort.columnKey === columnKey && sort.order === 'ascend') {\n newOrder = 'descend';\n } else if (sort.columnKey === columnKey && sort.order === 'descend') {\n newOrder = undefined;\n }\n\n const newSorter: SorterInfo<T> = { columnKey, order: newOrder, column };\n setSort(newSorter);\n if (onChange && pagination) {\n onChange({ current: pagination.current, pageSize: pagination.pageSize }, newSorter);\n }\n };\n\n const handleSelectAll = (checked: boolean) => {\n if (rowSelection) {\n // Lấy rowKey của các dòng trên trang và không bị disabled\n const allRowKeysOnPage = processedData\n .filter((row) => !rowSelection.isDisable?.(row)) // chỉ lấy row không disabled\n .map(getRowKey);\n\n if (checked) {\n // Khi checked: chỉ thêm các row không disable trên page vào danh sách selected (giữ các row đã chọn trước đó)\n const newSelectedKeys = [\n ...new Set([...rowSelection.selectedRowKeys, ...allRowKeysOnPage]),\n ];\n const newSelectedRows = dataSource.filter((r) => newSelectedKeys.includes(getRowKey(r)));\n rowSelection.onChange?.(newSelectedKeys, newSelectedRows);\n } else {\n // Khi uncheck: chỉ bỏ chọn các row không disabled trên page khỏi danh sách selected\n const newSelectedKeys = rowSelection.selectedRowKeys.filter(\n (k) => !allRowKeysOnPage.includes(k),\n );\n const newSelectedRows = dataSource.filter((r) => newSelectedKeys.includes(getRowKey(r)));\n rowSelection.onChange?.(newSelectedKeys, newSelectedRows);\n }\n }\n };\n\n const handleSelectRow = (record: T, checked: boolean) => {\n if (rowSelection) {\n const key = getRowKey(record);\n const currentSelected = rowSelection.selectedRowKeys;\n const newSelectedKeys = checked\n ? [...currentSelected, key]\n : currentSelected.filter((k) => k !== key);\n const newSelectedRows = dataSource.filter((r) => newSelectedKeys.includes(getRowKey(r)));\n rowSelection.onChange?.(newSelectedKeys, newSelectedRows);\n }\n };\n\n const processedData = useMemo(() => {\n let data = [...dataSource];\n\n const { column, order } = sort;\n if (column && order && column.sorter) {\n data.sort((a, b) => {\n if (typeof column.sorter === 'function') {\n return order === 'ascend' ? column.sorter(a, b) : -column.sorter(a, b);\n }\n const valA = a[column.dataIndex as string];\n const valB = b[column.dataIndex as string];\n if (valA < valB) return order === 'ascend' ? -1 : 1;\n if (valA > valB) return order === 'ascend' ? 1 : -1;\n return 0;\n });\n }\n\n if (pagination && !hasRefreshDataSource) {\n const { current, pageSize } = pagination;\n const startIndex = (current - 1) * pageSize;\n data = data.slice(startIndex, startIndex + pageSize);\n }\n\n return data;\n }, [dataSource, sort, pagination]);\n\n const getStickyStyles = (col: ColumnType<T>, baseZIndex: number): React.CSSProperties => {\n const key = String(col.key || col.dataIndex);\n const styles: React.CSSProperties = {\n minWidth: `${col.width}px`,\n };\n\n if (col.fixed === 'left') {\n styles.position = 'sticky';\n styles.left = leftOffsets[key] ?? 0;\n styles.zIndex = baseZIndex + 1;\n styles.boxShadow = '10px 0 5px -2px #888';\n styles.width = `${col.width}px`;\n styles.maxWidth = `${col.width}px`;\n styles.boxSizing = 'border-box';\n }\n\n if (col.fixed === 'right') {\n styles.position = 'sticky';\n styles.right = rightOffsets[key] ?? 0;\n styles.zIndex = baseZIndex + 1;\n styles.boxShadow = '-10px 0px 10px 1px #aaaaaa';\n styles.width = `${col.width}px`;\n styles.maxWidth = `${col.width}px`;\n styles.boxSizing = 'border-box';\n }\n\n return styles;\n };\n\n const renderHeader = () => {\n // Calculate checkbox state for select all\n const enabledRows = processedData.filter((row) => !rowSelection?.isDisable?.(row));\n const selectedEnabledRowsCount = enabledRows.filter((row) =>\n rowSelection?.selectedRowKeys.includes(getRowKey(row)),\n ).length;\n const isAllSelected = enabledRows.length > 0 && selectedEnabledRowsCount === enabledRows.length;\n const isIndeterminate =\n selectedEnabledRowsCount > 0 && selectedEnabledRowsCount < enabledRows.length;\n\n return (\n <TableRow className={cn('', typeof rowClassName === 'string' ? rowClassName : '')}>\n {rowSelection && (\n <TableHead\n style={{ width: 50, minWidth: 50, maxWidth: 50, maxHeight: 40 }}\n className={cn('bg-muted text-t14m sticky left-0 h-10')}\n >\n <Checkbox\n checked={isAllSelected || isIndeterminate}\n disabled={\n // Disable nếu không có row nào, hoặc tất cả row trên page đều bị disable\n processedData.length === 0 ||\n processedData.every((row) => rowSelection.isDisable?.(row))\n }\n onCheckedChange={handleSelectAll}\n className=\"border-border bg-background\"\n indicator={isIndeterminate ? <MinusIcon16 className=\"ic-white h-4 w-4\" /> : undefined}\n />\n </TableHead>\n )}\n {columns.map((col) => {\n const styles = getStickyStyles(col, 10);\n return (\n <TableHead\n key={col.key || (col.dataIndex as string)}\n style={{\n ...styles,\n }}\n className={cn(\n 'text-t14m text-foreground bg-muted h-10 px-4 py-2 font-medium',\n col.fixed === 'right' &&\n `after:absolute after:inset-0 after:size-full after:shadow-[-8px_0_30px_-10px_rgba(0,0,0,0.2)] after:content-['']`,\n col.fixed === 'left' &&\n `after:absolute after:inset-0 after:size-full after:shadow-[10px_0_30px_-15px_rgba(0,0,0,0.2)] after:content-['']`,\n )}\n >\n {col.sorter ? (\n <Button\n size=\"sm\"\n variant=\"ghost\"\n onClick={() => handleSort(col)}\n className=\"text-t14m -ml-4\"\n >\n {col.title}\n {sort.columnKey !== (col.key || col.dataIndex) && (\n <ArrowUpDown className=\"ml-2 size-4\" />\n )}\n {sort.columnKey === (col.key || col.dataIndex) && sort.order === 'ascend' && (\n <ArrowUp className=\"ml-2 size-4\" />\n )}\n {sort.columnKey === (col.key || col.dataIndex) && sort.order === 'descend' && (\n <ArrowDown className=\"ml-2 size-4\" />\n )}\n </Button>\n ) : (\n col.title\n )}\n </TableHead>\n );\n })}\n </TableRow>\n );\n };\n\n const handleRowClick = (record: T) => () => {\n onRowClick?.(record);\n };\n\n const renderBody = () => {\n if (loading && !processedData?.length) {\n // Show skeleton rows matching table structure\n const skeletonRows = Array.from({ length: 5 }, (_, rowIndex) => (\n <TableRow key={`skeleton-row-${rowIndex}`} className=\"text-t14m\">\n {rowSelection && (\n <TableCell\n style={{ width: 50, minWidth: 50, maxWidth: 50 }}\n className=\"sticky left-0 h-12 px-4 py-2\"\n >\n <Skeleton className=\"h-4 w-4 rounded\" />\n </TableCell>\n )}\n {columns.map((col) => {\n const styles = getStickyStyles(col, 10);\n const colKey = String(col.key || col.dataIndex);\n return (\n <TableCell\n key={`skeleton-${rowIndex}-${colKey}`}\n style={styles}\n className={cn(\n 'h-12 px-4 py-2',\n col.fixed === 'right' &&\n `after:absolute after:inset-0 after:size-full after:shadow-[-8px_0_30px_-10px_rgba(0,0,0,0.2)] after:content-['']`,\n col.fixed === 'left' &&\n `after:absolute after:inset-0 after:size-full after:shadow-[10px_0_30px_-15px_rgba(0,0,0,0.2)] after:content-['']`,\n )}\n >\n <Skeleton className=\"h-4 w-full\" />\n </TableCell>\n );\n })}\n </TableRow>\n ));\n return <>{skeletonRows}</>;\n }\n\n if (processedData.length === 0) {\n return (\n <TableRow>\n <TableCell\n colSpan={columns.length + (rowSelection ? 1 : 0)}\n className=\"text-muted-foreground text-t16m h-24 text-center\"\n >\n <StatusState type=\"noData\" {...emptyStateProps} />\n </TableCell>\n </TableRow>\n );\n }\n\n return processedData.map((record, index) => {\n const dynamicRowClassName =\n typeof rowClassName === 'function'\n ? rowClassName(record, index)\n : typeof rowClassName === 'string'\n ? rowClassName\n : '';\n\n return (\n <TableRow\n key={getRowKey(record)}\n className={cn('text-t14m group', dynamicRowClassName)}\n data-state={rowSelection?.selectedRowKeys.includes(getRowKey(record)) && 'selected'}\n onClick={handleRowClick(record)}\n >\n {rowSelection && (\n <TableCell\n style={{ width: 50, minWidth: 50, maxWidth: 50 }}\n className={cn(\n 'group-hover:bg-accent sticky left-0 h-12 px-4 py-2 transition duration-300',\n rowSelection.selectedRowKeys.includes(getRowKey(record))\n ? 'bg-primary/10'\n : 'bg-background',\n )}\n >\n <Checkbox\n checked={rowSelection.selectedRowKeys.includes(getRowKey(record))}\n onCheckedChange={(checked) => handleSelectRow(record, !!checked)}\n className={cn('border-border bg-background')}\n disabled={rowSelection?.isDisable?.(record)}\n />\n </TableCell>\n )}\n {columns.map((col) => {\n const styles = getStickyStyles(col, 10);\n if (scroll?.y) {\n styles.position = 'sticky';\n styles.top = 0;\n styles.zIndex = styles.zIndex || 20;\n }\n\n return (\n <TableCell\n key={col.key || (col.dataIndex as string)}\n style={{\n ...styles,\n wordBreak: 'break-word',\n }}\n className={cn(\n 'text-t14m text-foreground group-hover:bg-accent bg-background h-12 px-4 py-2 !pr-4 transition duration-300',\n col.fixed === 'right' &&\n `after:absolute after:inset-0 after:size-full after:shadow-[-8px_0_30px_-10px_rgba(0,0,0,0.2)] after:content-['']`,\n col.fixed === 'left' &&\n `after:absolute after:inset-0 after:size-full after:shadow-[10px_0_30px_-15px_rgba(0,0,0,0.2)] after:content-['']`,\n rowSelection &&\n rowSelection.selectedRowKeys.includes(getRowKey(record)) &&\n 'bg-primary/10',\n )}\n >\n {col.render\n ? col.render(getValueByPath(record, col.dataIndex as string), record, index)\n : String(getValueByPath(record, col.dataIndex as string) ?? '')}\n </TableCell>\n );\n })}\n </TableRow>\n );\n });\n };\n\n return (\n <div\n className={cn(\n 'flex flex-col overflow-hidden rounded-bl-md rounded-br-md bg-white',\n className,\n )}\n >\n <div className=\"relative\">\n <div\n className=\"relative overflow-auto\"\n style={{\n maxHeight: scroll?.y,\n overflowY: scroll?.y ? 'auto' : 'hidden',\n overflowX: scroll?.x ? 'auto' : 'hidden',\n }}\n >\n <Table style={tableStyle} className={tableClassName}>\n <TableHeader className={cn('bg-muted h-14', headerClassName)}>\n {renderHeader()}\n </TableHeader>\n <TableBody className={bodyClassName}>{renderBody()}</TableBody>\n </Table>\n </div>\n </div>\n\n {pagination && (\n <TablePagination\n config={{\n ...pagination,\n total: isNaN(pagination?.total) ? dataSource.length : pagination?.total,\n loading,\n }}\n />\n )}\n </div>\n );\n}\n"]}
@@ -0,0 +1,83 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var enhancedTable = require('./enhanced-table');
5
+ var react = require('react');
6
+ var helpers = require('../../../lib/helpers');
7
+ var types = require('./types');
8
+ var tablePagination = require('./table-pagination');
9
+
10
+ function ListingTable(props) {
11
+ const containerRef = react.useRef();
12
+ const [scrollY, setScrollY] = react.useState(0);
13
+ const calculateScrollY = helpers.debounce(() => {
14
+ if (!containerRef?.current) return;
15
+ const table = containerRef.current?.getElementsByClassName("ant-table-wrapper")?.[0];
16
+ if (containerRef.current?.clientHeight < table?.clientHeight) {
17
+ const thead = containerRef.current?.getElementsByClassName("ant-table-header")?.[0];
18
+ const pagination = containerRef.current?.getElementsByClassName("ant-pagination")?.[0];
19
+ setScrollY(
20
+ containerRef.current.clientHeight - (thead?.clientHeight ?? 0) - (pagination?.clientHeight ?? 0) - 18
21
+ );
22
+ }
23
+ const parentTable = containerRef?.current?.querySelector(".ant-table-body") || containerRef?.current?.querySelector(".ant-table-content");
24
+ const onScrollParent = (e) => {
25
+ const childTables = e.target.querySelectorAll(".ant-table-content");
26
+ childTables.forEach((childTable) => {
27
+ childTable.scrollLeft = e.target.scrollLeft;
28
+ });
29
+ };
30
+ parentTable?.addEventListener("scroll", onScrollParent);
31
+ }, 100);
32
+ react.useEffect(() => {
33
+ let mutationObserver;
34
+ let resizeObserver;
35
+ if (containerRef?.current) {
36
+ calculateScrollY();
37
+ mutationObserver = new MutationObserver(calculateScrollY);
38
+ mutationObserver.observe(containerRef?.current, {
39
+ attributes: true,
40
+ childList: true,
41
+ subtree: true
42
+ });
43
+ resizeObserver = new ResizeObserver(calculateScrollY);
44
+ resizeObserver.observe(containerRef?.current, {
45
+ attributes: true,
46
+ childList: true,
47
+ subtree: true
48
+ });
49
+ }
50
+ return () => {
51
+ if (mutationObserver) mutationObserver.disconnect();
52
+ if (resizeObserver) resizeObserver.disconnect();
53
+ };
54
+ }, [containerRef]);
55
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { ref: containerRef, className: "flex flex-col gap-4", children: /* @__PURE__ */ jsxRuntime.jsx(
56
+ enhancedTable.EnhancedTable,
57
+ {
58
+ ...props,
59
+ scroll: {
60
+ y: scrollY ? scrollY : void 0,
61
+ x: 0
62
+ }
63
+ }
64
+ ) });
65
+ }
66
+
67
+ Object.defineProperty(exports, "EnhancedTable", {
68
+ enumerable: true,
69
+ get: function () { return enhancedTable.EnhancedTable; }
70
+ });
71
+ Object.defineProperty(exports, "TablePagination", {
72
+ enumerable: true,
73
+ get: function () { return tablePagination.TablePagination; }
74
+ });
75
+ exports.ListingTable = ListingTable;
76
+ Object.keys(types).forEach(function (k) {
77
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
78
+ enumerable: true,
79
+ get: function () { return types[k]; }
80
+ });
81
+ });
82
+ //# sourceMappingURL=index.js.map
83
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/common/interactive/table/index.tsx"],"names":["useRef","useState","debounce","useEffect","jsx","EnhancedTable"],"mappings":";;;;;;;;;AAOO,SAAS,aAA+C,KAAA,EAA6B;AAC1F,EAAA,MAAM,eAAeA,YAAA,EAAY;AACjC,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAIC,eAAS,CAAC,CAAA;AAExC,EAAA,MAAM,gBAAA,GAAmBC,iBAAS,MAAM;AACtC,IAAA,IAAI,CAAC,cAAc,OAAA,EAAS;AAE5B,IAAA,MAAM,QAAQ,YAAA,CAAa,OAAA,EAAS,sBAAA,CAAuB,mBAAmB,IAAI,CAAC,CAAA;AAEnF,IAAA,IAAI,YAAA,CAAa,OAAA,EAAS,YAAA,GAAe,KAAA,EAAO,YAAA,EAAc;AAC5D,MAAA,MAAM,QAAQ,YAAA,CAAa,OAAA,EAAS,sBAAA,CAAuB,kBAAkB,IAAI,CAAC,CAAA;AAClF,MAAA,MAAM,aAAa,YAAA,CAAa,OAAA,EAAS,sBAAA,CAAuB,gBAAgB,IAAI,CAAC,CAAA;AACrF,MAAA,UAAA;AAAA,QACE,YAAA,CAAa,QAAQ,YAAA,IAClB,KAAA,EAAO,gBAAgB,CAAA,CAAA,IACvB,UAAA,EAAY,gBAAgB,CAAA,CAAA,GAC7B;AAAA,OACJ;AAAA,IACF;AAGA,IAAA,MAAM,WAAA,GACJ,cAAc,OAAA,EAAS,aAAA,CAAc,iBAAiB,CAAA,IACtD,YAAA,EAAc,OAAA,EAAS,aAAA,CAAc,oBAAoB,CAAA;AAE3D,IAAA,MAAM,cAAA,GAAiB,CAAC,CAAA,KAAW;AACjC,MAAA,MAAM,WAAA,GAAc,CAAA,CAAE,MAAA,CAAO,gBAAA,CAAiB,oBAAoB,CAAA;AAClE,MAAA,WAAA,CAAY,OAAA,CAAQ,CAAC,UAAA,KAAoB;AACvC,QAAA,UAAA,CAAW,UAAA,GAAa,EAAE,MAAA,CAAO,UAAA;AAAA,MACnC,CAAC,CAAA;AAAA,IACH,CAAA;AAEA,IAAA,WAAA,EAAa,gBAAA,CAAiB,UAAU,cAAc,CAAA;AAAA,EACxD,GAAG,GAAG,CAAA;AAEN,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,gBAAA;AACJ,IAAA,IAAI,cAAA;AAEJ,IAAA,IAAI,cAAc,OAAA,EAAS;AACzB,MAAA,gBAAA,EAAiB;AAEjB,MAAA,gBAAA,GAAmB,IAAI,iBAAiB,gBAAgB,CAAA;AACxD,MAAA,gBAAA,CAAiB,OAAA,CAAQ,cAAc,OAAA,EAAS;AAAA,QAC9C,UAAA,EAAY,IAAA;AAAA,QACZ,SAAA,EAAW,IAAA;AAAA,QACX,OAAA,EAAS;AAAA,OACV,CAAA;AAED,MAAA,cAAA,GAAiB,IAAI,eAAe,gBAAgB,CAAA;AACpD,MAAA,cAAA,CAAe,OAAA,CAAQ,cAAc,OAAA,EAAS;AAAA,QAC5C,UAAA,EAAY,IAAA;AAAA,QACZ,SAAA,EAAW,IAAA;AAAA,QACX,OAAA,EAAS;AAAA,OACV,CAAA;AAAA,IACH;AAEA,IAAA,OAAO,MAAM;AACX,MAAA,IAAI,gBAAA,mBAAmC,UAAA,EAAW;AAClD,MAAA,IAAI,cAAA,iBAA+B,UAAA,EAAW;AAAA,IAChD,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,YAAY,CAAC,CAAA;AAEjB,EAAA,uBACEC,cAAA,CAAC,KAAA,EAAA,EAAI,GAAA,EAAK,YAAA,EAAc,WAAU,qBAAA,EAEhC,QAAA,kBAAAA,cAAA;AAAA,IAACC,2BAAA;AAAA,IAAA;AAAA,MACE,GAAG,KAAA;AAAA,MACJ,MAAA,EAAQ;AAAA,QACN,CAAA,EAAG,UAAU,OAAA,GAAU,MAAA;AAAA,QACvB,CAAA,EAAG;AAAA;AACL;AAAA,GACF,EACF,CAAA;AAEJ","file":"index.js","sourcesContent":["import { EnhancedTable } from './enhanced-table';\nimport { EnhancedTableProps } from './types';\nimport { useEffect, useRef, useState } from 'react';\nimport { debounce } from '../../../lib/helpers';\n\ninterface ListingTableProps<T extends object> extends EnhancedTableProps<T> {}\n\nexport function ListingTable<T extends { [key: string]: any }>(props: ListingTableProps<T>) {\n const containerRef = useRef<any>();\n const [scrollY, setScrollY] = useState(0);\n\n const calculateScrollY = debounce(() => {\n if (!containerRef?.current) return;\n\n const table = containerRef.current?.getElementsByClassName('ant-table-wrapper')?.[0];\n\n if (containerRef.current?.clientHeight < table?.clientHeight) {\n const thead = containerRef.current?.getElementsByClassName('ant-table-header')?.[0];\n const pagination = containerRef.current?.getElementsByClassName('ant-pagination')?.[0];\n setScrollY(\n containerRef.current.clientHeight -\n (thead?.clientHeight ?? 0) -\n (pagination?.clientHeight ?? 0) -\n 18,\n );\n }\n\n // Scroll\n const parentTable =\n containerRef?.current?.querySelector('.ant-table-body') ||\n containerRef?.current?.querySelector('.ant-table-content');\n\n const onScrollParent = (e: any) => {\n const childTables = e.target.querySelectorAll('.ant-table-content');\n childTables.forEach((childTable: any) => {\n childTable.scrollLeft = e.target.scrollLeft;\n });\n };\n\n parentTable?.addEventListener('scroll', onScrollParent);\n }, 100);\n\n useEffect(() => {\n let mutationObserver: any;\n let resizeObserver: any;\n\n if (containerRef?.current) {\n calculateScrollY();\n\n mutationObserver = new MutationObserver(calculateScrollY);\n mutationObserver.observe(containerRef?.current, {\n attributes: true,\n childList: true,\n subtree: true,\n });\n\n resizeObserver = new ResizeObserver(calculateScrollY);\n resizeObserver.observe(containerRef?.current, {\n attributes: true,\n childList: true,\n subtree: true,\n });\n }\n\n return () => {\n if (mutationObserver) mutationObserver.disconnect();\n if (resizeObserver) resizeObserver.disconnect();\n };\n }, [containerRef]);\n\n return (\n <div ref={containerRef} className=\"flex flex-col gap-4\">\n {/*<Filter />*/}\n <EnhancedTable\n {...props}\n scroll={{\n y: scrollY ? scrollY : undefined,\n x: 0,\n }}\n />\n </div>\n );\n}\n\n// Export all types and components\nexport * from './types';\nexport { EnhancedTable } from './enhanced-table';\nexport { TablePagination } from './table-pagination';\n"]}
@@ -0,0 +1,68 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { EnhancedTable } from './enhanced-table';
3
+ export { EnhancedTable } from './enhanced-table';
4
+ import { useRef, useState, useEffect } from 'react';
5
+ import { debounce } from '../../../lib/helpers';
6
+ export * from './types';
7
+ export { TablePagination } from './table-pagination';
8
+
9
+ function ListingTable(props) {
10
+ const containerRef = useRef();
11
+ const [scrollY, setScrollY] = useState(0);
12
+ const calculateScrollY = debounce(() => {
13
+ if (!containerRef?.current) return;
14
+ const table = containerRef.current?.getElementsByClassName("ant-table-wrapper")?.[0];
15
+ if (containerRef.current?.clientHeight < table?.clientHeight) {
16
+ const thead = containerRef.current?.getElementsByClassName("ant-table-header")?.[0];
17
+ const pagination = containerRef.current?.getElementsByClassName("ant-pagination")?.[0];
18
+ setScrollY(
19
+ containerRef.current.clientHeight - (thead?.clientHeight ?? 0) - (pagination?.clientHeight ?? 0) - 18
20
+ );
21
+ }
22
+ const parentTable = containerRef?.current?.querySelector(".ant-table-body") || containerRef?.current?.querySelector(".ant-table-content");
23
+ const onScrollParent = (e) => {
24
+ const childTables = e.target.querySelectorAll(".ant-table-content");
25
+ childTables.forEach((childTable) => {
26
+ childTable.scrollLeft = e.target.scrollLeft;
27
+ });
28
+ };
29
+ parentTable?.addEventListener("scroll", onScrollParent);
30
+ }, 100);
31
+ useEffect(() => {
32
+ let mutationObserver;
33
+ let resizeObserver;
34
+ if (containerRef?.current) {
35
+ calculateScrollY();
36
+ mutationObserver = new MutationObserver(calculateScrollY);
37
+ mutationObserver.observe(containerRef?.current, {
38
+ attributes: true,
39
+ childList: true,
40
+ subtree: true
41
+ });
42
+ resizeObserver = new ResizeObserver(calculateScrollY);
43
+ resizeObserver.observe(containerRef?.current, {
44
+ attributes: true,
45
+ childList: true,
46
+ subtree: true
47
+ });
48
+ }
49
+ return () => {
50
+ if (mutationObserver) mutationObserver.disconnect();
51
+ if (resizeObserver) resizeObserver.disconnect();
52
+ };
53
+ }, [containerRef]);
54
+ return /* @__PURE__ */ jsx("div", { ref: containerRef, className: "flex flex-col gap-4", children: /* @__PURE__ */ jsx(
55
+ EnhancedTable,
56
+ {
57
+ ...props,
58
+ scroll: {
59
+ y: scrollY ? scrollY : void 0,
60
+ x: 0
61
+ }
62
+ }
63
+ ) });
64
+ }
65
+
66
+ export { ListingTable };
67
+ //# sourceMappingURL=index.mjs.map
68
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/common/interactive/table/index.tsx"],"names":[],"mappings":";;;;;;;;AAOO,SAAS,aAA+C,KAAA,EAA6B;AAC1F,EAAA,MAAM,eAAe,MAAA,EAAY;AACjC,EAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAI,SAAS,CAAC,CAAA;AAExC,EAAA,MAAM,gBAAA,GAAmB,SAAS,MAAM;AACtC,IAAA,IAAI,CAAC,cAAc,OAAA,EAAS;AAE5B,IAAA,MAAM,QAAQ,YAAA,CAAa,OAAA,EAAS,sBAAA,CAAuB,mBAAmB,IAAI,CAAC,CAAA;AAEnF,IAAA,IAAI,YAAA,CAAa,OAAA,EAAS,YAAA,GAAe,KAAA,EAAO,YAAA,EAAc;AAC5D,MAAA,MAAM,QAAQ,YAAA,CAAa,OAAA,EAAS,sBAAA,CAAuB,kBAAkB,IAAI,CAAC,CAAA;AAClF,MAAA,MAAM,aAAa,YAAA,CAAa,OAAA,EAAS,sBAAA,CAAuB,gBAAgB,IAAI,CAAC,CAAA;AACrF,MAAA,UAAA;AAAA,QACE,YAAA,CAAa,QAAQ,YAAA,IAClB,KAAA,EAAO,gBAAgB,CAAA,CAAA,IACvB,UAAA,EAAY,gBAAgB,CAAA,CAAA,GAC7B;AAAA,OACJ;AAAA,IACF;AAGA,IAAA,MAAM,WAAA,GACJ,cAAc,OAAA,EAAS,aAAA,CAAc,iBAAiB,CAAA,IACtD,YAAA,EAAc,OAAA,EAAS,aAAA,CAAc,oBAAoB,CAAA;AAE3D,IAAA,MAAM,cAAA,GAAiB,CAAC,CAAA,KAAW;AACjC,MAAA,MAAM,WAAA,GAAc,CAAA,CAAE,MAAA,CAAO,gBAAA,CAAiB,oBAAoB,CAAA;AAClE,MAAA,WAAA,CAAY,OAAA,CAAQ,CAAC,UAAA,KAAoB;AACvC,QAAA,UAAA,CAAW,UAAA,GAAa,EAAE,MAAA,CAAO,UAAA;AAAA,MACnC,CAAC,CAAA;AAAA,IACH,CAAA;AAEA,IAAA,WAAA,EAAa,gBAAA,CAAiB,UAAU,cAAc,CAAA;AAAA,EACxD,GAAG,GAAG,CAAA;AAEN,EAAA,SAAA,CAAU,MAAM;AACd,IAAA,IAAI,gBAAA;AACJ,IAAA,IAAI,cAAA;AAEJ,IAAA,IAAI,cAAc,OAAA,EAAS;AACzB,MAAA,gBAAA,EAAiB;AAEjB,MAAA,gBAAA,GAAmB,IAAI,iBAAiB,gBAAgB,CAAA;AACxD,MAAA,gBAAA,CAAiB,OAAA,CAAQ,cAAc,OAAA,EAAS;AAAA,QAC9C,UAAA,EAAY,IAAA;AAAA,QACZ,SAAA,EAAW,IAAA;AAAA,QACX,OAAA,EAAS;AAAA,OACV,CAAA;AAED,MAAA,cAAA,GAAiB,IAAI,eAAe,gBAAgB,CAAA;AACpD,MAAA,cAAA,CAAe,OAAA,CAAQ,cAAc,OAAA,EAAS;AAAA,QAC5C,UAAA,EAAY,IAAA;AAAA,QACZ,SAAA,EAAW,IAAA;AAAA,QACX,OAAA,EAAS;AAAA,OACV,CAAA;AAAA,IACH;AAEA,IAAA,OAAO,MAAM;AACX,MAAA,IAAI,gBAAA,mBAAmC,UAAA,EAAW;AAClD,MAAA,IAAI,cAAA,iBAA+B,UAAA,EAAW;AAAA,IAChD,CAAA;AAAA,EACF,CAAA,EAAG,CAAC,YAAY,CAAC,CAAA;AAEjB,EAAA,uBACE,GAAA,CAAC,KAAA,EAAA,EAAI,GAAA,EAAK,YAAA,EAAc,WAAU,qBAAA,EAEhC,QAAA,kBAAA,GAAA;AAAA,IAAC,aAAA;AAAA,IAAA;AAAA,MACE,GAAG,KAAA;AAAA,MACJ,MAAA,EAAQ;AAAA,QACN,CAAA,EAAG,UAAU,OAAA,GAAU,MAAA;AAAA,QACvB,CAAA,EAAG;AAAA;AACL;AAAA,GACF,EACF,CAAA;AAEJ","file":"index.mjs","sourcesContent":["import { EnhancedTable } from './enhanced-table';\nimport { EnhancedTableProps } from './types';\nimport { useEffect, useRef, useState } from 'react';\nimport { debounce } from '../../../lib/helpers';\n\ninterface ListingTableProps<T extends object> extends EnhancedTableProps<T> {}\n\nexport function ListingTable<T extends { [key: string]: any }>(props: ListingTableProps<T>) {\n const containerRef = useRef<any>();\n const [scrollY, setScrollY] = useState(0);\n\n const calculateScrollY = debounce(() => {\n if (!containerRef?.current) return;\n\n const table = containerRef.current?.getElementsByClassName('ant-table-wrapper')?.[0];\n\n if (containerRef.current?.clientHeight < table?.clientHeight) {\n const thead = containerRef.current?.getElementsByClassName('ant-table-header')?.[0];\n const pagination = containerRef.current?.getElementsByClassName('ant-pagination')?.[0];\n setScrollY(\n containerRef.current.clientHeight -\n (thead?.clientHeight ?? 0) -\n (pagination?.clientHeight ?? 0) -\n 18,\n );\n }\n\n // Scroll\n const parentTable =\n containerRef?.current?.querySelector('.ant-table-body') ||\n containerRef?.current?.querySelector('.ant-table-content');\n\n const onScrollParent = (e: any) => {\n const childTables = e.target.querySelectorAll('.ant-table-content');\n childTables.forEach((childTable: any) => {\n childTable.scrollLeft = e.target.scrollLeft;\n });\n };\n\n parentTable?.addEventListener('scroll', onScrollParent);\n }, 100);\n\n useEffect(() => {\n let mutationObserver: any;\n let resizeObserver: any;\n\n if (containerRef?.current) {\n calculateScrollY();\n\n mutationObserver = new MutationObserver(calculateScrollY);\n mutationObserver.observe(containerRef?.current, {\n attributes: true,\n childList: true,\n subtree: true,\n });\n\n resizeObserver = new ResizeObserver(calculateScrollY);\n resizeObserver.observe(containerRef?.current, {\n attributes: true,\n childList: true,\n subtree: true,\n });\n }\n\n return () => {\n if (mutationObserver) mutationObserver.disconnect();\n if (resizeObserver) resizeObserver.disconnect();\n };\n }, [containerRef]);\n\n return (\n <div ref={containerRef} className=\"flex flex-col gap-4\">\n {/*<Filter />*/}\n <EnhancedTable\n {...props}\n scroll={{\n y: scrollY ? scrollY : undefined,\n x: 0,\n }}\n />\n </div>\n );\n}\n\n// Export all types and components\nexport * from './types';\nexport { EnhancedTable } from './enhanced-table';\nexport { TablePagination } from './table-pagination';\n"]}
@@ -0,0 +1,12 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var pagination = require('../pagination');
5
+
6
+ const TablePagination = ({ config }) => {
7
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { className: "border-t px-4 py-3 md:px-6", children: /* @__PURE__ */ jsxRuntime.jsx(pagination.Pagination, { ...config }) });
8
+ };
9
+
10
+ exports.TablePagination = TablePagination;
11
+ //# sourceMappingURL=table-pagination.js.map
12
+ //# sourceMappingURL=table-pagination.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../../src/common/interactive/table/table-pagination.tsx"],"names":["jsx","Pagination"],"mappings":";;;;;AAGO,MAAM,eAAA,GAAkB,CAAC,EAAE,MAAA,EAAO,KAAyC;AAChF,EAAA,uBACEA,cAAA,CAAC,SAAI,SAAA,EAAU,4BAAA,EACb,yCAACC,qBAAA,EAAA,EAAY,GAAG,QAAQ,CAAA,EAC1B,CAAA;AAEJ","file":"table-pagination.js","sourcesContent":["import { Pagination } from '../pagination';\nimport { TablePaginationConfig } from './types';\n\nexport const TablePagination = ({ config }: { config: TablePaginationConfig }) => {\n return (\n <div className=\"border-t px-4 py-3 md:px-6\">\n <Pagination {...config} />\n </div>\n );\n};\n"]}