@wavemaker-ai/react-runtime 1.0.0-rc.647499 → 1.0.0-rc.647565

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 +808 -3177
  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,357 +1,295 @@
1
- "use strict";
2
1
  "use client";
3
-
4
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
- var _typeof = require("@babel/runtime/helpers/typeof");
6
- Object.defineProperty(exports, "__esModule", {
7
- value: true
8
- });
9
- exports["default"] = exports.WmList = void 0;
10
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
14
- var _react = _interopRequireWildcard(require("react"));
15
- var _clsx = _interopRequireDefault(require("clsx"));
16
- var _Box = _interopRequireDefault(require("@mui/material/Box"));
17
- var _List = _interopRequireDefault(require("@mui/material/List"));
18
- var _withBaseWrapper = require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper");
19
- var _WidgetProvider = require("@wavemaker-ai/react-runtime/context/WidgetProvider");
20
- var _components = require("@wavemaker-ai/react-runtime/components/data/pagination/components");
21
- var _components2 = require("./components");
22
- var _common = require("@wavemaker-ai/react-runtime/components/common");
23
- var _hooks = require("./hooks");
24
- var _constants = require("./utils/constants");
25
- var _listHelpers = require("./utils/list-helpers");
26
- var _utils = require("../table/utils");
27
- var _listWidgetMethods = require("./utils/list-widget-methods");
28
- var _types = require("../types");
29
- var _isEqual = _interopRequireDefault(require("lodash-es/isEqual"));
30
- var _styleUtils = require("@wavemaker-ai/react-runtime/utils/style-utils");
31
- var _withStandalone = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withStandalone"));
32
- 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); }
33
- var __jsx = _react["default"].createElement;
34
- 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; }
35
- 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; } // Import hooks
36
- // Import components
37
- // Import utilities
38
- var WmList = function WmList(props) {
39
- var _listener$Widgets, _paginationState$pagi5, _paginationState$pagi6, _datasource$loading;
40
- // ==================== PROPS DESTRUCTURING ====================
41
- var className = props.className,
42
- styles = props.styles,
43
- width = props.width,
44
- height = props.height,
45
- _props$tabIndex = props.tabIndex,
46
- tabIndex = _props$tabIndex === void 0 ? 0 : _props$tabIndex,
47
- _props$hidden = props.hidden,
48
- hidden = _props$hidden === void 0 ? false : _props$hidden,
49
- _props$name = props.name,
50
- name = _props$name === void 0 ? "list" : _props$name,
51
- _props$boundarylinks = props.boundarylinks,
52
- boundarylinks = _props$boundarylinks === void 0 ? _constants.LIST_DEFAULTS.BOUNDARY_LINKS : _props$boundarylinks,
53
- _props$collapsible = props.collapsible,
54
- collapsible = _props$collapsible === void 0 ? _constants.LIST_DEFAULTS.COLLAPSIBLE : _props$collapsible,
55
- _props$direction = props.direction,
56
- direction = _props$direction === void 0 ? _constants.LIST_DIRECTION.VERTICAL : _props$direction,
57
- _props$disableitem = props.disableitem,
58
- disableitem = _props$disableitem === void 0 ? false : _props$disableitem,
59
- _props$enablereorder = props.enablereorder,
60
- enablereorder = _props$enablereorder === void 0 ? false : _props$enablereorder,
61
- _props$multiselect = props.multiselect,
62
- multiselect = _props$multiselect === void 0 ? _constants.LIST_DEFAULTS.MULTISELECT : _props$multiselect,
63
- _props$selectfirstite = props.selectfirstitem,
64
- selectfirstitem = _props$selectfirstite === void 0 ? _constants.LIST_DEFAULTS.SELECT_FIRST_ITEM : _props$selectfirstite,
65
- _props$selectionlimit = props.selectionlimit,
66
- selectionlimit = _props$selectionlimit === void 0 ? _constants.LIST_DEFAULTS.SELECTION_LIMIT : _props$selectionlimit,
67
- _props$hidehorizontal = props.hidehorizontalscrollbar,
68
- hidehorizontalscrollbar = _props$hidehorizontal === void 0 ? false : _props$hidehorizontal,
69
- _props$dataset = props.dataset,
70
- dataset = _props$dataset === void 0 ? [] : _props$dataset,
71
- _props$datafield = props.datafield,
72
- datafield = _props$datafield === void 0 ? "" : _props$datafield,
73
- _props$displayfield = props.displayfield,
74
- displayfield = _props$displayfield === void 0 ? "" : _props$displayfield,
75
- displaylabel = props.displaylabel,
76
- getDisplayExpression = props.getDisplayExpression,
77
- datasource = props.datasource,
78
- _props$deferload = props.deferload,
79
- deferload = _props$deferload === void 0 ? false : _props$deferload,
80
- _props$groupby = props.groupby,
81
- groupby = _props$groupby === void 0 ? "" : _props$groupby,
82
- _props$orderby = props.orderby,
83
- orderby = _props$orderby === void 0 ? "" : _props$orderby,
84
- _props$navigation = props.navigation,
85
- navigation = _props$navigation === void 0 ? _constants.LIST_NAVIGATION_TYPES.NONE : _props$navigation,
86
- _props$navigationalig = props.navigationalign,
87
- navigationalign = _props$navigationalig === void 0 ? _constants.LIST_ALIGN.LEFT : _props$navigationalig,
88
- pagesize = props.pagesize,
89
- _props$maxsize = props.maxsize,
90
- maxsize = _props$maxsize === void 0 ? _constants.LIST_DEFAULTS.MAX_SIZE : _props$maxsize,
91
- _props$showcount = props.showcount,
92
- showcount = _props$showcount === void 0 ? _constants.LIST_DEFAULTS.SHOW_COUNT : _props$showcount,
93
- _props$showrecordcoun = props.showrecordcount,
94
- showrecordcount = _props$showrecordcoun === void 0 ? _constants.LIST_DEFAULTS.SHOW_RECORD_COUNT : _props$showrecordcoun,
95
- _props$allowpagesizec = props.allowpagesizechange,
96
- allowpagesizechange = _props$allowpagesizec === void 0 ? false : _props$allowpagesizec,
97
- _props$pagesizeoption = props.pagesizeoptions,
98
- pagesizeoptions = _props$pagesizeoption === void 0 ? "5,10,20,50,100" : _props$pagesizeoption,
99
- _props$paginationclas = props.paginationclass,
100
- paginationclass = _props$paginationclas === void 0 ? "" : _props$paginationclas,
101
- _props$showNavigation = props.showNavigation,
102
- showNavigation = _props$showNavigation === void 0 ? true : _props$showNavigation,
103
- _props$title = props.title,
104
- title = _props$title === void 0 ? "" : _props$title,
105
- _props$subheading = props.subheading,
106
- subheading = _props$subheading === void 0 ? "" : _props$subheading,
107
- _props$iconclass = props.iconclass,
108
- iconclass = _props$iconclass === void 0 ? "" : _props$iconclass,
109
- _props$nodatamessage = props.nodatamessage,
110
- nodatamessage = _props$nodatamessage === void 0 ? _constants.LIST_MESSAGES.NO_DATA : _props$nodatamessage,
111
- _props$loadingdatamsg = props.loadingdatamsg,
112
- loadingdatamsg = _props$loadingdatamsg === void 0 ? _constants.LIST_MESSAGES.LOADING : _props$loadingdatamsg,
113
- _props$loadingicon = props.loadingicon,
114
- loadingicon = _props$loadingicon === void 0 ? "fa-spinner" : _props$loadingicon,
115
- _props$ondemandmessag = props.ondemandmessage,
116
- ondemandmessage = _props$ondemandmessag === void 0 ? _constants.LIST_MESSAGES.LOAD_MORE : _props$ondemandmessag,
117
- _props$listclass = props.listclass,
118
- listclass = _props$listclass === void 0 ? "list-group media-list" : _props$listclass,
119
- _props$itemclass = props.itemclass,
120
- itemclass = _props$itemclass === void 0 ? "list-group-item" : _props$itemclass,
121
- _props$horizontalalig = props.horizontalalign,
122
- horizontalalign = _props$horizontalalig === void 0 ? _constants.LIST_ALIGN.LEFT : _props$horizontalalig,
123
- itemsperrow = props.itemsperrow,
124
- _props$statehandler = props.statehandler,
125
- statehandler = _props$statehandler === void 0 ? "none" : _props$statehandler,
126
- onSelect = props.onSelect,
127
- onClick = props.onClick,
128
- onDblclick = props.onDblclick,
129
- onMouseEnter = props.onMouseEnter,
130
- onMouseLeave = props.onMouseLeave,
131
- onReorder = props.onReorder,
132
- onSelectionlimitexceed = props.onSelectionlimitexceed,
133
- onBeforedatarender = props.onBeforedatarender,
134
- onRender = props.onRender,
135
- onPaginationchange = props.onPaginationchange,
136
- onSetrecord = props.onSetrecord,
137
- onPageChange = props.onPageChange,
138
- renderItem = props.renderItem,
139
- children = props.children,
140
- itemAttrs = props.itemAttrs,
141
- listener = props.listener,
142
- layoutClassName = props.layoutClassName,
143
- wrap = props.wrap,
144
- alignment = props.alignment,
145
- gap = props.gap,
146
- columngap = props.columngap,
147
- _props$standalone = props.standalone,
148
- standalone = _props$standalone === void 0 ? false : _props$standalone;
149
- var datasetHashRef = (0, _react.useRef)([]);
150
- var _useState = (0, _react.useState)(null),
151
- currentDataset = _useState[0],
152
- setCurrentDataset = _useState[1];
153
- var Widgets = (0, _WidgetProvider.useWidgetProxy)(undefined, standalone);
154
- // ==================== STATE INITIALIZATION ====================
155
- var widgetInstance = Widgets[name];
156
-
157
- // ==================== DATASOURCE SUBSCRIPTION ====================
158
- // Disable state management for On-Demand and Scroll navigation
159
- var effectiveStateHandlerForSubscription = navigation === _constants.LIST_NAVIGATION_TYPES.ON_DEMAND || navigation === _constants.LIST_NAVIGATION_TYPES.SCROLL ? "none" : statehandler;
160
-
161
- // Subscribe to 'toggle-variable-state' event to handle state params
162
- (0, _hooks.useDataSourceSubscription)({
163
- datasource: datasource,
2
+ var __defProp = Object.defineProperty;
3
+ var __defProps = Object.defineProperties;
4
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
5
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
8
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
+ var __spreadValues = (a, b) => {
10
+ for (var prop in b || (b = {}))
11
+ if (__hasOwnProp.call(b, prop))
12
+ __defNormalProp(a, prop, b[prop]);
13
+ if (__getOwnPropSymbols)
14
+ for (var prop of __getOwnPropSymbols(b)) {
15
+ if (__propIsEnum.call(b, prop))
16
+ __defNormalProp(a, prop, b[prop]);
17
+ }
18
+ return a;
19
+ };
20
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
21
+ import { jsx, jsxs } from "react/jsx-runtime";
22
+ import React, {
23
+ useCallback,
24
+ useEffect,
25
+ useMemo,
26
+ useRef,
27
+ useState
28
+ } from "react";
29
+ import clsx from "clsx";
30
+ import Box from "@mui/material/Box";
31
+ import List from "@mui/material/List";
32
+ import { withBaseWrapper } from "../../../higherOrder/withBaseWrapper";
33
+ import { useWidgetProxy } from "../../../context/WidgetProvider";
34
+ import { InlineNavigation } from "../pagination/components";
35
+ import { NoDataMessage, useDragAndDrop } from "./components";
36
+ import { AppSpinner } from "../../common";
37
+ import {
38
+ useListData,
39
+ useListState,
40
+ useGroupedData,
41
+ useListEventHandlers,
42
+ useListPagination,
43
+ useListEffects,
44
+ useDataSourceSubscription,
45
+ useListStateManager
46
+ } from "./hooks";
47
+ import { ListHeader, ListPagination, ListItems } from "./components";
48
+ import {
49
+ DEFAULT_CLS,
50
+ LIST_NAVIGATION_TYPES,
51
+ LIST_DEFAULTS,
52
+ LIST_MESSAGES,
53
+ LIST_ALIGN,
54
+ LIST_DIRECTION,
55
+ INSETION_POSITION
56
+ } from "./utils/constants";
57
+ import {
58
+ getItemsPerRowClass,
59
+ getTextAlignClass,
60
+ getSafeDataset,
61
+ getListState,
62
+ saveListState,
63
+ hasListGroupAutoLayoutClass
64
+ } from "./utils/list-helpers";
65
+ import { addUniqueRowIds } from "../table/utils";
66
+ import { useListWidgetMethods } from "./utils/list-widget-methods";
67
+ import { DataSource } from "../types";
68
+ import isEqual from "lodash-es/isEqual";
69
+ import { filterAutoLayoutClasses } from "../../../utils/style-utils";
70
+ import withStandalone from "../../../higherOrder/withStandalone";
71
+ const WmList = (props) => {
72
+ var _a, _b, _c, _d, _e;
73
+ const {
74
+ // Layout & Styling
75
+ className,
76
+ styles,
77
+ width,
78
+ height,
79
+ tabIndex = 0,
80
+ hidden = false,
81
+ // List Configuration
82
+ name = "list",
83
+ boundarylinks = LIST_DEFAULTS.BOUNDARY_LINKS,
84
+ collapsible = LIST_DEFAULTS.COLLAPSIBLE,
85
+ direction = LIST_DIRECTION.VERTICAL,
86
+ disableitem = false,
87
+ enablereorder = false,
88
+ multiselect = LIST_DEFAULTS.MULTISELECT,
89
+ selectfirstitem = LIST_DEFAULTS.SELECT_FIRST_ITEM,
90
+ selectionlimit = LIST_DEFAULTS.SELECTION_LIMIT,
91
+ hidehorizontalscrollbar = false,
92
+ selecteditem,
93
+ // Data Props
94
+ dataset = [],
95
+ datafield = "",
96
+ displayfield = "",
97
+ displaylabel,
98
+ getDisplayExpression,
99
+ datasource,
100
+ deferload = false,
101
+ // Grouping & Ordering
102
+ groupby = "",
103
+ orderby = "",
104
+ // Pagination
105
+ navigation = LIST_NAVIGATION_TYPES.NONE,
106
+ navigationalign = LIST_ALIGN.LEFT,
107
+ pagesize,
108
+ maxsize = LIST_DEFAULTS.MAX_SIZE,
109
+ showcount = LIST_DEFAULTS.SHOW_COUNT,
110
+ showrecordcount = LIST_DEFAULTS.SHOW_RECORD_COUNT,
111
+ allowpagesizechange = false,
112
+ pagesizeoptions = "5,10,20,50,100",
113
+ paginationclass = "",
114
+ showNavigation = true,
115
+ // Display Text
116
+ title = "",
117
+ subheading = "",
118
+ iconclass = "",
119
+ nodatamessage = LIST_MESSAGES.NO_DATA,
120
+ loadingdatamsg = LIST_MESSAGES.LOADING,
121
+ loadingicon = "fa-spinner",
122
+ ondemandmessage = LIST_MESSAGES.LOAD_MORE,
123
+ // Styling Classes
124
+ listclass = "list-group media-list",
125
+ itemclass = "list-group-item",
126
+ horizontalalign = LIST_ALIGN.LEFT,
127
+ itemsperrow,
128
+ // State Management
129
+ statehandler = "none",
130
+ // Event Handlers
131
+ onSelect,
132
+ onClick,
133
+ onDblclick,
134
+ onMouseEnter,
135
+ onMouseLeave,
136
+ onReorder,
137
+ onSelectionlimitexceed,
138
+ onBeforedatarender,
139
+ onRender,
140
+ onPaginationchange,
141
+ onSetrecord,
142
+ onPageChange,
143
+ // Template & Rendering
144
+ renderItem,
145
+ children,
146
+ itemAttrs,
147
+ // Widget Instance
148
+ listener,
149
+ layoutClassName,
150
+ wrap,
151
+ alignment,
152
+ gap,
153
+ columngap,
154
+ standalone = false
155
+ } = props;
156
+ const datasetHashRef = useRef([]);
157
+ const [currentDataset, setCurrentDataset] = useState(null);
158
+ const Widgets = useWidgetProxy(void 0, standalone);
159
+ const widgetInstance = Widgets[name];
160
+ const effectiveStateHandlerForSubscription = navigation === LIST_NAVIGATION_TYPES.ON_DEMAND || navigation === LIST_NAVIGATION_TYPES.SCROLL ? "none" : statehandler;
161
+ useDataSourceSubscription({
162
+ datasource,
164
163
  statehandler: effectiveStateHandlerForSubscription,
165
- name: name,
166
- onPageRestored: function onPageRestored(restoredPage) {
167
- // Store the restored page number to apply when pagination is ready
164
+ name,
165
+ onPageRestored: (restoredPage) => {
168
166
  setRestoredPageNumber(restoredPage);
169
167
  }
170
168
  });
171
-
172
- // Get proxy from page context for reactive widget access
173
-
174
- // is dataset from modal variable
175
- var _useState2 = (0, _react.useState)(false),
176
- isDatasetFromModalVariable = _useState2[0],
177
- setIsDatasetFromModalVariable = _useState2[1];
178
- var resolvedDataset = (0, _listHelpers.getSafeDataset)(dataset);
179
- if (!(0, _isEqual["default"])(datasetHashRef.current, resolvedDataset)) {
169
+ const [isDatasetFromModalVariable, setIsDatasetFromModalVariable] = useState(false);
170
+ const resolvedDataset = getSafeDataset(dataset, datasource);
171
+ if (!isEqual(datasetHashRef.current, resolvedDataset)) {
180
172
  datasetHashRef.current = resolvedDataset;
181
173
  setCurrentDataset(resolvedDataset);
182
174
  }
183
- var safeDataset = (0, _react.useMemo)(function () {
184
- return (0, _utils.addUniqueRowIds)(resolvedDataset, {
185
- type: "list"
186
- });
175
+ const safeDataset = useMemo(() => {
176
+ return addUniqueRowIds(resolvedDataset, { type: "list" });
187
177
  }, [currentDataset]);
188
-
189
- // Initial render tracking
190
- var _useState3 = (0, _react.useState)(true),
191
- initialRender = _useState3[0],
192
- setinitialRender = _useState3[1];
193
-
194
- // User interaction tracking
195
- var userInitiatedSelectionRef = _react["default"].useRef(false);
196
- var listScrollContainerRef = (0, _react.useRef)(null);
197
- var scrollSentinelRef = (0, _react.useRef)(null); // Scroll sentinel: list sets when row, pagination sets when vertical
198
-
199
- // ==================== ON-DEMAND NAVIGATION STATE ====================
200
- // For On-Demand navigation, accumulate data from multiple pages
201
- var _useState4 = (0, _react.useState)([]),
202
- accumulatedData = _useState4[0],
203
- setAccumulatedData = _useState4[1];
204
- var _useState5 = (0, _react.useState)(-1),
205
- lastLoadedPage = _useState5[0],
206
- setLastLoadedPage = _useState5[1];
207
- var _useState6 = (0, _react.useState)(true),
208
- isFirstLoad = _useState6[0],
209
- setIsFirstLoad = _useState6[1];
210
- var _useState7 = (0, _react.useState)(0),
211
- onDemandCurrentPage = _useState7[0],
212
- setOnDemandCurrentPage = _useState7[1];
213
-
214
- // Determine if we're using server-side pagination
215
- // Check if datasource is API-aware (server-side) rather than checking runtime pagination data
216
- var isServerSidePagination = (0, _react.useCallback)(function () {
217
- if (navigation === _constants.LIST_NAVIGATION_TYPES.NONE) {
178
+ const [initialRender, setinitialRender] = useState(true);
179
+ const userInitiatedSelectionRef = React.useRef(false);
180
+ const listScrollContainerRef = useRef(null);
181
+ const scrollSentinelRef = useRef(null);
182
+ const [accumulatedData, setAccumulatedData] = useState([]);
183
+ const [lastLoadedPage, setLastLoadedPage] = useState(-1);
184
+ const [isFirstLoad, setIsFirstLoad] = useState(true);
185
+ const [onDemandCurrentPage, setOnDemandCurrentPage] = useState(0);
186
+ const isServerSidePagination = useCallback(() => {
187
+ if (navigation === LIST_NAVIGATION_TYPES.NONE) {
218
188
  return false;
219
189
  }
220
- return !!(datasource && datasource.execute && datasource.execute(_types.DataSource.Operation.IS_PAGEABLE));
190
+ return !!(datasource && datasource.execute && datasource.execute(DataSource.Operation.IS_PAGEABLE));
221
191
  }, [datasource, navigation]);
222
- var _useState8 = (0, _react.useState)(false),
223
- isListCleared = _useState8[0],
224
- setIsListCleared = _useState8[1];
225
- // Use accumulated data for On-Demand and Scroll navigation (preserve old + new data when loading more)
226
- var effectiveDataset = (0, _react.useMemo)(function () {
192
+ const [isListCleared, setIsListCleared] = useState(false);
193
+ const effectiveDataset = useMemo(() => {
227
194
  if (isListCleared) return [];
228
- if (navigation === _constants.LIST_NAVIGATION_TYPES.ON_DEMAND && datasource && accumulatedData.length > 0) {
195
+ if (navigation === LIST_NAVIGATION_TYPES.ON_DEMAND && datasource && accumulatedData.length > 0) {
229
196
  return accumulatedData;
230
197
  }
231
- if (navigation === _constants.LIST_NAVIGATION_TYPES.SCROLL && datasource && accumulatedData.length > 0) {
198
+ if (navigation === LIST_NAVIGATION_TYPES.SCROLL && datasource && accumulatedData.length > 0) {
232
199
  return accumulatedData;
233
200
  }
234
201
  return safeDataset;
235
202
  }, [navigation, datasource, accumulatedData, safeDataset, isListCleared]);
236
-
237
- // ==================== STATE PERSISTENCE ====================
238
- // Restore persisted state before initializing hooks
239
- var _useMemo = (0, _react.useMemo)(function () {
240
- var _datasource$paginatio, _datasource$paginatio2;
241
- // Skip state restoration for On-Demand and Scroll navigation
242
- if (navigation === _constants.LIST_NAVIGATION_TYPES.ON_DEMAND || navigation === _constants.LIST_NAVIGATION_TYPES.SCROLL) {
243
- return {
244
- initialPage: 1,
245
- initialPageSize: pagesize || (resolvedDataset === null || resolvedDataset === void 0 ? void 0 : resolvedDataset.length),
246
- initialSelectedItems: [],
247
- initialActualPageSize: undefined
248
- };
249
- }
250
- var persisted = (0, _listHelpers.getListState)(name, statehandler);
251
-
252
- // Determine the actual page size (original datasource page size)
253
- var actualPageSize;
254
- if ((persisted === null || persisted === void 0 ? void 0 : persisted.actualpagesize) !== undefined) {
255
- // If we have a persisted actualPageSize, use it (it should never change)
256
- actualPageSize = persisted.actualpagesize;
257
- } else if (datasource !== null && datasource !== void 0 && (_datasource$paginatio = datasource.pagination) !== null && _datasource$paginatio !== void 0 && _datasource$paginatio.size) {
258
- // Otherwise, if this is the first load, capture it from datasource
259
- actualPageSize = datasource.pagination.size;
260
- } else if (datasource !== null && datasource !== void 0 && datasource.maxResults) {
261
- // Fallback to maxResults if available
262
- actualPageSize = datasource.maxResults;
263
- }
264
- if (persisted) {
265
- // Get the pagination page
266
- var restoredPage = persisted.pagination || 1;
267
-
268
- // Get selected indices for the restored page if selectedItem exists
269
- var selectedItemIndexes = persisted.selectedItem ? persisted.selectedItem.filter(function (item) {
270
- return item.page === restoredPage;
271
- }).map(function (item) {
272
- return item.index;
273
- }) : [];
274
-
275
- // Get persisted page size
276
- var persistedPageSize = persisted.pagesize || pagesize;
277
-
278
- // Set datasource maxResults if we have a persisted pageSize and datasource
279
- if (persisted.pagesize && isServerSidePagination() && datasource && datasource.maxResults !== undefined) {
280
- datasource.maxResults = persistedPageSize || (resolvedDataset === null || resolvedDataset === void 0 ? void 0 : resolvedDataset.length);
281
- }
282
- return {
283
- initialPage: restoredPage,
284
- initialPageSize: persistedPageSize || (resolvedDataset === null || resolvedDataset === void 0 ? void 0 : resolvedDataset.length),
285
- initialSelectedItems: selectedItemIndexes,
286
- initialActualPageSize: actualPageSize
287
- };
288
- }
289
-
290
- // Angular wm-list: maxResults defaults to `pagesize || 20` — do not use full dataset length as page size
291
- // for Basic/Classic/Pager when the widget omits `pagesize` (otherwise pagination never appears).
292
- // Scroll / On-Demand already returned above; here use Angular default page size whenever pager is enabled.
293
- var clientDefaultPageSize = navigation && navigation !== _constants.LIST_NAVIGATION_TYPES.NONE ? _constants.LIST_DEFAULTS.PAGESIZE : resolvedDataset === null || resolvedDataset === void 0 ? void 0 : resolvedDataset.length;
203
+ const { initialPage, initialPageSize, initialSelectedItems, initialActualPageSize } = useMemo(() => {
204
+ var _a2, _b2;
205
+ if (navigation === LIST_NAVIGATION_TYPES.ON_DEMAND || navigation === LIST_NAVIGATION_TYPES.SCROLL) {
294
206
  return {
295
207
  initialPage: 1,
296
- initialPageSize: pagesize || (isServerSidePagination() && datasource !== null && datasource !== void 0 && (_datasource$paginatio2 = datasource.pagination) !== null && _datasource$paginatio2 !== void 0 && _datasource$paginatio2.size ? datasource.pagination.size : isServerSidePagination() ? resolvedDataset === null || resolvedDataset === void 0 ? void 0 : resolvedDataset.length : clientDefaultPageSize),
208
+ initialPageSize: pagesize || (resolvedDataset == null ? void 0 : resolvedDataset.length),
297
209
  initialSelectedItems: [],
210
+ initialActualPageSize: void 0
211
+ };
212
+ }
213
+ const persisted = getListState(name, statehandler);
214
+ let actualPageSize;
215
+ if ((persisted == null ? void 0 : persisted.actualpagesize) !== void 0) {
216
+ actualPageSize = persisted.actualpagesize;
217
+ } else if ((_a2 = datasource == null ? void 0 : datasource.pagination) == null ? void 0 : _a2.size) {
218
+ actualPageSize = datasource.pagination.size;
219
+ } else if (datasource == null ? void 0 : datasource.maxResults) {
220
+ actualPageSize = datasource.maxResults;
221
+ }
222
+ if (persisted) {
223
+ const restoredPage = persisted.pagination || 1;
224
+ const selectedItemIndexes = persisted.selectedItem ? persisted.selectedItem.filter((item) => item.page === restoredPage).map((item) => item.index) : [];
225
+ const persistedPageSize = persisted.pagesize || pagesize;
226
+ if (persisted.pagesize && isServerSidePagination() && datasource && datasource.maxResults !== void 0) {
227
+ datasource.maxResults = persistedPageSize || (resolvedDataset == null ? void 0 : resolvedDataset.length);
228
+ }
229
+ return {
230
+ initialPage: restoredPage,
231
+ initialPageSize: persistedPageSize || (resolvedDataset == null ? void 0 : resolvedDataset.length),
232
+ initialSelectedItems: selectedItemIndexes,
298
233
  initialActualPageSize: actualPageSize
299
234
  };
300
- }, [name, statehandler, pagesize, navigation, isServerSidePagination(), datasource, resolvedDataset]),
301
- initialPage = _useMemo.initialPage,
302
- initialPageSize = _useMemo.initialPageSize,
303
- initialSelectedItems = _useMemo.initialSelectedItems,
304
- initialActualPageSize = _useMemo.initialActualPageSize;
305
-
306
- // ==================== PAGE RESTORE STATE ====================
307
- // Store the restored page number until pagination state is ready
308
- var _useState9 = (0, _react.useState)(null),
309
- restoredPageNumber = _useState9[0],
310
- setRestoredPageNumber = _useState9[1];
311
-
312
- // ==================== DATA PROCESSING HOOKS ====================
313
- // Process dataset with ordering and transformations
314
- var orderedDataset = (0, _hooks.useListData)(effectiveDataset, {
315
- datafield: datafield,
316
- displayfield: displayfield,
317
- displaylabel: displaylabel,
318
- getDisplayExpression: getDisplayExpression,
319
- orderby: orderby,
320
- groupby: groupby
235
+ }
236
+ const clientDefaultPageSize = navigation && navigation !== LIST_NAVIGATION_TYPES.NONE ? LIST_DEFAULTS.PAGESIZE : resolvedDataset == null ? void 0 : resolvedDataset.length;
237
+ return {
238
+ initialPage: 1,
239
+ initialPageSize: pagesize || (isServerSidePagination() && ((_b2 = datasource == null ? void 0 : datasource.pagination) == null ? void 0 : _b2.size) ? datasource.pagination.size : isServerSidePagination() ? resolvedDataset == null ? void 0 : resolvedDataset.length : clientDefaultPageSize),
240
+ initialSelectedItems: [],
241
+ initialActualPageSize: actualPageSize
242
+ };
243
+ }, [
244
+ name,
245
+ statehandler,
246
+ pagesize,
247
+ navigation,
248
+ isServerSidePagination(),
249
+ datasource,
250
+ resolvedDataset
251
+ ]);
252
+ const [restoredPageNumber, setRestoredPageNumber] = useState(null);
253
+ const orderedDataset = useListData(effectiveDataset, {
254
+ datafield,
255
+ displayfield,
256
+ displaylabel,
257
+ getDisplayExpression,
258
+ orderby,
259
+ groupby
321
260
  });
322
-
323
- // Drag and drop functionality
324
- var _useDragAndDrop = (0, _components2.useDragAndDrop)(orderedDataset, onReorder, orderby),
325
- items = _useDragAndDrop.items,
326
- handleDragEnd = _useDragAndDrop.handleDragEnd,
327
- hasBeenReordered = _useDragAndDrop.hasBeenReordered;
328
-
329
- // Group data if groupby is specified
330
- var groupedData = (0, _hooks.useGroupedData)(items, groupby);
331
-
332
- // ==================== PAGINATION HOOK ====================
333
- var paginationState = (0, _hooks.useListPagination)({
334
- items: items,
335
- groupedData: groupedData,
336
- groupby: groupby,
337
- pagesize: initialPageSize || (resolvedDataset === null || resolvedDataset === void 0 ? void 0 : resolvedDataset.length),
338
- allowpagesizechange: allowpagesizechange,
339
- pagesizeoptions: pagesizeoptions,
340
- navigation: navigation,
341
- initialPage: initialPage,
342
- datasource: datasource
261
+ const { items, handleDragEnd, hasBeenReordered } = useDragAndDrop(
262
+ orderedDataset,
263
+ onReorder,
264
+ orderby
265
+ );
266
+ const groupedData = useGroupedData(items, groupby);
267
+ const paginationState = useListPagination({
268
+ items,
269
+ groupedData,
270
+ groupby,
271
+ pagesize: initialPageSize || (resolvedDataset == null ? void 0 : resolvedDataset.length),
272
+ allowpagesizechange,
273
+ pagesizeoptions,
274
+ navigation,
275
+ initialPage,
276
+ datasource
343
277
  });
344
-
345
- // ==================== LIST STATE HOOK ====================
346
- var listState = (0, _hooks.useListState)(items, paginationState.currentPageSize, selectfirstitem, selectionlimit, listener, name, standalone);
347
-
348
- // ==================== EVENT HANDLERS HOOK ====================
349
- var eventHandlers = (0, _hooks.useListEventHandlers)({
350
- items: items,
351
- multiselect: multiselect,
352
- disableitem: disableitem,
353
- selectionlimit: selectionlimit,
354
- collapsible: collapsible,
278
+ const listState = useListState(
279
+ items,
280
+ paginationState.currentPageSize,
281
+ selectfirstitem,
282
+ selectionlimit,
283
+ listener,
284
+ name,
285
+ standalone
286
+ );
287
+ const eventHandlers = useListEventHandlers({
288
+ items,
289
+ multiselect,
290
+ disableitem,
291
+ selectionlimit,
292
+ collapsible,
355
293
  selectedItems: listState.selectedItems,
356
294
  setSelectedItems: listState.setSelectedItems,
357
295
  activeItems: listState.activeItems,
@@ -366,326 +304,346 @@ var WmList = function WmList(props) {
366
304
  setVisibleItems: paginationState.setVisibleItems,
367
305
  isLoadingMore: listState.isLoadingMore,
368
306
  setIsLoadingMore: listState.setIsLoadingMore,
369
- onClick: onClick,
370
- onDblclick: onDblclick,
371
- onMouseEnter: onMouseEnter,
372
- onMouseLeave: onMouseLeave,
373
- onSelectionlimitexceed: onSelectionlimitexceed,
374
- onPaginationchange: onPaginationchange,
375
- onPageChange: onPageChange,
376
- onSetrecord: onSetrecord,
377
- widgetInstance: widgetInstance,
378
- onSelect: onSelect,
379
- userInitiatedSelectionRef: userInitiatedSelectionRef,
380
- datasource: datasource,
307
+ onClick,
308
+ onDblclick,
309
+ onMouseEnter,
310
+ onMouseLeave,
311
+ onSelectionlimitexceed,
312
+ onPaginationchange,
313
+ onPageChange,
314
+ onSetrecord,
315
+ widgetInstance,
316
+ onSelect,
317
+ userInitiatedSelectionRef,
318
+ datasource,
381
319
  pagesize: paginationState.currentPageSize,
382
- navigation: navigation,
383
- onDemandCurrentPage: onDemandCurrentPage,
384
- setOnDemandCurrentPage: setOnDemandCurrentPage,
320
+ navigation,
321
+ onDemandCurrentPage,
322
+ setOnDemandCurrentPage,
385
323
  isServerSidePagination: isServerSidePagination(),
386
- listener: listener,
387
- name: name,
388
- standalone: standalone
324
+ listener,
325
+ name,
326
+ standalone
389
327
  });
390
-
391
- // Effect to update current page size if pagesize is not provided
392
- (0, _react.useEffect)(function () {
328
+ useEffect(() => {
393
329
  if (pagesize) return;
394
330
  if (!resolvedDataset.length) return;
395
- if (navigation === _constants.LIST_NAVIGATION_TYPES.NONE || !navigation) {
331
+ if (navigation === LIST_NAVIGATION_TYPES.NONE || !navigation) {
396
332
  paginationState.setCurrentPageSize(resolvedDataset.length);
397
333
  }
398
334
  }, [resolvedDataset.length, pagesize, paginationState]);
399
-
400
- // ==================== STATE MANAGEMENT ====================
401
- // Disable state management for On-Demand and Scroll navigation
402
- var effectiveStateHandler = navigation === _constants.LIST_NAVIGATION_TYPES.ON_DEMAND || navigation === _constants.LIST_NAVIGATION_TYPES.SCROLL ? "none" : statehandler;
403
- var stateManager = (0, _hooks.useListStateManager)({
404
- name: name,
335
+ const effectiveStateHandler = navigation === LIST_NAVIGATION_TYPES.ON_DEMAND || navigation === LIST_NAVIGATION_TYPES.SCROLL ? "none" : statehandler;
336
+ const stateManager = useListStateManager({
337
+ name,
405
338
  storage: effectiveStateHandler,
406
339
  currentPage: paginationState.currentPage,
407
340
  currentPageSize: paginationState.currentPageSize,
408
341
  selectedItems: listState.selectedItems,
409
- items: items,
410
- initialActualPageSize: initialActualPageSize,
411
- multiselect: multiselect,
342
+ items,
343
+ initialActualPageSize,
344
+ multiselect,
412
345
  isServerSidePagination: isServerSidePagination(),
413
- datasource: datasource
346
+ datasource
414
347
  });
415
-
416
- // When Scroll navigation loads more, pagination calls this with accumulated result so list preserves old + new data
417
- var handleScrollDataUpdate = (0, _react.useCallback)(function (data) {
348
+ const handleScrollDataUpdate = useCallback((data) => {
418
349
  setAccumulatedData(data);
419
350
  }, []);
420
-
421
- // ==================== EVENT HANDLER FUNCTIONS ====================
422
- var handlePageSizeChange = function handlePageSizeChange(newPageSize) {
423
- // Get the old page size BEFORE updating
424
- var oldPageSize = paginationState.currentPageSize;
425
-
426
- // Get current persisted state to access all selected items across pages
427
- var currentPersistedState = (0, _listHelpers.getListState)(name, statehandler);
428
-
429
- // Build the state for page size change
430
- var newState = stateManager.getStateForPageSizeChange(newPageSize, currentPersistedState === null || currentPersistedState === void 0 ? void 0 : currentPersistedState.selectedItem, (currentPersistedState === null || currentPersistedState === void 0 ? void 0 : currentPersistedState.pagesize) || oldPageSize);
431
-
432
- // Save the state BEFORE changing page size
433
- (0, _listHelpers.saveListState)(name, statehandler, newState);
434
-
435
- // Update datasource maxResults if datasource has paging capability (similar to Angular)
436
- if (isServerSidePagination() && datasource && datasource.maxResults !== undefined) {
351
+ const handlePageSizeChange = (newPageSize) => {
352
+ const oldPageSize = paginationState.currentPageSize;
353
+ const currentPersistedState = getListState(name, statehandler);
354
+ const newState = stateManager.getStateForPageSizeChange(
355
+ newPageSize,
356
+ currentPersistedState == null ? void 0 : currentPersistedState.selectedItem,
357
+ (currentPersistedState == null ? void 0 : currentPersistedState.pagesize) || oldPageSize
358
+ );
359
+ saveListState(name, statehandler, newState);
360
+ if (isServerSidePagination() && datasource && datasource.maxResults !== void 0) {
437
361
  datasource.maxResults = newPageSize;
438
- datasource.invoke({
439
- page: 1,
440
- size: newPageSize
441
- });
362
+ datasource.invoke({ page: 1, size: newPageSize });
442
363
  }
443
364
  };
444
-
445
- // ==================== WIDGET METHODS ====================
446
- var widgetMethods = (0, _listWidgetMethods.useListWidgetMethods)(items, listState, multiselect, onSelect, widgetInstance, listener, userInitiatedSelectionRef, name, Widgets, paginationState.currentPageSize, setIsListCleared, handlePageSizeChange);
447
-
448
- // ==================== ALL SIDE EFFECTS ====================
449
- (0, _hooks.useListEffects)({
450
- name: name,
451
- navigation: navigation,
452
- datasource: datasource,
453
- safeDataset: safeDataset,
454
- items: items,
455
- orderedDataset: orderedDataset,
456
- groupedData: groupedData,
457
- groupby: groupby,
458
- orderby: orderby,
459
- selectfirstitem: selectfirstitem,
365
+ const widgetMethods = useListWidgetMethods(
366
+ items,
367
+ listState,
368
+ multiselect,
369
+ onSelect,
370
+ widgetInstance,
371
+ listener,
372
+ userInitiatedSelectionRef,
373
+ name,
374
+ Widgets,
375
+ paginationState.currentPageSize,
376
+ setIsListCleared,
377
+ handlePageSizeChange
378
+ );
379
+ useEffect(() => {
380
+ if (selecteditem === void 0) {
381
+ return;
382
+ }
383
+ if (Array.isArray(selecteditem)) {
384
+ selecteditem.forEach((item) => widgetMethods.selectItem(item));
385
+ } else {
386
+ widgetMethods.selectItem(selecteditem);
387
+ }
388
+ }, [selecteditem, widgetMethods, listState]);
389
+ useListEffects({
390
+ name,
391
+ navigation,
392
+ datasource,
393
+ safeDataset,
394
+ items,
395
+ orderedDataset,
396
+ groupedData,
397
+ groupby,
398
+ orderby,
399
+ selectfirstitem,
460
400
  statehandler: effectiveStateHandler,
461
- accumulatedData: accumulatedData,
462
- lastLoadedPage: lastLoadedPage,
463
- isFirstLoad: isFirstLoad,
464
- onDemandCurrentPage: onDemandCurrentPage,
465
- hasBeenReordered: hasBeenReordered,
466
- initialRender: initialRender,
467
- initialPage: initialPage,
468
- initialPageSize: initialPageSize,
469
- initialSelectedItems: initialSelectedItems,
470
- initialActualPageSize: initialActualPageSize,
471
- setAccumulatedData: setAccumulatedData,
472
- setLastLoadedPage: setLastLoadedPage,
473
- setIsFirstLoad: setIsFirstLoad,
474
- setOnDemandCurrentPage: setOnDemandCurrentPage,
475
- setinitialRender: setinitialRender,
476
- listState: listState,
477
- paginationState: paginationState,
478
- widgetMethods: widgetMethods,
479
- onSelect: onSelect,
480
- widgetInstance: widgetInstance,
481
- listener: listener,
482
- userInitiatedSelectionRef: userInitiatedSelectionRef,
483
- restoredPageNumber: restoredPageNumber,
484
- setRestoredPageNumber: setRestoredPageNumber,
485
- showNavigation: showNavigation,
486
- stateManager: stateManager,
487
- standalone: standalone
401
+ accumulatedData,
402
+ lastLoadedPage,
403
+ isFirstLoad,
404
+ onDemandCurrentPage,
405
+ hasBeenReordered,
406
+ initialRender,
407
+ initialPage,
408
+ initialPageSize,
409
+ initialSelectedItems,
410
+ initialActualPageSize,
411
+ setAccumulatedData,
412
+ setLastLoadedPage,
413
+ setIsFirstLoad,
414
+ setOnDemandCurrentPage,
415
+ setinitialRender,
416
+ listState,
417
+ paginationState,
418
+ widgetMethods,
419
+ onSelect,
420
+ widgetInstance,
421
+ listener,
422
+ userInitiatedSelectionRef,
423
+ restoredPageNumber,
424
+ setRestoredPageNumber,
425
+ showNavigation,
426
+ stateManager,
427
+ standalone
488
428
  });
489
-
490
- // ==================== COMPUTED VALUES ====================
491
- // Use datasource noDataFound if available, otherwise check safeDataset
492
- var noDataFound = Boolean(listener === null || listener === void 0 || (_listener$Widgets = listener.Widgets) === null || _listener$Widgets === void 0 || (_listener$Widgets = _listener$Widgets[name]) === null || _listener$Widgets === void 0 ? void 0 : _listener$Widgets.cleared) || !safeDataset || safeDataset.length === 0;
493
- var itemsPerRowClass = (0, _listHelpers.getItemsPerRowClass)(itemsperrow, direction);
494
- var textAlignClass = (0, _listHelpers.getTextAlignClass)(horizontalalign);
495
- var showPaginationBasedOnVariableConfiguration = (0, _react.useMemo)(function () {
496
- var _paginationState$pagi, _paginationState$pagi2, _paginationState$pagi3, _paginationState$pagi4;
497
- // if dataset is from modal variable(means client side pagination, all records are loaded in the dataset on first load itself) then show pagination if records are greater than 5 records
498
-
499
- if (isDatasetFromModalVariable && paginationState !== null && paginationState !== void 0 && paginationState.totalItems) {
500
- // if records are less than 5 records then do not show pagination
501
- if ((paginationState === null || paginationState === void 0 ? void 0 : paginationState.totalItems) < _constants.LIST_DEFAULTS.PAGESIZE_FOR_MODAL_VARIABLE) {
429
+ const noDataFound = Boolean((_b = (_a = listener == null ? void 0 : listener.Widgets) == null ? void 0 : _a[name]) == null ? void 0 : _b.cleared) || !safeDataset || safeDataset.length === 0;
430
+ const itemsPerRowClass = getItemsPerRowClass(itemsperrow, direction);
431
+ const textAlignClass = getTextAlignClass(horizontalalign);
432
+ const showPaginationBasedOnVariableConfiguration = useMemo(() => {
433
+ var _a2, _b2, _c2, _d2;
434
+ if (isDatasetFromModalVariable && (paginationState == null ? void 0 : paginationState.totalItems)) {
435
+ if ((paginationState == null ? void 0 : paginationState.totalItems) < LIST_DEFAULTS.PAGESIZE_FOR_MODAL_VARIABLE) {
502
436
  return false;
503
437
  }
504
- // In modal variable if total records are greater than 5 then set current page size to 5 and show pagination
505
- paginationState.setCurrentPageSize(_constants.LIST_DEFAULTS.PAGESIZE_FOR_MODAL_VARIABLE);
438
+ paginationState.setCurrentPageSize(LIST_DEFAULTS.PAGESIZE_FOR_MODAL_VARIABLE);
506
439
  return true;
507
440
  }
508
- if ((paginationState === null || paginationState === void 0 || (_paginationState$pagi = paginationState.paginationMeta) === null || _paginationState$pagi === void 0 ? void 0 : _paginationState$pagi.totalElements) === undefined || (paginationState === null || paginationState === void 0 || (_paginationState$pagi2 = paginationState.paginationMeta) === null || _paginationState$pagi2 === void 0 ? void 0 : _paginationState$pagi2.size) === undefined) {
441
+ if (((_a2 = paginationState == null ? void 0 : paginationState.paginationMeta) == null ? void 0 : _a2.totalElements) === void 0 || ((_b2 = paginationState == null ? void 0 : paginationState.paginationMeta) == null ? void 0 : _b2.size) === void 0) {
509
442
  return false;
510
443
  }
511
- return (paginationState === null || paginationState === void 0 || (_paginationState$pagi3 = paginationState.paginationMeta) === null || _paginationState$pagi3 === void 0 ? void 0 : _paginationState$pagi3.totalElements) > ((_paginationState$pagi4 = paginationState.paginationMeta) === null || _paginationState$pagi4 === void 0 ? void 0 : _paginationState$pagi4.size) || !!allowpagesizechange;
512
- }, [paginationState === null || paginationState === void 0 || (_paginationState$pagi5 = paginationState.paginationMeta) === null || _paginationState$pagi5 === void 0 ? void 0 : _paginationState$pagi5.totalElements, paginationState === null || paginationState === void 0 || (_paginationState$pagi6 = paginationState.paginationMeta) === null || _paginationState$pagi6 === void 0 ? void 0 : _paginationState$pagi6.size, isDatasetFromModalVariable, paginationState === null || paginationState === void 0 ? void 0 : paginationState.totalItems]);
513
-
514
- // check if dataset is from modal variable
515
- (0, _react.useEffect)(function () {
516
- (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
517
- var result;
518
- return _regenerator["default"].wrap(function _callee$(_context) {
519
- while (1) switch (_context.prev = _context.next) {
520
- case 0:
521
- _context.next = 2;
522
- return datasource && datasource.execute && (datasource === null || datasource === void 0 ? void 0 : datasource.execute(_types.DataSource.Operation.IS_API_AWARE));
523
- case 2:
524
- result = _context.sent;
525
- if (result === false) {
526
- setIsDatasetFromModalVariable(true);
527
- } else {
528
- setIsDatasetFromModalVariable(false);
529
- }
530
- case 4:
531
- case "end":
532
- return _context.stop();
533
- }
534
- }, _callee);
535
- }))();
444
+ return ((_c2 = paginationState == null ? void 0 : paginationState.paginationMeta) == null ? void 0 : _c2.totalElements) > ((_d2 = paginationState.paginationMeta) == null ? void 0 : _d2.size) || !!allowpagesizechange;
445
+ }, [
446
+ (_c = paginationState == null ? void 0 : paginationState.paginationMeta) == null ? void 0 : _c.totalElements,
447
+ (_d = paginationState == null ? void 0 : paginationState.paginationMeta) == null ? void 0 : _d.size,
448
+ isDatasetFromModalVariable,
449
+ paginationState == null ? void 0 : paginationState.totalItems
450
+ ]);
451
+ useEffect(() => {
452
+ (async () => {
453
+ const result = await (datasource && datasource.execute && (datasource == null ? void 0 : datasource.execute(DataSource.Operation.IS_API_AWARE)));
454
+ if (result === false) {
455
+ setIsDatasetFromModalVariable(true);
456
+ } else {
457
+ setIsDatasetFromModalVariable(false);
458
+ }
459
+ })();
536
460
  }, [datasource]);
537
- var showHorizontalScrollSentinel = showNavigation && navigation === _constants.LIST_NAVIGATION_TYPES.SCROLL && (direction === _constants.LIST_DIRECTION.HORIZONTAL || direction === "row");
538
- var hostAutoLayoutPrefixes = ["pos-"].concat((0, _toConsumableArray2["default"])(_constants.INSETION_POSITION), ["zi-", "w-", "h-"]);
539
- var wrapper_autoLayout_Classes = (0, _react.useMemo)(function () {
540
- return (0, _styleUtils.filterAutoLayoutClasses)(layoutClassName, hostAutoLayoutPrefixes);
541
- }, [layoutClassName]);
542
- var ul_autoLayout_Classes = (0, _react.useMemo)(function () {
543
- return (0, _styleUtils.filterAutoLayoutClasses)(layoutClassName, hostAutoLayoutPrefixes, "exclude");
544
- }, [layoutClassName]);
545
- var hasListGroupAutoLayout = (0, _react.useMemo)(function () {
546
- return (0, _listHelpers.hasListGroupAutoLayoutClass)({
547
- direction: direction,
548
- wrap: wrap,
549
- alignment: alignment,
550
- gap: gap,
551
- columngap: columngap
552
- });
553
- }, [direction, wrap, alignment, gap, columngap]);
554
-
555
- // ==================== RENDER ====================
556
- return __jsx(_Box["default"], {
557
- className: (0, _clsx["default"])(_constants.DEFAULT_CLS, "wm-overflow-inherit", "wm-position-relative", className, hidden && "wm-hidden", wrapper_autoLayout_Classes),
558
- component: "div",
559
- "data-name": name,
560
- name: name,
561
- "data-navigation": navigation
562
- }, __jsx(_components2.ListHeader, {
563
- title: title,
564
- subheading: subheading,
565
- iconclass: iconclass
566
- }), __jsx(_common.AppSpinner, {
567
- show: (_datasource$loading = datasource === null || datasource === void 0 ? void 0 : datasource.loading) !== null && _datasource$loading !== void 0 ? _datasource$loading : false,
568
- spinnermessages: [loadingdatamsg]
569
- }), __jsx(_components.InlineNavigation, {
570
- navigation: navigation,
571
- currentPage: paginationState.currentPage,
572
- totalPages: paginationState.effectiveTotalPages,
573
- noDataFound: noDataFound,
574
- onPageChange: eventHandlers.handlePageChange,
575
- isLoading: listState.isLoadingMore,
576
- showNavigation: showNavigation
577
- }, __jsx(_List["default"], {
578
- ref: listScrollContainerRef,
579
- className: (0, _clsx["default"])("app-livelist-container", "clearfix", listclass, textAlignClass, hidehorizontalscrollbar ? "hide-scrollbar" : "", direction === _constants.LIST_DIRECTION.HORIZONTAL ? "app-horizontal-list" : "", hasListGroupAutoLayout && "list-group-autolayout", ul_autoLayout_Classes),
580
- style: _objectSpread({}, styles),
581
- tabIndex: tabIndex,
582
- role: "list"
583
- }, noDataFound ? __jsx(_components2.NoDataMessage, {
584
- message: nodatamessage
585
- }) : __jsx(_components2.ListItems, {
586
- items: items,
587
- groupedData: groupedData,
588
- groupby: groupby,
589
- navigation: navigation,
590
- currentPage: paginationState.currentPage,
591
- pagesize: paginationState.currentPageSize,
592
- visibleItems: paginationState.visibleItems,
593
- orderby: orderby,
594
- disableitem: disableitem,
595
- itemclass: itemclass,
596
- itemsPerRowClass: itemsPerRowClass,
597
- direction: direction,
598
- enablereorder: enablereorder,
599
- activeItems: listState.activeItems,
600
- name: name,
601
- tabIndex: tabIndex,
602
- renderItem: renderItem,
603
- itemTemplate: children,
604
- nodatamessage: nodatamessage,
605
- ondemandmessage: ondemandmessage,
606
- loadingicon: loadingicon,
607
- loadingdatamsg: loadingdatamsg,
608
- paginationclass: paginationclass,
609
- isLoadingMore: listState.isLoadingMore,
610
- collapsible: collapsible,
611
- showcount: showcount,
612
- groupCollapsed: listState.groupCollapsed,
613
- handleListItemClick: eventHandlers.handleListItemClick,
614
- handleListItemDoubleClick: eventHandlers.handleListItemDoubleClick,
615
- handleListItemMouseEnter: eventHandlers.handleListItemMouseEnter,
616
- handleListItemMouseLeave: eventHandlers.handleListItemMouseLeave,
617
- handleDragEnd: handleDragEnd,
618
- handleLoadMore: eventHandlers.handleLoadMore,
619
- handleHeaderClick: eventHandlers.handleHeaderClick,
620
- onBeforedatarender: onBeforedatarender,
621
- onRender: onRender,
622
- widgetInstance: widgetInstance,
623
- rawDataset: safeDataset,
624
- datasource: datasource,
625
- totalItems: paginationState.totalItems,
626
- isServerSidePagination: isServerSidePagination(),
627
- showNavigation: showNavigation,
628
- itemAttrs: itemAttrs,
629
- hasListGroupAutoLayout: hasListGroupAutoLayout,
630
- standalone: standalone
631
- }), showHorizontalScrollSentinel && __jsx(_Box["default"], {
632
- ref: scrollSentinelRef,
633
- component: "span",
634
- sx: {
635
- display: "block",
636
- width: "1px",
637
- height: "1px",
638
- minWidth: "1px",
639
- minHeight: "1px",
640
- flexShrink: 0,
641
- margin: 0,
642
- padding: 0,
643
- overflow: "hidden",
644
- visibility: "hidden",
645
- pointerEvents: "none"
646
- }
647
- })), showPaginationBasedOnVariableConfiguration && showNavigation && navigation && navigation !== _constants.LIST_NAVIGATION_TYPES.INLINE && navigation !== _constants.LIST_NAVIGATION_TYPES.ON_DEMAND && navigation !== _constants.LIST_NAVIGATION_TYPES.NONE && __jsx(_Box["default"], {
648
- component: "div",
649
- className: "panel-footer"
650
- }, __jsx(_components2.ListPagination, {
651
- name: name,
652
- navigation: navigation,
653
- listDirection: direction,
654
- scrollContainerRef: listScrollContainerRef,
655
- sentinelRef: scrollSentinelRef,
656
- orderedDataset: groupby ? Array(paginationState.totalItems).fill(null) : items,
657
- pagesize: paginationState.currentPageSize,
658
- navigationalign: navigationalign,
659
- showrecordcount: showrecordcount,
660
- maxsize: maxsize,
661
- boundarylinks: boundarylinks,
662
- paginationclass: paginationclass,
663
- allowpagesizechange: allowpagesizechange,
664
- pagesizeoptions: pagesizeoptions,
665
- widgetInstance: widgetInstance,
666
- onPaginationChange: eventHandlers.handlePaginationChange,
667
- onSetRecord: eventHandlers.handleSetRecord,
668
- onPageSizeChange: handlePageSizeChange,
669
- currentPage: paginationState.currentPage,
670
- listener: listener,
671
- paginationMeta: paginationState.paginationMeta,
672
- totalItems: paginationState.totalItems,
673
- datasource: datasource,
674
- isLoadingMore: listState.isLoadingMore,
675
- setIsLoadingMore: listState.setIsLoadingMore,
676
- isServerSidePagination: isServerSidePagination(),
677
- onDataUpdate: handleScrollDataUpdate
678
- }))));
461
+ const showHorizontalScrollSentinel = showNavigation && navigation === LIST_NAVIGATION_TYPES.SCROLL && (direction === LIST_DIRECTION.HORIZONTAL || direction === "row");
462
+ const hostAutoLayoutPrefixes = ["pos-", ...INSETION_POSITION, "zi-", "w-", "h-"];
463
+ const wrapper_autoLayout_Classes = useMemo(
464
+ () => filterAutoLayoutClasses(layoutClassName, hostAutoLayoutPrefixes),
465
+ [layoutClassName]
466
+ );
467
+ const ul_autoLayout_Classes = useMemo(
468
+ () => filterAutoLayoutClasses(
469
+ layoutClassName,
470
+ hostAutoLayoutPrefixes,
471
+ "exclude"
472
+ ),
473
+ [layoutClassName]
474
+ );
475
+ const hasListGroupAutoLayout = useMemo(
476
+ () => hasListGroupAutoLayoutClass({
477
+ direction,
478
+ wrap,
479
+ alignment,
480
+ gap,
481
+ columngap
482
+ }),
483
+ [direction, wrap, alignment, gap, columngap]
484
+ );
485
+ return /* @__PURE__ */ jsxs(
486
+ Box,
487
+ __spreadProps(__spreadValues({
488
+ className: clsx(
489
+ DEFAULT_CLS,
490
+ "wm-position-relative",
491
+ className,
492
+ hidden && "wm-hidden",
493
+ wrapper_autoLayout_Classes
494
+ ),
495
+ component: "div",
496
+ "data-name": name
497
+ }, { name }), {
498
+ "data-navigation": navigation,
499
+ children: [
500
+ /* @__PURE__ */ jsx(ListHeader, { title, subheading, iconclass }),
501
+ /* @__PURE__ */ jsx(AppSpinner, { show: (_e = datasource == null ? void 0 : datasource.loading) != null ? _e : false, spinnermessages: [loadingdatamsg] }),
502
+ /* @__PURE__ */ jsxs(
503
+ InlineNavigation,
504
+ {
505
+ navigation,
506
+ currentPage: paginationState.currentPage,
507
+ totalPages: paginationState.effectiveTotalPages,
508
+ noDataFound,
509
+ onPageChange: eventHandlers.handlePageChange,
510
+ isLoading: listState.isLoadingMore,
511
+ showNavigation,
512
+ children: [
513
+ /* @__PURE__ */ jsxs(
514
+ List,
515
+ {
516
+ ref: listScrollContainerRef,
517
+ className: clsx(
518
+ "app-livelist-container",
519
+ "clearfix",
520
+ listclass,
521
+ textAlignClass,
522
+ hidehorizontalscrollbar ? "hide-scrollbar" : "",
523
+ direction === LIST_DIRECTION.HORIZONTAL ? "app-horizontal-list" : "",
524
+ hasListGroupAutoLayout && "list-group-autolayout",
525
+ ul_autoLayout_Classes
526
+ ),
527
+ style: __spreadValues({}, styles),
528
+ tabIndex,
529
+ role: "list",
530
+ children: [
531
+ noDataFound ? /* @__PURE__ */ jsx(NoDataMessage, { message: nodatamessage }) : /* @__PURE__ */ jsx(
532
+ ListItems,
533
+ {
534
+ items,
535
+ groupedData,
536
+ groupby,
537
+ navigation,
538
+ currentPage: paginationState.currentPage,
539
+ pagesize: paginationState.currentPageSize,
540
+ visibleItems: paginationState.visibleItems,
541
+ orderby,
542
+ disableitem,
543
+ itemclass,
544
+ itemsPerRowClass,
545
+ direction,
546
+ enablereorder,
547
+ activeItems: listState.activeItems,
548
+ name,
549
+ tabIndex,
550
+ renderItem,
551
+ itemTemplate: children,
552
+ nodatamessage,
553
+ ondemandmessage,
554
+ loadingicon,
555
+ loadingdatamsg,
556
+ paginationclass,
557
+ isLoadingMore: listState.isLoadingMore,
558
+ collapsible,
559
+ showcount,
560
+ groupCollapsed: listState.groupCollapsed,
561
+ handleListItemClick: eventHandlers.handleListItemClick,
562
+ handleListItemDoubleClick: eventHandlers.handleListItemDoubleClick,
563
+ handleListItemMouseEnter: eventHandlers.handleListItemMouseEnter,
564
+ handleListItemMouseLeave: eventHandlers.handleListItemMouseLeave,
565
+ handleDragEnd,
566
+ handleLoadMore: eventHandlers.handleLoadMore,
567
+ handleHeaderClick: eventHandlers.handleHeaderClick,
568
+ onBeforedatarender,
569
+ onRender,
570
+ widgetInstance,
571
+ rawDataset: safeDataset,
572
+ datasource,
573
+ totalItems: paginationState.totalItems,
574
+ isServerSidePagination: isServerSidePagination(),
575
+ showNavigation,
576
+ itemAttrs,
577
+ hasListGroupAutoLayout,
578
+ standalone
579
+ }
580
+ ),
581
+ showHorizontalScrollSentinel && /* @__PURE__ */ jsx(
582
+ Box,
583
+ {
584
+ ref: scrollSentinelRef,
585
+ component: "span",
586
+ sx: {
587
+ display: "block",
588
+ width: "1px",
589
+ height: "1px",
590
+ minWidth: "1px",
591
+ minHeight: "1px",
592
+ flexShrink: 0,
593
+ margin: 0,
594
+ padding: 0,
595
+ overflow: "hidden",
596
+ visibility: "hidden",
597
+ pointerEvents: "none"
598
+ }
599
+ }
600
+ )
601
+ ]
602
+ }
603
+ ),
604
+ showPaginationBasedOnVariableConfiguration && showNavigation && navigation && navigation !== LIST_NAVIGATION_TYPES.INLINE && navigation !== LIST_NAVIGATION_TYPES.ON_DEMAND && navigation !== LIST_NAVIGATION_TYPES.NONE && /* @__PURE__ */ jsx(Box, { component: "div", className: "panel-footer", children: /* @__PURE__ */ jsx(
605
+ ListPagination,
606
+ {
607
+ name,
608
+ navigation,
609
+ listDirection: direction,
610
+ scrollContainerRef: listScrollContainerRef,
611
+ sentinelRef: scrollSentinelRef,
612
+ orderedDataset: groupby ? Array(paginationState.totalItems).fill(null) : items,
613
+ pagesize: paginationState.currentPageSize,
614
+ navigationalign,
615
+ showrecordcount,
616
+ maxsize,
617
+ boundarylinks,
618
+ paginationclass,
619
+ allowpagesizechange,
620
+ pagesizeoptions,
621
+ widgetInstance,
622
+ onPaginationChange: eventHandlers.handlePaginationChange,
623
+ onSetRecord: eventHandlers.handleSetRecord,
624
+ onPageSizeChange: handlePageSizeChange,
625
+ currentPage: paginationState.currentPage,
626
+ listener,
627
+ paginationMeta: paginationState.paginationMeta,
628
+ totalItems: paginationState.totalItems,
629
+ datasource,
630
+ isLoadingMore: listState.isLoadingMore,
631
+ setIsLoadingMore: listState.setIsLoadingMore,
632
+ isServerSidePagination: isServerSidePagination(),
633
+ onDataUpdate: handleScrollDataUpdate
634
+ }
635
+ ) })
636
+ ]
637
+ }
638
+ )
639
+ ]
640
+ })
641
+ );
679
642
  };
680
643
  WmList.displayName = "WmList";
681
- var WmListStandalone = exports.WmList = (0, _withStandalone["default"])(WmList);
682
- /**
683
- * The WmList component provides a way to display a collection of data items.
684
- *
685
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/data-list--showcase)
686
- *
687
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/data-list--docs)
688
- *
689
- * @param props - {@link WmListProps}
690
- */
691
- var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WmList);
644
+ const WmListStandalone = withStandalone(WmList);
645
+ var list_default = withBaseWrapper(WmList);
646
+ export {
647
+ WmListStandalone as WmList,
648
+ list_default as default
649
+ };