@wavemaker-ai/react-runtime 1.0.0-rc.309 → 1.0.0-rc.314

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 (574) hide show
  1. package/.npmignore +4 -0
  2. package/actions/base-action.js +12 -29
  3. package/actions/login-action.js +35 -52
  4. package/actions/logout-action.js +21 -38
  5. package/actions/navigation-action.js +251 -346
  6. package/actions/notification-action.js +121 -149
  7. package/actions/timer-action.js +95 -151
  8. package/actions/toast-provider.js +62 -76
  9. package/actions/toast.js +95 -91
  10. package/actions/toast.service.js +59 -79
  11. package/actions/types/index.js +6 -9
  12. package/components/advanced/carousel/index.js +358 -366
  13. package/components/advanced/carousel/props.js +0 -5
  14. package/components/advanced/carousel/template.js +102 -80
  15. package/components/advanced/login/index.js +227 -285
  16. package/components/advanced/login/props.js +0 -5
  17. package/components/advanced/marquee/index.js +169 -163
  18. package/components/advanced/marquee/props.js +0 -5
  19. package/components/basic/anchor/index.js +207 -187
  20. package/components/basic/anchor/props.js +0 -5
  21. package/components/basic/audio/index.js +110 -72
  22. package/components/basic/audio/props.js +0 -5
  23. package/components/basic/html/index.js +163 -203
  24. package/components/basic/html/props.js +0 -5
  25. package/components/basic/html/utils.js +30 -28
  26. package/components/basic/icon/index.js +98 -84
  27. package/components/basic/icon/props.js +0 -5
  28. package/components/basic/iframe/iframe.utils.js +7 -16
  29. package/components/basic/iframe/index.js +97 -103
  30. package/components/basic/iframe/props.js +0 -5
  31. package/components/basic/label/index.js +156 -134
  32. package/components/basic/label/props.js +0 -5
  33. package/components/basic/message/index.js +129 -113
  34. package/components/basic/message/props.js +0 -5
  35. package/components/basic/picture/index.js +156 -127
  36. package/components/basic/picture/props.js +0 -5
  37. package/components/basic/progress-bar/index.js +240 -176
  38. package/components/basic/progress-bar/props.js +5 -31
  39. package/components/basic/progress-circle/index.js +166 -183
  40. package/components/basic/progress-circle/props.js +14 -34
  41. package/components/basic/richtexteditor/index.js +430 -396
  42. package/components/basic/richtexteditor/props.js +0 -5
  43. package/components/basic/search/index.js +812 -931
  44. package/components/basic/search/props.js +0 -5
  45. package/components/basic/search/providers.js +233 -380
  46. package/components/basic/spinner/index.js +210 -200
  47. package/components/basic/spinner/props.js +4 -22
  48. package/components/basic/tile/index.js +73 -81
  49. package/components/basic/tile/props.js +0 -5
  50. package/components/basic/tree/Components/TreeNodeComponent.js +238 -170
  51. package/components/basic/tree/hooks/useTreePartialNodeApi.js +143 -135
  52. package/components/basic/tree/index.js +378 -454
  53. package/components/basic/tree/props.js +0 -5
  54. package/components/basic/tree/utils.js +129 -185
  55. package/components/basic/video/index.js +161 -107
  56. package/components/basic/video/props.js +0 -5
  57. package/components/chart/index.js +42 -50
  58. package/components/chart/props.js +31 -37
  59. package/components/chart/src/ChartRenderer.js +172 -154
  60. package/components/chart/src/chart.js +391 -213
  61. package/components/chart/src/chartStyles.generated.js +6 -14
  62. package/components/chart/src/chartUtils.js +228 -272
  63. package/components/chart/src/constants.d.ts +13 -0
  64. package/components/chart/src/constants.js +316 -90
  65. package/components/chart/src/d3Setup.js +11 -30
  66. package/components/chart/src/dataUtils.js +362 -446
  67. package/components/chart/src/formatUtils.js +47 -38
  68. package/components/chart/src/index.js +11 -19
  69. package/components/chart/src/nvd3Source.generated.js +5 -13
  70. package/components/chart/src/pieDonutResponsiveLayout.d.ts +5 -0
  71. package/components/chart/src/pieDonutResponsiveLayout.js +76 -96
  72. package/components/chart/src/types.js +0 -5
  73. package/components/common/AppSpinner.js +17 -33
  74. package/components/common/app-spinner.js +11 -22
  75. package/components/common/customTemplate/index.d.ts +3 -0
  76. package/components/common/customTemplate/index.js +6 -0
  77. package/components/common/customTemplate/props.d.ts +20 -0
  78. package/components/common/customTemplate/props.js +0 -0
  79. package/components/common/customTemplate/template.d.ts +3 -0
  80. package/components/common/customTemplate/template.js +27 -0
  81. package/components/common/customTemplate/useCustomTemplate.d.ts +8 -0
  82. package/components/common/customTemplate/useCustomTemplate.js +17 -0
  83. package/components/common/customTemplate/utils.d.ts +6 -0
  84. package/components/common/customTemplate/utils.js +12 -0
  85. package/components/common/index.js +4 -12
  86. package/components/constants.js +81 -77
  87. package/components/container/accordion/accordion-pane/index.js +105 -118
  88. package/components/container/accordion/accordion-pane/props.js +5 -21
  89. package/components/container/accordion/index.js +225 -243
  90. package/components/container/accordion/props.js +5 -16
  91. package/components/container/index.js +214 -150
  92. package/components/container/layout-grid/grid-column/index.js +68 -43
  93. package/components/container/layout-grid/grid-column/props.js +0 -5
  94. package/components/container/layout-grid/grid-row/index.js +12 -29
  95. package/components/container/layout-grid/grid-row/props.js +0 -5
  96. package/components/container/layout-grid/index.js +53 -38
  97. package/components/container/layout-grid/props.js +0 -5
  98. package/components/container/linear-layout/index.js +56 -60
  99. package/components/container/linear-layout/linear-layout-item/index.js +43 -47
  100. package/components/container/linear-layout/linear-layout-item/props.js +0 -5
  101. package/components/container/linear-layout/props.js +0 -5
  102. package/components/container/panel/components/panel-content/index.js +7 -16
  103. package/components/container/panel/components/panel-header/index.js +166 -146
  104. package/components/container/panel/components/panel-header/props.js +0 -5
  105. package/components/container/panel/hooks.js +76 -102
  106. package/components/container/panel/index.js +289 -252
  107. package/components/container/panel/props.js +0 -5
  108. package/components/container/props.js +0 -5
  109. package/components/container/repeat-template/index.js +65 -44
  110. package/components/container/repeat-template/props.js +0 -5
  111. package/components/container/tabs/index.js +517 -526
  112. package/components/container/tabs/props.js +5 -28
  113. package/components/container/tabs/tab-pane/index.js +105 -100
  114. package/components/container/tabs/tab-pane/props.js +0 -5
  115. package/components/container/tabs/utils.js +30 -35
  116. package/components/container/wizard/WizardContext.js +9 -11
  117. package/components/container/wizard/components/StepComponents.js +76 -99
  118. package/components/container/wizard/components/WizardStep.js +107 -85
  119. package/components/container/wizard/index.js +791 -921
  120. package/components/container/wizard/props.js +0 -5
  121. package/components/container/wizard/utils.js +97 -131
  122. package/components/container/wizard/wizard-action/index.js +41 -81
  123. package/components/container/wizard/wizard-step/index.js +140 -120
  124. package/components/data/card/card-actions/index.js +13 -31
  125. package/components/data/card/card-content/index.js +27 -36
  126. package/components/data/card/card-footer/index.js +13 -31
  127. package/components/data/card/index.js +192 -199
  128. package/components/data/card/props.js +0 -5
  129. package/components/data/form/base-form/constant.js +5 -8
  130. package/components/data/form/base-form/hooks/index.js +26 -77
  131. package/components/data/form/base-form/hooks/useFormDataSync.js +106 -212
  132. package/components/data/form/base-form/hooks/useFormOperations.js +109 -161
  133. package/components/data/form/base-form/hooks/useFormSubmission.js +220 -280
  134. package/components/data/form/base-form/hooks/useFormValidation.js +119 -168
  135. package/components/data/form/base-form/hooks/useParentFormRelationship.js +67 -103
  136. package/components/data/form/base-form/index.js +531 -646
  137. package/components/data/form/base-form/props.js +74 -151
  138. package/components/data/form/base-form/utils.js +210 -323
  139. package/components/data/form/dynamic-fields/constant.js +43 -53
  140. package/components/data/form/dynamic-fields/index.js +135 -144
  141. package/components/data/form/dynamic-fields/props.js +0 -5
  142. package/components/data/form/dynamic-fields/utils.js +99 -158
  143. package/components/data/form/form-action/index.js +107 -85
  144. package/components/data/form/form-body/index.js +52 -26
  145. package/components/data/form/form-context.js +43 -59
  146. package/components/data/form/form-controller/hooks/index.js +43 -57
  147. package/components/data/form/form-controller/props.js +5 -8
  148. package/components/data/form/form-controller/utils.js +54 -49
  149. package/components/data/form/form-controller/validation-contrustor.js +203 -426
  150. package/components/data/form/form-controller/withFormController.js +319 -269
  151. package/components/data/form/form-dynamic-section/index.js +47 -41
  152. package/components/data/form/form-dynamic-section/props.js +0 -5
  153. package/components/data/form/form-field/base-field.js +97 -109
  154. package/components/data/form/form-field/index.js +91 -82
  155. package/components/data/form/form-field/props.js +0 -5
  156. package/components/data/form/form-footer/index.js +52 -25
  157. package/components/data/form/form-header/index.js +61 -58
  158. package/components/data/form/index.js +95 -74
  159. package/components/data/form/props.js +0 -5
  160. package/components/data/list/components/GroupHeader.js +34 -33
  161. package/components/data/list/components/GroupedListItems.js +108 -104
  162. package/components/data/list/components/ListContainer.js +22 -27
  163. package/components/data/list/components/ListDND.js +193 -185
  164. package/components/data/list/components/ListHeader.js +32 -49
  165. package/components/data/list/components/ListItem.js +153 -146
  166. package/components/data/list/components/ListItemWithTemplate.js +87 -105
  167. package/components/data/list/components/ListItems.js +180 -194
  168. package/components/data/list/components/ListPagination.js +127 -153
  169. package/components/data/list/components/LoadMoreButton.js +25 -33
  170. package/components/data/list/components/NoDataMessage.js +9 -22
  171. package/components/data/list/components/StandardListItems.js +79 -85
  172. package/components/data/list/components/index.js +31 -119
  173. package/components/data/list/components/props.js +0 -5
  174. package/components/data/list/hooks/index.js +22 -75
  175. package/components/data/list/hooks/props.js +0 -5
  176. package/components/data/list/hooks/useCurrentPageItems.js +20 -38
  177. package/components/data/list/hooks/useGroupedData.js +19 -33
  178. package/components/data/list/hooks/useListData.js +17 -47
  179. package/components/data/list/hooks/useListEffects.js +168 -237
  180. package/components/data/list/hooks/useListEventHandlers.js +301 -285
  181. package/components/data/list/hooks/useListPagination.js +90 -136
  182. package/components/data/list/hooks/useListState.js +49 -91
  183. package/components/data/list/hooks/useListStateManager.js +104 -159
  184. package/components/data/list/hooks/usePaginatedGroupedData.js +74 -110
  185. package/components/data/list/index.d.ts +1 -0
  186. package/components/data/list/index.js +579 -621
  187. package/components/data/list/props.d.ts +4 -0
  188. package/components/data/list/props.js +0 -5
  189. package/components/data/list/templates/media-template.js +29 -50
  190. package/components/data/list/utils/constants.js +20 -32
  191. package/components/data/list/utils/list-helpers.d.ts +2 -1
  192. package/components/data/list/utils/list-helpers.js +71 -115
  193. package/components/data/list/utils/list-widget-methods.js +56 -76
  194. package/components/data/list/utils/widget-instance-utils.js +20 -57
  195. package/components/data/live-filter/index.js +219 -271
  196. package/components/data/live-filter/props.js +5 -12
  197. package/components/data/live-form/index.js +68 -91
  198. package/components/data/live-form/props.js +5 -12
  199. package/components/data/pagination/components/BasicPagination.js +124 -104
  200. package/components/data/pagination/components/ClassicPagination.js +167 -190
  201. package/components/data/pagination/components/InlinePagination.js +97 -98
  202. package/components/data/pagination/components/LoadingComponent.js +17 -30
  203. package/components/data/pagination/components/PageSizeSelector.js +176 -169
  204. package/components/data/pagination/components/PagerNavigation.js +84 -105
  205. package/components/data/pagination/components/TotalRecords.js +48 -47
  206. package/components/data/pagination/components/index.js +14 -47
  207. package/components/data/pagination/components/props.js +0 -5
  208. package/components/data/pagination/hooks/index.js +6 -19
  209. package/components/data/pagination/hooks/props.js +0 -5
  210. package/components/data/pagination/hooks/useNavigationSize.js +12 -21
  211. package/components/data/pagination/hooks/usePagination.js +702 -905
  212. package/components/data/pagination/index.js +336 -389
  213. package/components/data/table/components/AddNewRow.js +122 -154
  214. package/components/data/table/components/EditableCell.js +68 -75
  215. package/components/data/table/components/FieldValidationError.js +19 -20
  216. package/components/data/table/components/RowCells.js +97 -80
  217. package/components/data/table/components/RowExpansionButton.js +43 -39
  218. package/components/data/table/components/SummaryCell.js +54 -88
  219. package/components/data/table/components/SummaryRow.js +45 -52
  220. package/components/data/table/components/SummaryRowFooter.js +35 -42
  221. package/components/data/table/components/TableBody.js +222 -218
  222. package/components/data/table/components/TableDataRow.js +113 -106
  223. package/components/data/table/components/TableFilters.js +391 -390
  224. package/components/data/table/components/TableFooterActions.js +25 -32
  225. package/components/data/table/components/TableHeader.js +460 -435
  226. package/components/data/table/components/TablePanelHeading.js +157 -181
  227. package/components/data/table/components/index.js +27 -95
  228. package/components/data/table/hooks/index.js +21 -230
  229. package/components/data/table/hooks/use-edited-rows.js +59 -94
  230. package/components/data/table/hooks/useCellState.js +58 -83
  231. package/components/data/table/hooks/useCustomExpressionColumns.js +65 -86
  232. package/components/data/table/hooks/useDynamicColumns.js +59 -92
  233. package/components/data/table/hooks/useEditingState.js +30 -41
  234. package/components/data/table/hooks/useFormWidget.js +163 -172
  235. package/components/data/table/hooks/usePaginationState.js +67 -77
  236. package/components/data/table/hooks/usePanelStructure.js +47 -41
  237. package/components/data/table/hooks/useResponsiveColumns.js +14 -20
  238. package/components/data/table/hooks/useRowExpansion.js +131 -127
  239. package/components/data/table/hooks/useRowHandlers.js +56 -69
  240. package/components/data/table/hooks/useRowSelection.js +249 -329
  241. package/components/data/table/hooks/useServerSideSorting.js +109 -175
  242. package/components/data/table/hooks/useTableColumns.js +322 -331
  243. package/components/data/table/hooks/useTableData.js +111 -166
  244. package/components/data/table/hooks/useTableEdit.js +526 -564
  245. package/components/data/table/hooks/useTableEffects.js +60 -107
  246. package/components/data/table/hooks/useTableFilter.js +244 -237
  247. package/components/data/table/hooks/useTableInitialization.js +44 -76
  248. package/components/data/table/hooks/useTableState.js +39 -61
  249. package/components/data/table/hooks/useTableStateManager.js +295 -468
  250. package/components/data/table/index.js +1553 -1713
  251. package/components/data/table/live-table/index.js +157 -219
  252. package/components/data/table/props.js +0 -5
  253. package/components/data/table/table-action/index.js +97 -75
  254. package/components/data/table/table-column/index.js +48 -42
  255. package/components/data/table/table-group/index.js +7 -25
  256. package/components/data/table/table-row/index.js +63 -55
  257. package/components/data/table/table-row-action/index.js +102 -77
  258. package/components/data/table/utils/buildSelectionColumns.js +86 -137
  259. package/components/data/table/utils/columnBuilder.js +116 -158
  260. package/components/data/table/utils/columnProxy.js +48 -66
  261. package/components/data/table/utils/columnWidthDistribution.js +40 -64
  262. package/components/data/table/utils/constants.js +92 -40
  263. package/components/data/table/utils/crud-handlers.js +292 -473
  264. package/components/data/table/utils/dynamic-columns.js +99 -144
  265. package/components/data/table/utils/groupHeaderUtils.js +36 -61
  266. package/components/data/table/utils/index.d.ts +8 -5
  267. package/components/data/table/utils/index.js +419 -639
  268. package/components/data/table/utils/renderDisplayCell.js +127 -169
  269. package/components/data/table/utils/script-page-size-broadcast.js +17 -29
  270. package/components/data/table/utils/selectionUtils.js +59 -113
  271. package/components/data/table/utils/table-helpers.js +38 -74
  272. package/components/data/table/utils/validation.js +35 -78
  273. package/components/data/table/utils/widgetMapping.d.ts +5 -0
  274. package/components/data/table/utils/widgetMapping.js +41 -0
  275. package/components/data/types.js +112 -112
  276. package/components/data/utils/field-data-utils.js +38 -42
  277. package/components/data/utils/filter-field-util.js +42 -44
  278. package/components/data/utils/index.js +112 -111
  279. package/components/dialogs/alert-dialog/index.js +83 -78
  280. package/components/dialogs/alert-dialog/props.js +0 -5
  281. package/components/dialogs/confirm-dialog/index.js +102 -92
  282. package/components/dialogs/confirm-dialog/props.js +0 -5
  283. package/components/dialogs/dialog/index.js +93 -69
  284. package/components/dialogs/dialog/props.js +0 -5
  285. package/components/dialogs/dialog-actions/index.js +12 -26
  286. package/components/dialogs/dialog-actions/props.js +0 -5
  287. package/components/dialogs/dialog-body/index.js +13 -30
  288. package/components/dialogs/dialog-body/props.js +0 -5
  289. package/components/dialogs/dialog-content/index.js +48 -41
  290. package/components/dialogs/dialog-content/props.js +0 -5
  291. package/components/dialogs/dialog-header/index.js +88 -101
  292. package/components/dialogs/dialog-header/props.js +0 -5
  293. package/components/dialogs/iframe-dialog/index.js +136 -128
  294. package/components/dialogs/iframe-dialog/props.js +0 -5
  295. package/components/dialogs/index.js +104 -101
  296. package/components/dialogs/login-dialog/index.js +285 -347
  297. package/components/dialogs/login-dialog/props.js +0 -5
  298. package/components/dialogs/page-dialog/index.js +95 -86
  299. package/components/dialogs/page-dialog/props.js +0 -5
  300. package/components/dialogs/props.js +0 -5
  301. package/components/dialogs/withDialogWrapper.js +110 -83
  302. package/components/form/button/index.js +296 -245
  303. package/components/form/button/props.js +0 -5
  304. package/components/form/button-group/index.js +80 -69
  305. package/components/form/button-group/props.js +0 -5
  306. package/components/input/calendar/index.js +409 -362
  307. package/components/input/calendar/props.js +0 -5
  308. package/components/input/calendar/utils.js +164 -172
  309. package/components/input/chips/SortableChip/index.js +109 -100
  310. package/components/input/chips/SortableChip/props.js +0 -5
  311. package/components/input/chips/index.js +663 -570
  312. package/components/input/chips/props.js +0 -5
  313. package/components/input/chips/utils.js +131 -122
  314. package/components/input/color-picker/index.js +536 -594
  315. package/components/input/color-picker/props.js +0 -5
  316. package/components/input/composite/index.js +71 -110
  317. package/components/input/composite/props.js +0 -5
  318. package/components/input/currency/index.js +277 -224
  319. package/components/input/currency/props.js +0 -5
  320. package/components/input/default/checkbox/index.js +329 -250
  321. package/components/input/default/checkbox/props.js +0 -5
  322. package/components/input/default/checkboxset/index.d.ts +2 -0
  323. package/components/input/default/checkboxset/index.js +529 -446
  324. package/components/input/default/checkboxset/props.d.ts +4 -0
  325. package/components/input/default/checkboxset/props.js +0 -5
  326. package/components/input/default/checkboxset/utils.js +15 -25
  327. package/components/input/default/radioset/index.d.ts +2 -0
  328. package/components/input/default/radioset/index.js +409 -350
  329. package/components/input/default/radioset/props.d.ts +6 -0
  330. package/components/input/default/radioset/props.js +0 -5
  331. package/components/input/default/switch/index.js +494 -458
  332. package/components/input/default/switch/prop.js +0 -5
  333. package/components/input/epoch/date/components/DatePickerPopover.js +242 -193
  334. package/components/input/epoch/date/index.js +638 -518
  335. package/components/input/epoch/date/props.js +0 -5
  336. package/components/input/epoch/date/styled.js +61 -70
  337. package/components/input/epoch/date/utils.js +67 -115
  338. package/components/input/epoch/datetime/index.js +758 -695
  339. package/components/input/epoch/datetime/props.js +0 -5
  340. package/components/input/epoch/datetime/utils.js +121 -186
  341. package/components/input/epoch/time/index.js +441 -415
  342. package/components/input/epoch/time/props.js +0 -5
  343. package/components/input/epoch/time/utils.js +101 -112
  344. package/components/input/fileupload/Utils.js +70 -97
  345. package/components/input/fileupload/components/ListItems.js +132 -130
  346. package/components/input/fileupload/components/MultiUpload.js +80 -77
  347. package/components/input/fileupload/components/SingleUpload.js +57 -57
  348. package/components/input/fileupload/index.js +253 -178
  349. package/components/input/fileupload/props.js +0 -5
  350. package/components/input/fileupload/useFileUpload.js +209 -258
  351. package/components/input/number/index.js +434 -393
  352. package/components/input/number/props.js +0 -5
  353. package/components/input/rating/index.js +401 -394
  354. package/components/input/rating/props.js +0 -5
  355. package/components/input/select/index.js +408 -463
  356. package/components/input/select/props.js +0 -5
  357. package/components/input/slider/index.js +339 -332
  358. package/components/input/slider/props.js +0 -5
  359. package/components/input/text/index.d.ts +3 -3
  360. package/components/input/text/index.js +438 -475
  361. package/components/input/text/props.d.ts +1 -1
  362. package/components/input/text/props.js +0 -5
  363. package/components/input/text/util.js +82 -222
  364. package/components/input/textarea/index.js +322 -358
  365. package/components/input/textarea/props.js +0 -5
  366. package/components/input/upload/index.js +135 -131
  367. package/components/input/upload/props.js +0 -5
  368. package/components/input/util/index.js +9 -11
  369. package/components/layout/footer/index.js +12 -35
  370. package/components/layout/footer/props.js +0 -5
  371. package/components/layout/header/index.js +12 -38
  372. package/components/layout/header/props.js +0 -5
  373. package/components/layout/leftnav/index.js +38 -44
  374. package/components/layout/leftnav/props.js +0 -5
  375. package/components/layout/rightnav/index.js +12 -36
  376. package/components/layout/rightnav/props.js +0 -5
  377. package/components/layout/topnav/index.js +24 -38
  378. package/components/layout/topnav/props.js +0 -5
  379. package/components/navbar/index.js +119 -98
  380. package/components/navbar/nav/index.js +236 -232
  381. package/components/navbar/nav/props.js +0 -5
  382. package/components/navbar/nav-item/index.js +74 -65
  383. package/components/navbar/nav-item/props.js +0 -5
  384. package/components/navigation/breadcrumb/index.js +38 -61
  385. package/components/navigation/breadcrumb/props.js +0 -5
  386. package/components/navigation/menu/components/ListItems.js +76 -67
  387. package/components/navigation/menu/constants.js +27 -42
  388. package/components/navigation/menu/hooks/useHoverState.hook.js +20 -47
  389. package/components/navigation/menu/hooks/useKeyboardMovements.hook.js +34 -28
  390. package/components/navigation/menu/hooks/useTransformedDataset.hook.js +21 -14
  391. package/components/navigation/menu/index.js +911 -846
  392. package/components/navigation/menu/props.js +0 -5
  393. package/components/navigation/menu/utils/action-task.js +6 -9
  394. package/components/navigation/menu/utils/role-filter.js +41 -56
  395. package/components/navigation/popover/index.js +191 -205
  396. package/components/navigation/popover/props.js +5 -8
  397. package/components/page/content/index.js +9 -31
  398. package/components/page/content/props.js +0 -5
  399. package/components/page/error-boundary/index.js +115 -105
  400. package/components/page/error-boundary/props.js +0 -5
  401. package/components/page/index.js +84 -102
  402. package/components/page/page-content/index.js +21 -30
  403. package/components/page/page-content/props.js +0 -5
  404. package/components/page/partial/index.js +50 -45
  405. package/components/page/partial/props.js +0 -5
  406. package/components/page/partial-container/index.js +81 -107
  407. package/components/page/partial-container/props.d.ts +1 -1
  408. package/components/page/partial-container/props.js +0 -5
  409. package/components/page/props.js +0 -5
  410. package/components/page/toast-container/index.js +20 -41
  411. package/components/page/toast-container/props.js +0 -5
  412. package/components/prefab/container/index.js +60 -53
  413. package/components/prefab/container/props.js +0 -5
  414. package/components/prefab/index.js +76 -61
  415. package/components/prefab/props.js +0 -5
  416. package/context/AppContext.d.ts +1 -1
  417. package/context/AppContext.js +17 -18
  418. package/context/AppSpinnerProvider.js +19 -34
  419. package/context/LayoutProvider.js +54 -57
  420. package/context/LocalizationProvider.js +34 -49
  421. package/context/PrefabContext.js +68 -119
  422. package/context/WidgetProvider.js +160 -166
  423. package/core/app-config.js +0 -1
  424. package/core/app.service.js +200 -327
  425. package/core/appVariablesStore.js +10 -15
  426. package/core/appstore.js +37 -53
  427. package/core/constants/currency-constant.js +81 -83
  428. package/core/constants/events.js +34 -44
  429. package/core/constants/index.js +21 -31
  430. package/core/dialog.service.js +52 -72
  431. package/core/event-notifier.js +94 -131
  432. package/core/formatter/array-formatters.js +18 -32
  433. package/core/formatter/date-formatters.js +140 -204
  434. package/core/formatter/index.js +64 -117
  435. package/core/formatter/number-formatters.js +115 -159
  436. package/core/formatter/security-formatters.js +233 -283
  437. package/core/formatter/string-formatters.js +23 -45
  438. package/core/formatter/types.js +12 -18
  439. package/core/formatters.js +6 -24
  440. package/core/proxy-service.js +242 -306
  441. package/core/script-registry.js +87 -134
  442. package/core/security.service.js +8 -11
  443. package/core/util/compare.js +13 -25
  444. package/core/util/dom.js +32 -63
  445. package/core/util/index.d.ts +5 -0
  446. package/core/util/index.js +95 -95
  447. package/core/util/safe-is-equal.js +42 -94
  448. package/core/util/security.js +114 -153
  449. package/core/util/utils.d.ts +8 -1
  450. package/core/util/utils.js +124 -132
  451. package/core/widget-observer.js +34 -61
  452. package/higherOrder/BaseApp.js +327 -500
  453. package/higherOrder/BaseAppProps.js +0 -5
  454. package/higherOrder/BaseDateTime.js +277 -231
  455. package/higherOrder/BasePage.js +479 -735
  456. package/higherOrder/BasePartial.js +87 -114
  457. package/higherOrder/BasePrefab.js +190 -206
  458. package/higherOrder/DataNav.js +287 -302
  459. package/higherOrder/helper.js +62 -48
  460. package/higherOrder/props.js +0 -5
  461. package/higherOrder/withBaseWrapper.js +123 -168
  462. package/higherOrder/withStandalone.js +28 -26
  463. package/hooks/useAccess.js +113 -289
  464. package/hooks/useAppConfig.js +15 -40
  465. package/hooks/useAuth.js +256 -495
  466. package/hooks/useDataSourceSubscription.d.ts +3 -3
  467. package/hooks/useDataSourceSubscription.js +99 -109
  468. package/hooks/useDebounce.js +28 -56
  469. package/hooks/useDeviceVisibility.js +14 -23
  470. package/hooks/useHttp.d.ts +1 -0
  471. package/hooks/useHttp.js +318 -493
  472. package/libs/index.js +4 -13
  473. package/libs/prefab/index.js +6 -20
  474. package/mui-config/theme-provider.js +9 -17
  475. package/mui-config/theme.js +6 -9
  476. package/package-lock.json +822 -3191
  477. package/package.json +3 -19
  478. package/providers/AppProviders.js +21 -24
  479. package/runtime-dynamic/App.js +65 -93
  480. package/runtime-dynamic/app-initializer.js +207 -400
  481. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  482. package/runtime-dynamic/components/PageWrapper.js +23 -35
  483. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  484. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  485. package/runtime-dynamic/components/partial-content.js +66 -48
  486. package/runtime-dynamic/components/prefab-content.js +37 -30
  487. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  488. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  489. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  490. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  491. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  492. package/runtime-dynamic/factories/startup-info.js +12 -25
  493. package/runtime-dynamic/factories/utils.d.ts +1 -9
  494. package/runtime-dynamic/factories/utils.js +47 -130
  495. package/runtime-dynamic/index.js +56 -191
  496. package/runtime-dynamic/main.js +42 -70
  497. package/runtime-dynamic/preview-mode.js +14 -29
  498. package/runtime-dynamic/preview-navigation.js +21 -30
  499. package/runtime-dynamic/preview-path.d.ts +5 -0
  500. package/runtime-dynamic/preview-path.js +13 -0
  501. package/runtime-dynamic/preview-resource-base.js +15 -31
  502. package/runtime-dynamic/registry/component-registry.js +269 -334
  503. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  504. package/runtime-dynamic/registry/index.js +24 -63
  505. package/runtime-dynamic/registry/store.d.ts +1 -0
  506. package/runtime-dynamic/registry/store.js +18 -23
  507. package/runtime-dynamic/routes.js +53 -81
  508. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  509. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  510. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  511. package/runtime-dynamic/services/cache.js +27 -33
  512. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  513. package/runtime-dynamic/services/compile-render.js +142 -0
  514. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  515. package/runtime-dynamic/services/css-scoping.js +27 -28
  516. package/runtime-dynamic/services/fragment-url.js +37 -50
  517. package/runtime-dynamic/services/index.js +48 -152
  518. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  519. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  520. package/runtime-dynamic/services/prefab-resources.js +42 -130
  521. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  522. package/runtime-dynamic/services/resource-manager.js +32 -63
  523. package/runtime-dynamic/services/script-executor.js +50 -61
  524. package/runtime-dynamic/services/variable-factory.js +141 -184
  525. package/runtime-dynamic/services/variable-registry.js +69 -115
  526. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  527. package/runtime-dynamic/shims/next-image.js +79 -50
  528. package/runtime-dynamic/shims/next-link.js +58 -32
  529. package/runtime-dynamic/shims/next-navigation.js +17 -34
  530. package/runtime-dynamic/utils/index.d.ts +2 -0
  531. package/runtime-dynamic/utils/index.js +22 -24
  532. package/store/bindActions/i18nActions.js +16 -18
  533. package/store/index.js +29 -35
  534. package/store/middleware/navigationMiddleware.js +25 -45
  535. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  536. package/store/slices/appConfigSlice.js +65 -94
  537. package/store/slices/authSlice.js +317 -471
  538. package/store/slices/i18nSlice.js +169 -168
  539. package/store/slices/navigationSlice.js +22 -20
  540. package/store/util/resolve-path.d.ts +1 -0
  541. package/store/util/resolve-path.js +7 -0
  542. package/store/viewport.service.js +150 -194
  543. package/types/index.js +10 -15
  544. package/utils/attr.js +198 -41
  545. package/utils/custom-expression/index.js +55 -151
  546. package/utils/custom-expression/parser.js +106 -182
  547. package/utils/dataset-util.js +113 -154
  548. package/utils/eval-expression.js +10 -19
  549. package/utils/form-state.util.js +60 -118
  550. package/utils/form-utils.js +49 -190
  551. package/utils/format-util.js +113 -184
  552. package/utils/layoutsize-util.js +11 -17
  553. package/utils/lib-error-skipper.js +54 -52
  554. package/utils/page-params-util.js +50 -40
  555. package/utils/pending-tab-navigation-intent.js +7 -17
  556. package/utils/resource-url.js +8 -19
  557. package/utils/state-persistance.js +136 -253
  558. package/utils/style-utils.d.ts +2 -0
  559. package/utils/style-utils.js +25 -74
  560. package/utils/transformedDataset-utils.js +353 -381
  561. package/utils/widget-cleanup-util.js +42 -74
  562. package/utils/widgets.js +19 -31
  563. package/variables/base-variable.js +117 -166
  564. package/variables/constants.js +5 -8
  565. package/variables/crud-variable.js +150 -181
  566. package/variables/live-variable.d.ts +1 -1
  567. package/variables/live-variable.js +140 -174
  568. package/variables/metadata.service.js +74 -116
  569. package/variables/model-variable.js +68 -78
  570. package/variables/service-variable.js +171 -285
  571. package/wm-namespace.js +11 -14
  572. package/components/chart/src/css.d.js +0 -1
  573. package/tsconfig.declaration.tsbuildinfo +0 -1
  574. package/types/global.d.js +0 -3
@@ -1,450 +1,475 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.TableHeaderComponent = void 0;
9
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
- var _react = _interopRequireWildcard(require("react"));
14
- var _material = require("@mui/material");
15
- var _reactTable = require("@tanstack/react-table");
16
- var _utils = require("../utils");
17
- var _TableFilters = require("./TableFilters");
18
- var _groupHeaderUtils = require("../utils/groupHeaderUtils");
19
- var _excluded = ["header", "enablesort", "rowSpan", "children", "className", "style", "title", "onClick"],
20
- _excluded2 = ["rowSpan", "columnwidth"];
21
- function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
22
- var __jsx = _react["default"].createElement;
23
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
24
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
25
- // Helper component for rendering a standard table header cell
26
- var StandardHeaderCell = /*#__PURE__*/(0, _react.memo)(function (_ref) {
27
- var _header$column$column;
28
- var header = _ref.header,
29
- enablesort = _ref.enablesort,
30
- _ref$rowSpan = _ref.rowSpan,
31
- rowSpan = _ref$rowSpan === void 0 ? 1 : _ref$rowSpan,
32
- children = _ref.children,
33
- className = _ref.className,
34
- style = _ref.style,
35
- title = _ref.title,
36
- onClick = _ref.onClick,
37
- rest = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
38
- var canSort = enablesort && header.column.getCanSort();
39
- var isSorted = header.column.getIsSorted();
40
-
41
- // Merge className with meta className if present
42
- var metaClassName = ((_header$column$column = header.column.columnDef) === null || _header$column$column === void 0 || (_header$column$column = _header$column$column.meta) === null || _header$column$column === void 0 ? void 0 : _header$column$column.className) || "";
43
- var resizableClass = header.column.getCanResize() ? " ui-resizable" : "";
44
- var mergedClassName = "".concat(_utils.TABLE_CSS_CLASSES.headerCell, " ").concat(metaClassName, " ").concat(className || "", " ").concat(resizableClass).trim();
45
-
46
- // Merge default styles with provided styles
47
- var mergedStyle = _objectSpread({
48
- cursor: canSort ? "pointer" : "default",
49
- userSelect: "none",
50
- width: header.getSize(),
51
- position: "relative"
52
- }, style);
53
-
54
- // Get title from header definition or use provided title
55
- var headerTitle = header.column.columnDef.header && typeof header.column.columnDef.header !== "function" ? header.column.columnDef.header.toString() : "";
56
- return __jsx(_material.TableCell, (0, _extends2["default"])({
57
- className: mergedClassName,
58
- rowSpan: rowSpan,
59
- style: mergedStyle,
60
- title: title || headerTitle,
61
- onClick: onClick || (canSort ? header.column.getToggleSortingHandler() : undefined)
62
- }, rest), children || __jsx(_react["default"].Fragment, null, __jsx(_material.Box, {
63
- component: "span"
64
- }, header.isPlaceholder ? null : (0, _reactTable.flexRender)(header.column.columnDef.header, header.getContext())), canSort && __jsx(_material.Box, {
65
- style: {
66
- zIndex: 90
67
- },
68
- component: "span",
69
- className: "sort-buttons-container ".concat(isSorted ? "active" : "")
70
- }, __jsx(_material.Box, {
71
- component: "i",
72
- className: "sort-icon".concat(isSorted === "asc" ? " ".concat(_utils.TABLE_CSS_CLASSES.ascIcon) : isSorted === "desc" ? " ".concat(_utils.TABLE_CSS_CLASSES.descIcon) : "")
73
- })), header.column.getCanResize() && __jsx(_material.Box, {
74
- className: "ui-resizable-handle ui-resizable-e",
75
- onMouseDown: header.getResizeHandler(),
76
- onTouchStart: header.getResizeHandler()
77
- })));
78
- });
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ var __objRest = (source, exclude) => {
21
+ var target = {};
22
+ for (var prop in source)
23
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
+ target[prop] = source[prop];
25
+ if (source != null && __getOwnPropSymbols)
26
+ for (var prop of __getOwnPropSymbols(source)) {
27
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
+ target[prop] = source[prop];
29
+ }
30
+ return target;
31
+ };
32
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
33
+ import React, { memo, useMemo } from "react";
34
+ import { TableHead, TableRow, TableCell, Box } from "@mui/material";
35
+ import { flexRender } from "@tanstack/react-table";
36
+ import { TABLE_CSS_CLASSES } from "../utils";
37
+ import { TableFilterRow } from "./TableFilters";
38
+ import { calculateMaxDepth, generateHeaderRows, hasTableGroups } from "../utils/groupHeaderUtils";
39
+ const StandardHeaderCell = memo(
40
+ (_a) => {
41
+ var _b = _a, {
42
+ header,
43
+ enablesort,
44
+ rowSpan = 1,
45
+ children,
46
+ className,
47
+ style,
48
+ title,
49
+ onClick
50
+ } = _b, rest = __objRest(_b, [
51
+ "header",
52
+ "enablesort",
53
+ "rowSpan",
54
+ "children",
55
+ "className",
56
+ "style",
57
+ "title",
58
+ "onClick"
59
+ ]);
60
+ var _a2, _b2;
61
+ const canSort = enablesort && header.column.getCanSort();
62
+ const isSorted = header.column.getIsSorted();
63
+ const metaClassName = ((_b2 = (_a2 = header.column.columnDef) == null ? void 0 : _a2.meta) == null ? void 0 : _b2.className) || "";
64
+ const resizableClass = header.column.getCanResize() ? " ui-resizable" : "";
65
+ const mergedClassName = `${TABLE_CSS_CLASSES.headerCell} ${metaClassName} ${className || ""} ${resizableClass}`.trim();
66
+ const mergedStyle = __spreadValues({
67
+ cursor: canSort ? "pointer" : "default",
68
+ userSelect: "none",
69
+ width: header.getSize(),
70
+ position: "relative"
71
+ }, style);
72
+ const headerTitle = header.column.columnDef.header && typeof header.column.columnDef.header !== "function" ? header.column.columnDef.header.toString() : "";
73
+ return /* @__PURE__ */ jsx(
74
+ TableCell,
75
+ __spreadProps(__spreadValues({
76
+ className: mergedClassName,
77
+ rowSpan,
78
+ style: mergedStyle,
79
+ title: title || headerTitle,
80
+ onClick: onClick || (canSort ? header.column.getToggleSortingHandler() : void 0)
81
+ }, rest), {
82
+ children: children || /* @__PURE__ */ jsxs(Fragment, { children: [
83
+ /* @__PURE__ */ jsx(Box, { component: "span", children: header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext()) }),
84
+ canSort && /* @__PURE__ */ jsx(
85
+ Box,
86
+ {
87
+ style: { zIndex: 90 },
88
+ component: "span",
89
+ className: `sort-buttons-container ${isSorted ? "active" : ""}`,
90
+ children: /* @__PURE__ */ jsx(
91
+ Box,
92
+ {
93
+ component: "i",
94
+ className: `sort-icon${isSorted === "asc" ? ` ${TABLE_CSS_CLASSES.ascIcon}` : isSorted === "desc" ? ` ${TABLE_CSS_CLASSES.descIcon}` : ""}`
95
+ }
96
+ )
97
+ }
98
+ ),
99
+ header.column.getCanResize() && /* @__PURE__ */ jsx(
100
+ Box,
101
+ {
102
+ className: "ui-resizable-handle ui-resizable-e",
103
+ onMouseDown: header.getResizeHandler(),
104
+ onTouchStart: header.getResizeHandler()
105
+ }
106
+ )
107
+ ] })
108
+ })
109
+ );
110
+ }
111
+ );
79
112
  StandardHeaderCell.displayName = "StandardHeaderCell";
80
-
81
- // Helper component for rendering a group header cell
82
- var GroupHeaderCell = /*#__PURE__*/(0, _react.memo)(function (_ref2) {
83
- var headerCell = _ref2.headerCell;
84
- var groupClasses = ["app-datagrid-group-header-cell"];
85
- if (headerCell["class"]) groupClasses.push(headerCell["class"]);
113
+ const GroupHeaderCell = memo(({ headerCell }) => {
114
+ const groupClasses = ["app-datagrid-group-header-cell"];
115
+ if (headerCell.class) groupClasses.push(headerCell.class);
86
116
  if (headerCell.colClass) groupClasses.push(headerCell.colClass);
87
- var groupStyles = _objectSpread({
117
+ const groupStyles = __spreadValues({
88
118
  textAlign: headerCell.textAlignment || "center",
89
119
  backgroundColor: headerCell.backgroundColor
90
120
  }, headerCell.styles || {});
91
- return __jsx(_material.TableCell, {
92
- className: groupClasses.join(" "),
93
- colSpan: headerCell.colspan || 1,
94
- style: groupStyles,
95
- title: headerCell.displayName
96
- }, __jsx("span", {
97
- className: "header-data"
98
- }, headerCell.displayName));
121
+ return /* @__PURE__ */ jsx(
122
+ TableCell,
123
+ {
124
+ className: groupClasses.join(" "),
125
+ colSpan: headerCell.colspan || 1,
126
+ style: groupStyles,
127
+ title: headerCell.displayName,
128
+ children: /* @__PURE__ */ jsx("span", { className: "header-data", children: headerCell.displayName })
129
+ }
130
+ );
99
131
  });
100
132
  GroupHeaderCell.displayName = "GroupHeaderCell";
101
-
102
- // Helper component for expansion header cell
103
- var ExpansionHeaderCell = /*#__PURE__*/(0, _react.memo)(function (_ref3) {
104
- var _ref3$rowSpan = _ref3.rowSpan,
105
- rowSpan = _ref3$rowSpan === void 0 ? 1 : _ref3$rowSpan,
106
- columnwidth = _ref3.columnwidth,
107
- rest = (0, _objectWithoutProperties2["default"])(_ref3, _excluded2);
108
- return __jsx(_material.TableCell, (0, _extends2["default"])({}, rest, {
109
- className: "".concat(_utils.TABLE_CSS_CLASSES.headerCell, " ").concat(rest.className || "").trim(),
110
- rowSpan: rowSpan,
111
- style: _objectSpread({
112
- width: columnwidth || "50px",
113
- padding: "8px",
114
- userSelect: "none"
115
- }, rest.style)
116
- }));
117
- });
133
+ const ExpansionHeaderCell = memo(
134
+ (_c) => {
135
+ var _d = _c, {
136
+ rowSpan = 1,
137
+ columnwidth
138
+ } = _d, rest = __objRest(_d, [
139
+ "rowSpan",
140
+ "columnwidth"
141
+ ]);
142
+ return /* @__PURE__ */ jsx(
143
+ TableCell,
144
+ __spreadProps(__spreadValues({}, rest), {
145
+ className: `${TABLE_CSS_CLASSES.headerCell} ${rest.className || ""}`.trim(),
146
+ rowSpan,
147
+ style: __spreadValues({
148
+ width: columnwidth || "50px",
149
+ padding: "8px",
150
+ userSelect: "none"
151
+ }, rest.style)
152
+ })
153
+ );
154
+ }
155
+ );
118
156
  ExpansionHeaderCell.displayName = "ExpansionHeaderCell";
119
- var TableHeaderComponent = exports.TableHeaderComponent = /*#__PURE__*/(0, _react.memo)(function (_ref4) {
120
- var table = _ref4.table,
121
- enablesort = _ref4.enablesort,
122
- _ref4$enablecolumnsel = _ref4.enablecolumnselection,
123
- enablecolumnselection = _ref4$enablecolumnsel === void 0 ? false : _ref4$enablecolumnsel,
124
- _ref4$rowClass = _ref4.rowClass,
125
- rowClass = _ref4$rowClass === void 0 ? "" : _ref4$rowClass,
126
- rowExpansionConfig = _ref4.rowExpansionConfig,
127
- filterMode = _ref4.filterMode,
128
- columnFilters = _ref4.columnFilters,
129
- onColumnFilterChange = _ref4.onColumnFilterChange,
130
- renderFormWidget = _ref4.renderFormWidget,
131
- listener = _ref4.listener,
132
- tableStructure = _ref4.tableStructure,
133
- onColumnSelect = _ref4.onColumnSelect,
134
- onColumnDeselect = _ref4.onColumnDeselect,
135
- onHeaderclick = _ref4.onHeaderclick,
136
- tableName = _ref4.tableName;
137
- var hasExpansion = rowExpansionConfig && rowExpansionConfig.show;
138
-
139
- // Check if we have grouped columns
140
- var hasGroups = (0, _react.useMemo)(function () {
141
- return tableStructure && (0, _groupHeaderUtils.hasTableGroups)(tableStructure);
142
- }, [tableStructure]);
143
-
144
- // Calculate the maximum depth of the header structure
145
- var maxHeaderDepth = (0, _react.useMemo)(function () {
146
- if (!hasGroups || !tableStructure) return 1;
147
- return (0, _groupHeaderUtils.calculateMaxDepth)(tableStructure);
148
- }, [hasGroups, tableStructure]);
149
-
150
- // Generate header rows for grouped columns
151
- var groupHeaderRows = (0, _react.useMemo)(function () {
152
- if (!hasGroups || !tableStructure) return [];
153
- return (0, _groupHeaderUtils.generateHeaderRows)(tableStructure, maxHeaderDepth);
154
- }, [hasGroups, tableStructure, maxHeaderDepth]);
155
-
156
- // Calculate where to insert the expansion header for non-grouped tables
157
- var getExpansionInsertIndex = _react["default"].useMemo(function () {
158
- var _table$getHeaderGroup;
159
- if (!hasExpansion || !rowExpansionConfig) return -1;
160
- var position = rowExpansionConfig.position;
161
- var headers = ((_table$getHeaderGroup = table.getHeaderGroups()[0]) === null || _table$getHeaderGroup === void 0 ? void 0 : _table$getHeaderGroup.headers) || [];
162
-
163
- // If position is -1, insert before last column
164
- if (position === "-1" || position === -1) {
165
- return headers.length - 1;
166
- }
167
-
168
- // If position is a number, use it as index for data columns
169
- if (typeof position === "number" || typeof position === "string" && !isNaN(Number(position))) {
170
- var positionNum = Number(position);
171
- // Find the index of the first data column
172
- var dataColumnStartIndex = 0;
173
- for (var i = 0; i < headers.length; i++) {
174
- var header = headers[i];
175
- // Skip system columns (multiSelect, radioSelect, row-index, actions)
176
- if (header.id !== "multiSelect" && header.id !== "radioSelect" && header.id !== "row-index" && header.id !== "actions") {
177
- dataColumnStartIndex = i;
178
- break;
179
- }
157
+ const TableHeaderComponent = memo(
158
+ ({
159
+ table,
160
+ enablesort,
161
+ enablecolumnselection = false,
162
+ rowClass = "",
163
+ rowExpansionConfig,
164
+ filterMode,
165
+ columnFilters,
166
+ onColumnFilterChange,
167
+ renderFormWidget,
168
+ listener,
169
+ tableStructure,
170
+ onColumnSelect,
171
+ onColumnDeselect,
172
+ onHeaderclick,
173
+ tableName
174
+ }) => {
175
+ const hasExpansion = rowExpansionConfig && rowExpansionConfig.show;
176
+ const hasGroups = useMemo(() => {
177
+ return tableStructure && hasTableGroups(tableStructure);
178
+ }, [tableStructure]);
179
+ const maxHeaderDepth = useMemo(() => {
180
+ if (!hasGroups || !tableStructure) return 1;
181
+ return calculateMaxDepth(tableStructure);
182
+ }, [hasGroups, tableStructure]);
183
+ const groupHeaderRows = useMemo(() => {
184
+ if (!hasGroups || !tableStructure) return [];
185
+ return generateHeaderRows(tableStructure, maxHeaderDepth);
186
+ }, [hasGroups, tableStructure, maxHeaderDepth]);
187
+ const getExpansionInsertIndex = React.useMemo(() => {
188
+ var _a;
189
+ if (!hasExpansion || !rowExpansionConfig) return -1;
190
+ const position = rowExpansionConfig.position;
191
+ const headers = ((_a = table.getHeaderGroups()[0]) == null ? void 0 : _a.headers) || [];
192
+ if (position === "-1" || position === -1) {
193
+ return headers.length - 1;
180
194
  }
181
- return dataColumnStartIndex + positionNum;
182
- }
183
-
184
- // If position is a string (column name), find the column
185
- if (typeof position === "string") {
186
- var columnIndex = headers.findIndex(function (header) {
187
- // Check direct match with id
188
- if (header.id === position || header.column.id === position) {
189
- return true;
190
- }
191
- // Check accessorKey for nested paths
192
- var column = header.column.columnDef;
193
- if (column.accessorKey === position) {
194
- return true;
195
+ if (typeof position === "number" || typeof position === "string" && !isNaN(Number(position))) {
196
+ const positionNum = Number(position);
197
+ let dataColumnStartIndex = 0;
198
+ for (let i = 0; i < headers.length; i++) {
199
+ const header = headers[i];
200
+ if (header.id !== "multiSelect" && header.id !== "radioSelect" && header.id !== "row-index" && header.id !== "actions") {
201
+ dataColumnStartIndex = i;
202
+ break;
203
+ }
195
204
  }
196
- // For nested paths like "name.location.url", TanStack converts dots to underscores in id
197
- var normalizedPosition = position.replace(/\./g, "_");
198
- return header.id === normalizedPosition || header.column.id === normalizedPosition;
199
- });
200
- // Return index + 1 to place AFTER the named column
201
- return columnIndex >= 0 ? columnIndex + 1 : 0;
202
- }
203
- return 0;
204
- }, [hasExpansion, rowExpansionConfig, table]);
205
-
206
- // Render grouped headers if we have groups
207
- if (hasGroups && groupHeaderRows.length > 0) {
208
- return __jsx(_material.TableHead, {
209
- className: "table-header thead-sticky"
210
- }, table.getHeaderGroups().map(function (headerGroup, groupIndex) {
211
- // For grouped tables, we only render the first header group from the table
212
- // and replace its content with our grouped structure
213
- if (groupIndex > 0) return null;
214
- return groupHeaderRows.map(function (headerRow, rowIndex) {
215
- return __jsx(_material.TableRow, {
216
- key: "header-row-".concat(rowIndex),
217
- className: "".concat(_utils.TABLE_CSS_CLASSES.tableRow, " ").concat(rowClass)
218
- }, rowIndex === 0 && headerGroup.headers.filter(function (header) {
219
- return ["multiSelect", "radioSelect", "rowIndex", "row-index"].includes(header.column.id);
220
- }).map(function (header) {
221
- return __jsx(StandardHeaderCell, {
222
- key: header.id,
223
- header: header,
224
- enablesort: enablesort,
225
- rowSpan: maxHeaderDepth
226
- });
227
- }), rowIndex === 0 && hasExpansion && __jsx(ExpansionHeaderCell, {
228
- key: "expansion-header",
229
- rowSpan: maxHeaderDepth,
230
- columnwidth: rowExpansionConfig === null || rowExpansionConfig === void 0 ? void 0 : rowExpansionConfig.columnwidth
231
- }), headerRow.map(function (headerCell, cellIndex) {
232
- if (headerCell.isGroup) {
233
- return __jsx(GroupHeaderCell, {
234
- key: "group-".concat(cellIndex, "-").concat(headerCell.field),
235
- headerCell: headerCell
236
- });
237
- } else if (headerCell.column) {
238
- // Find the corresponding header from the table
239
- var header = headerGroup.headers.find(function (h) {
240
- return h.column.id === headerCell.field || h.column.columnDef.accessorKey === headerCell.field;
241
- });
242
- if (header) {
243
- return __jsx(StandardHeaderCell, {
244
- key: header.id,
245
- header: header,
246
- enablesort: enablesort,
247
- rowSpan: headerCell.rowspan || 1
248
- });
249
- }
205
+ return dataColumnStartIndex + positionNum;
206
+ }
207
+ if (typeof position === "string") {
208
+ const columnIndex = headers.findIndex((header) => {
209
+ if (header.id === position || header.column.id === position) {
210
+ return true;
250
211
  }
251
- return null;
252
- }), rowIndex === 0 && headerGroup.headers.filter(function (header) {
253
- return header.column.id === "actions";
254
- }).map(function (header) {
255
- return __jsx(StandardHeaderCell, {
256
- key: header.id,
257
- header: header,
258
- enablesort: enablesort,
259
- rowSpan: maxHeaderDepth
260
- });
261
- }));
262
- });
263
- }), filterMode === "multicolumn" && __jsx(_TableFilters.TableFilterRow, {
264
- columns: table.getAllFlatColumns().map(function (col) {
265
- return col.columnDef;
266
- }),
267
- columnFilters: columnFilters || {},
268
- onColumnFilterChange: onColumnFilterChange || function () {},
269
- filterMode: filterMode,
270
- renderFormWidget: renderFormWidget,
271
- listener: listener
272
- }));
273
- }
274
-
275
- // Default rendering for non-grouped tables
276
- return __jsx(_material.TableHead, {
277
- className: "table-header thead-sticky"
278
- }, table.getHeaderGroups().map(function (headerGroup) {
279
- return __jsx(_material.TableRow, {
280
- key: headerGroup.id,
281
- className: "".concat(_utils.TABLE_CSS_CLASSES.tableRow, " ").concat(rowClass),
282
- tabIndex: 0,
283
- role: "row"
284
- }, headerGroup.headers.map(function (header, headerIndex) {
285
- var _header$column$column2;
286
- var cells = [];
287
-
288
- // Insert expansion header before this cell if it's at the calculated position
289
- if (hasExpansion && headerIndex === getExpansionInsertIndex) {
290
- cells.push(__jsx(ExpansionHeaderCell, {
291
- key: "expansion-header-".concat(headerIndex),
292
- className: _utils.TABLE_CSS_CLASSES.headerCell,
293
- style: {
294
- width: (rowExpansionConfig === null || rowExpansionConfig === void 0 ? void 0 : rowExpansionConfig.columnwidth) || "50px",
295
- padding: "8px",
296
- userSelect: "none"
297
- },
298
- role: "columnheader",
299
- "data-col-id": headerIndex,
300
- tabIndex: 0,
301
- "data-col-field": header.column.id,
302
- columnwidth: rowExpansionConfig === null || rowExpansionConfig === void 0 ? void 0 : rowExpansionConfig.columnwidth
303
- }));
212
+ const column = header.column.columnDef;
213
+ if (column.accessorKey === position) {
214
+ return true;
215
+ }
216
+ const normalizedPosition = position.replace(/\./g, "_");
217
+ return header.id === normalizedPosition || header.column.id === normalizedPosition;
218
+ });
219
+ return columnIndex >= 0 ? columnIndex + 1 : 0;
304
220
  }
305
-
306
- // Column selection feature
307
- var columnId = header.column.id;
308
-
309
- // Determine if this is a system column (excluded from column selection)
310
- var isSystemColumn = columnId === "multiSelect" || columnId === "radioSelect" || columnId === "row-index" || columnId === "rowIndex" || columnId === "actions";
311
-
312
- // Handle header cell click - column selection takes priority over sorting
313
- var handleHeaderClick = function handleHeaderClick(event) {
314
- // Call onHeaderclick callback if provided
315
- if (onHeaderclick) {
316
- var _listener$Widgets;
317
- var colDef = header.column.columnDef;
318
- var columnData = {
319
- field: columnId,
320
- caption: colDef.header || columnId,
321
- colDef: colDef
322
- };
323
- onHeaderclick(event, listener === null || listener === void 0 || (_listener$Widgets = listener.Widgets) === null || _listener$Widgets === void 0 ? void 0 : _listener$Widgets[tableName || ""], columnData);
324
- }
325
-
326
- // Skip system columns from column selection
327
- if (enablecolumnselection && !isSystemColumn) {
328
- // Column selection has priority - toggle class directly on the element
329
- var target = event.currentTarget;
330
- var isCurrentlySelected = target.classList.contains(_utils.TABLE_CSS_CLASSES.selectedColumn);
331
-
332
- // Get current visible rows directly from table at click time
333
- // This ensures we get the actual displayed rows based on current page size
334
- var currentRows = table.getRowModel().rows.map(function (row) {
335
- return row.original;
336
- });
337
-
338
- // Extract column data from current visible rows
339
- var _colDef = header.column.columnDef;
340
- var accessorKey = _colDef.accessorKey || columnId;
341
- var _columnData = currentRows.map(function (row) {
342
- // Handle nested paths (e.g., "name.location.url")
343
- if (accessorKey.includes(".")) {
344
- return accessorKey.split(".").reduce(function (obj, key) {
345
- return obj === null || obj === void 0 ? void 0 : obj[key];
346
- }, row);
347
- }
348
- return row[accessorKey];
349
- });
350
- if (isCurrentlySelected) {
351
- // Deselect: remove the class and call callback
352
- target.classList.remove(_utils.TABLE_CSS_CLASSES.selectedColumn);
353
- onColumnDeselect === null || onColumnDeselect === void 0 || onColumnDeselect(event, columnId, header.column.columnDef, _columnData);
354
- } else {
355
- // Select: add the class and call callback
356
- target.classList.add(_utils.TABLE_CSS_CLASSES.selectedColumn);
357
- onColumnSelect === null || onColumnSelect === void 0 || onColumnSelect(event, columnId, header.column.columnDef, _columnData);
221
+ return 0;
222
+ }, [hasExpansion, rowExpansionConfig, table]);
223
+ if (hasGroups && groupHeaderRows.length > 0) {
224
+ return /* @__PURE__ */ jsxs(TableHead, { className: "table-header thead-sticky", children: [
225
+ table.getHeaderGroups().map((headerGroup, groupIndex) => {
226
+ if (groupIndex > 0) return null;
227
+ return groupHeaderRows.map((headerRow, rowIndex) => /* @__PURE__ */ jsxs(
228
+ TableRow,
229
+ {
230
+ className: `${TABLE_CSS_CLASSES.tableRow} ${rowClass}`,
231
+ children: [
232
+ rowIndex === 0 && headerGroup.headers.filter(
233
+ (header) => ["multiSelect", "radioSelect", "rowIndex", "row-index"].includes(
234
+ header.column.id
235
+ )
236
+ ).map((header) => /* @__PURE__ */ jsx(
237
+ StandardHeaderCell,
238
+ {
239
+ header,
240
+ enablesort,
241
+ rowSpan: maxHeaderDepth
242
+ },
243
+ header.id
244
+ )),
245
+ rowIndex === 0 && hasExpansion && /* @__PURE__ */ jsx(
246
+ ExpansionHeaderCell,
247
+ {
248
+ rowSpan: maxHeaderDepth,
249
+ columnwidth: rowExpansionConfig == null ? void 0 : rowExpansionConfig.columnwidth
250
+ },
251
+ "expansion-header"
252
+ ),
253
+ headerRow.map((headerCell, cellIndex) => {
254
+ if (headerCell.isGroup) {
255
+ return /* @__PURE__ */ jsx(
256
+ GroupHeaderCell,
257
+ {
258
+ headerCell
259
+ },
260
+ `group-${cellIndex}-${headerCell.field}`
261
+ );
262
+ } else if (headerCell.column) {
263
+ const header = headerGroup.headers.find(
264
+ (h) => h.column.id === headerCell.field || h.column.columnDef.accessorKey === headerCell.field
265
+ );
266
+ if (header) {
267
+ return /* @__PURE__ */ jsx(
268
+ StandardHeaderCell,
269
+ {
270
+ header,
271
+ enablesort,
272
+ rowSpan: headerCell.rowspan || 1
273
+ },
274
+ header.id
275
+ );
276
+ }
277
+ }
278
+ return null;
279
+ }),
280
+ rowIndex === 0 && headerGroup.headers.filter((header) => header.column.id === "actions").map((header) => /* @__PURE__ */ jsx(
281
+ StandardHeaderCell,
282
+ {
283
+ header,
284
+ enablesort,
285
+ rowSpan: maxHeaderDepth
286
+ },
287
+ header.id
288
+ ))
289
+ ]
290
+ },
291
+ `header-row-${rowIndex}`
292
+ ));
293
+ }),
294
+ filterMode === "multicolumn" && /* @__PURE__ */ jsx(
295
+ TableFilterRow,
296
+ {
297
+ columns: table.getAllFlatColumns().map((col) => col.columnDef),
298
+ columnFilters: columnFilters || {},
299
+ onColumnFilterChange: onColumnFilterChange || (() => {
300
+ }),
301
+ filterMode,
302
+ renderFormWidget,
303
+ listener
358
304
  }
359
- return; // Don't execute sorting
360
- }
361
-
362
- // Fall back to sorting if column selection is not enabled
363
- if (enablesort && header.column.getCanSort()) {
364
- var _header$column$getTog;
365
- (_header$column$getTog = header.column.getToggleSortingHandler()) === null || _header$column$getTog === void 0 || _header$column$getTog(event);
366
- }
367
- };
368
- var isClickable = enablecolumnselection && !isSystemColumn || enablesort && header.column.getCanSort();
369
-
370
- // Add the regular header cell (ui-resizable when column can resize, match Angular)
371
- var headerCellResizableClass = header.column.getCanResize() ? " ui-resizable" : "";
372
- cells.push(__jsx(_material.TableCell, {
373
- key: header.id,
374
- className: "".concat(_utils.TABLE_CSS_CLASSES.headerCell, " ").concat(((_header$column$column2 = header.column.columnDef) === null || _header$column$column2 === void 0 || (_header$column$column2 = _header$column$column2.meta) === null || _header$column$column2 === void 0 ? void 0 : _header$column$column2.className) || "", " ").concat(headerCellResizableClass).trim(),
375
- style: {
376
- cursor: isClickable ? "pointer" : "default",
377
- userSelect: "none",
378
- width: header.getSize(),
379
- position: "relative",
380
- fontSize: "inherit",
381
- color: "inherit",
382
- fontWeight: "bold",
383
- lineHeight: "inherit"
384
- },
385
- title: header.column.columnDef.header && typeof header.column.columnDef.header !== "function" ? header.column.columnDef.header.toString() : "",
386
- onClick: handleHeaderClick,
387
- role: "columnheader",
388
- "data-col-id": headerIndex,
389
- tabIndex: 0,
390
- "data-col-field": header.column.id
391
- }, header.isPlaceholder ? null : (0, _reactTable.flexRender)(header.column.columnDef.header, header.getContext()), enablesort && !enablecolumnselection && header.column.getCanSort() && __jsx(_material.Box, {
392
- style: {
393
- zIndex: 90
305
+ )
306
+ ] });
307
+ }
308
+ return /* @__PURE__ */ jsxs(TableHead, { className: "table-header thead-sticky", children: [
309
+ table.getHeaderGroups().map((headerGroup) => /* @__PURE__ */ jsx(
310
+ TableRow,
311
+ {
312
+ className: `${TABLE_CSS_CLASSES.tableRow} ${rowClass}`,
313
+ tabIndex: 0,
314
+ role: "row",
315
+ children: headerGroup.headers.map((header, headerIndex) => {
316
+ var _a, _b;
317
+ const cells = [];
318
+ if (hasExpansion && headerIndex === getExpansionInsertIndex) {
319
+ cells.push(
320
+ /* @__PURE__ */ jsx(
321
+ ExpansionHeaderCell,
322
+ {
323
+ className: TABLE_CSS_CLASSES.headerCell,
324
+ style: {
325
+ width: (rowExpansionConfig == null ? void 0 : rowExpansionConfig.columnwidth) || "50px",
326
+ padding: "8px",
327
+ userSelect: "none"
328
+ },
329
+ role: "columnheader",
330
+ "data-col-id": headerIndex,
331
+ tabIndex: 0,
332
+ "data-col-field": header.column.id,
333
+ columnwidth: rowExpansionConfig == null ? void 0 : rowExpansionConfig.columnwidth
334
+ },
335
+ `expansion-header-${headerIndex}`
336
+ )
337
+ );
338
+ }
339
+ const columnId = header.column.id;
340
+ const isSystemColumn = columnId === "multiSelect" || columnId === "radioSelect" || columnId === "row-index" || columnId === "rowIndex" || columnId === "actions";
341
+ const handleHeaderClick = (event) => {
342
+ var _a2, _b2;
343
+ if (onHeaderclick) {
344
+ const colDef = header.column.columnDef;
345
+ const columnData = {
346
+ field: columnId,
347
+ caption: colDef.header || columnId,
348
+ colDef
349
+ };
350
+ onHeaderclick(event, (_a2 = listener == null ? void 0 : listener.Widgets) == null ? void 0 : _a2[tableName || ""], columnData);
351
+ }
352
+ if (enablecolumnselection && !isSystemColumn) {
353
+ const target = event.currentTarget;
354
+ const isCurrentlySelected = target.classList.contains(
355
+ TABLE_CSS_CLASSES.selectedColumn
356
+ );
357
+ const currentRows = table.getRowModel().rows.map((row) => row.original);
358
+ const colDef = header.column.columnDef;
359
+ const accessorKey = colDef.accessorKey || columnId;
360
+ const columnData = currentRows.map((row) => {
361
+ if (accessorKey.includes(".")) {
362
+ return accessorKey.split(".").reduce((obj, key) => obj == null ? void 0 : obj[key], row);
363
+ }
364
+ return row[accessorKey];
365
+ });
366
+ if (isCurrentlySelected) {
367
+ target.classList.remove(TABLE_CSS_CLASSES.selectedColumn);
368
+ onColumnDeselect == null ? void 0 : onColumnDeselect(event, columnId, header.column.columnDef, columnData);
369
+ } else {
370
+ target.classList.add(TABLE_CSS_CLASSES.selectedColumn);
371
+ onColumnSelect == null ? void 0 : onColumnSelect(event, columnId, header.column.columnDef, columnData);
372
+ }
373
+ return;
374
+ }
375
+ if (enablesort && header.column.getCanSort()) {
376
+ (_b2 = header.column.getToggleSortingHandler()) == null ? void 0 : _b2(event);
377
+ }
378
+ };
379
+ const isClickable = enablecolumnselection && !isSystemColumn || enablesort && header.column.getCanSort();
380
+ const headerCellResizableClass = header.column.getCanResize() ? " ui-resizable" : "";
381
+ cells.push(
382
+ /* @__PURE__ */ jsxs(
383
+ TableCell,
384
+ {
385
+ className: `${TABLE_CSS_CLASSES.headerCell} ${((_b = (_a = header.column.columnDef) == null ? void 0 : _a.meta) == null ? void 0 : _b.className) || ""} ${headerCellResizableClass}`.trim(),
386
+ style: {
387
+ cursor: isClickable ? "pointer" : "default",
388
+ userSelect: "none",
389
+ width: header.getSize(),
390
+ position: "relative",
391
+ fontSize: "inherit",
392
+ color: "inherit",
393
+ fontWeight: "bold",
394
+ lineHeight: "inherit"
395
+ },
396
+ title: header.column.columnDef.header && typeof header.column.columnDef.header !== "function" ? header.column.columnDef.header.toString() : "",
397
+ onClick: handleHeaderClick,
398
+ role: "columnheader",
399
+ "data-col-id": headerIndex,
400
+ tabIndex: 0,
401
+ "data-col-field": header.column.id,
402
+ children: [
403
+ header.isPlaceholder ? null : flexRender(header.column.columnDef.header, header.getContext()),
404
+ enablesort && !enablecolumnselection && header.column.getCanSort() && /* @__PURE__ */ jsx(
405
+ Box,
406
+ {
407
+ style: { zIndex: 90 },
408
+ component: "span",
409
+ className: `sort-buttons-container ${header.column.getIsSorted() ? "active" : ""}`,
410
+ children: /* @__PURE__ */ jsx(
411
+ Box,
412
+ {
413
+ component: "i",
414
+ className: `sort-icon${header.column.getIsSorted() === "asc" ? ` ${TABLE_CSS_CLASSES.ascIcon}` : header.column.getIsSorted() === "desc" ? ` ${TABLE_CSS_CLASSES.descIcon}` : ""}`
415
+ }
416
+ )
417
+ }
418
+ ),
419
+ header.column.getCanResize() && /* @__PURE__ */ jsx(
420
+ Box,
421
+ {
422
+ className: "ui-resizable-handle ui-resizable-e",
423
+ onMouseDown: header.getResizeHandler(),
424
+ onTouchStart: header.getResizeHandler()
425
+ }
426
+ )
427
+ ]
428
+ },
429
+ header.id
430
+ )
431
+ );
432
+ return /* @__PURE__ */ jsx(React.Fragment, { children: cells }, `header-group-${headerIndex}`);
433
+ })
394
434
  },
395
- component: "span",
396
- className: "sort-buttons-container ".concat(header.column.getIsSorted() ? "active" : "")
397
- }, __jsx(_material.Box, {
398
- component: "i",
399
- className: "sort-icon".concat(header.column.getIsSorted() === "asc" ? " ".concat(_utils.TABLE_CSS_CLASSES.ascIcon) : header.column.getIsSorted() === "desc" ? " ".concat(_utils.TABLE_CSS_CLASSES.descIcon) : "")
400
- })), header.column.getCanResize() && __jsx(_material.Box, {
401
- className: "ui-resizable-handle ui-resizable-e",
402
- onMouseDown: header.getResizeHandler(),
403
- onTouchStart: header.getResizeHandler()
404
- })));
405
- return __jsx(_react["default"].Fragment, {
406
- key: "header-group-".concat(headerIndex)
407
- }, cells);
408
- }));
409
- }), filterMode === "multicolumn" && __jsx(_TableFilters.TableFilterRow, {
410
- columns: table.getAllFlatColumns().map(function (col) {
411
- return col.columnDef;
412
- }),
413
- columnFilters: columnFilters || {},
414
- onColumnFilterChange: onColumnFilterChange || function () {},
415
- filterMode: filterMode,
416
- renderFormWidget: renderFormWidget,
417
- listener: listener
418
- }));
419
- }, function (prevProps, nextProps) {
420
- // Compare props including the sorting state
421
- var prevSorting = prevProps.sorting || [];
422
- var nextSorting = nextProps.sorting || [];
423
- if (prevProps.ColClassSignature !== nextProps.ColClassSignature) {
424
- return false;
435
+ headerGroup.id
436
+ )),
437
+ filterMode === "multicolumn" && /* @__PURE__ */ jsx(
438
+ TableFilterRow,
439
+ {
440
+ columns: table.getAllFlatColumns().map((col) => col.columnDef),
441
+ columnFilters: columnFilters || {},
442
+ onColumnFilterChange: onColumnFilterChange || (() => {
443
+ }),
444
+ filterMode,
445
+ renderFormWidget,
446
+ listener
447
+ }
448
+ )
449
+ ] });
450
+ },
451
+ (prevProps, nextProps) => {
452
+ const prevSorting = prevProps.sorting || [];
453
+ const nextSorting = nextProps.sorting || [];
454
+ if (prevProps.ColClassSignature !== nextProps.ColClassSignature) {
455
+ return false;
456
+ }
457
+ const sortingEqual = prevSorting.length === nextSorting.length && prevSorting.every((prevSort, index) => {
458
+ const nextSort = nextSorting[index];
459
+ return prevSort.id === nextSort.id && prevSort.desc === nextSort.desc;
460
+ });
461
+ const prevSizing = prevProps.columnSizing || {};
462
+ const nextSizing = nextProps.columnSizing || {};
463
+ const sizingKeys = /* @__PURE__ */ new Set([...Object.keys(prevSizing), ...Object.keys(nextSizing)]);
464
+ const sizingEqual = Array.from(sizingKeys).every((key) => prevSizing[key] === nextSizing[key]);
465
+ const prevSelection = prevProps.rowSelection || {};
466
+ const nextSelection = nextProps.rowSelection || {};
467
+ const selectionKeys = /* @__PURE__ */ new Set([...Object.keys(prevSelection), ...Object.keys(nextSelection)]);
468
+ const selectionEqual = selectionKeys.size === Object.keys(prevSelection).length && selectionKeys.size === Object.keys(nextSelection).length && Array.from(selectionKeys).every((key) => prevSelection[key] === nextSelection[key]);
469
+ return prevProps.enablesort === nextProps.enablesort && prevProps.enablecolumnselection === nextProps.enablecolumnselection && prevProps.rowClass === nextProps.rowClass && sortingEqual && sizingEqual && selectionEqual && prevProps.rowExpansionConfig === nextProps.rowExpansionConfig && prevProps.columnsVersion === nextProps.columnsVersion && prevProps.filterMode === nextProps.filterMode && JSON.stringify(prevProps.columnFilters || {}) === JSON.stringify(nextProps.columnFilters || {});
425
470
  }
426
-
427
- // Deep compare sorting arrays
428
- var sortingEqual = prevSorting.length === nextSorting.length && prevSorting.every(function (prevSort, index) {
429
- var nextSort = nextSorting[index];
430
- return prevSort.id === nextSort.id && prevSort.desc === nextSort.desc;
431
- });
432
-
433
- // Compare column sizing
434
- var prevSizing = prevProps.columnSizing || {};
435
- var nextSizing = nextProps.columnSizing || {};
436
- var sizingKeys = new Set([].concat((0, _toConsumableArray2["default"])(Object.keys(prevSizing)), (0, _toConsumableArray2["default"])(Object.keys(nextSizing))));
437
- var sizingEqual = Array.from(sizingKeys).every(function (key) {
438
- return prevSizing[key] === nextSizing[key];
439
- });
440
-
441
- // Compare row selection
442
- var prevSelection = prevProps.rowSelection || {};
443
- var nextSelection = nextProps.rowSelection || {};
444
- var selectionKeys = new Set([].concat((0, _toConsumableArray2["default"])(Object.keys(prevSelection)), (0, _toConsumableArray2["default"])(Object.keys(nextSelection))));
445
- var selectionEqual = selectionKeys.size === Object.keys(prevSelection).length && selectionKeys.size === Object.keys(nextSelection).length && Array.from(selectionKeys).every(function (key) {
446
- return prevSelection[key] === nextSelection[key];
447
- });
448
- return prevProps.enablesort === nextProps.enablesort && prevProps.enablecolumnselection === nextProps.enablecolumnselection && prevProps.rowClass === nextProps.rowClass && sortingEqual && sizingEqual && selectionEqual && prevProps.rowExpansionConfig === nextProps.rowExpansionConfig && prevProps.columnsVersion === nextProps.columnsVersion && prevProps.filterMode === nextProps.filterMode && JSON.stringify(prevProps.columnFilters || {}) === JSON.stringify(nextProps.columnFilters || {});
449
- });
450
- TableHeaderComponent.displayName = "TableHeaderComponent";
471
+ );
472
+ TableHeaderComponent.displayName = "TableHeaderComponent";
473
+ export {
474
+ TableHeaderComponent
475
+ };