ikoncomponents 1.4.8 → 1.4.9

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 (575) hide show
  1. package/dist/commands/init.js +57 -0
  2. package/dist/index.js +3 -116
  3. package/dist/utlis/copyDir.js +7 -0
  4. package/package.json +12 -90
  5. package/templates/default/hooks/use-mobile.ts +19 -0
  6. package/templates/default/ikonShade/accordion.tsx +66 -0
  7. package/templates/default/ikonShade/alert-dialog.tsx +179 -0
  8. package/templates/default/ikonShade/alert.tsx +66 -0
  9. package/templates/default/ikonShade/aspect-ratio.tsx +11 -0
  10. package/templates/default/ikonShade/avatar.tsx +53 -0
  11. package/templates/default/ikonShade/badge.tsx +49 -0
  12. package/templates/default/ikonShade/breadcrumb.tsx +109 -0
  13. package/templates/default/ikonShade/button.tsx +64 -0
  14. package/templates/default/ikonShade/calendar.tsx +227 -0
  15. package/templates/default/ikonShade/card.tsx +92 -0
  16. package/templates/default/ikonShade/checkbox.tsx +33 -0
  17. package/templates/default/ikonShade/collapsible.tsx +33 -0
  18. package/templates/default/ikonShade/command.tsx +184 -0
  19. package/templates/default/ikonShade/date-input.tsx +259 -0
  20. package/templates/default/ikonShade/date-range-picker.tsx +103 -0
  21. package/templates/default/ikonShade/dialog.tsx +143 -0
  22. package/templates/default/ikonShade/drawer.tsx +134 -0
  23. package/templates/default/ikonShade/dropdown-menu.tsx +259 -0
  24. package/templates/default/ikonShade/form.tsx +166 -0
  25. package/templates/default/ikonShade/hover-card.tsx +44 -0
  26. package/templates/default/ikonShade/input-otp.tsx +71 -0
  27. package/templates/default/ikonShade/input.tsx +22 -0
  28. package/templates/default/ikonShade/label.tsx +24 -0
  29. package/templates/default/ikonShade/navigation-menu.tsx +195 -0
  30. package/templates/default/ikonShade/popover.tsx +48 -0
  31. package/templates/default/ikonShade/progress.tsx +40 -0
  32. package/templates/default/ikonShade/radio-group.tsx +45 -0
  33. package/templates/default/ikonShade/scroll-area.tsx +58 -0
  34. package/templates/default/ikonShade/select.tsx +184 -0
  35. package/templates/default/ikonShade/separator.tsx +28 -0
  36. package/templates/default/ikonShade/sheet.tsx +139 -0
  37. package/templates/default/ikonShade/sidebar.tsx +726 -0
  38. package/templates/default/ikonShade/skeleton.tsx +15 -0
  39. package/templates/default/ikonShade/slider.tsx +64 -0
  40. package/templates/default/ikonShade/sonner.tsx +25 -0
  41. package/templates/default/ikonShade/switch.tsx +31 -0
  42. package/templates/default/ikonShade/table.tsx +116 -0
  43. package/templates/default/ikonShade/tabs.tsx +67 -0
  44. package/templates/default/ikonShade/textarea.tsx +18 -0
  45. package/templates/default/ikonShade/toggle-group.tsx +83 -0
  46. package/templates/default/ikonShade/toggle.tsx +47 -0
  47. package/templates/default/ikonShade/tooltip.tsx +65 -0
  48. package/templates/default/ikonShade/workflow.tsx +119 -0
  49. package/templates/default/ikoncomponents/action-menu/index.tsx +108 -0
  50. package/templates/default/ikoncomponents/action-menu/type.ts +18 -0
  51. package/templates/default/ikoncomponents/activity-sheet/index.tsx +63 -0
  52. package/templates/default/ikoncomponents/alert-dialog/dialog-context.tsx +65 -0
  53. package/templates/default/ikoncomponents/alert-dialog/index.tsx +80 -0
  54. package/templates/default/ikoncomponents/app-breadcrumb/BreadcrumbProvider.tsx +68 -0
  55. package/templates/default/ikoncomponents/app-breadcrumb/index.tsx +222 -0
  56. package/templates/default/ikoncomponents/big-calendar/big-calender-event/index.tsx +38 -0
  57. package/templates/default/ikoncomponents/big-calendar/big-calender-toolbar/index.tsx +81 -0
  58. package/templates/default/ikoncomponents/big-calendar/index.css +879 -0
  59. package/templates/default/ikoncomponents/big-calendar/index.tsx +59 -0
  60. package/templates/default/ikoncomponents/big-calendar/type.ts +37 -0
  61. package/templates/default/ikoncomponents/buttons/index.tsx +127 -0
  62. package/templates/default/ikoncomponents/combobox-input/index.tsx +75 -0
  63. package/templates/default/ikoncomponents/combobox-input/type.ts +14 -0
  64. package/templates/default/ikoncomponents/custom-combo-dropdown/index.tsx +242 -0
  65. package/templates/default/ikoncomponents/data-table/datatable-column-filter/index.tsx +80 -0
  66. package/templates/default/ikoncomponents/data-table/datatable-faceted-filter/index.tsx +149 -0
  67. package/templates/default/ikoncomponents/data-table/datatable-filter-menu/index.tsx +98 -0
  68. package/templates/default/ikoncomponents/data-table/datatable-pagination/index.tsx +119 -0
  69. package/templates/default/ikoncomponents/data-table/datatable-toolbar/index.tsx +45 -0
  70. package/templates/default/ikoncomponents/data-table/function.ts +7 -0
  71. package/templates/default/ikoncomponents/data-table/index.tsx +549 -0
  72. package/templates/default/ikoncomponents/data-table/type.ts +75 -0
  73. package/templates/default/ikoncomponents/e-chart/index.tsx +183 -0
  74. package/templates/default/ikoncomponents/file-input/index.tsx +27 -0
  75. package/templates/default/ikoncomponents/fileUpload/index.tsx +121 -0
  76. package/templates/default/ikoncomponents/form-fields/combobox-input/index.tsx +111 -0
  77. package/templates/default/ikoncomponents/form-fields/combobox-input-value/index.tsx +121 -0
  78. package/templates/default/ikoncomponents/form-fields/date-input/index.tsx +80 -0
  79. package/templates/default/ikoncomponents/form-fields/file-input/index.tsx +9 -0
  80. package/templates/default/ikoncomponents/form-fields/input/index.tsx +27 -0
  81. package/{dist/ikoncomponents/form-fields/multi-combobox-input/index.js → templates/default/ikoncomponents/form-fields/multi-combobox-input/index.tsx} +574 -381
  82. package/templates/default/ikoncomponents/form-fields/otp-input/index.tsx +39 -0
  83. package/templates/default/ikoncomponents/form-fields/password-input/index.tsx +52 -0
  84. package/templates/default/ikoncomponents/form-fields/phone-input/index.tsx +7 -0
  85. package/templates/default/ikoncomponents/form-fields/textarea/index.tsx +28 -0
  86. package/templates/default/ikoncomponents/form-fields/types/index.ts +46 -0
  87. package/templates/default/ikoncomponents/glowing-effect/index.tsx +171 -0
  88. package/templates/default/ikoncomponents/icon/index.tsx +22 -0
  89. package/templates/default/ikoncomponents/image-cropper-upload/components/cropperImg.css +19 -0
  90. package/{dist/ikoncomponents/image-cropper-upload/components/newCropper.js → templates/default/ikoncomponents/image-cropper-upload/components/newCropper.tsx} +117 -85
  91. package/templates/default/ikoncomponents/image-cropper-upload/components/newImageUploadForm.tsx +352 -0
  92. package/templates/default/ikoncomponents/image-cropper-upload/cropper-form/index.tsx +250 -0
  93. package/templates/default/ikoncomponents/image-cropper-upload/cropper-form-with-modal/index.tsx +32 -0
  94. package/{dist/ikoncomponents/image-cropper-upload/image-cropper/index.js → templates/default/ikoncomponents/image-cropper-upload/image-cropper/index.tsx} +119 -87
  95. package/templates/default/ikoncomponents/image-cropper-upload/index.tsx +95 -0
  96. package/templates/default/ikoncomponents/image-cropper-upload/utils/index.ts +117 -0
  97. package/templates/default/ikoncomponents/loading-spinner/index.tsx +43 -0
  98. package/templates/default/ikoncomponents/main-layout/RefreshContext.tsx +30 -0
  99. package/templates/default/ikoncomponents/main-layout/SidebarNavContext.tsx +103 -0
  100. package/templates/default/ikoncomponents/main-layout/app-sidebar.tsx +36 -0
  101. package/templates/default/ikoncomponents/main-layout/footer.tsx +21 -0
  102. package/templates/default/ikoncomponents/main-layout/header.tsx +53 -0
  103. package/templates/default/ikoncomponents/main-layout/index.tsx +43 -0
  104. package/templates/default/ikoncomponents/main-layout/main-sidebar.tsx +389 -0
  105. package/templates/default/ikoncomponents/main-layout/nav-main.tsx +103 -0
  106. package/templates/default/ikoncomponents/multi-combobox/index.tsx +345 -0
  107. package/templates/default/ikoncomponents/no-data/index.tsx +11 -0
  108. package/templates/default/ikoncomponents/page-wrapper/index.tsx +30 -0
  109. package/templates/default/ikoncomponents/password-strength-meter/index.tsx +49 -0
  110. package/templates/default/ikoncomponents/phone-input/index.tsx +72 -0
  111. package/templates/default/ikoncomponents/provider-wrapper/index.tsx +32 -0
  112. package/templates/default/ikoncomponents/search-input/index.tsx +18 -0
  113. package/templates/default/ikoncomponents/sheet/index.tsx +34 -0
  114. package/templates/default/ikoncomponents/simple-widget/index.tsx +54 -0
  115. package/templates/default/ikoncomponents/skeleton-loader/skeleton-table.tsx +34 -0
  116. package/templates/default/ikoncomponents/skeleton-loader/skeleton-widget.tsx +13 -0
  117. package/templates/default/ikoncomponents/tabs/index.tsx +139 -0
  118. package/{dist/ikoncomponents/tabs/type.d.ts → templates/default/ikoncomponents/tabs/type.ts} +20 -20
  119. package/{dist/ikoncomponents/theme-toggle-btn/index.js → templates/default/ikoncomponents/theme-toggle-btn/index.tsx} +189 -118
  120. package/templates/default/ikoncomponents/title-progress/index.tsx +41 -0
  121. package/templates/default/ikoncomponents/tooltip/index.tsx +17 -0
  122. package/templates/default/ikoncomponents/twolevel-dropdown/convertToDropdownNodes.tsx +33 -0
  123. package/templates/default/ikoncomponents/twolevel-dropdown/index.tsx +279 -0
  124. package/templates/default/ikoncomponents/upload-tab/index.tsx +237 -0
  125. package/templates/default/ikoncomponents/widgets/index.tsx +81 -0
  126. package/templates/default/ikoncomponents/widgets/type.ts +11 -0
  127. package/templates/default/ikoncomponents/work-in-progress/index.tsx +16 -0
  128. package/{dist/index.d.ts → templates/default/index.ts} +234 -139
  129. package/templates/default/styles.css +1159 -0
  130. package/templates/default/utils/actions/account/index.ts +33 -0
  131. package/templates/default/utils/actions/account/type.ts +4 -0
  132. package/{dist/utils/actions/auth/index.js → templates/default/utils/actions/auth/index.ts} +69 -58
  133. package/templates/default/utils/actions/common/revalidate.ts +18 -0
  134. package/templates/default/utils/actions/common/type.ts +4 -0
  135. package/{dist/utils/actions/common/utils.js → templates/default/utils/actions/common/utils.ts} +28 -25
  136. package/templates/default/utils/actions/software/index.ts +106 -0
  137. package/templates/default/utils/api/accountService/index.ts +103 -0
  138. package/templates/default/utils/api/accountService/type.ts +4 -0
  139. package/templates/default/utils/api/file-upload/index.ts +103 -0
  140. package/templates/default/utils/api/file-upload/type.ts +8 -0
  141. package/{dist/utils/api/ikonBaseApi.js → templates/default/utils/api/ikonBaseApi.ts} +132 -104
  142. package/templates/default/utils/api/loginService/index.ts +108 -0
  143. package/{dist/utils/api/loginService/type.d.ts → templates/default/utils/api/loginService/type.ts} +35 -32
  144. package/templates/default/utils/api/softwareService/index.ts +356 -0
  145. package/templates/default/utils/api/softwareService/type.ts +62 -0
  146. package/{dist/utils/border-radius-provider.js → templates/default/utils/border-radius-provider.tsx} +59 -35
  147. package/templates/default/utils/cn.ts +6 -0
  148. package/{dist/utils/font-provider.js → templates/default/utils/font-provider.tsx} +61 -37
  149. package/templates/default/utils/session/cookieSession.ts +49 -0
  150. package/templates/default/utils/theme-provider/index.tsx +11 -0
  151. package/templates/default/utils/token-management/index.ts +115 -0
  152. package/templates/default/utils/token-management/types.ts +6 -0
  153. package/dist/hooks/use-mobile.d.ts +0 -2
  154. package/dist/hooks/use-mobile.d.ts.map +0 -1
  155. package/dist/hooks/use-mobile.js +0 -15
  156. package/dist/ikoncomponents/action-menu/index.d.ts +0 -6
  157. package/dist/ikoncomponents/action-menu/index.d.ts.map +0 -1
  158. package/dist/ikoncomponents/action-menu/index.js +0 -42
  159. package/dist/ikoncomponents/action-menu/type.d.ts +0 -15
  160. package/dist/ikoncomponents/action-menu/type.d.ts.map +0 -1
  161. package/dist/ikoncomponents/action-menu/type.js +0 -1
  162. package/dist/ikoncomponents/activity-sheet/index.d.ts +0 -12
  163. package/dist/ikoncomponents/activity-sheet/index.d.ts.map +0 -1
  164. package/dist/ikoncomponents/activity-sheet/index.js +0 -23
  165. package/dist/ikoncomponents/alert-dialog/dialog-context.d.ts +0 -22
  166. package/dist/ikoncomponents/alert-dialog/dialog-context.d.ts.map +0 -1
  167. package/dist/ikoncomponents/alert-dialog/dialog-context.js +0 -30
  168. package/dist/ikoncomponents/alert-dialog/index.d.ts +0 -15
  169. package/dist/ikoncomponents/alert-dialog/index.d.ts.map +0 -1
  170. package/dist/ikoncomponents/alert-dialog/index.js +0 -20
  171. package/dist/ikoncomponents/app-breadcrumb/BreadcrumbProvider.d.ts +0 -19
  172. package/dist/ikoncomponents/app-breadcrumb/BreadcrumbProvider.d.ts.map +0 -1
  173. package/dist/ikoncomponents/app-breadcrumb/BreadcrumbProvider.js +0 -43
  174. package/dist/ikoncomponents/app-breadcrumb/index.d.ts +0 -6
  175. package/dist/ikoncomponents/app-breadcrumb/index.d.ts.map +0 -1
  176. package/dist/ikoncomponents/app-breadcrumb/index.js +0 -57
  177. package/dist/ikoncomponents/big-calendar/big-calender-event/index.d.ts +0 -6
  178. package/dist/ikoncomponents/big-calendar/big-calender-event/index.d.ts.map +0 -1
  179. package/dist/ikoncomponents/big-calendar/big-calender-event/index.js +0 -16
  180. package/dist/ikoncomponents/big-calendar/big-calender-toolbar/index.d.ts +0 -3
  181. package/dist/ikoncomponents/big-calendar/big-calender-toolbar/index.d.ts.map +0 -1
  182. package/dist/ikoncomponents/big-calendar/big-calender-toolbar/index.js +0 -39
  183. package/dist/ikoncomponents/big-calendar/index.d.ts +0 -4
  184. package/dist/ikoncomponents/big-calendar/index.d.ts.map +0 -1
  185. package/dist/ikoncomponents/big-calendar/index.js +0 -35
  186. package/dist/ikoncomponents/big-calendar/type.d.ts +0 -32
  187. package/dist/ikoncomponents/big-calendar/type.d.ts.map +0 -1
  188. package/dist/ikoncomponents/big-calendar/type.js +0 -1
  189. package/dist/ikoncomponents/buttons/index.d.ts +0 -19
  190. package/dist/ikoncomponents/buttons/index.d.ts.map +0 -1
  191. package/dist/ikoncomponents/buttons/index.js +0 -38
  192. package/dist/ikoncomponents/combobox-input/index.d.ts +0 -3
  193. package/dist/ikoncomponents/combobox-input/index.d.ts.map +0 -1
  194. package/dist/ikoncomponents/combobox-input/index.js +0 -18
  195. package/dist/ikoncomponents/combobox-input/type.d.ts +0 -14
  196. package/dist/ikoncomponents/combobox-input/type.d.ts.map +0 -1
  197. package/dist/ikoncomponents/combobox-input/type.js +0 -1
  198. package/dist/ikoncomponents/custom-combo-dropdown/index.d.ts +0 -22
  199. package/dist/ikoncomponents/custom-combo-dropdown/index.d.ts.map +0 -1
  200. package/dist/ikoncomponents/custom-combo-dropdown/index.js +0 -85
  201. package/dist/ikoncomponents/data-table/datatable-column-filter/index.d.ts +0 -3
  202. package/dist/ikoncomponents/data-table/datatable-column-filter/index.d.ts.map +0 -1
  203. package/dist/ikoncomponents/data-table/datatable-column-filter/index.js +0 -22
  204. package/dist/ikoncomponents/data-table/datatable-faceted-filter/index.d.ts +0 -3
  205. package/dist/ikoncomponents/data-table/datatable-faceted-filter/index.d.ts.map +0 -1
  206. package/dist/ikoncomponents/data-table/datatable-faceted-filter/index.js +0 -35
  207. package/dist/ikoncomponents/data-table/datatable-filter-menu/index.d.ts +0 -3
  208. package/dist/ikoncomponents/data-table/datatable-filter-menu/index.d.ts.map +0 -1
  209. package/dist/ikoncomponents/data-table/datatable-filter-menu/index.js +0 -38
  210. package/dist/ikoncomponents/data-table/datatable-pagination/index.d.ts +0 -3
  211. package/dist/ikoncomponents/data-table/datatable-pagination/index.d.ts.map +0 -1
  212. package/dist/ikoncomponents/data-table/datatable-pagination/index.js +0 -13
  213. package/dist/ikoncomponents/data-table/datatable-toolbar/index.d.ts +0 -3
  214. package/dist/ikoncomponents/data-table/datatable-toolbar/index.d.ts.map +0 -1
  215. package/dist/ikoncomponents/data-table/datatable-toolbar/index.js +0 -18
  216. package/dist/ikoncomponents/data-table/function.d.ts +0 -2
  217. package/dist/ikoncomponents/data-table/function.d.ts.map +0 -1
  218. package/dist/ikoncomponents/data-table/function.js +0 -6
  219. package/dist/ikoncomponents/data-table/index.d.ts +0 -3
  220. package/dist/ikoncomponents/data-table/index.d.ts.map +0 -1
  221. package/dist/ikoncomponents/data-table/index.js +0 -223
  222. package/dist/ikoncomponents/data-table/type.d.ts +0 -61
  223. package/dist/ikoncomponents/data-table/type.d.ts.map +0 -1
  224. package/dist/ikoncomponents/data-table/type.js +0 -1
  225. package/dist/ikoncomponents/e-chart/index.d.ts +0 -16
  226. package/dist/ikoncomponents/e-chart/index.d.ts.map +0 -1
  227. package/dist/ikoncomponents/e-chart/index.js +0 -115
  228. package/dist/ikoncomponents/file-input/index.d.ts +0 -2
  229. package/dist/ikoncomponents/file-input/index.d.ts.map +0 -1
  230. package/dist/ikoncomponents/file-input/index.js +0 -21
  231. package/dist/ikoncomponents/fileUpload/index.d.ts +0 -16
  232. package/dist/ikoncomponents/fileUpload/index.d.ts.map +0 -1
  233. package/dist/ikoncomponents/fileUpload/index.js +0 -69
  234. package/dist/ikoncomponents/form-fields/combobox-input/index.d.ts +0 -3
  235. package/dist/ikoncomponents/form-fields/combobox-input/index.d.ts.map +0 -1
  236. package/dist/ikoncomponents/form-fields/combobox-input/index.js +0 -21
  237. package/dist/ikoncomponents/form-fields/combobox-input-value/index.d.ts +0 -19
  238. package/dist/ikoncomponents/form-fields/combobox-input-value/index.d.ts.map +0 -1
  239. package/dist/ikoncomponents/form-fields/combobox-input-value/index.js +0 -26
  240. package/dist/ikoncomponents/form-fields/date-input/index.d.ts +0 -3
  241. package/dist/ikoncomponents/form-fields/date-input/index.d.ts.map +0 -1
  242. package/dist/ikoncomponents/form-fields/date-input/index.js +0 -15
  243. package/dist/ikoncomponents/form-fields/file-input/index.d.ts +0 -2
  244. package/dist/ikoncomponents/form-fields/file-input/index.d.ts.map +0 -1
  245. package/dist/ikoncomponents/form-fields/file-input/index.js +0 -4
  246. package/dist/ikoncomponents/form-fields/input/index.d.ts +0 -3
  247. package/dist/ikoncomponents/form-fields/input/index.d.ts.map +0 -1
  248. package/dist/ikoncomponents/form-fields/input/index.js +0 -18
  249. package/dist/ikoncomponents/form-fields/multi-combobox-input/index.d.ts +0 -7
  250. package/dist/ikoncomponents/form-fields/multi-combobox-input/index.d.ts.map +0 -1
  251. package/dist/ikoncomponents/form-fields/otp-input/index.d.ts +0 -3
  252. package/dist/ikoncomponents/form-fields/otp-input/index.d.ts.map +0 -1
  253. package/dist/ikoncomponents/form-fields/otp-input/index.js +0 -18
  254. package/dist/ikoncomponents/form-fields/password-input/index.d.ts +0 -3
  255. package/dist/ikoncomponents/form-fields/password-input/index.d.ts.map +0 -1
  256. package/dist/ikoncomponents/form-fields/password-input/index.js +0 -23
  257. package/dist/ikoncomponents/form-fields/phone-input/index.d.ts +0 -2
  258. package/dist/ikoncomponents/form-fields/phone-input/index.d.ts.map +0 -1
  259. package/dist/ikoncomponents/form-fields/phone-input/index.js +0 -4
  260. package/dist/ikoncomponents/form-fields/textarea/index.d.ts +0 -3
  261. package/dist/ikoncomponents/form-fields/textarea/index.d.ts.map +0 -1
  262. package/dist/ikoncomponents/form-fields/textarea/index.js +0 -18
  263. package/dist/ikoncomponents/form-fields/types/index.d.ts +0 -37
  264. package/dist/ikoncomponents/form-fields/types/index.d.ts.map +0 -1
  265. package/dist/ikoncomponents/form-fields/types/index.js +0 -1
  266. package/dist/ikoncomponents/glowing-effect/index.d.ts +0 -15
  267. package/dist/ikoncomponents/glowing-effect/index.d.ts.map +0 -1
  268. package/dist/ikoncomponents/glowing-effect/index.js +0 -84
  269. package/dist/ikoncomponents/icon/index.d.ts +0 -9
  270. package/dist/ikoncomponents/icon/index.d.ts.map +0 -1
  271. package/dist/ikoncomponents/icon/index.js +0 -23
  272. package/dist/ikoncomponents/image-cropper-upload/components/newCropper.d.ts +0 -16
  273. package/dist/ikoncomponents/image-cropper-upload/components/newCropper.d.ts.map +0 -1
  274. package/dist/ikoncomponents/image-cropper-upload/components/newImageUploadForm.d.ts +0 -8
  275. package/dist/ikoncomponents/image-cropper-upload/components/newImageUploadForm.d.ts.map +0 -1
  276. package/dist/ikoncomponents/image-cropper-upload/components/newImageUploadForm.js +0 -145
  277. package/dist/ikoncomponents/image-cropper-upload/cropper-form/index.d.ts +0 -7
  278. package/dist/ikoncomponents/image-cropper-upload/cropper-form/index.d.ts.map +0 -1
  279. package/dist/ikoncomponents/image-cropper-upload/cropper-form/index.js +0 -92
  280. package/dist/ikoncomponents/image-cropper-upload/cropper-form-with-modal/index.d.ts +0 -7
  281. package/dist/ikoncomponents/image-cropper-upload/cropper-form-with-modal/index.d.ts.map +0 -1
  282. package/dist/ikoncomponents/image-cropper-upload/cropper-form-with-modal/index.js +0 -14
  283. package/dist/ikoncomponents/image-cropper-upload/image-cropper/index.d.ts +0 -15
  284. package/dist/ikoncomponents/image-cropper-upload/image-cropper/index.d.ts.map +0 -1
  285. package/dist/ikoncomponents/image-cropper-upload/index.d.ts +0 -28
  286. package/dist/ikoncomponents/image-cropper-upload/index.d.ts.map +0 -1
  287. package/dist/ikoncomponents/image-cropper-upload/index.js +0 -49
  288. package/dist/ikoncomponents/image-cropper-upload/utils/index.d.ts +0 -17
  289. package/dist/ikoncomponents/image-cropper-upload/utils/index.d.ts.map +0 -1
  290. package/dist/ikoncomponents/image-cropper-upload/utils/index.js +0 -73
  291. package/dist/ikoncomponents/loading-spinner/index.d.ts +0 -10
  292. package/dist/ikoncomponents/loading-spinner/index.d.ts.map +0 -1
  293. package/dist/ikoncomponents/loading-spinner/index.js +0 -19
  294. package/dist/ikoncomponents/main-layout/RefreshContext.d.ts +0 -11
  295. package/dist/ikoncomponents/main-layout/RefreshContext.d.ts.map +0 -1
  296. package/dist/ikoncomponents/main-layout/RefreshContext.js +0 -17
  297. package/dist/ikoncomponents/main-layout/SidebarNavContext.d.ts +0 -34
  298. package/dist/ikoncomponents/main-layout/SidebarNavContext.d.ts.map +0 -1
  299. package/dist/ikoncomponents/main-layout/SidebarNavContext.js +0 -52
  300. package/dist/ikoncomponents/main-layout/app-sidebar.d.ts +0 -4
  301. package/dist/ikoncomponents/main-layout/app-sidebar.d.ts.map +0 -1
  302. package/dist/ikoncomponents/main-layout/app-sidebar.js +0 -24
  303. package/dist/ikoncomponents/main-layout/footer.d.ts +0 -2
  304. package/dist/ikoncomponents/main-layout/footer.d.ts.map +0 -1
  305. package/dist/ikoncomponents/main-layout/footer.js +0 -5
  306. package/dist/ikoncomponents/main-layout/header.d.ts +0 -4
  307. package/dist/ikoncomponents/main-layout/header.d.ts.map +0 -1
  308. package/dist/ikoncomponents/main-layout/header.js +0 -15
  309. package/dist/ikoncomponents/main-layout/index.d.ts +0 -7
  310. package/dist/ikoncomponents/main-layout/index.d.ts.map +0 -1
  311. package/dist/ikoncomponents/main-layout/index.js +0 -12
  312. package/dist/ikoncomponents/main-layout/main-sidebar.d.ts +0 -61
  313. package/dist/ikoncomponents/main-layout/main-sidebar.d.ts.map +0 -1
  314. package/dist/ikoncomponents/main-layout/main-sidebar.js +0 -119
  315. package/dist/ikoncomponents/main-layout/nav-main.d.ts +0 -12
  316. package/dist/ikoncomponents/main-layout/nav-main.d.ts.map +0 -1
  317. package/dist/ikoncomponents/main-layout/nav-main.js +0 -33
  318. package/dist/ikoncomponents/multi-combobox/index.d.ts +0 -14
  319. package/dist/ikoncomponents/multi-combobox/index.d.ts.map +0 -1
  320. package/dist/ikoncomponents/multi-combobox/index.js +0 -202
  321. package/dist/ikoncomponents/no-data/index.d.ts +0 -4
  322. package/dist/ikoncomponents/no-data/index.d.ts.map +0 -1
  323. package/dist/ikoncomponents/no-data/index.js +0 -5
  324. package/dist/ikoncomponents/page-wrapper/index.d.ts +0 -10
  325. package/dist/ikoncomponents/page-wrapper/index.d.ts.map +0 -1
  326. package/dist/ikoncomponents/page-wrapper/index.js +0 -7
  327. package/dist/ikoncomponents/password-strength-meter/index.d.ts +0 -4
  328. package/dist/ikoncomponents/password-strength-meter/index.d.ts.map +0 -1
  329. package/dist/ikoncomponents/password-strength-meter/index.js +0 -40
  330. package/dist/ikoncomponents/phone-input/index.d.ts +0 -2
  331. package/dist/ikoncomponents/phone-input/index.d.ts.map +0 -1
  332. package/dist/ikoncomponents/phone-input/index.js +0 -41
  333. package/dist/ikoncomponents/provider-wrapper/index.d.ts +0 -7
  334. package/dist/ikoncomponents/provider-wrapper/index.d.ts.map +0 -1
  335. package/dist/ikoncomponents/provider-wrapper/index.js +0 -10
  336. package/dist/ikoncomponents/search-input/index.d.ts +0 -2
  337. package/dist/ikoncomponents/search-input/index.d.ts.map +0 -1
  338. package/dist/ikoncomponents/search-input/index.js +0 -19
  339. package/dist/ikoncomponents/sheet/index.d.ts +0 -11
  340. package/dist/ikoncomponents/sheet/index.d.ts.map +0 -1
  341. package/dist/ikoncomponents/sheet/index.js +0 -6
  342. package/dist/ikoncomponents/simple-widget/index.d.ts +0 -15
  343. package/dist/ikoncomponents/simple-widget/index.d.ts.map +0 -1
  344. package/dist/ikoncomponents/simple-widget/index.js +0 -14
  345. package/dist/ikoncomponents/skeleton-loader/skeleton-table.d.ts +0 -6
  346. package/dist/ikoncomponents/skeleton-loader/skeleton-table.d.ts.map +0 -1
  347. package/dist/ikoncomponents/skeleton-loader/skeleton-table.js +0 -6
  348. package/dist/ikoncomponents/skeleton-loader/skeleton-widget.d.ts +0 -4
  349. package/dist/ikoncomponents/skeleton-loader/skeleton-widget.d.ts.map +0 -1
  350. package/dist/ikoncomponents/skeleton-loader/skeleton-widget.js +0 -5
  351. package/dist/ikoncomponents/tabs/index.d.ts +0 -3
  352. package/dist/ikoncomponents/tabs/index.d.ts.map +0 -1
  353. package/dist/ikoncomponents/tabs/index.js +0 -50
  354. package/dist/ikoncomponents/tabs/type.d.ts.map +0 -1
  355. package/dist/ikoncomponents/tabs/type.js +0 -2
  356. package/dist/ikoncomponents/theme-toggle-btn/index.d.ts +0 -2
  357. package/dist/ikoncomponents/theme-toggle-btn/index.d.ts.map +0 -1
  358. package/dist/ikoncomponents/title-progress/index.d.ts +0 -13
  359. package/dist/ikoncomponents/title-progress/index.d.ts.map +0 -1
  360. package/dist/ikoncomponents/title-progress/index.js +0 -10
  361. package/dist/ikoncomponents/tooltip/index.d.ts +0 -6
  362. package/dist/ikoncomponents/tooltip/index.d.ts.map +0 -1
  363. package/dist/ikoncomponents/tooltip/index.js +0 -5
  364. package/dist/ikoncomponents/twolevel-dropdown/convertToDropdownNodes.d.ts +0 -10
  365. package/dist/ikoncomponents/twolevel-dropdown/convertToDropdownNodes.d.ts.map +0 -1
  366. package/dist/ikoncomponents/twolevel-dropdown/convertToDropdownNodes.js +0 -24
  367. package/dist/ikoncomponents/twolevel-dropdown/index.d.ts +0 -32
  368. package/dist/ikoncomponents/twolevel-dropdown/index.d.ts.map +0 -1
  369. package/dist/ikoncomponents/twolevel-dropdown/index.js +0 -143
  370. package/dist/ikoncomponents/upload-tab/index.d.ts +0 -2
  371. package/dist/ikoncomponents/upload-tab/index.d.ts.map +0 -1
  372. package/dist/ikoncomponents/upload-tab/index.js +0 -92
  373. package/dist/ikoncomponents/widgets/index.d.ts +0 -3
  374. package/dist/ikoncomponents/widgets/index.d.ts.map +0 -1
  375. package/dist/ikoncomponents/widgets/index.js +0 -14
  376. package/dist/ikoncomponents/widgets/type.d.ts +0 -11
  377. package/dist/ikoncomponents/widgets/type.d.ts.map +0 -1
  378. package/dist/ikoncomponents/widgets/type.js +0 -2
  379. package/dist/ikoncomponents/work-in-progress/index.d.ts +0 -2
  380. package/dist/ikoncomponents/work-in-progress/index.d.ts.map +0 -1
  381. package/dist/ikoncomponents/work-in-progress/index.js +0 -4
  382. package/dist/index.d.ts.map +0 -1
  383. package/dist/shadcn/accordion.d.ts +0 -8
  384. package/dist/shadcn/accordion.d.ts.map +0 -1
  385. package/dist/shadcn/accordion.js +0 -33
  386. package/dist/shadcn/alert-dialog.d.ts +0 -21
  387. package/dist/shadcn/alert-dialog.d.ts.map +0 -1
  388. package/dist/shadcn/alert-dialog.js +0 -83
  389. package/dist/shadcn/alert.d.ts +0 -10
  390. package/dist/shadcn/alert.d.ts.map +0 -1
  391. package/dist/shadcn/alert.js +0 -38
  392. package/dist/shadcn/aspect-ratio.d.ts +0 -4
  393. package/dist/shadcn/aspect-ratio.d.ts.map +0 -1
  394. package/dist/shadcn/aspect-ratio.js +0 -19
  395. package/dist/shadcn/avatar.d.ts +0 -7
  396. package/dist/shadcn/avatar.d.ts.map +0 -1
  397. package/dist/shadcn/avatar.js +0 -28
  398. package/dist/shadcn/badge.d.ts +0 -10
  399. package/dist/shadcn/badge.d.ts.map +0 -1
  400. package/dist/shadcn/badge.js +0 -35
  401. package/dist/shadcn/breadcrumb.d.ts +0 -12
  402. package/dist/shadcn/breadcrumb.d.ts.map +0 -1
  403. package/dist/shadcn/breadcrumb.js +0 -45
  404. package/dist/shadcn/button.d.ts +0 -11
  405. package/dist/shadcn/button.d.ts.map +0 -1
  406. package/dist/shadcn/button.js +0 -47
  407. package/dist/shadcn/calendar.d.ts +0 -9
  408. package/dist/shadcn/calendar.d.ts.map +0 -1
  409. package/dist/shadcn/calendar.js +0 -61
  410. package/dist/shadcn/card.d.ts +0 -10
  411. package/dist/shadcn/card.d.ts.map +0 -1
  412. package/dist/shadcn/card.js +0 -42
  413. package/dist/shadcn/checkbox.d.ts +0 -5
  414. package/dist/shadcn/checkbox.d.ts.map +0 -1
  415. package/dist/shadcn/checkbox.js +0 -21
  416. package/dist/shadcn/collapsible.d.ts +0 -6
  417. package/dist/shadcn/collapsible.d.ts.map +0 -1
  418. package/dist/shadcn/collapsible.js +0 -27
  419. package/dist/shadcn/command.d.ts +0 -19
  420. package/dist/shadcn/command.d.ts.map +0 -1
  421. package/dist/shadcn/command.js +0 -54
  422. package/dist/shadcn/date-input.d.ts +0 -8
  423. package/dist/shadcn/date-input.d.ts.map +0 -1
  424. package/dist/shadcn/date-input.js +0 -179
  425. package/dist/shadcn/date-range-picker.d.ts +0 -25
  426. package/dist/shadcn/date-range-picker.d.ts.map +0 -1
  427. package/dist/shadcn/date-range-picker.js +0 -45
  428. package/dist/shadcn/dialog.d.ts +0 -16
  429. package/dist/shadcn/dialog.d.ts.map +0 -1
  430. package/dist/shadcn/dialog.js +0 -57
  431. package/dist/shadcn/drawer.d.ts +0 -14
  432. package/dist/shadcn/drawer.d.ts.map +0 -1
  433. package/dist/shadcn/drawer.js +0 -56
  434. package/dist/shadcn/dropdown-menu.d.ts +0 -26
  435. package/dist/shadcn/dropdown-menu.d.ts.map +0 -1
  436. package/dist/shadcn/dropdown-menu.js +0 -77
  437. package/dist/shadcn/form.d.ts +0 -25
  438. package/dist/shadcn/form.d.ts.map +0 -1
  439. package/dist/shadcn/form.js +0 -70
  440. package/dist/shadcn/hover-card.d.ts +0 -7
  441. package/dist/shadcn/hover-card.d.ts.map +0 -1
  442. package/dist/shadcn/hover-card.js +0 -28
  443. package/dist/shadcn/input-otp.d.ts +0 -35
  444. package/dist/shadcn/input-otp.d.ts.map +0 -1
  445. package/dist/shadcn/input-otp.js +0 -40
  446. package/dist/shadcn/input.d.ts +0 -4
  447. package/dist/shadcn/input.d.ts.map +0 -1
  448. package/dist/shadcn/input.js +0 -18
  449. package/dist/shadcn/label.d.ts +0 -5
  450. package/dist/shadcn/label.d.ts.map +0 -1
  451. package/dist/shadcn/label.js +0 -20
  452. package/dist/shadcn/navigation-menu.d.ts +0 -17
  453. package/dist/shadcn/navigation-menu.d.ts.map +0 -1
  454. package/dist/shadcn/navigation-menu.js +0 -74
  455. package/dist/shadcn/popover.d.ts +0 -8
  456. package/dist/shadcn/popover.d.ts.map +0 -1
  457. package/dist/shadcn/popover.js +0 -32
  458. package/dist/shadcn/progress.d.ts +0 -9
  459. package/dist/shadcn/progress.d.ts.map +0 -1
  460. package/dist/shadcn/progress.js +0 -23
  461. package/dist/shadcn/radio-group.d.ts +0 -6
  462. package/dist/shadcn/radio-group.d.ts.map +0 -1
  463. package/dist/shadcn/radio-group.js +0 -25
  464. package/dist/shadcn/scroll-area.d.ts +0 -6
  465. package/dist/shadcn/scroll-area.d.ts.map +0 -1
  466. package/dist/shadcn/scroll-area.js +0 -26
  467. package/dist/shadcn/select.d.ts +0 -16
  468. package/dist/shadcn/select.d.ts.map +0 -1
  469. package/dist/shadcn/select.js +0 -59
  470. package/dist/shadcn/separator.d.ts +0 -5
  471. package/dist/shadcn/separator.d.ts.map +0 -1
  472. package/dist/shadcn/separator.js +0 -20
  473. package/dist/shadcn/sheet.d.ts +0 -14
  474. package/dist/shadcn/sheet.d.ts.map +0 -1
  475. package/dist/shadcn/sheet.js +0 -61
  476. package/dist/shadcn/sidebar.d.ts +0 -70
  477. package/dist/shadcn/sidebar.d.ts.map +0 -1
  478. package/dist/shadcn/sidebar.js +0 -242
  479. package/dist/shadcn/skeleton.d.ts +0 -4
  480. package/dist/shadcn/skeleton.d.ts.map +0 -1
  481. package/dist/shadcn/skeleton.js +0 -18
  482. package/dist/shadcn/slider.d.ts +0 -5
  483. package/dist/shadcn/slider.d.ts.map +0 -1
  484. package/dist/shadcn/slider.js +0 -26
  485. package/dist/shadcn/sonner.d.ts +0 -4
  486. package/dist/shadcn/sonner.d.ts.map +0 -1
  487. package/dist/shadcn/sonner.js +0 -25
  488. package/dist/shadcn/switch.d.ts +0 -5
  489. package/dist/shadcn/switch.d.ts.map +0 -1
  490. package/dist/shadcn/switch.js +0 -20
  491. package/dist/shadcn/table.d.ts +0 -11
  492. package/dist/shadcn/table.d.ts.map +0 -1
  493. package/dist/shadcn/table.js +0 -47
  494. package/dist/shadcn/tabs.d.ts +0 -8
  495. package/dist/shadcn/tabs.d.ts.map +0 -1
  496. package/dist/shadcn/tabs.js +0 -32
  497. package/dist/shadcn/textarea.d.ts +0 -4
  498. package/dist/shadcn/textarea.d.ts.map +0 -1
  499. package/dist/shadcn/textarea.js +0 -18
  500. package/dist/shadcn/toggle-group.d.ts +0 -10
  501. package/dist/shadcn/toggle-group.d.ts.map +0 -1
  502. package/dist/shadcn/toggle-group.js +0 -35
  503. package/dist/shadcn/toggle.d.ts +0 -10
  504. package/dist/shadcn/toggle.d.ts.map +0 -1
  505. package/dist/shadcn/toggle.js +0 -38
  506. package/dist/shadcn/tooltip.d.ts +0 -8
  507. package/dist/shadcn/tooltip.d.ts.map +0 -1
  508. package/dist/shadcn/tooltip.js +0 -32
  509. package/dist/shadcn/workflow.d.ts +0 -21
  510. package/dist/shadcn/workflow.d.ts.map +0 -1
  511. package/dist/shadcn/workflow.js +0 -20
  512. package/dist/styles.css +0 -1302
  513. package/dist/utils/actions/account/index.d.ts +0 -6
  514. package/dist/utils/actions/account/index.d.ts.map +0 -1
  515. package/dist/utils/actions/account/index.js +0 -28
  516. package/dist/utils/actions/account/type.d.ts +0 -5
  517. package/dist/utils/actions/account/type.d.ts.map +0 -1
  518. package/dist/utils/actions/account/type.js +0 -1
  519. package/dist/utils/actions/auth/index.d.ts +0 -8
  520. package/dist/utils/actions/auth/index.d.ts.map +0 -1
  521. package/dist/utils/actions/common/revalidate.d.ts +0 -3
  522. package/dist/utils/actions/common/revalidate.d.ts.map +0 -1
  523. package/dist/utils/actions/common/revalidate.js +0 -14
  524. package/dist/utils/actions/common/type.d.ts +0 -5
  525. package/dist/utils/actions/common/type.d.ts.map +0 -1
  526. package/dist/utils/actions/common/type.js +0 -1
  527. package/dist/utils/actions/common/utils.d.ts +0 -6
  528. package/dist/utils/actions/common/utils.d.ts.map +0 -1
  529. package/dist/utils/actions/software/index.d.ts +0 -12
  530. package/dist/utils/actions/software/index.d.ts.map +0 -1
  531. package/dist/utils/actions/software/index.js +0 -75
  532. package/dist/utils/api/accountService/index.d.ts +0 -24
  533. package/dist/utils/api/accountService/index.d.ts.map +0 -1
  534. package/dist/utils/api/accountService/index.js +0 -64
  535. package/dist/utils/api/accountService/type.d.ts +0 -5
  536. package/dist/utils/api/accountService/type.d.ts.map +0 -1
  537. package/dist/utils/api/accountService/type.js +0 -1
  538. package/dist/utils/api/file-upload/index.d.ts +0 -6
  539. package/dist/utils/api/file-upload/index.d.ts.map +0 -1
  540. package/dist/utils/api/file-upload/index.js +0 -80
  541. package/dist/utils/api/file-upload/type.d.ts +0 -7
  542. package/dist/utils/api/file-upload/type.d.ts.map +0 -1
  543. package/dist/utils/api/file-upload/type.js +0 -1
  544. package/dist/utils/api/ikonBaseApi.d.ts +0 -13
  545. package/dist/utils/api/ikonBaseApi.d.ts.map +0 -1
  546. package/dist/utils/api/loginService/index.d.ts +0 -13
  547. package/dist/utils/api/loginService/index.d.ts.map +0 -1
  548. package/dist/utils/api/loginService/index.js +0 -72
  549. package/dist/utils/api/loginService/type.d.ts.map +0 -1
  550. package/dist/utils/api/loginService/type.js +0 -1
  551. package/dist/utils/api/softwareService/index.d.ts +0 -65
  552. package/dist/utils/api/softwareService/index.d.ts.map +0 -1
  553. package/dist/utils/api/softwareService/index.js +0 -212
  554. package/dist/utils/api/softwareService/type.d.ts +0 -55
  555. package/dist/utils/api/softwareService/type.d.ts.map +0 -1
  556. package/dist/utils/api/softwareService/type.js +0 -1
  557. package/dist/utils/border-radius-provider.d.ts +0 -12
  558. package/dist/utils/border-radius-provider.d.ts.map +0 -1
  559. package/dist/utils/cn.d.ts +0 -3
  560. package/dist/utils/cn.d.ts.map +0 -1
  561. package/dist/utils/cn.js +0 -5
  562. package/dist/utils/font-provider.d.ts +0 -12
  563. package/dist/utils/font-provider.d.ts.map +0 -1
  564. package/dist/utils/session/cookieSession.d.ts +0 -9
  565. package/dist/utils/session/cookieSession.d.ts.map +0 -1
  566. package/dist/utils/session/cookieSession.js +0 -33
  567. package/dist/utils/theme-provider/index.d.ts +0 -4
  568. package/dist/utils/theme-provider/index.d.ts.map +0 -1
  569. package/dist/utils/theme-provider/index.js +0 -18
  570. package/dist/utils/token-management/index.d.ts +0 -11
  571. package/dist/utils/token-management/index.d.ts.map +0 -1
  572. package/dist/utils/token-management/index.js +0 -69
  573. package/dist/utils/token-management/types.d.ts +0 -7
  574. package/dist/utils/token-management/types.d.ts.map +0 -1
  575. package/dist/utils/token-management/types.js +0 -1
@@ -0,0 +1,549 @@
1
+ "use client";
2
+ import React, {
3
+ forwardRef,
4
+ useEffect,
5
+ useImperativeHandle,
6
+ useState,
7
+ } from "react";
8
+ import {
9
+ ColumnDef,
10
+ ColumnFiltersState,
11
+ SortingState,
12
+ VisibilityState,
13
+ GroupingState,
14
+ flexRender,
15
+ getCoreRowModel,
16
+ getFilteredRowModel,
17
+ getPaginationRowModel,
18
+ getSortedRowModel,
19
+ getGroupedRowModel,
20
+ getExpandedRowModel,
21
+ useReactTable,
22
+ getFacetedUniqueValues,
23
+ getFacetedMinMaxValues,
24
+ getFacetedRowModel,
25
+ Header,
26
+ Row,
27
+ PaginationState,
28
+ } from "@tanstack/react-table";
29
+ import {
30
+ ArrowDown,
31
+ ArrowDownToLine,
32
+ ArrowUp,
33
+ ArrowUpToLine,
34
+ ChevronDown,
35
+ ChevronLast,
36
+ ChevronRight,
37
+ ChevronUp,
38
+ X,
39
+ } from "lucide-react";
40
+
41
+ import { Button } from "../../ikonShade/button";
42
+ import {
43
+ Table,
44
+ TableBody,
45
+ TableCell,
46
+ TableFooter,
47
+ TableHead,
48
+ TableHeader,
49
+ TableRow,
50
+ } from "../../ikonShade/table";
51
+ import { DataTableToolbar } from "./datatable-toolbar";
52
+ import { getDataTableColumnTitle } from "./function";
53
+ import { DataTableProps, DragDropHeaderProp, DTColumnsProps } from "./type";
54
+ import { Checkbox } from "../../ikonShade/checkbox";
55
+ import { DataTablePagination } from "./datatable-pagination";
56
+ import { ActionMenu } from "../action-menu";
57
+ import { cx } from "class-variance-authority";
58
+
59
+ export const DataTable = (
60
+ <TData, TValue>(
61
+ { columns, data, extraParams, onTableReady }: DataTableProps<TData, TValue>,
62
+ ref: any
63
+ ) => {
64
+ const [sorting, setSorting] = React.useState<SortingState>([]);
65
+ const [globalFilter, setGlobalFilter] = React.useState("");
66
+ const [columnFilters, setColumnFilters] =
67
+ React.useState<ColumnFiltersState>([]);
68
+
69
+ const [pagination, setPagination] = React.useState<PaginationState>({
70
+ pageIndex: extraParams?.pageIndex || 0,
71
+ pageSize: extraParams?.pageSize || 15,
72
+ });
73
+ // useImperativeHandle(ref, () => ({
74
+ // toggleAllRowsExpanded: (expanded: boolean) => {
75
+ // table.toggleAllRowsExpanded(expanded);
76
+ // },
77
+ // getTableInstance: () => table, // Optional: Expose the entire table instance if needed
78
+ // }));
79
+ const [columnVisibility, setColumnVisibility] =
80
+ React.useState<VisibilityState>({});
81
+ const [grouping, setGrouping] = React.useState<GroupingState>([]);
82
+ const [expanded, setExpanded] = React.useState({});
83
+ const [rowSelection, setRowSelection] = React.useState({});
84
+
85
+ columns = columns.map((column: any) => {
86
+ if (!column?.filterFn) {
87
+ column.filterFn = "arrIncludesSome";
88
+ }
89
+ return column;
90
+ });
91
+
92
+ useEffect(() => {
93
+ if (extraParams?.checkBoxColumnCallback)
94
+ extraParams.checkBoxColumnCallback(
95
+ table.getFilteredSelectedRowModel().rows
96
+ );
97
+ }, [rowSelection]);
98
+
99
+ if (extraParams?.checkBoxColumn) {
100
+ columns.splice(0, 0, {
101
+ id: "checkBoxColumn",
102
+ header: ({ table }) => (
103
+ <Checkbox
104
+ checked={
105
+ table.getIsAllPageRowsSelected() ||
106
+ (table.getIsSomePageRowsSelected() && "indeterminate")
107
+ }
108
+ onCheckedChange={(value) =>
109
+ table.toggleAllPageRowsSelected(!!value)
110
+ }
111
+ aria-label="Select all"
112
+ />
113
+ ),
114
+
115
+ cell: ({ row }) => (
116
+ <>
117
+ <Checkbox
118
+ checked={row.getIsSelected()}
119
+ onCheckedChange={(value) => row.toggleSelected(!!value)}
120
+ aria-label="Select row"
121
+ />
122
+ </>
123
+ ),
124
+ enableSorting: false,
125
+ enableHiding: false,
126
+ });
127
+ }
128
+
129
+ if (extraParams?.actionMenu || extraParams?.groupActionMenu) {
130
+ columns.push({
131
+ id: "DTActions",
132
+ accessorKey: "Actions",
133
+ header: () => <div className="text-center">Action</div>,
134
+ size: 20,
135
+ headerClassName: "text-center",
136
+ cell: ({ row }) => {
137
+ if (row.getIsGrouped()) {
138
+ return extraParams?.groupActionMenu ? (
139
+ <div className="text-end">
140
+ <ActionMenu
141
+ actionMenus={extraParams.groupActionMenu.items}
142
+ extraActionParams={{
143
+ arguments: [
144
+ row.original,
145
+ ...(extraParams.groupActionMenu.extraArguments || []),
146
+ ],
147
+ }}
148
+ />
149
+ </div>
150
+ ) : null;
151
+ } else if (extraParams?.actionMenu) {
152
+ return (
153
+ <div className="text-center">
154
+ <ActionMenu
155
+ actionMenus={extraParams.actionMenu.items}
156
+ extraActionParams={{
157
+ arguments: [
158
+ row.original,
159
+ ...(extraParams.actionMenu.extraArguments || []),
160
+ ],
161
+ }}
162
+ />
163
+ </div>
164
+ );
165
+ } else {
166
+ return null;
167
+ }
168
+ },
169
+ enableSorting: false,
170
+ enableHiding: false,
171
+ });
172
+ }
173
+
174
+ // const onPaginationChange = (state: any) => {
175
+ // console.warn(state);
176
+ // setPagination(state);
177
+ // extraParams?.onPaginationChange?.(state);
178
+ // }
179
+
180
+ useEffect(() => {
181
+ extraParams?.onPaginationChange?.(pagination);
182
+ }, [pagination]);
183
+
184
+ const table = useReactTable({
185
+ data,
186
+ columns,
187
+ state: {
188
+ sorting,
189
+ globalFilter,
190
+ columnFilters,
191
+ columnVisibility,
192
+ rowSelection,
193
+ grouping,
194
+ expanded,
195
+ pagination,
196
+ },
197
+ onPaginationChange: setPagination,
198
+ onSortingChange: setSorting,
199
+ onExpandedChange: setExpanded,
200
+ onColumnFiltersChange: setColumnFilters,
201
+ onColumnVisibilityChange: setColumnVisibility,
202
+ onGroupingChange: setGrouping,
203
+ onGlobalFilterChange: setGlobalFilter,
204
+ onRowSelectionChange: setRowSelection,
205
+ getCoreRowModel: getCoreRowModel(),
206
+ getPaginationRowModel: getPaginationRowModel(),
207
+ getSortedRowModel: getSortedRowModel(),
208
+ getFilteredRowModel: getFilteredRowModel(),
209
+ getGroupedRowModel: getGroupedRowModel(),
210
+ getExpandedRowModel: getExpandedRowModel(),
211
+ getFacetedRowModel: getFacetedRowModel(),
212
+ getFacetedUniqueValues: getFacetedUniqueValues(),
213
+ getFacetedMinMaxValues: getFacetedMinMaxValues(),
214
+ manualPagination: (extraParams?.pagination == undefined || extraParams?.pagination == true) ? undefined : true
215
+ });
216
+
217
+ useImperativeHandle(ref, () => table);
218
+
219
+ const [droppedHeaders, setDroppedHeaders] = useState<DragDropHeaderProp[]>(
220
+ []
221
+ );
222
+ // Drag Event Handlers
223
+ const handleDragStart = (
224
+ e: React.DragEvent<HTMLDivElement>,
225
+ header: Header<TData, unknown>
226
+ ) => {
227
+ const headerObj = {
228
+ id: header.id,
229
+ title: getDataTableColumnTitle(header.column),
230
+ };
231
+ e.dataTransfer.setData("headerObj", JSON.stringify(headerObj));
232
+ e.dataTransfer.effectAllowed = "move";
233
+ };
234
+
235
+ const handleDrop = (e: React.DragEvent<HTMLDivElement>) => {
236
+ e.preventDefault();
237
+ const headerObj = JSON.parse(e.dataTransfer.getData("headerObj"));
238
+ if (!droppedHeaders.find((e) => e.id == headerObj.id)) {
239
+ setDroppedHeaders((prevHeaders) => [...prevHeaders, headerObj]);
240
+ const column = table.getColumn(headerObj.id);
241
+ if (column) {
242
+ column.getToggleGroupingHandler()();
243
+ }
244
+ }
245
+ };
246
+
247
+ const handleDragOver = (e: React.DragEvent<HTMLDivElement>) => {
248
+ e.preventDefault(); // Necessary to allow dropping
249
+ };
250
+
251
+ const handleRemoveGrouping = (groupId: string) => {
252
+ const newDroppedHeaders = droppedHeaders.filter(
253
+ (header) => header.id !== groupId
254
+ );
255
+ setDroppedHeaders(() => [...newDroppedHeaders]);
256
+ const column = table.getColumn(groupId);
257
+ if (column) {
258
+ column.getToggleGroupingHandler()();
259
+ }
260
+ };
261
+
262
+ const [isMount, setIsMount] = useState<boolean>(false);
263
+ useEffect(() => {
264
+ if (!isMount) {
265
+ setIsMount(true);
266
+ }
267
+ if (extraParams?.defaultGroups) {
268
+ table.setGrouping(extraParams?.defaultGroups);
269
+ }
270
+ }, []);
271
+
272
+ useEffect(() => {
273
+ if (onTableReady) {
274
+ onTableReady(table);
275
+ }
276
+ }, [onTableReady, table]);
277
+
278
+ return (
279
+ isMount && (
280
+ <div className="w-full h-full flex flex-col gap-3 justify-between">
281
+ <div className="flex-grow flex flex-col gap-3 overflow-hidden">
282
+ {(extraParams?.defaultTools == undefined ||
283
+ extraParams.defaultTools ||
284
+ extraParams.extraTools) && (
285
+ <DataTableToolbar table={table} extraParams={extraParams} />
286
+ )}
287
+
288
+ <div className="flex-grow flex flex-col overflow-hidden">
289
+ {(extraParams?.grouping == undefined || extraParams.grouping) && (
290
+ <div
291
+ className="w-full border-t min-h-10 px-2 py-1 flex gap-3 items-center text-sm bg-card-new"
292
+ onDrop={handleDrop}
293
+ onDragOver={handleDragOver}
294
+ >
295
+ {droppedHeaders.length === 0
296
+ ? "Drag a column header here to group its column"
297
+ : droppedHeaders.map((header, index) => (
298
+ <div
299
+ key={header.id}
300
+ className="rounded-md px-2 py-1 bg-muted text-muted-foreground flex gap-3 items-center"
301
+ >
302
+ {header.title}
303
+ <span onClick={() => handleRemoveGrouping(header.id)}>
304
+ <X size={15} />
305
+ </span>
306
+ </div>
307
+ ))}
308
+ </div>
309
+ )}
310
+ <div className="flex-grow overflow-hidden">
311
+ <Table className="border-t whitespace-nowrap bg-card-new">
312
+ {(extraParams?.header == undefined || extraParams.header) && (
313
+ <TableHeader className="sticky top-0 z-10 border-t bg-card-new">
314
+ {table.getHeaderGroups().map((headerGroup) => (
315
+ <TableRow key={headerGroup.id} className={cx("")}>
316
+ {headerGroup.headers.map((header) => {
317
+ if (header.column.getIsGrouped()) {
318
+ if (
319
+ header.column.getGroupedIndex() <
320
+ droppedHeaders.length - 1
321
+ ) {
322
+ return null;
323
+ }
324
+ return (
325
+ <TableHead
326
+ key={header.id}
327
+ colSpan={droppedHeaders.length}
328
+ className={cx(
329
+ "w-36 ",
330
+ "text-left"
331
+ )}
332
+ ></TableHead>
333
+ );
334
+ } else {
335
+ return (
336
+ <TableHead
337
+ key={header.id}
338
+ {...(extraParams?.grouping == undefined ||
339
+ extraParams.grouping
340
+ ? {
341
+ onDragStart: (e) =>
342
+ handleDragStart(e, header),
343
+ draggable: true,
344
+ }
345
+ : {})}
346
+ className={cx(
347
+ "text-left"
348
+ )}
349
+ >
350
+ {header.isPlaceholder ? null : (extraParams?.sorting ==
351
+ undefined ||
352
+ extraParams.sorting) &&
353
+ header.column.getCanSort() ? (
354
+ <div
355
+ onClick={header.column.getToggleSortingHandler()}
356
+ className={cx(
357
+ "-mx-2 inline-flex cursor-pointer select-none items-center gap-2 rounded-md px-2 py-1 hover:bg-muted"
358
+ )}
359
+ >
360
+ <div>
361
+ {flexRender(
362
+ header.column.columnDef.header,
363
+ header.getContext()
364
+ )}
365
+ </div>
366
+ {header.column.getCanSort() ? (
367
+ <div className="-space-y-2">
368
+ <ChevronUp
369
+ className={cx(
370
+ "size-3.5 text-foreground",
371
+ header.column.getIsSorted() ===
372
+ "desc"
373
+ ? "opacity-30"
374
+ : ""
375
+ )}
376
+ aria-hidden="true"
377
+ />
378
+ <ChevronDown
379
+ className={cx(
380
+ "size-3.5 text-foreground",
381
+ header.column.getIsSorted() ===
382
+ "asc"
383
+ ? "opacity-30"
384
+ : ""
385
+ )}
386
+ aria-hidden="true"
387
+ />
388
+ </div>
389
+ ) : null}
390
+ </div>
391
+ ) : (
392
+ flexRender(
393
+ header.column.columnDef.header,
394
+ header.getContext()
395
+ )
396
+ )}
397
+ </TableHead>
398
+ );
399
+ }
400
+ })}
401
+ </TableRow>
402
+ ))}
403
+ </TableHeader>
404
+ )}
405
+ <TableBody>
406
+ {table.getRowModel().rows.length ? (
407
+ table.getRowModel().rows.map((row) =>
408
+ row.getIsGrouped() ? (
409
+ <TableRow key={row.id}>
410
+ {row.getVisibleCells().map((cell) => {
411
+ if (cell.column.getIndex() < row.depth) {
412
+ return null;
413
+ }
414
+ return (
415
+ // colSpan={cell.column.getIndex() == row.depth ? row.depth + 1 : undefined}
416
+ <TableCell
417
+ key={cell.id}
418
+ colSpan={
419
+ cell.column.getIndex() == row.depth
420
+ ? row.depth + 1
421
+ : undefined
422
+ }
423
+ className={
424
+ cell.column.getIndex() == row.depth
425
+ ? "w-36"
426
+ : ""
427
+ }
428
+ >
429
+ {cell.getIsGrouped() ? (
430
+ <Button
431
+ variant="link"
432
+ onClick={row.getToggleExpandedHandler()}
433
+ className={`text-right text-foreground`}
434
+ style={{
435
+ marginLeft: row.depth + "rem",
436
+ }}
437
+ >
438
+ {row.getIsExpanded() ? (
439
+ <ChevronDown />
440
+ ) : (
441
+ <ChevronRight />
442
+ )}{" "}
443
+ {flexRender(
444
+ cell.column.columnDef.cell,
445
+ cell.getContext()
446
+ )}{" "}
447
+ ({row.subRows.length})
448
+ </Button>
449
+ ) : cell.column.id == "DTActions" ? (
450
+ flexRender(
451
+ cell.column.columnDef.cell,
452
+ cell.getContext()
453
+ )
454
+ ) : cell.getIsAggregated() ? (
455
+ flexRender(
456
+ cell.column.columnDef.aggregatedCell ??
457
+ cell.column.columnDef.cell,
458
+ cell.getContext()
459
+ )
460
+ ) : cell.getIsPlaceholder() ? null : (
461
+ flexRender(
462
+ cell.column.columnDef.cell,
463
+ cell.getContext()
464
+ )
465
+ )}
466
+ </TableCell>
467
+ );
468
+ })}
469
+ </TableRow>
470
+ ) : (
471
+ <TableRow
472
+ key={row.id}
473
+ className={cx(
474
+ row.getIsSelected() ? "bg-accent/10" : ""
475
+ )}
476
+ {...(extraParams?.checkBoxColumn && {
477
+ onClick: () =>
478
+ row.toggleSelected(!row.getIsSelected()),
479
+ })}
480
+ >
481
+ {row.getVisibleCells().map((cell, index) => (
482
+ <TableCell
483
+ key={cell.id}
484
+ className={cx(
485
+ row.getIsSelected() ? "relative" : "",
486
+ !(
487
+ extraParams?.actionMenu ||
488
+ extraParams?.groupActionMenu
489
+ ) && "py-2"
490
+ )}
491
+ >
492
+ {index === 0 && row.getIsSelected() && (
493
+ <div className="absolute inset-y-0 left-0 w-0.5 bg-primary" />
494
+ )}
495
+ {cell.getIsPlaceholder()
496
+ ? null
497
+ : flexRender(
498
+ cell.column.columnDef.cell,
499
+ cell.getContext()
500
+ )}
501
+ </TableCell>
502
+ ))}
503
+ </TableRow>
504
+ )
505
+ )
506
+ ) : (
507
+ <TableRow>
508
+ <TableCell
509
+ colSpan={columns.length}
510
+ className="h-24 text-center"
511
+ >
512
+ No results.
513
+ </TableCell>
514
+ </TableRow>
515
+ )}
516
+ </TableBody>
517
+ {extraParams?.footer && (
518
+ <TableFooter className="sticky bottom-0 bg-background text-foreground">
519
+ {table.getFooterGroups().map((group) => (
520
+ <TableRow>
521
+ {group.headers.map((header) => (
522
+ <TableCell>
523
+ {header.isPlaceholder ? null : (
524
+ <div className="flex items-center">
525
+ {flexRender(
526
+ header.column.columnDef.footer,
527
+ header.getContext()
528
+ )}
529
+ </div>
530
+ )}
531
+ </TableCell>
532
+ ))}
533
+ </TableRow>
534
+ ))}
535
+ </TableFooter>
536
+ )}
537
+ </Table>
538
+ </div>
539
+ </div>
540
+ </div>
541
+ {(extraParams?.paginationBar == undefined ||
542
+ extraParams.paginationBar) && (
543
+ <DataTablePagination table={table} extraParams={extraParams} />
544
+ )}
545
+ </div>
546
+ )
547
+ );
548
+ }
549
+ );
@@ -0,0 +1,75 @@
1
+ import {
2
+ Column,
3
+ ColumnDef,
4
+ PaginationState,
5
+ Table,
6
+ } from "@tanstack/react-table";
7
+ import { ActionMenuProps } from "../action-menu/type";
8
+
9
+ export interface DataTableProps<TData, TValue> {
10
+ data: TData[];
11
+ columns: DTColumnsProps<TData, TValue>[];
12
+ extraParams?: DTExtraParamsProps;
13
+ onTableReady?: (table: any) => void;
14
+ }
15
+
16
+ export type DTColumnsProps<TData, TValue = unknown> = ColumnDef<
17
+ TData,
18
+ TValue
19
+ > & {
20
+ title?: string;
21
+ headerClassName?: string;
22
+ };
23
+
24
+ export interface DTExtraParamsProps {
25
+ defaultGroups?: string[];
26
+ grouping?: boolean;
27
+ header?: boolean;
28
+ footer?: boolean;
29
+ defaultTools?: ("columnFilter" | "search" | "filter")[] | boolean;
30
+ extraTools?: any;
31
+ sorting?: boolean;
32
+ paginationBar?: boolean;
33
+ rowsPerPage?: boolean;
34
+ pagination?: boolean;
35
+ numberOfRows?: boolean;
36
+ checkBoxColumn?: boolean;
37
+ checkBoxColumnCallback?: (selectedRows: any[]) => void;
38
+ actionMenu?: DTActionMenuProps;
39
+ groupActionMenu?: DTActionMenuProps;
40
+ pageSize?: number;
41
+ pageIndex?: number;
42
+ pageSizeArray?: number[];
43
+ rowSelection?: boolean;
44
+ onPaginationChange?: (state: PaginationState) => void;
45
+ defaultRowSelection?: (row: any) => boolean;
46
+ }
47
+
48
+ export interface DTActionMenuProps {
49
+ items: ActionMenuProps[];
50
+ extraArguments?: any[];
51
+ }
52
+
53
+ export interface DataTableViewOptionsProps<TData> {
54
+ table: Table<TData>;
55
+ }
56
+ export interface DTToolBarProps<TData> {
57
+ table: Table<TData>;
58
+ extraParams?: DTExtraParamsProps;
59
+ }
60
+ export interface DataTableFilterProps<TData> {
61
+ table: Table<TData>;
62
+ }
63
+
64
+ export interface DataTableFacetedFilterProps<TData, TValue> {
65
+ column: Column<TData, TValue>;
66
+ }
67
+ export interface DataTablePaginationProps<TData> {
68
+ table: Table<TData>;
69
+ extraParams?: DTExtraParamsProps;
70
+ }
71
+
72
+ export interface DragDropHeaderProp {
73
+ id: string;
74
+ title: string;
75
+ }