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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (574) hide show
  1. package/.npmignore +4 -0
  2. package/actions/base-action.js +12 -29
  3. package/actions/login-action.js +35 -52
  4. package/actions/logout-action.js +21 -38
  5. package/actions/navigation-action.js +251 -346
  6. package/actions/notification-action.js +121 -149
  7. package/actions/timer-action.js +95 -151
  8. package/actions/toast-provider.js +62 -76
  9. package/actions/toast.js +95 -91
  10. package/actions/toast.service.js +59 -79
  11. package/actions/types/index.js +6 -9
  12. package/components/advanced/carousel/index.js +358 -366
  13. package/components/advanced/carousel/props.js +0 -5
  14. package/components/advanced/carousel/template.js +102 -80
  15. package/components/advanced/login/index.js +227 -285
  16. package/components/advanced/login/props.js +0 -5
  17. package/components/advanced/marquee/index.js +169 -163
  18. package/components/advanced/marquee/props.js +0 -5
  19. package/components/basic/anchor/index.js +207 -187
  20. package/components/basic/anchor/props.js +0 -5
  21. package/components/basic/audio/index.js +110 -72
  22. package/components/basic/audio/props.js +0 -5
  23. package/components/basic/html/index.js +163 -203
  24. package/components/basic/html/props.js +0 -5
  25. package/components/basic/html/utils.js +30 -28
  26. package/components/basic/icon/index.js +98 -84
  27. package/components/basic/icon/props.js +0 -5
  28. package/components/basic/iframe/iframe.utils.js +7 -16
  29. package/components/basic/iframe/index.js +97 -103
  30. package/components/basic/iframe/props.js +0 -5
  31. package/components/basic/label/index.js +156 -134
  32. package/components/basic/label/props.js +0 -5
  33. package/components/basic/message/index.js +129 -113
  34. package/components/basic/message/props.js +0 -5
  35. package/components/basic/picture/index.js +156 -127
  36. package/components/basic/picture/props.js +0 -5
  37. package/components/basic/progress-bar/index.js +240 -176
  38. package/components/basic/progress-bar/props.js +5 -31
  39. package/components/basic/progress-circle/index.js +166 -183
  40. package/components/basic/progress-circle/props.js +14 -34
  41. package/components/basic/richtexteditor/index.js +430 -396
  42. package/components/basic/richtexteditor/props.js +0 -5
  43. package/components/basic/search/index.js +812 -931
  44. package/components/basic/search/props.js +0 -5
  45. package/components/basic/search/providers.js +233 -380
  46. package/components/basic/spinner/index.js +210 -200
  47. package/components/basic/spinner/props.js +4 -22
  48. package/components/basic/tile/index.js +73 -81
  49. package/components/basic/tile/props.js +0 -5
  50. package/components/basic/tree/Components/TreeNodeComponent.js +238 -170
  51. package/components/basic/tree/hooks/useTreePartialNodeApi.js +143 -135
  52. package/components/basic/tree/index.js +378 -454
  53. package/components/basic/tree/props.js +0 -5
  54. package/components/basic/tree/utils.js +129 -185
  55. package/components/basic/video/index.js +161 -107
  56. package/components/basic/video/props.js +0 -5
  57. package/components/chart/index.js +42 -50
  58. package/components/chart/props.js +31 -37
  59. package/components/chart/src/ChartRenderer.js +172 -154
  60. package/components/chart/src/chart.js +391 -213
  61. package/components/chart/src/chartStyles.generated.js +6 -14
  62. package/components/chart/src/chartUtils.js +228 -272
  63. package/components/chart/src/constants.d.ts +13 -0
  64. package/components/chart/src/constants.js +316 -90
  65. package/components/chart/src/d3Setup.js +11 -30
  66. package/components/chart/src/dataUtils.js +362 -446
  67. package/components/chart/src/formatUtils.js +47 -38
  68. package/components/chart/src/index.js +11 -19
  69. package/components/chart/src/nvd3Source.generated.js +5 -13
  70. package/components/chart/src/pieDonutResponsiveLayout.d.ts +5 -0
  71. package/components/chart/src/pieDonutResponsiveLayout.js +76 -96
  72. package/components/chart/src/types.js +0 -5
  73. package/components/common/AppSpinner.js +17 -33
  74. package/components/common/app-spinner.js +11 -22
  75. package/components/common/customTemplate/index.d.ts +3 -0
  76. package/components/common/customTemplate/index.js +6 -0
  77. package/components/common/customTemplate/props.d.ts +20 -0
  78. package/components/common/customTemplate/props.js +0 -0
  79. package/components/common/customTemplate/template.d.ts +3 -0
  80. package/components/common/customTemplate/template.js +27 -0
  81. package/components/common/customTemplate/useCustomTemplate.d.ts +8 -0
  82. package/components/common/customTemplate/useCustomTemplate.js +17 -0
  83. package/components/common/customTemplate/utils.d.ts +6 -0
  84. package/components/common/customTemplate/utils.js +12 -0
  85. package/components/common/index.js +4 -12
  86. package/components/constants.js +81 -77
  87. package/components/container/accordion/accordion-pane/index.js +105 -118
  88. package/components/container/accordion/accordion-pane/props.js +5 -21
  89. package/components/container/accordion/index.js +225 -243
  90. package/components/container/accordion/props.js +5 -16
  91. package/components/container/index.js +214 -150
  92. package/components/container/layout-grid/grid-column/index.js +68 -43
  93. package/components/container/layout-grid/grid-column/props.js +0 -5
  94. package/components/container/layout-grid/grid-row/index.js +12 -29
  95. package/components/container/layout-grid/grid-row/props.js +0 -5
  96. package/components/container/layout-grid/index.js +53 -38
  97. package/components/container/layout-grid/props.js +0 -5
  98. package/components/container/linear-layout/index.js +56 -60
  99. package/components/container/linear-layout/linear-layout-item/index.js +43 -47
  100. package/components/container/linear-layout/linear-layout-item/props.js +0 -5
  101. package/components/container/linear-layout/props.js +0 -5
  102. package/components/container/panel/components/panel-content/index.js +7 -16
  103. package/components/container/panel/components/panel-header/index.js +166 -146
  104. package/components/container/panel/components/panel-header/props.js +0 -5
  105. package/components/container/panel/hooks.js +76 -102
  106. package/components/container/panel/index.js +289 -252
  107. package/components/container/panel/props.js +0 -5
  108. package/components/container/props.js +0 -5
  109. package/components/container/repeat-template/index.js +65 -44
  110. package/components/container/repeat-template/props.js +0 -5
  111. package/components/container/tabs/index.js +517 -526
  112. package/components/container/tabs/props.js +5 -28
  113. package/components/container/tabs/tab-pane/index.js +105 -100
  114. package/components/container/tabs/tab-pane/props.js +0 -5
  115. package/components/container/tabs/utils.js +30 -35
  116. package/components/container/wizard/WizardContext.js +9 -11
  117. package/components/container/wizard/components/StepComponents.js +76 -99
  118. package/components/container/wizard/components/WizardStep.js +107 -85
  119. package/components/container/wizard/index.js +791 -921
  120. package/components/container/wizard/props.js +0 -5
  121. package/components/container/wizard/utils.js +97 -131
  122. package/components/container/wizard/wizard-action/index.js +41 -81
  123. package/components/container/wizard/wizard-step/index.js +140 -120
  124. package/components/data/card/card-actions/index.js +13 -31
  125. package/components/data/card/card-content/index.js +27 -36
  126. package/components/data/card/card-footer/index.js +13 -31
  127. package/components/data/card/index.js +192 -199
  128. package/components/data/card/props.js +0 -5
  129. package/components/data/form/base-form/constant.js +5 -8
  130. package/components/data/form/base-form/hooks/index.js +26 -77
  131. package/components/data/form/base-form/hooks/useFormDataSync.js +106 -212
  132. package/components/data/form/base-form/hooks/useFormOperations.js +109 -161
  133. package/components/data/form/base-form/hooks/useFormSubmission.js +220 -280
  134. package/components/data/form/base-form/hooks/useFormValidation.js +119 -168
  135. package/components/data/form/base-form/hooks/useParentFormRelationship.js +67 -103
  136. package/components/data/form/base-form/index.js +531 -646
  137. package/components/data/form/base-form/props.js +74 -151
  138. package/components/data/form/base-form/utils.js +210 -323
  139. package/components/data/form/dynamic-fields/constant.js +43 -53
  140. package/components/data/form/dynamic-fields/index.js +135 -144
  141. package/components/data/form/dynamic-fields/props.js +0 -5
  142. package/components/data/form/dynamic-fields/utils.js +99 -158
  143. package/components/data/form/form-action/index.js +107 -85
  144. package/components/data/form/form-body/index.js +52 -26
  145. package/components/data/form/form-context.js +43 -59
  146. package/components/data/form/form-controller/hooks/index.js +43 -57
  147. package/components/data/form/form-controller/props.js +5 -8
  148. package/components/data/form/form-controller/utils.js +54 -49
  149. package/components/data/form/form-controller/validation-contrustor.js +203 -426
  150. package/components/data/form/form-controller/withFormController.js +319 -269
  151. package/components/data/form/form-dynamic-section/index.js +47 -41
  152. package/components/data/form/form-dynamic-section/props.js +0 -5
  153. package/components/data/form/form-field/base-field.js +97 -109
  154. package/components/data/form/form-field/index.js +91 -82
  155. package/components/data/form/form-field/props.js +0 -5
  156. package/components/data/form/form-footer/index.js +52 -25
  157. package/components/data/form/form-header/index.js +61 -58
  158. package/components/data/form/index.js +95 -74
  159. package/components/data/form/props.js +0 -5
  160. package/components/data/list/components/GroupHeader.js +34 -33
  161. package/components/data/list/components/GroupedListItems.js +108 -104
  162. package/components/data/list/components/ListContainer.js +22 -27
  163. package/components/data/list/components/ListDND.js +193 -185
  164. package/components/data/list/components/ListHeader.js +32 -49
  165. package/components/data/list/components/ListItem.js +153 -146
  166. package/components/data/list/components/ListItemWithTemplate.js +87 -105
  167. package/components/data/list/components/ListItems.js +180 -194
  168. package/components/data/list/components/ListPagination.js +127 -153
  169. package/components/data/list/components/LoadMoreButton.js +25 -33
  170. package/components/data/list/components/NoDataMessage.js +9 -22
  171. package/components/data/list/components/StandardListItems.js +79 -85
  172. package/components/data/list/components/index.js +31 -119
  173. package/components/data/list/components/props.js +0 -5
  174. package/components/data/list/hooks/index.js +22 -75
  175. package/components/data/list/hooks/props.js +0 -5
  176. package/components/data/list/hooks/useCurrentPageItems.js +20 -38
  177. package/components/data/list/hooks/useGroupedData.js +19 -33
  178. package/components/data/list/hooks/useListData.js +17 -47
  179. package/components/data/list/hooks/useListEffects.js +168 -237
  180. package/components/data/list/hooks/useListEventHandlers.js +301 -285
  181. package/components/data/list/hooks/useListPagination.js +90 -136
  182. package/components/data/list/hooks/useListState.js +49 -91
  183. package/components/data/list/hooks/useListStateManager.js +104 -159
  184. package/components/data/list/hooks/usePaginatedGroupedData.js +74 -110
  185. package/components/data/list/index.d.ts +1 -0
  186. package/components/data/list/index.js +579 -621
  187. package/components/data/list/props.d.ts +4 -0
  188. package/components/data/list/props.js +0 -5
  189. package/components/data/list/templates/media-template.js +29 -50
  190. package/components/data/list/utils/constants.js +20 -32
  191. package/components/data/list/utils/list-helpers.d.ts +2 -1
  192. package/components/data/list/utils/list-helpers.js +71 -115
  193. package/components/data/list/utils/list-widget-methods.js +56 -76
  194. package/components/data/list/utils/widget-instance-utils.js +20 -57
  195. package/components/data/live-filter/index.js +219 -271
  196. package/components/data/live-filter/props.js +5 -12
  197. package/components/data/live-form/index.js +68 -91
  198. package/components/data/live-form/props.js +5 -12
  199. package/components/data/pagination/components/BasicPagination.js +124 -104
  200. package/components/data/pagination/components/ClassicPagination.js +167 -190
  201. package/components/data/pagination/components/InlinePagination.js +97 -98
  202. package/components/data/pagination/components/LoadingComponent.js +17 -30
  203. package/components/data/pagination/components/PageSizeSelector.js +176 -169
  204. package/components/data/pagination/components/PagerNavigation.js +84 -105
  205. package/components/data/pagination/components/TotalRecords.js +48 -47
  206. package/components/data/pagination/components/index.js +14 -47
  207. package/components/data/pagination/components/props.js +0 -5
  208. package/components/data/pagination/hooks/index.js +6 -19
  209. package/components/data/pagination/hooks/props.js +0 -5
  210. package/components/data/pagination/hooks/useNavigationSize.js +12 -21
  211. package/components/data/pagination/hooks/usePagination.js +702 -905
  212. package/components/data/pagination/index.js +336 -389
  213. package/components/data/table/components/AddNewRow.js +122 -154
  214. package/components/data/table/components/EditableCell.js +68 -75
  215. package/components/data/table/components/FieldValidationError.js +19 -20
  216. package/components/data/table/components/RowCells.js +97 -80
  217. package/components/data/table/components/RowExpansionButton.js +43 -39
  218. package/components/data/table/components/SummaryCell.js +54 -88
  219. package/components/data/table/components/SummaryRow.js +45 -52
  220. package/components/data/table/components/SummaryRowFooter.js +35 -42
  221. package/components/data/table/components/TableBody.js +222 -218
  222. package/components/data/table/components/TableDataRow.js +113 -106
  223. package/components/data/table/components/TableFilters.js +391 -390
  224. package/components/data/table/components/TableFooterActions.js +25 -32
  225. package/components/data/table/components/TableHeader.js +460 -435
  226. package/components/data/table/components/TablePanelHeading.js +157 -181
  227. package/components/data/table/components/index.js +27 -95
  228. package/components/data/table/hooks/index.js +21 -230
  229. package/components/data/table/hooks/use-edited-rows.js +59 -94
  230. package/components/data/table/hooks/useCellState.js +58 -83
  231. package/components/data/table/hooks/useCustomExpressionColumns.js +65 -86
  232. package/components/data/table/hooks/useDynamicColumns.js +59 -92
  233. package/components/data/table/hooks/useEditingState.js +30 -41
  234. package/components/data/table/hooks/useFormWidget.js +163 -172
  235. package/components/data/table/hooks/usePaginationState.js +67 -77
  236. package/components/data/table/hooks/usePanelStructure.js +47 -41
  237. package/components/data/table/hooks/useResponsiveColumns.js +14 -20
  238. package/components/data/table/hooks/useRowExpansion.js +131 -127
  239. package/components/data/table/hooks/useRowHandlers.js +56 -69
  240. package/components/data/table/hooks/useRowSelection.js +249 -329
  241. package/components/data/table/hooks/useServerSideSorting.js +109 -175
  242. package/components/data/table/hooks/useTableColumns.js +322 -331
  243. package/components/data/table/hooks/useTableData.js +111 -166
  244. package/components/data/table/hooks/useTableEdit.js +526 -564
  245. package/components/data/table/hooks/useTableEffects.js +60 -107
  246. package/components/data/table/hooks/useTableFilter.js +244 -237
  247. package/components/data/table/hooks/useTableInitialization.js +44 -76
  248. package/components/data/table/hooks/useTableState.js +39 -61
  249. package/components/data/table/hooks/useTableStateManager.js +295 -468
  250. package/components/data/table/index.js +1553 -1713
  251. package/components/data/table/live-table/index.js +157 -219
  252. package/components/data/table/props.js +0 -5
  253. package/components/data/table/table-action/index.js +97 -75
  254. package/components/data/table/table-column/index.js +48 -42
  255. package/components/data/table/table-group/index.js +7 -25
  256. package/components/data/table/table-row/index.js +63 -55
  257. package/components/data/table/table-row-action/index.js +102 -77
  258. package/components/data/table/utils/buildSelectionColumns.js +86 -137
  259. package/components/data/table/utils/columnBuilder.js +116 -158
  260. package/components/data/table/utils/columnProxy.js +48 -66
  261. package/components/data/table/utils/columnWidthDistribution.js +40 -64
  262. package/components/data/table/utils/constants.js +92 -40
  263. package/components/data/table/utils/crud-handlers.js +292 -473
  264. package/components/data/table/utils/dynamic-columns.js +99 -144
  265. package/components/data/table/utils/groupHeaderUtils.js +36 -61
  266. package/components/data/table/utils/index.d.ts +8 -5
  267. package/components/data/table/utils/index.js +419 -639
  268. package/components/data/table/utils/renderDisplayCell.js +127 -169
  269. package/components/data/table/utils/script-page-size-broadcast.js +17 -29
  270. package/components/data/table/utils/selectionUtils.js +59 -113
  271. package/components/data/table/utils/table-helpers.js +38 -74
  272. package/components/data/table/utils/validation.js +35 -78
  273. package/components/data/table/utils/widgetMapping.d.ts +5 -0
  274. package/components/data/table/utils/widgetMapping.js +41 -0
  275. package/components/data/types.js +112 -112
  276. package/components/data/utils/field-data-utils.js +38 -42
  277. package/components/data/utils/filter-field-util.js +42 -44
  278. package/components/data/utils/index.js +112 -111
  279. package/components/dialogs/alert-dialog/index.js +83 -78
  280. package/components/dialogs/alert-dialog/props.js +0 -5
  281. package/components/dialogs/confirm-dialog/index.js +102 -92
  282. package/components/dialogs/confirm-dialog/props.js +0 -5
  283. package/components/dialogs/dialog/index.js +93 -69
  284. package/components/dialogs/dialog/props.js +0 -5
  285. package/components/dialogs/dialog-actions/index.js +12 -26
  286. package/components/dialogs/dialog-actions/props.js +0 -5
  287. package/components/dialogs/dialog-body/index.js +13 -30
  288. package/components/dialogs/dialog-body/props.js +0 -5
  289. package/components/dialogs/dialog-content/index.js +48 -41
  290. package/components/dialogs/dialog-content/props.js +0 -5
  291. package/components/dialogs/dialog-header/index.js +88 -101
  292. package/components/dialogs/dialog-header/props.js +0 -5
  293. package/components/dialogs/iframe-dialog/index.js +136 -128
  294. package/components/dialogs/iframe-dialog/props.js +0 -5
  295. package/components/dialogs/index.js +104 -101
  296. package/components/dialogs/login-dialog/index.js +285 -347
  297. package/components/dialogs/login-dialog/props.js +0 -5
  298. package/components/dialogs/page-dialog/index.js +95 -86
  299. package/components/dialogs/page-dialog/props.js +0 -5
  300. package/components/dialogs/props.js +0 -5
  301. package/components/dialogs/withDialogWrapper.js +110 -83
  302. package/components/form/button/index.js +296 -245
  303. package/components/form/button/props.js +0 -5
  304. package/components/form/button-group/index.js +80 -69
  305. package/components/form/button-group/props.js +0 -5
  306. package/components/input/calendar/index.js +409 -362
  307. package/components/input/calendar/props.js +0 -5
  308. package/components/input/calendar/utils.js +164 -172
  309. package/components/input/chips/SortableChip/index.js +109 -100
  310. package/components/input/chips/SortableChip/props.js +0 -5
  311. package/components/input/chips/index.js +663 -570
  312. package/components/input/chips/props.js +0 -5
  313. package/components/input/chips/utils.js +131 -122
  314. package/components/input/color-picker/index.js +536 -594
  315. package/components/input/color-picker/props.js +0 -5
  316. package/components/input/composite/index.js +71 -110
  317. package/components/input/composite/props.js +0 -5
  318. package/components/input/currency/index.js +277 -224
  319. package/components/input/currency/props.js +0 -5
  320. package/components/input/default/checkbox/index.js +329 -250
  321. package/components/input/default/checkbox/props.js +0 -5
  322. package/components/input/default/checkboxset/index.d.ts +2 -0
  323. package/components/input/default/checkboxset/index.js +529 -446
  324. package/components/input/default/checkboxset/props.d.ts +4 -0
  325. package/components/input/default/checkboxset/props.js +0 -5
  326. package/components/input/default/checkboxset/utils.js +15 -25
  327. package/components/input/default/radioset/index.d.ts +2 -0
  328. package/components/input/default/radioset/index.js +409 -350
  329. package/components/input/default/radioset/props.d.ts +6 -0
  330. package/components/input/default/radioset/props.js +0 -5
  331. package/components/input/default/switch/index.js +494 -458
  332. package/components/input/default/switch/prop.js +0 -5
  333. package/components/input/epoch/date/components/DatePickerPopover.js +242 -193
  334. package/components/input/epoch/date/index.js +638 -518
  335. package/components/input/epoch/date/props.js +0 -5
  336. package/components/input/epoch/date/styled.js +61 -70
  337. package/components/input/epoch/date/utils.js +67 -115
  338. package/components/input/epoch/datetime/index.js +758 -695
  339. package/components/input/epoch/datetime/props.js +0 -5
  340. package/components/input/epoch/datetime/utils.js +121 -186
  341. package/components/input/epoch/time/index.js +441 -415
  342. package/components/input/epoch/time/props.js +0 -5
  343. package/components/input/epoch/time/utils.js +101 -112
  344. package/components/input/fileupload/Utils.js +70 -97
  345. package/components/input/fileupload/components/ListItems.js +132 -130
  346. package/components/input/fileupload/components/MultiUpload.js +80 -77
  347. package/components/input/fileupload/components/SingleUpload.js +57 -57
  348. package/components/input/fileupload/index.js +253 -178
  349. package/components/input/fileupload/props.js +0 -5
  350. package/components/input/fileupload/useFileUpload.js +209 -258
  351. package/components/input/number/index.js +434 -393
  352. package/components/input/number/props.js +0 -5
  353. package/components/input/rating/index.js +401 -394
  354. package/components/input/rating/props.js +0 -5
  355. package/components/input/select/index.js +408 -463
  356. package/components/input/select/props.js +0 -5
  357. package/components/input/slider/index.js +339 -332
  358. package/components/input/slider/props.js +0 -5
  359. package/components/input/text/index.d.ts +3 -3
  360. package/components/input/text/index.js +438 -475
  361. package/components/input/text/props.d.ts +1 -1
  362. package/components/input/text/props.js +0 -5
  363. package/components/input/text/util.js +82 -222
  364. package/components/input/textarea/index.js +322 -358
  365. package/components/input/textarea/props.js +0 -5
  366. package/components/input/upload/index.js +135 -131
  367. package/components/input/upload/props.js +0 -5
  368. package/components/input/util/index.js +9 -11
  369. package/components/layout/footer/index.js +12 -35
  370. package/components/layout/footer/props.js +0 -5
  371. package/components/layout/header/index.js +12 -38
  372. package/components/layout/header/props.js +0 -5
  373. package/components/layout/leftnav/index.js +38 -44
  374. package/components/layout/leftnav/props.js +0 -5
  375. package/components/layout/rightnav/index.js +12 -36
  376. package/components/layout/rightnav/props.js +0 -5
  377. package/components/layout/topnav/index.js +24 -38
  378. package/components/layout/topnav/props.js +0 -5
  379. package/components/navbar/index.js +119 -98
  380. package/components/navbar/nav/index.js +236 -232
  381. package/components/navbar/nav/props.js +0 -5
  382. package/components/navbar/nav-item/index.js +74 -65
  383. package/components/navbar/nav-item/props.js +0 -5
  384. package/components/navigation/breadcrumb/index.js +38 -61
  385. package/components/navigation/breadcrumb/props.js +0 -5
  386. package/components/navigation/menu/components/ListItems.js +76 -67
  387. package/components/navigation/menu/constants.js +27 -42
  388. package/components/navigation/menu/hooks/useHoverState.hook.js +20 -47
  389. package/components/navigation/menu/hooks/useKeyboardMovements.hook.js +34 -28
  390. package/components/navigation/menu/hooks/useTransformedDataset.hook.js +21 -14
  391. package/components/navigation/menu/index.js +911 -846
  392. package/components/navigation/menu/props.js +0 -5
  393. package/components/navigation/menu/utils/action-task.js +6 -9
  394. package/components/navigation/menu/utils/role-filter.js +41 -56
  395. package/components/navigation/popover/index.js +191 -205
  396. package/components/navigation/popover/props.js +5 -8
  397. package/components/page/content/index.js +9 -31
  398. package/components/page/content/props.js +0 -5
  399. package/components/page/error-boundary/index.js +115 -105
  400. package/components/page/error-boundary/props.js +0 -5
  401. package/components/page/index.js +84 -102
  402. package/components/page/page-content/index.js +21 -30
  403. package/components/page/page-content/props.js +0 -5
  404. package/components/page/partial/index.js +50 -45
  405. package/components/page/partial/props.js +0 -5
  406. package/components/page/partial-container/index.js +81 -107
  407. package/components/page/partial-container/props.d.ts +1 -1
  408. package/components/page/partial-container/props.js +0 -5
  409. package/components/page/props.js +0 -5
  410. package/components/page/toast-container/index.js +20 -41
  411. package/components/page/toast-container/props.js +0 -5
  412. package/components/prefab/container/index.js +60 -53
  413. package/components/prefab/container/props.js +0 -5
  414. package/components/prefab/index.js +76 -61
  415. package/components/prefab/props.js +0 -5
  416. package/context/AppContext.d.ts +1 -1
  417. package/context/AppContext.js +17 -18
  418. package/context/AppSpinnerProvider.js +19 -34
  419. package/context/LayoutProvider.js +54 -57
  420. package/context/LocalizationProvider.js +34 -49
  421. package/context/PrefabContext.js +68 -119
  422. package/context/WidgetProvider.js +160 -166
  423. package/core/app-config.js +0 -1
  424. package/core/app.service.js +200 -327
  425. package/core/appVariablesStore.js +10 -15
  426. package/core/appstore.js +37 -53
  427. package/core/constants/currency-constant.js +81 -83
  428. package/core/constants/events.js +34 -44
  429. package/core/constants/index.js +21 -31
  430. package/core/dialog.service.js +52 -72
  431. package/core/event-notifier.js +94 -131
  432. package/core/formatter/array-formatters.js +18 -32
  433. package/core/formatter/date-formatters.js +140 -204
  434. package/core/formatter/index.js +64 -117
  435. package/core/formatter/number-formatters.js +115 -159
  436. package/core/formatter/security-formatters.js +233 -283
  437. package/core/formatter/string-formatters.js +23 -45
  438. package/core/formatter/types.js +12 -18
  439. package/core/formatters.js +6 -24
  440. package/core/proxy-service.js +242 -306
  441. package/core/script-registry.js +87 -134
  442. package/core/security.service.js +8 -11
  443. package/core/util/compare.js +13 -25
  444. package/core/util/dom.js +32 -63
  445. package/core/util/index.d.ts +5 -0
  446. package/core/util/index.js +95 -95
  447. package/core/util/safe-is-equal.js +42 -94
  448. package/core/util/security.js +114 -153
  449. package/core/util/utils.d.ts +8 -1
  450. package/core/util/utils.js +124 -132
  451. package/core/widget-observer.js +34 -61
  452. package/higherOrder/BaseApp.js +327 -500
  453. package/higherOrder/BaseAppProps.js +0 -5
  454. package/higherOrder/BaseDateTime.js +277 -231
  455. package/higherOrder/BasePage.js +479 -735
  456. package/higherOrder/BasePartial.js +87 -114
  457. package/higherOrder/BasePrefab.js +190 -206
  458. package/higherOrder/DataNav.js +287 -302
  459. package/higherOrder/helper.js +62 -48
  460. package/higherOrder/props.js +0 -5
  461. package/higherOrder/withBaseWrapper.js +123 -168
  462. package/higherOrder/withStandalone.js +28 -26
  463. package/hooks/useAccess.js +113 -289
  464. package/hooks/useAppConfig.js +15 -40
  465. package/hooks/useAuth.js +256 -495
  466. package/hooks/useDataSourceSubscription.d.ts +3 -3
  467. package/hooks/useDataSourceSubscription.js +99 -109
  468. package/hooks/useDebounce.js +28 -56
  469. package/hooks/useDeviceVisibility.js +14 -23
  470. package/hooks/useHttp.d.ts +1 -0
  471. package/hooks/useHttp.js +318 -493
  472. package/libs/index.js +4 -13
  473. package/libs/prefab/index.js +6 -20
  474. package/mui-config/theme-provider.js +9 -17
  475. package/mui-config/theme.js +6 -9
  476. package/package-lock.json +822 -3191
  477. package/package.json +3 -19
  478. package/providers/AppProviders.js +21 -24
  479. package/runtime-dynamic/App.js +65 -93
  480. package/runtime-dynamic/app-initializer.js +207 -400
  481. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  482. package/runtime-dynamic/components/PageWrapper.js +23 -35
  483. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  484. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  485. package/runtime-dynamic/components/partial-content.js +66 -48
  486. package/runtime-dynamic/components/prefab-content.js +37 -30
  487. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  488. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  489. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  490. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  491. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  492. package/runtime-dynamic/factories/startup-info.js +12 -25
  493. package/runtime-dynamic/factories/utils.d.ts +1 -9
  494. package/runtime-dynamic/factories/utils.js +47 -130
  495. package/runtime-dynamic/index.js +56 -191
  496. package/runtime-dynamic/main.js +42 -70
  497. package/runtime-dynamic/preview-mode.js +14 -29
  498. package/runtime-dynamic/preview-navigation.js +21 -30
  499. package/runtime-dynamic/preview-path.d.ts +5 -0
  500. package/runtime-dynamic/preview-path.js +13 -0
  501. package/runtime-dynamic/preview-resource-base.js +15 -31
  502. package/runtime-dynamic/registry/component-registry.js +269 -334
  503. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  504. package/runtime-dynamic/registry/index.js +24 -63
  505. package/runtime-dynamic/registry/store.d.ts +1 -0
  506. package/runtime-dynamic/registry/store.js +18 -23
  507. package/runtime-dynamic/routes.js +53 -81
  508. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  509. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  510. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  511. package/runtime-dynamic/services/cache.js +27 -33
  512. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  513. package/runtime-dynamic/services/compile-render.js +142 -0
  514. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  515. package/runtime-dynamic/services/css-scoping.js +27 -28
  516. package/runtime-dynamic/services/fragment-url.js +37 -50
  517. package/runtime-dynamic/services/index.js +48 -152
  518. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  519. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  520. package/runtime-dynamic/services/prefab-resources.js +42 -130
  521. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  522. package/runtime-dynamic/services/resource-manager.js +32 -63
  523. package/runtime-dynamic/services/script-executor.js +50 -61
  524. package/runtime-dynamic/services/variable-factory.js +141 -184
  525. package/runtime-dynamic/services/variable-registry.js +69 -115
  526. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  527. package/runtime-dynamic/shims/next-image.js +79 -50
  528. package/runtime-dynamic/shims/next-link.js +58 -32
  529. package/runtime-dynamic/shims/next-navigation.js +17 -34
  530. package/runtime-dynamic/utils/index.d.ts +2 -0
  531. package/runtime-dynamic/utils/index.js +22 -24
  532. package/store/bindActions/i18nActions.js +16 -18
  533. package/store/index.js +29 -35
  534. package/store/middleware/navigationMiddleware.js +25 -45
  535. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  536. package/store/slices/appConfigSlice.js +65 -94
  537. package/store/slices/authSlice.js +317 -471
  538. package/store/slices/i18nSlice.js +169 -168
  539. package/store/slices/navigationSlice.js +22 -20
  540. package/store/util/resolve-path.d.ts +1 -0
  541. package/store/util/resolve-path.js +7 -0
  542. package/store/viewport.service.js +150 -194
  543. package/types/index.js +10 -15
  544. package/utils/attr.js +198 -41
  545. package/utils/custom-expression/index.js +55 -151
  546. package/utils/custom-expression/parser.js +106 -182
  547. package/utils/dataset-util.js +113 -154
  548. package/utils/eval-expression.js +10 -19
  549. package/utils/form-state.util.js +60 -118
  550. package/utils/form-utils.js +49 -190
  551. package/utils/format-util.js +113 -184
  552. package/utils/layoutsize-util.js +11 -17
  553. package/utils/lib-error-skipper.js +54 -52
  554. package/utils/page-params-util.js +50 -40
  555. package/utils/pending-tab-navigation-intent.js +7 -17
  556. package/utils/resource-url.js +8 -19
  557. package/utils/state-persistance.js +136 -253
  558. package/utils/style-utils.d.ts +2 -0
  559. package/utils/style-utils.js +25 -74
  560. package/utils/transformedDataset-utils.js +353 -381
  561. package/utils/widget-cleanup-util.js +42 -74
  562. package/utils/widgets.js +19 -31
  563. package/variables/base-variable.js +117 -166
  564. package/variables/constants.js +5 -8
  565. package/variables/crud-variable.js +150 -181
  566. package/variables/live-variable.d.ts +1 -1
  567. package/variables/live-variable.js +140 -174
  568. package/variables/metadata.service.js +74 -116
  569. package/variables/model-variable.js +68 -78
  570. package/variables/service-variable.js +171 -285
  571. package/wm-namespace.js +11 -14
  572. package/components/chart/src/css.d.js +0 -1
  573. package/tsconfig.declaration.tsbuildinfo +0 -1
  574. package/types/global.d.js +0 -3
@@ -1,323 +1,339 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.useListEventHandlers = void 0;
8
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
9
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
10
- var _react = require("react");
11
- var _lodashEs = require("lodash-es");
12
- var _listHelpers = require("../utils/list-helpers");
13
- var _WidgetProvider = require("@wavemaker-ai/react-runtime/context/WidgetProvider");
14
- var _widgetInstanceUtils = require("../utils/widget-instance-utils");
15
- 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; }
16
- 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; }
17
- /**
18
- * Custom hook for managing list event handlers
19
- * Extracts all event handling logic from the main component
20
- */
21
- var useListEventHandlers = exports.useListEventHandlers = function useListEventHandlers(props) {
22
- var items = props.items,
23
- multiselect = props.multiselect,
24
- disableitem = props.disableitem,
25
- selectionlimit = props.selectionlimit,
26
- collapsible = props.collapsible,
27
- selectedItems = props.selectedItems,
28
- setSelectedItems = props.setSelectedItems,
29
- activeItems = props.activeItems,
30
- setActiveItems = props.setActiveItems,
31
- firstSelectedItem = props.firstSelectedItem,
32
- setFirstSelectedItem = props.setFirstSelectedItem,
33
- groupCollapsed = props.groupCollapsed,
34
- setGroupCollapsed = props.setGroupCollapsed,
35
- currentPage = props.currentPage,
36
- setCurrentPage = props.setCurrentPage,
37
- visibleItems = props.visibleItems,
38
- setVisibleItems = props.setVisibleItems,
39
- setIsLoadingMore = props.setIsLoadingMore,
40
- onClick = props.onClick,
41
- onDblclick = props.onDblclick,
42
- onMouseEnter = props.onMouseEnter,
43
- onMouseLeave = props.onMouseLeave,
44
- onSelectionlimitexceed = props.onSelectionlimitexceed,
45
- onPaginationchange = props.onPaginationchange,
46
- onPageChange = props.onPageChange,
47
- onSetrecord = props.onSetrecord,
48
- widgetInstance = props.widgetInstance,
49
- onSelect = props.onSelect,
50
- userInitiatedSelectionRef = props.userInitiatedSelectionRef,
51
- datasource = props.datasource,
52
- isServerSidePagination = props.isServerSidePagination,
53
- pagesize = props.pagesize,
54
- navigation = props.navigation,
55
- onDemandCurrentPage = props.onDemandCurrentPage,
56
- setOnDemandCurrentPage = props.setOnDemandCurrentPage,
57
- listener = props.listener,
58
- name = props.name,
59
- _props$standalone = props.standalone,
60
- standalone = _props$standalone === void 0 ? false : _props$standalone;
61
- var selectedItemsRef = (0, _react.useRef)(selectedItems);
62
- var Widgets = (0, _WidgetProvider.useWidgetProxy)(undefined, standalone);
63
- (0, _react.useEffect)(function () {
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { useCallback, useRef, useEffect } from "react";
21
+ import { findIndex, includes, filter, slice, min, max } from "lodash-es";
22
+ import { getSelectedItemWidgets } from "../utils/list-helpers";
23
+ import { useWidgetProxy } from "../../../../context/WidgetProvider";
24
+ import { setWidgetIndex, setWidgetPageIndex, setWidgetItem } from "../utils/widget-instance-utils";
25
+ const useListEventHandlers = (props) => {
26
+ const {
27
+ items,
28
+ multiselect,
29
+ disableitem,
30
+ selectionlimit,
31
+ collapsible,
32
+ selectedItems,
33
+ setSelectedItems,
34
+ activeItems,
35
+ setActiveItems,
36
+ firstSelectedItem,
37
+ setFirstSelectedItem,
38
+ groupCollapsed,
39
+ setGroupCollapsed,
40
+ currentPage,
41
+ setCurrentPage,
42
+ visibleItems,
43
+ setVisibleItems,
44
+ setIsLoadingMore,
45
+ onClick,
46
+ onDblclick,
47
+ onMouseEnter,
48
+ onMouseLeave,
49
+ onSelectionlimitexceed,
50
+ onPaginationchange,
51
+ onPageChange,
52
+ onSetrecord,
53
+ widgetInstance,
54
+ onSelect,
55
+ userInitiatedSelectionRef,
56
+ datasource,
57
+ isServerSidePagination,
58
+ pagesize,
59
+ navigation,
60
+ onDemandCurrentPage,
61
+ setOnDemandCurrentPage,
62
+ listener,
63
+ name,
64
+ standalone = false
65
+ } = props;
66
+ const selectedItemsRef = useRef(selectedItems);
67
+ const Widgets = useWidgetProxy(void 0, standalone);
68
+ useEffect(() => {
64
69
  selectedItemsRef.current = selectedItems;
65
70
  }, [selectedItems]);
66
-
67
- // Helper function to call onSelect and mark as user-initiated
68
- var callOnSelect = (0, _react.useCallback)(function (selectedItem, event) {
69
- if (onSelect && widgetInstance && selectedItem) {
70
- if (userInitiatedSelectionRef) {
71
- userInitiatedSelectionRef.current = true;
71
+ const callOnSelect = useCallback(
72
+ (selectedItem, event) => {
73
+ if (onSelect && widgetInstance && selectedItem) {
74
+ if (userInitiatedSelectionRef) {
75
+ userInitiatedSelectionRef.current = true;
76
+ }
77
+ setWidgetIndex(widgetInstance, items, selectedItem);
78
+ onSelect(widgetInstance, selectedItem, event != null ? event : void 0);
72
79
  }
73
- // Set $index on widget instance
74
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, selectedItem);
75
- onSelect(widgetInstance, selectedItem, event !== null && event !== void 0 ? event : undefined);
76
- }
77
- }, [onSelect, userInitiatedSelectionRef, items]);
78
- var handleListItemClick = (0, _react.useCallback)(function (event, item) {
79
- if (disableitem) return;
80
- var selectCount = selectedItems.length;
81
- var isItemSelected = (0, _lodashEs.includes)(selectedItems, item);
82
- var isItemActive = activeItems.has(item);
83
- if (multiselect) {
84
- // Handle Shift+Click for range selection
85
- if (event.shiftKey && firstSelectedItem && firstSelectedItem !== item) {
86
- var firstIndex = (0, _lodashEs.findIndex)(items, function (i) {
87
- return i === firstSelectedItem;
88
- });
89
- var lastIndex = (0, _lodashEs.findIndex)(items, function (i) {
90
- return i === item;
91
- });
92
- if (firstIndex !== -1 && lastIndex !== -1) {
93
- var start = (0, _lodashEs.min)([firstIndex, lastIndex]);
94
- var end = (0, _lodashEs.max)([firstIndex, lastIndex]);
95
- var rangeCount = end - start + 1;
96
- if (selectionlimit > 0 && rangeCount > selectionlimit) {
97
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, item);
98
- onSelectionlimitexceed === null || onSelectionlimitexceed === void 0 || onSelectionlimitexceed(event, widgetInstance);
80
+ },
81
+ [onSelect, userInitiatedSelectionRef, items]
82
+ );
83
+ const handleListItemClick = useCallback(
84
+ (event, item) => {
85
+ if (disableitem) return;
86
+ const selectCount = selectedItems.length;
87
+ const isItemSelected = includes(selectedItems, item);
88
+ const isItemActive = activeItems.has(item);
89
+ if (multiselect) {
90
+ if (event.shiftKey && firstSelectedItem && firstSelectedItem !== item) {
91
+ const firstIndex = findIndex(items, (i) => i === firstSelectedItem);
92
+ const lastIndex = findIndex(items, (i) => i === item);
93
+ if (firstIndex !== -1 && lastIndex !== -1) {
94
+ const start = min([firstIndex, lastIndex]);
95
+ const end = max([firstIndex, lastIndex]);
96
+ const rangeCount = end - start + 1;
97
+ if (selectionlimit > 0 && rangeCount > selectionlimit) {
98
+ setWidgetIndex(widgetInstance, items, item);
99
+ onSelectionlimitexceed == null ? void 0 : onSelectionlimitexceed(event, widgetInstance);
100
+ return;
101
+ }
102
+ const rangeItems = slice(items, start, end + 1);
103
+ selectedItemsRef.current = rangeItems;
104
+ setSelectedItems(rangeItems);
105
+ setActiveItems(new Set(rangeItems));
106
+ if (!isItemActive) {
107
+ callOnSelect(item, event);
108
+ }
109
+ setWidgetIndex(widgetInstance, items, item);
110
+ onClick == null ? void 0 : onClick(event, widgetInstance);
99
111
  return;
100
112
  }
101
- var rangeItems = (0, _lodashEs.slice)(items, start, end + 1);
102
- selectedItemsRef.current = rangeItems;
103
- setSelectedItems(rangeItems);
104
- setActiveItems(new Set(rangeItems));
105
- // Only call onSelect if this is a new selection (not already active)
106
- if (!isItemActive) {
107
- callOnSelect(item, event); // Pass the current item that triggered the range selection
108
- }
109
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, item);
110
- onClick === null || onClick === void 0 || onClick(event, widgetInstance); // Use widgetInstance instead of item
111
- return;
112
- }
113
- }
114
-
115
- // Handle Ctrl+Click for individual item selection toggle
116
- if (event.ctrlKey) {
117
- if (selectionlimit > 0 && selectCount >= selectionlimit && !isItemSelected) {
118
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, item);
119
- onSelectionlimitexceed === null || onSelectionlimitexceed === void 0 || onSelectionlimitexceed(event, widgetInstance);
120
- return;
121
113
  }
122
- if (isItemSelected) {
123
- var newSelectedItems = (0, _lodashEs.filter)(selectedItems, function (selectedItem) {
124
- return selectedItem !== item;
125
- });
126
- selectedItemsRef.current = newSelectedItems;
127
- setSelectedItems(newSelectedItems);
128
- var newActiveItems = new Set(activeItems);
129
- newActiveItems["delete"](item);
130
- setActiveItems(newActiveItems);
114
+ if (event.ctrlKey) {
115
+ if (selectionlimit > 0 && selectCount >= selectionlimit && !isItemSelected) {
116
+ setWidgetIndex(widgetInstance, items, item);
117
+ onSelectionlimitexceed == null ? void 0 : onSelectionlimitexceed(event, widgetInstance);
118
+ return;
119
+ }
120
+ if (isItemSelected) {
121
+ const newSelectedItems = filter(selectedItems, (selectedItem) => selectedItem !== item);
122
+ selectedItemsRef.current = newSelectedItems;
123
+ setSelectedItems(newSelectedItems);
124
+ const newActiveItems = new Set(activeItems);
125
+ newActiveItems.delete(item);
126
+ setActiveItems(newActiveItems);
127
+ } else {
128
+ const newSelectedItems = [...selectedItems, item];
129
+ selectedItemsRef.current = newSelectedItems;
130
+ setSelectedItems(newSelectedItems);
131
+ const newActiveItems = new Set(activeItems);
132
+ newActiveItems.add(item);
133
+ setActiveItems(newActiveItems);
134
+ if (!isItemActive) {
135
+ callOnSelect(item, event);
136
+ }
137
+ }
138
+ setFirstSelectedItem(item);
131
139
  } else {
132
- var _newSelectedItems = [].concat((0, _toConsumableArray2["default"])(selectedItems), [item]);
133
- selectedItemsRef.current = _newSelectedItems;
134
- setSelectedItems(_newSelectedItems);
135
- var _newActiveItems = new Set(activeItems);
136
- _newActiveItems.add(item);
137
- setActiveItems(_newActiveItems);
138
- // Only call onSelect if this is a new selection (not already active)
139
- if (!isItemActive) {
140
- callOnSelect(item, event); // Pass the current item being selected
140
+ if (!isItemSelected) {
141
+ const newSelectedItems = [item];
142
+ selectedItemsRef.current = newSelectedItems;
143
+ setSelectedItems(newSelectedItems);
144
+ setActiveItems(/* @__PURE__ */ new Set([item]));
145
+ setFirstSelectedItem(item);
146
+ if (!isItemActive) {
147
+ callOnSelect(item, event);
148
+ }
141
149
  }
142
150
  }
143
- setFirstSelectedItem(item);
144
151
  } else {
145
- // Normal click without Ctrl - select item without deselecting if already selected
146
152
  if (!isItemSelected) {
147
- // If clicking an unselected item, select only this item
148
- var _newSelectedItems2 = [item];
149
- selectedItemsRef.current = _newSelectedItems2;
150
- setSelectedItems(_newSelectedItems2);
151
- setActiveItems(new Set([item]));
153
+ const newSelectedItems = [item];
154
+ selectedItemsRef.current = newSelectedItems;
155
+ setSelectedItems(newSelectedItems);
156
+ setActiveItems(/* @__PURE__ */ new Set([item]));
152
157
  setFirstSelectedItem(item);
153
- // Only call onSelect if this is a new selection (not already active)
154
158
  if (!isItemActive) {
155
- callOnSelect(item, event); // Pass the current item being selected
159
+ callOnSelect(item, event);
156
160
  }
157
161
  }
158
- // If item is already selected, do nothing (don't deselect)
159
162
  }
160
- } else {
161
- // Single select mode - only select, don't deselect on normal click
162
- if (!isItemSelected) {
163
- // If clicking an unselected item, select it
164
- var _newSelectedItems3 = [item];
165
- selectedItemsRef.current = _newSelectedItems3;
166
- setSelectedItems(_newSelectedItems3);
167
- setActiveItems(new Set([item]));
168
- setFirstSelectedItem(item);
169
- // Only call onSelect if this is a new selection (not already active)
170
- if (!isItemActive) {
171
- callOnSelect(item, event); // Pass the current item being selected
172
- }
163
+ getSelectedItemWidgets(event, listener, name || "", item || null, Widgets);
164
+ setWidgetItem(widgetInstance, items, item);
165
+ onClick == null ? void 0 : onClick(event, widgetInstance);
166
+ },
167
+ [
168
+ disableitem,
169
+ selectedItems,
170
+ multiselect,
171
+ firstSelectedItem,
172
+ items,
173
+ selectionlimit,
174
+ activeItems,
175
+ setSelectedItems,
176
+ setActiveItems,
177
+ setFirstSelectedItem,
178
+ onSelectionlimitexceed,
179
+ onClick,
180
+ callOnSelect
181
+ ]
182
+ );
183
+ const handleListItemDoubleClick = useCallback(
184
+ (event, item) => {
185
+ if (onDblclick) {
186
+ setWidgetIndex(widgetInstance, items, item);
187
+ onDblclick(event, widgetInstance);
173
188
  }
174
- // If item is already selected, do nothing (don't deselect)
175
- }
176
- (0, _listHelpers.getSelectedItemWidgets)(event, listener, name || "", item || null, Widgets);
177
- (0, _widgetInstanceUtils.setWidgetItem)(widgetInstance, items, item);
178
- onClick === null || onClick === void 0 || onClick(event, widgetInstance); // Use widgetInstance instead of item
179
- }, [disableitem, selectedItems, multiselect, firstSelectedItem, items, selectionlimit, activeItems, setSelectedItems, setActiveItems, setFirstSelectedItem, onSelectionlimitexceed, onClick, callOnSelect]);
180
- var handleListItemDoubleClick = (0, _react.useCallback)(function (event, item) {
181
- if (onDblclick) {
182
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, item);
183
- onDblclick(event, widgetInstance);
184
- }
185
- }, [onDblclick, items]);
186
- var handleListItemMouseEnter = (0, _react.useCallback)(function (event, item) {
187
- // Use widgetInstance instead of item
188
- if (onMouseEnter) {
189
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, item);
190
- onMouseEnter(event, widgetInstance);
191
- }
192
- }, [onMouseEnter, items]);
193
- var handleListItemMouseLeave = (0, _react.useCallback)(function (event, item) {
194
- if (onMouseLeave) {
195
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, item);
196
- onMouseLeave(event, widgetInstance);
197
- }
198
- }, [onMouseLeave, items]);
199
- var handleHeaderClick = (0, _react.useCallback)(function (groupKey) {
200
- if (collapsible) {
201
- setGroupCollapsed(_objectSpread(_objectSpread({}, groupCollapsed), {}, (0, _defineProperty2["default"])({}, groupKey, !groupCollapsed[groupKey])));
202
- }
203
- }, [collapsible, groupCollapsed, setGroupCollapsed]);
204
- var handlePaginationChange = (0, _react.useCallback)(function (event, widget, index) {
205
- if (index && currentPage !== index) {
206
- // Update the current page
207
- setCurrentPage(index);
208
-
209
- // Trigger the callbacks - datasource handling is now done in usePagination hook
210
- (0, _widgetInstanceUtils.setWidgetPageIndex)(widgetInstance, index);
211
- onPaginationchange === null || onPaginationchange === void 0 || onPaginationchange(event, widgetInstance, index);
212
- onPageChange === null || onPageChange === void 0 || onPageChange(event, index);
213
- }
214
- }, [currentPage, setCurrentPage, onPaginationchange, onPageChange, widgetInstance]);
215
- var handleSetRecord = (0, _react.useCallback)(function (event, widget, index, data) {
216
- if (index) {
217
- setCurrentPage(index);
218
- (0, _widgetInstanceUtils.setWidgetIndex)(widgetInstance, items, data);
219
- onSetrecord === null || onSetrecord === void 0 || onSetrecord(event, widgetInstance, index, data);
220
- }
221
- }, [setCurrentPage, onSetrecord, items]);
222
- var handlePageChange = (0, _react.useCallback)(function (page) {
223
- // Update the current page
224
- setCurrentPage(page);
225
-
226
- // For server-side pagination, invoke the datasource
227
- if (isServerSidePagination && datasource && typeof datasource.invoke === "function") {
228
- // Set loading state
229
- setIsLoadingMore(true);
230
-
231
- // Invoke datasource for the new page
232
- var invokeResult = datasource.invoke({
233
- page: page
234
- });
235
- Promise.resolve(invokeResult).then(function () {
236
- // Trigger the callbacks after successful data fetch
237
- (0, _widgetInstanceUtils.setWidgetPageIndex)(widgetInstance, page);
238
- onPaginationchange === null || onPaginationchange === void 0 || onPaginationchange(null, widgetInstance, page);
239
- onPageChange === null || onPageChange === void 0 || onPageChange(null, page);
240
- setIsLoadingMore(false);
241
- })["catch"](function (error) {
242
- console.error("Error loading page data:", error);
243
- setIsLoadingMore(false);
244
- // Revert to previous page on error
245
- setCurrentPage(currentPage);
246
- });
247
- } else {
248
- // For client-side pagination, just trigger callbacks
249
- (0, _widgetInstanceUtils.setWidgetPageIndex)(widgetInstance, page);
250
- onPaginationchange === null || onPaginationchange === void 0 || onPaginationchange(null, widgetInstance, page);
251
- onPageChange === null || onPageChange === void 0 || onPageChange(null, page);
252
- }
253
- }, [setCurrentPage, onPaginationchange, onPageChange, widgetInstance, currentPage, setIsLoadingMore, isServerSidePagination, datasource]);
254
- var handleLoadMore = (0, _react.useCallback)(function () {
189
+ },
190
+ [onDblclick, items]
191
+ );
192
+ const handleListItemMouseEnter = useCallback(
193
+ (event, item) => {
194
+ if (onMouseEnter) {
195
+ setWidgetIndex(widgetInstance, items, item);
196
+ onMouseEnter(event, widgetInstance);
197
+ }
198
+ },
199
+ [onMouseEnter, items]
200
+ );
201
+ const handleListItemMouseLeave = useCallback(
202
+ (event, item) => {
203
+ if (onMouseLeave) {
204
+ setWidgetIndex(widgetInstance, items, item);
205
+ onMouseLeave(event, widgetInstance);
206
+ }
207
+ },
208
+ [onMouseLeave, items]
209
+ );
210
+ const handleHeaderClick = useCallback(
211
+ (groupKey) => {
212
+ if (collapsible) {
213
+ setGroupCollapsed(__spreadProps(__spreadValues({}, groupCollapsed), {
214
+ [groupKey]: !groupCollapsed[groupKey]
215
+ }));
216
+ }
217
+ },
218
+ [collapsible, groupCollapsed, setGroupCollapsed]
219
+ );
220
+ const handlePaginationChange = useCallback(
221
+ (event, widget, index) => {
222
+ if (index && currentPage !== index) {
223
+ setCurrentPage(index);
224
+ setWidgetPageIndex(widgetInstance, index);
225
+ onPaginationchange == null ? void 0 : onPaginationchange(event, widgetInstance, index);
226
+ onPageChange == null ? void 0 : onPageChange(event, index);
227
+ }
228
+ },
229
+ [currentPage, setCurrentPage, onPaginationchange, onPageChange, widgetInstance]
230
+ );
231
+ const handleSetRecord = useCallback(
232
+ (event, widget, index, data) => {
233
+ if (index) {
234
+ setCurrentPage(index);
235
+ setWidgetIndex(widgetInstance, items, data);
236
+ onSetrecord == null ? void 0 : onSetrecord(event, widgetInstance, index, data);
237
+ }
238
+ },
239
+ [setCurrentPage, onSetrecord, items]
240
+ );
241
+ const handlePageChange = useCallback(
242
+ (page) => {
243
+ setCurrentPage(page);
244
+ if (isServerSidePagination && datasource && typeof datasource.invoke === "function") {
245
+ setIsLoadingMore(true);
246
+ const invokeResult = datasource.invoke({ page });
247
+ Promise.resolve(invokeResult).then(() => {
248
+ setWidgetPageIndex(widgetInstance, page);
249
+ onPaginationchange == null ? void 0 : onPaginationchange(null, widgetInstance, page);
250
+ onPageChange == null ? void 0 : onPageChange(null, page);
251
+ setIsLoadingMore(false);
252
+ }).catch((error) => {
253
+ console.error("Error loading page data:", error);
254
+ setIsLoadingMore(false);
255
+ setCurrentPage(currentPage);
256
+ });
257
+ } else {
258
+ setWidgetPageIndex(widgetInstance, page);
259
+ onPaginationchange == null ? void 0 : onPaginationchange(null, widgetInstance, page);
260
+ onPageChange == null ? void 0 : onPageChange(null, page);
261
+ }
262
+ },
263
+ [
264
+ setCurrentPage,
265
+ onPaginationchange,
266
+ onPageChange,
267
+ widgetInstance,
268
+ currentPage,
269
+ setIsLoadingMore,
270
+ isServerSidePagination,
271
+ datasource
272
+ ]
273
+ );
274
+ const handleLoadMore = useCallback(() => {
275
+ var _a;
255
276
  setIsLoadingMore(true);
256
- var pageSize = pagesize || 10;
257
- var nextPage;
258
-
259
- // For server-side pagination
277
+ const pageSize = pagesize || 10;
278
+ let nextPage;
260
279
  if (isServerSidePagination && datasource && typeof datasource.invoke === "function") {
261
- // For On-Demand navigation, use our tracked page state
262
- if (navigation === "On-Demand" && onDemandCurrentPage !== undefined) {
263
- // onDemandCurrentPage is 0-indexed (0 = page 1)
264
- // We need to load the next page: current + 1, then convert to 1-indexed for API
265
- var nextPageZeroIndexed = onDemandCurrentPage + 1;
266
- nextPage = nextPageZeroIndexed + 1; // Convert to 1-indexed for API
280
+ if (navigation === "On-Demand" && onDemandCurrentPage !== void 0) {
281
+ const nextPageZeroIndexed = onDemandCurrentPage + 1;
282
+ nextPage = nextPageZeroIndexed + 1;
267
283
  } else {
268
- var _datasource$paginatio;
269
- // For other navigation types, use pagination metadata
270
- var currentPageFromMeta = (_datasource$paginatio = datasource.pagination) === null || _datasource$paginatio === void 0 ? void 0 : _datasource$paginatio.number;
271
- if (currentPageFromMeta !== undefined) {
272
- // currentPageFromMeta is 0-indexed, add 2 to get next page for 1-indexed API
284
+ const currentPageFromMeta = (_a = datasource.pagination) == null ? void 0 : _a.number;
285
+ if (currentPageFromMeta !== void 0) {
273
286
  nextPage = currentPageFromMeta + 2;
274
287
  } else {
275
- // Fallback calculation
276
- var loadedItems = items.length;
277
- var _currentPage = Math.floor(loadedItems / pageSize);
278
- nextPage = _currentPage + 1;
288
+ const loadedItems = items.length;
289
+ const currentPage2 = Math.floor(loadedItems / pageSize);
290
+ nextPage = currentPage2 + 1;
279
291
  }
280
292
  }
281
-
282
- // Invoke the datasource for the next page
283
- // Wrap the result in Promise.resolve to handle cases where invoke doesn't return a Promise
284
- var invokeResult = datasource.invoke({
285
- page: nextPage
286
- });
287
- Promise.resolve(invokeResult).then(function () {
288
- // Update visible items to reflect the expected count
293
+ const invokeResult = datasource.invoke({ page: nextPage });
294
+ Promise.resolve(invokeResult).then(() => {
289
295
  setVisibleItems(visibleItems + pageSize);
290
-
291
- // For On-Demand, update the page state after successful load
292
296
  if (navigation === "On-Demand" && setOnDemandCurrentPage) {
293
- // Page has been loaded, update to the loaded page number (0-indexed)
294
297
  setOnDemandCurrentPage(onDemandCurrentPage + 1);
295
298
  }
296
299
  setIsLoadingMore(false);
297
- })["catch"](function (error) {
300
+ }).catch((error) => {
298
301
  console.error("Error loading more data:", error);
299
302
  setIsLoadingMore(false);
300
303
  });
301
304
  } else {
302
- // Client-side pagination
303
- var _currentPage2 = Math.floor(visibleItems / pageSize);
304
- nextPage = _currentPage2 + 1;
305
- setVisibleItems((0, _lodashEs.min)([visibleItems + pageSize, items.length]));
306
- setTimeout(function () {
305
+ const currentPage2 = Math.floor(visibleItems / pageSize);
306
+ nextPage = currentPage2 + 1;
307
+ setVisibleItems(min([visibleItems + pageSize, items.length]));
308
+ setTimeout(() => {
307
309
  setIsLoadingMore(false);
308
310
  }, 10);
309
311
  }
310
- onPageChange === null || onPageChange === void 0 || onPageChange(null, nextPage);
311
- }, [setIsLoadingMore, setVisibleItems, visibleItems, items.length, onPageChange, datasource, pagesize, navigation, onDemandCurrentPage, setOnDemandCurrentPage]);
312
+ onPageChange == null ? void 0 : onPageChange(null, nextPage);
313
+ }, [
314
+ setIsLoadingMore,
315
+ setVisibleItems,
316
+ visibleItems,
317
+ items.length,
318
+ onPageChange,
319
+ datasource,
320
+ pagesize,
321
+ navigation,
322
+ onDemandCurrentPage,
323
+ setOnDemandCurrentPage
324
+ ]);
312
325
  return {
313
- handleListItemClick: handleListItemClick,
314
- handleListItemDoubleClick: handleListItemDoubleClick,
315
- handleListItemMouseEnter: handleListItemMouseEnter,
316
- handleListItemMouseLeave: handleListItemMouseLeave,
317
- handleHeaderClick: handleHeaderClick,
318
- handlePaginationChange: handlePaginationChange,
319
- handleSetRecord: handleSetRecord,
320
- handlePageChange: handlePageChange,
321
- handleLoadMore: handleLoadMore
326
+ handleListItemClick,
327
+ handleListItemDoubleClick,
328
+ handleListItemMouseEnter,
329
+ handleListItemMouseLeave,
330
+ handleHeaderClick,
331
+ handlePaginationChange,
332
+ handleSetRecord,
333
+ handlePageChange,
334
+ handleLoadMore
322
335
  };
323
- };
336
+ };
337
+ export {
338
+ useListEventHandlers
339
+ };