@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,31 +1,41 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports.useTableEdit = void 0;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
12
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
13
- var _react = _interopRequireWildcard(require("react"));
14
- var _lodashEs = require("lodash-es");
15
- var _components = require("../components");
16
- var _AddNewRow = require("../components/AddNewRow");
17
- var _utils = require("../utils");
18
- var _useEditingState2 = require("./useEditingState");
19
- var _validation = require("../utils/validation");
20
- var _crudHandlers = require("../utils/crud-handlers");
21
- var _useEditedRows = require("./use-edited-rows");
22
- var _formContext = require("@wavemaker-ai/react-runtime/components/data/form/form-context");
23
- 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); }
24
- var __jsx = _react["default"].createElement;
25
- 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; }
26
- 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; }
27
- // Mode-specific behavior configurations
28
- var MODE_CONFIGS = {
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 { Fragment, jsx } from "react/jsx-runtime";
21
+ import { useCallback, useRef, useEffect } from "react";
22
+ import { find, forEach, entries, get, every } from "lodash-es";
23
+ import { EditableCell } from "../components";
24
+ import { AddNewRow } from "../components/AddNewRow";
25
+ import { validateEditingFields, TABLE_MESSAGES, INTERNAL_PROPERTIES } from "../utils";
26
+ import { useEditingState } from "./useEditingState";
27
+ import {
28
+ validateField,
29
+ resetValidationState as resetValidation,
30
+ updateValidationErrors
31
+ } from "../utils/validation";
32
+ import { handleServerOperation } from "../utils/crud-handlers";
33
+ import { useUpdateEditedCell, useEditedRowsContext } from "./use-edited-rows";
34
+ import {
35
+ useFormContext,
36
+ useParentFormData
37
+ } from "../../form/form-context";
38
+ const MODE_CONFIGS = {
29
39
  inline: {
30
40
  showNewRowFormByDefault: false,
31
41
  startEditOnRowClick: false,
@@ -57,595 +67,547 @@ var MODE_CONFIGS = {
57
67
  cancelsAddNewRowOnEdit: false
58
68
  }
59
69
  };
60
- var useTableEdit = exports.useTableEdit = function useTableEdit(_ref) {
61
- var _ref$editMode = _ref.editMode,
62
- editMode = _ref$editMode === void 0 ? "none" : _ref$editMode,
63
- internalDataset = _ref.internalDataset,
64
- setInternalDataset = _ref.setInternalDataset,
65
- wmTableColumns = _ref.wmTableColumns,
66
- cellState = _ref.cellState,
67
- renderFormWidget = _ref.renderFormWidget,
68
- listener = _ref.listener,
69
- onRowUpdate = _ref.onRowUpdate,
70
- onRowDelete = _ref.onRowDelete,
71
- onNewRowAdded = _ref.onNewRowAdded,
72
- _ref$showrowindex = _ref.showrowindex,
73
- showrowindex = _ref$showrowindex === void 0 ? false : _ref$showrowindex,
74
- _ref$radioselect = _ref.radioselect,
75
- radioselect = _ref$radioselect === void 0 ? false : _ref$radioselect,
76
- _ref$multiselect = _ref.multiselect,
77
- multiselect = _ref$multiselect === void 0 ? false : _ref$multiselect,
78
- _ref$rowActions = _ref.rowActions,
79
- rowActions = _ref$rowActions === void 0 ? [] : _ref$rowActions,
80
- _ref$formposition = _ref.formposition,
81
- formposition = _ref$formposition === void 0 ? "bottom" : _ref$formposition,
82
- _ref$insertmessage = _ref.insertmessage,
83
- insertmessage = _ref$insertmessage === void 0 ? _utils.TABLE_MESSAGES.insertSuccess : _ref$insertmessage,
84
- _ref$updatemessage = _ref.updatemessage,
85
- updatemessage = _ref$updatemessage === void 0 ? _utils.TABLE_MESSAGES.updateSuccess : _ref$updatemessage,
86
- _ref$errormessage = _ref.errormessage,
87
- errormessage = _ref$errormessage === void 0 ? _utils.TABLE_MESSAGES.operationError : _ref$errormessage,
88
- showToast = _ref.showToast,
89
- _ref$hasRowExpansion = _ref.hasRowExpansion,
90
- hasRowExpansion = _ref$hasRowExpansion === void 0 ? false : _ref$hasRowExpansion,
91
- _ref$expansionPositio = _ref.expansionPosition,
92
- expansionPosition = _ref$expansionPositio === void 0 ? 0 : _ref$expansionPositio,
93
- datasource = _ref.datasource,
94
- binddataset = _ref.binddataset,
95
- onSuccess = _ref.onSuccess,
96
- onError = _ref.onError,
97
- onRowinsert = _ref.onRowinsert,
98
- onRowupdate = _ref.onRowupdate,
99
- tableRef = _ref.tableRef,
100
- isServerSidePagination = _ref.isServerSidePagination,
101
- tableName = _ref.tableName;
102
- var updateCell = (0, _useEditedRows.useUpdateEditedCell)();
103
- var _useEditedRowsContext = (0, _useEditedRows.useEditedRowsContext)(),
104
- getEdits = _useEditedRowsContext.getEdits,
105
- removeRowEdits = _useEditedRowsContext.removeRowEdits;
106
- // Use the editing state hook
107
- var _useEditingState = (0, _useEditingState2.useEditingState)(),
108
- editingRowId = _useEditingState.editingRowId,
109
- isAddingNewRow = _useEditingState.isAddingNewRow,
110
- sessionKey = _useEditingState.sessionKey,
111
- editingRowDataRef = _useEditingState.editingRowDataRef,
112
- newRowDataRef = _useEditingState.newRowDataRef,
113
- setEditingRowId = _useEditingState.setEditingRowId,
114
- setIsAddingNewRow = _useEditingState.setIsAddingNewRow,
115
- incrementSessionKey = _useEditingState.incrementSessionKey,
116
- resetEditingData = _useEditingState.resetEditingData,
117
- isRowEditing = _useEditingState.isRowEditing;
118
-
119
- // Validation refs
120
- var formContext = (0, _formContext.useFormContext)();
121
- var updateFormData = formContext === null || formContext === void 0 ? void 0 : formContext.updateFormData;
122
- // Get parent form data context for proper data path resolution (used when table is inside a prefab)
123
- var parentFormDataContext = (0, _formContext.useParentFormData)();
124
- // Memoize the parent data path to avoid unnecessary re-renders
125
- // Use explicit undefined check (not falsy) to allow empty string as valid path
126
- var parentDataPath = (parentFormDataContext === null || parentFormDataContext === void 0 ? void 0 : parentFormDataContext.parentDataPath) !== undefined ? parentFormDataContext.parentDataPath : undefined;
127
- var fieldRefs = (0, _react.useRef)({});
128
- var fieldValidationErrorsRef = (0, _react.useRef)({});
129
- var cellUpdateCallbacksRef = (0, _react.useRef)({});
130
- var originalRowDataRef = (0, _react.useRef)({});
131
- var validationState = {
132
- fieldRefs: fieldRefs,
70
+ const useTableEdit = ({
71
+ editMode = "none",
72
+ internalDataset,
73
+ setInternalDataset,
74
+ wmTableColumns,
75
+ cellState,
76
+ renderFormWidget,
77
+ listener,
78
+ onRowUpdate,
79
+ onRowDelete,
80
+ onNewRowAdded,
81
+ showrowindex = false,
82
+ radioselect = false,
83
+ multiselect = false,
84
+ rowActions = [],
85
+ formposition = "bottom",
86
+ insertmessage = TABLE_MESSAGES.insertSuccess,
87
+ updatemessage = TABLE_MESSAGES.updateSuccess,
88
+ errormessage = TABLE_MESSAGES.operationError,
89
+ showToast,
90
+ hasRowExpansion = false,
91
+ expansionPosition = 0,
92
+ datasource,
93
+ binddataset,
94
+ onSuccess,
95
+ onError,
96
+ onRowinsert,
97
+ onRowupdate,
98
+ tableRef,
99
+ isServerSidePagination,
100
+ tableName
101
+ }) => {
102
+ const updateCell = useUpdateEditedCell();
103
+ const { getEdits, removeRowEdits } = useEditedRowsContext();
104
+ const {
105
+ editingRowId,
106
+ isAddingNewRow,
107
+ sessionKey,
108
+ editingRowDataRef,
109
+ newRowDataRef,
110
+ setEditingRowId,
111
+ setIsAddingNewRow,
112
+ incrementSessionKey,
113
+ resetEditingData,
114
+ isRowEditing
115
+ } = useEditingState();
116
+ const formContext = useFormContext();
117
+ const updateFormData = formContext == null ? void 0 : formContext.updateFormData;
118
+ const parentFormDataContext = useParentFormData();
119
+ const parentDataPath = (parentFormDataContext == null ? void 0 : parentFormDataContext.parentDataPath) !== void 0 ? parentFormDataContext.parentDataPath : void 0;
120
+ const fieldRefs = useRef({});
121
+ const fieldValidationErrorsRef = useRef({});
122
+ const cellUpdateCallbacksRef = useRef({});
123
+ const originalRowDataRef = useRef({});
124
+ const validationState = {
125
+ fieldRefs,
133
126
  fieldValidationErrors: fieldValidationErrorsRef,
134
127
  cellUpdateCallbacks: cellUpdateCallbacksRef
135
128
  };
136
-
137
- // Get mode configuration
138
- var config = MODE_CONFIGS[editMode] || MODE_CONFIGS.none;
139
-
140
- // Reset validation state wrapper
141
- var resetValidationState = (0, _react.useCallback)(function (context) {
142
- (0, _validation.resetValidationState)(context, editingRowId, validationState);
143
- }, [editingRowId]);
144
-
145
- // Set default new row form visibility based on mode
146
- (0, _react.useEffect)(function () {
129
+ const config = MODE_CONFIGS[editMode] || MODE_CONFIGS.none;
130
+ const resetValidationState = useCallback(
131
+ (context) => {
132
+ resetValidation(context, editingRowId, validationState);
133
+ },
134
+ [editingRowId]
135
+ );
136
+ useEffect(() => {
147
137
  setIsAddingNewRow(config.showNewRowFormByDefault);
148
138
  }, [editMode, config.showNewRowFormByDefault, setIsAddingNewRow]);
149
-
150
- // Start editing function
151
- var startEditing = (0, _react.useCallback)(function (rowData, rowId) {
152
- if (editMode === "none") {
153
- console.warn("Editing is not enabled. Set editmode to enable this feature.");
154
- return;
155
- }
156
- originalRowDataRef.current = _objectSpread({}, rowData);
157
-
158
- // Cancel add new row if configured for this mode
159
- if (config.cancelsAddNewRowOnEdit && isAddingNewRow) {
160
- setIsAddingNewRow(false);
161
- }
162
-
163
- // Reset editing data and start fresh
164
- resetEditingData();
165
- setEditingRowId(rowId);
166
-
167
- // Initialize with existing edits if available
168
- var existingEdits = getEdits(rowId) || {};
169
- editingRowDataRef.current = _objectSpread(_objectSpread({}, rowData), existingEdits);
170
- resetValidationState(editMode === "quickedit" ? "all" : undefined);
171
- incrementSessionKey();
172
- }, [editMode, config.cancelsAddNewRowOnEdit, isAddingNewRow, resetValidationState, setEditingRowId, setIsAddingNewRow, incrementSessionKey, resetEditingData, getEdits]);
173
-
174
- // Cancel editing function
175
- var cancelEditing = (0, _react.useCallback)(function () {
176
- // Clear persisted edits for this row if we are cancelling
139
+ const startEditing = useCallback(
140
+ (rowData, rowId) => {
141
+ if (editMode === "none") {
142
+ console.warn("Editing is not enabled. Set editmode to enable this feature.");
143
+ return;
144
+ }
145
+ originalRowDataRef.current = __spreadValues({}, rowData);
146
+ if (config.cancelsAddNewRowOnEdit && isAddingNewRow) {
147
+ setIsAddingNewRow(false);
148
+ }
149
+ resetEditingData();
150
+ setEditingRowId(rowId);
151
+ const existingEdits = getEdits(rowId) || {};
152
+ editingRowDataRef.current = __spreadValues(__spreadValues({}, rowData), existingEdits);
153
+ resetValidationState(editMode === "quickedit" ? "all" : void 0);
154
+ incrementSessionKey();
155
+ },
156
+ [
157
+ editMode,
158
+ config.cancelsAddNewRowOnEdit,
159
+ isAddingNewRow,
160
+ resetValidationState,
161
+ setEditingRowId,
162
+ setIsAddingNewRow,
163
+ incrementSessionKey,
164
+ resetEditingData,
165
+ getEdits
166
+ ]
167
+ );
168
+ const cancelEditing = useCallback(() => {
177
169
  if (editingRowId) {
178
170
  removeRowEdits(editingRowId);
179
- // Also clear cellState if it exists
180
171
  if (cellState) {
181
- // Note: cellState doesn't have a clearRow method exposed easily here without path iteration.
182
- // But removeRowEdits handles the EditedRowsContext which drives the view.
183
- // Ideally we should clear cellState too, but let's focus on the visual consistency first.
184
172
  }
185
173
  }
186
174
  setEditingRowId(null);
187
-
188
- // For inline mode, also cancel add new row and clear refs
189
175
  if (editMode === "inline") {
190
176
  setIsAddingNewRow(false);
191
- // Clear the editing data ref to ensure no old values persist
192
177
  editingRowDataRef.current = {};
193
178
  }
194
179
  resetEditingData();
195
-
196
- // Reset validation based on mode
197
- resetValidationState(editMode === "quickedit" ? "all" : undefined);
180
+ resetValidationState(editMode === "quickedit" ? "all" : void 0);
198
181
  incrementSessionKey();
199
- }, [editMode, editingRowId, resetValidationState, setEditingRowId, setIsAddingNewRow, incrementSessionKey, resetEditingData, removeRowEdits, cellState]);
200
-
201
- // Generic save function that works for both edit modes
202
- var saveEditingInternal = (0, _react.useCallback)(/*#__PURE__*/function () {
203
- var _ref2 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(rowId, isNewRow, rowDataRef, onSaveSuccess) {
204
- var currentRowId, activeElement, editableCellContainer, fieldName, inputValue, currentEditingData, originalData, hasChanges, relevantFieldRefs, validationResult, result;
205
- return _regenerator["default"].wrap(function _callee$(_context) {
206
- while (1) switch (_context.prev = _context.next) {
207
- case 0:
208
- currentRowId = rowId || (isNewRow ? "new-row" : null);
209
- if (currentRowId) {
210
- _context.next = 3;
211
- break;
212
- }
213
- return _context.abrupt("return", Promise.resolve(false));
214
- case 3:
215
- // Capture value from active input element BEFORE blur
216
- // This is needed because inputs use updateon="blur" and save triggers on mousedown (before blur)
217
- // The blur event handler runs async, so we need to read the DOM value directly
218
- activeElement = document.activeElement;
219
- if (activeElement) {
220
- // Get the field name from the closest editable cell container
221
- editableCellContainer = activeElement.closest("[data-field-name]");
222
- if (editableCellContainer) {
223
- fieldName = editableCellContainer.getAttribute("data-field-name");
224
- inputValue = activeElement.value; // Update editingRowDataRef with the current DOM value
225
- if (fieldName && inputValue !== undefined) {
226
- rowDataRef.current = _objectSpread(_objectSpread({}, rowDataRef.current), {}, (0, _defineProperty2["default"])({}, fieldName, inputValue));
227
- }
228
- }
229
-
230
- // Now blur to clean up focus state
231
- if (activeElement.blur) {
232
- activeElement.blur();
233
- }
234
- }
235
-
236
- // Get current editing data
237
- currentEditingData = rowDataRef.current;
238
- originalData = originalRowDataRef.current; // Check if any changes were made (only for existing rows, not new rows)
239
- if (!(!isNewRow && originalData && currentEditingData)) {
240
- _context.next = 13;
241
- break;
242
- }
243
- hasChanges = wmTableColumns.some(function (column) {
244
- if (!column.field || column.readonly) return false;
245
- var originalValue = (0, _lodashEs.get)(originalData, column.field);
246
- var currentValue = (0, _lodashEs.get)(currentEditingData, column.field);
247
- // Compare stringified values to handle type differences
248
- return String(originalValue !== null && originalValue !== void 0 ? originalValue : "") !== String(currentValue !== null && currentValue !== void 0 ? currentValue : "");
182
+ }, [
183
+ editMode,
184
+ editingRowId,
185
+ resetValidationState,
186
+ setEditingRowId,
187
+ setIsAddingNewRow,
188
+ incrementSessionKey,
189
+ resetEditingData,
190
+ removeRowEdits,
191
+ cellState
192
+ ]);
193
+ const saveEditingInternal = useCallback(
194
+ async (rowId, isNewRow, rowDataRef, onSaveSuccess) => {
195
+ const currentRowId = rowId || (isNewRow ? "new-row" : null);
196
+ if (!currentRowId) return Promise.resolve(false);
197
+ const activeElement = document.activeElement;
198
+ if (activeElement) {
199
+ const editableCellContainer = activeElement.closest("[data-field-name]");
200
+ if (editableCellContainer) {
201
+ const fieldName = editableCellContainer.getAttribute("data-field-name");
202
+ const inputValue = activeElement.value;
203
+ if (fieldName && inputValue !== void 0) {
204
+ rowDataRef.current = __spreadProps(__spreadValues({}, rowDataRef.current), {
205
+ [fieldName]: inputValue
249
206
  });
250
- if (hasChanges) {
251
- _context.next = 13;
252
- break;
253
- }
254
- showToast === null || showToast === void 0 || showToast("No changes detected", "Info");
255
- // Still close edit mode even if no changes - call onSaveSuccess to reset state
256
- if (onSaveSuccess) {
257
- if (rowId) {
258
- removeRowEdits(rowId);
259
- }
260
- onSaveSuccess();
261
- }
262
- return _context.abrupt("return", true);
263
- case 13:
264
- // Filter field refs to only include fields for the current row
265
- relevantFieldRefs = {};
266
- (0, _lodashEs.forEach)((0, _lodashEs.entries)(fieldRefs.current), function (_ref3) {
267
- var _ref4 = (0, _slicedToArray2["default"])(_ref3, 2),
268
- fieldKey = _ref4[0],
269
- fieldElement = _ref4[1];
270
- if (fieldKey.startsWith("".concat(currentRowId, "_"))) {
271
- relevantFieldRefs[fieldKey] = fieldElement;
272
- }
273
- });
274
-
275
- // Validate only the relevant fields
276
- validationResult = (0, _utils.validateEditingFields)(relevantFieldRefs, currentRowId);
277
- if (validationResult.isValid) {
278
- _context.next = 19;
279
- break;
280
- }
281
- (0, _validation.updateValidationErrors)(validationResult, relevantFieldRefs, validationState);
282
- return _context.abrupt("return", false);
283
- case 19:
284
- _context.next = 21;
285
- return (0, _crudHandlers.handleServerOperation)({
286
- isNewRow: isNewRow,
287
- rowId: rowId,
288
- currentEditingData: currentEditingData,
289
- wmTableColumns: wmTableColumns,
290
- datasource: datasource,
291
- binddataset: binddataset,
292
- setInternalDataset: setInternalDataset,
293
- onNewRowAdded: onNewRowAdded,
294
- onRowUpdate: onRowUpdate,
295
- showToast: showToast,
296
- onSuccess: onSuccess,
297
- onError: onError,
298
- onRowinsert: onRowinsert,
299
- onRowupdate: onRowupdate,
300
- insertmessage: insertmessage,
301
- updatemessage: updatemessage,
302
- errormessage: errormessage,
303
- tableInstance: tableRef === null || tableRef === void 0 ? void 0 : tableRef.current,
304
- isServerSidePagination: isServerSidePagination,
305
- listener: listener,
306
- widgetName: tableName
307
- });
308
- case 21:
309
- result = _context.sent;
310
- if (result) {
311
- _context.next = 24;
312
- break;
313
- }
314
- return _context.abrupt("return", false);
315
- case 24:
316
- if (updateFormData && tableName) {
317
- // Sync the complete array to parent form using functional updater for latest state
318
- setInternalDataset(function (currentDataset) {
319
- // Use parentDataPath (from ParentFormDataContext) when table is inside a prefab with parent form
320
- // This ensures the table data is stored under the prefab's name (e.g., "employees")
321
- // rather than the table's name (e.g., "EmployeeInfoTable1")
322
- // Use explicit undefined check to allow empty string as valid (though unlikely) path
323
- var tableKey = parentDataPath !== undefined && parentDataPath !== "" ? parentDataPath : tableName;
324
-
325
- // Clean and filter the dataset
326
- var cleanedDataset = currentDataset.map(function (row) {
327
- // Remove all internal properties from each row using centralized constant
328
- var cleanRow = _objectSpread({}, row);
329
- _utils.INTERNAL_PROPERTIES.forEach(function (prop) {
330
- return delete cleanRow[prop];
331
- });
332
- return cleanRow;
333
- }).filter(function (row) {
334
- // Filter out empty rows - check if row has at least one meaningful value
335
- var hasData = Object.entries(row).some(function (_ref5) {
336
- var _ref6 = (0, _slicedToArray2["default"])(_ref5, 2),
337
- _ = _ref6[0],
338
- value = _ref6[1];
339
- return value !== null && value !== undefined && value !== "";
340
- });
341
- return hasData;
342
- });
343
-
344
- // Update parent form with cleaned data (without internal properties)
345
- updateFormData((0, _defineProperty2["default"])({}, tableKey, cleanedDataset));
346
-
347
- // Return the original dataset unchanged (internal properties needed for table functionality)
348
- return currentDataset;
349
- });
350
- }
351
- if (onSaveSuccess) {
352
- // CLEAR EDITS ON SUCCESS
353
- if (rowId) {
354
- removeRowEdits(rowId);
355
- }
356
- onSaveSuccess();
207
+ }
208
+ }
209
+ if (activeElement.blur) {
210
+ activeElement.blur();
211
+ }
212
+ }
213
+ const currentEditingData = rowDataRef.current;
214
+ const originalData = originalRowDataRef.current;
215
+ if (!isNewRow && originalData && currentEditingData) {
216
+ const hasChanges = wmTableColumns.some((column) => {
217
+ if (!column.field || column.readonly) return false;
218
+ const originalValue = get(originalData, column.field);
219
+ const currentValue = get(currentEditingData, column.field);
220
+ return String(originalValue != null ? originalValue : "") !== String(currentValue != null ? currentValue : "");
221
+ });
222
+ if (!hasChanges) {
223
+ showToast == null ? void 0 : showToast("No changes detected", "Info");
224
+ if (onSaveSuccess) {
225
+ if (rowId) {
226
+ removeRowEdits(rowId);
357
227
  }
358
- return _context.abrupt("return", true);
359
- case 27:
360
- case "end":
361
- return _context.stop();
228
+ onSaveSuccess();
229
+ }
230
+ return true;
362
231
  }
363
- }, _callee);
364
- }));
365
- return function (_x, _x2, _x3, _x4) {
366
- return _ref2.apply(this, arguments);
367
- };
368
- }(), [internalDataset, wmTableColumns, datasource, binddataset, setInternalDataset, onNewRowAdded, onRowUpdate, showToast, onSuccess, onError, onRowinsert, onRowupdate, insertmessage, updatemessage, errormessage, removeRowEdits, updateFormData, tableName, parentDataPath]);
369
-
370
- // Save editing function
371
- var saveEditing = (0, _react.useCallback)(/*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
372
- var isNewRow, rowId, dataRef, success;
373
- return _regenerator["default"].wrap(function _callee2$(_context2) {
374
- while (1) switch (_context2.prev = _context2.next) {
375
- case 0:
376
- isNewRow = editMode === "inline" ? isAddingNewRow : false;
377
- rowId = editingRowId || (isNewRow ? "new-row" : null);
378
- dataRef = editMode === "quickedit" && !editingRowId ? newRowDataRef : editingRowDataRef;
379
- _context2.next = 5;
380
- return saveEditingInternal(rowId, isNewRow, dataRef, function () {
381
- // Reset editing state
382
- setEditingRowId(null);
383
-
384
- // For inline mode, reset add new row and clear the ref completely
385
- if (editMode === "inline") {
386
- setIsAddingNewRow(false);
387
- // Clear the editing data ref to ensure no old values persist
388
- editingRowDataRef.current = {};
232
+ }
233
+ const relevantFieldRefs = {};
234
+ forEach(entries(fieldRefs.current), ([fieldKey, fieldElement]) => {
235
+ if (fieldKey.startsWith(`${currentRowId}_`)) {
236
+ relevantFieldRefs[fieldKey] = fieldElement;
237
+ }
238
+ });
239
+ const validationResult = validateEditingFields(relevantFieldRefs, currentRowId);
240
+ if (!validationResult.isValid) {
241
+ updateValidationErrors(validationResult, relevantFieldRefs, validationState);
242
+ return false;
243
+ }
244
+ const result = await handleServerOperation({
245
+ isNewRow,
246
+ rowId,
247
+ currentEditingData,
248
+ wmTableColumns,
249
+ datasource,
250
+ binddataset,
251
+ setInternalDataset,
252
+ onNewRowAdded,
253
+ onRowUpdate,
254
+ showToast,
255
+ onSuccess,
256
+ onError,
257
+ onRowinsert,
258
+ onRowupdate,
259
+ insertmessage,
260
+ updatemessage,
261
+ errormessage,
262
+ tableInstance: tableRef == null ? void 0 : tableRef.current,
263
+ isServerSidePagination,
264
+ listener,
265
+ widgetName: tableName
266
+ });
267
+ if (!result) return false;
268
+ if (updateFormData && tableName) {
269
+ setInternalDataset((currentDataset) => {
270
+ const tableKey = parentDataPath !== void 0 && parentDataPath !== "" ? parentDataPath : tableName;
271
+ const cleanedDataset = currentDataset.map((row) => {
272
+ const cleanRow = __spreadValues({}, row);
273
+ INTERNAL_PROPERTIES.forEach((prop) => delete cleanRow[prop]);
274
+ return cleanRow;
275
+ }).filter((row) => {
276
+ const hasData = Object.entries(row).some(
277
+ ([_, value]) => value !== null && value !== void 0 && value !== ""
278
+ );
279
+ return hasData;
280
+ });
281
+ updateFormData({ [tableKey]: cleanedDataset });
282
+ return currentDataset;
283
+ });
284
+ }
285
+ if (onSaveSuccess) {
286
+ if (rowId) {
287
+ removeRowEdits(rowId);
288
+ }
289
+ onSaveSuccess();
290
+ }
291
+ return true;
292
+ },
293
+ [
294
+ internalDataset,
295
+ wmTableColumns,
296
+ datasource,
297
+ binddataset,
298
+ setInternalDataset,
299
+ onNewRowAdded,
300
+ onRowUpdate,
301
+ showToast,
302
+ onSuccess,
303
+ onError,
304
+ onRowinsert,
305
+ onRowupdate,
306
+ insertmessage,
307
+ updatemessage,
308
+ errormessage,
309
+ removeRowEdits,
310
+ updateFormData,
311
+ tableName,
312
+ parentDataPath
313
+ ]
314
+ );
315
+ const saveEditing = useCallback(async () => {
316
+ const isNewRow = editMode === "inline" ? isAddingNewRow : false;
317
+ const rowId = editingRowId || (isNewRow ? "new-row" : null);
318
+ const dataRef = editMode === "quickedit" && !editingRowId ? newRowDataRef : editingRowDataRef;
319
+ const success = await saveEditingInternal(rowId, isNewRow, dataRef, () => {
320
+ setEditingRowId(null);
321
+ if (editMode === "inline") {
322
+ setIsAddingNewRow(false);
323
+ editingRowDataRef.current = {};
324
+ }
325
+ resetEditingData();
326
+ resetValidationState(
327
+ editMode === "quickedit" ? editingRowId ? "editing" : "new-row" : void 0
328
+ );
329
+ incrementSessionKey();
330
+ });
331
+ return success;
332
+ }, [
333
+ editMode,
334
+ editingRowId,
335
+ isAddingNewRow,
336
+ resetEditingData,
337
+ resetValidationState,
338
+ setEditingRowId,
339
+ setIsAddingNewRow,
340
+ incrementSessionKey,
341
+ saveEditingInternal
342
+ ]);
343
+ const updateFieldValue = useCallback(
344
+ (fieldName, newValue, rowId) => {
345
+ const effectiveRowId = rowId || editingRowId || "new-row";
346
+ if (cellState && effectiveRowId !== "new-row") {
347
+ cellState.setValue(["cells", effectiveRowId, fieldName], newValue);
348
+ updateCell(effectiveRowId, fieldName, newValue);
349
+ }
350
+ if (editMode === "quickedit" && String(effectiveRowId) !== "new-row") {
351
+ setInternalDataset((prev) => {
352
+ return prev.map((row) => {
353
+ if ((row._wmTableRowId || row.id) === effectiveRowId) {
354
+ return __spreadProps(__spreadValues({}, row), { [fieldName]: newValue });
389
355
  }
390
- resetEditingData();
391
-
392
- // Reset validation based on context
393
- resetValidationState(editMode === "quickedit" ? editingRowId ? "editing" : "new-row" : undefined);
394
- incrementSessionKey();
356
+ return row;
395
357
  });
396
- case 5:
397
- success = _context2.sent;
398
- return _context2.abrupt("return", success);
399
- case 7:
400
- case "end":
401
- return _context2.stop();
358
+ });
402
359
  }
403
- }, _callee2);
404
- })), [editMode, editingRowId, isAddingNewRow, resetEditingData, resetValidationState, setEditingRowId, setIsAddingNewRow, incrementSessionKey, saveEditingInternal]);
405
-
406
- // Update field value function
407
- var updateFieldValue = (0, _react.useCallback)(function (fieldName, newValue, rowId) {
408
- // Determine the actual row ID from the passed parameter or context
409
- var effectiveRowId = rowId || editingRowId || "new-row";
410
-
411
- // Update cellState if available (for tracking changes without re-renders)
412
- if (cellState && effectiveRowId !== "new-row") {
413
- cellState.setValue(["cells", effectiveRowId, fieldName], newValue);
414
- updateCell(effectiveRowId, fieldName, newValue);
415
- }
416
-
417
- // FIX: Only update internalDataset for quickedit mode (real-time updates needed)
418
- // For inline mode, skip this to avoid re-renders - dataset will be updated on save
419
- if (editMode === "quickedit" && String(effectiveRowId) !== "new-row") {
420
- setInternalDataset(function (prev) {
421
- return prev.map(function (row) {
422
- // Match by ID
423
- if ((row._wmTableRowId || row.id) === effectiveRowId) {
424
- return _objectSpread(_objectSpread({}, row), {}, (0, _defineProperty2["default"])({}, fieldName, newValue));
425
- }
426
- return row;
360
+ if (editMode === "quickedit" && effectiveRowId === "new-row") {
361
+ newRowDataRef.current = __spreadProps(__spreadValues({}, newRowDataRef.current), {
362
+ [fieldName]: newValue
427
363
  });
428
- });
429
- }
430
-
431
- // In quickedit mode, check if this update is for the new row
432
- if (editMode === "quickedit" && effectiveRowId === "new-row") {
433
- // For quickedit new row, update newRowDataRef
434
- newRowDataRef.current = _objectSpread(_objectSpread({}, newRowDataRef.current), {}, (0, _defineProperty2["default"])({}, fieldName, newValue));
435
- var column = (0, _lodashEs.find)(wmTableColumns, function (col) {
436
- return col.field === fieldName;
437
- });
438
- (0, _validation.validateField)("new-row", fieldName, newValue, column, validationState);
439
- } else {
440
- // For all other cases (including editing existing rows), update editingRowDataRef
441
- editingRowDataRef.current = _objectSpread(_objectSpread({}, editingRowDataRef.current), {}, (0, _defineProperty2["default"])({}, fieldName, newValue));
442
- var _column = (0, _lodashEs.find)(wmTableColumns, function (col) {
443
- return col.field === fieldName;
444
- });
445
- (0, _validation.validateField)(effectiveRowId, fieldName, newValue, _column, validationState);
446
- }
447
- }, [editMode, editingRowId, wmTableColumns, cellState, setInternalDataset]);
448
-
449
- // Save new row (for quickedit mode)
450
- var saveNewRow = (0, _react.useCallback)(function () {
451
- var success = saveEditingInternal(null, true, newRowDataRef, function () {
364
+ const column = find(wmTableColumns, (col) => col.field === fieldName);
365
+ validateField("new-row", fieldName, newValue, column, validationState);
366
+ } else {
367
+ editingRowDataRef.current = __spreadProps(__spreadValues({}, editingRowDataRef.current), {
368
+ [fieldName]: newValue
369
+ });
370
+ const column = find(wmTableColumns, (col) => col.field === fieldName);
371
+ validateField(effectiveRowId, fieldName, newValue, column, validationState);
372
+ }
373
+ },
374
+ [editMode, editingRowId, wmTableColumns, cellState, setInternalDataset]
375
+ );
376
+ const saveNewRow = useCallback(() => {
377
+ const success = saveEditingInternal(null, true, newRowDataRef, () => {
452
378
  newRowDataRef.current = {};
453
379
  resetValidationState("new-row");
454
380
  incrementSessionKey();
455
381
  });
456
382
  return success;
457
383
  }, [resetValidationState, incrementSessionKey, saveEditingInternal]);
458
-
459
- // Handle keyboard events (for modes that support it)
460
- var handleKeyDown = (0, _react.useCallback)(function (e, sourceRowId) {
461
- // Handle Enter key for inline mode as well (not just quickedit)
462
- if (editMode === "inline" && e.key === "Enter" && !e.shiftKey) {
463
- e.preventDefault();
464
- e.stopPropagation();
465
- saveEditing();
466
- return;
467
- }
468
-
469
- // Handle Escape key for inline mode
470
- if (editMode === "inline" && e.key === "Escape") {
471
- e.preventDefault();
472
- e.stopPropagation();
473
- cancelEditing();
474
- return;
475
- }
476
- if (!config.hasKeyboardNavigation || editMode !== "quickedit") return;
477
-
478
- // Determine if the event is from the new row
479
- var isFromNewRow = sourceRowId === "new-row";
480
- var isEditingRow = editingRowId !== null && !isFromNewRow;
481
- if (e.key === "Enter" && !e.shiftKey) {
482
- e.preventDefault();
483
- e.stopPropagation();
484
- isFromNewRow ? saveNewRow() : saveEditing();
485
- } else if (e.key === "Escape") {
486
- e.preventDefault();
487
- e.stopPropagation();
488
- if (isFromNewRow) {
489
- newRowDataRef.current = {};
490
- resetValidationState("new-row");
491
- incrementSessionKey();
492
- } else if (isEditingRow) {
384
+ const handleKeyDown = useCallback(
385
+ (e, sourceRowId) => {
386
+ if (editMode === "inline" && e.key === "Enter" && !e.shiftKey) {
387
+ e.preventDefault();
388
+ e.stopPropagation();
389
+ saveEditing();
390
+ return;
391
+ }
392
+ if (editMode === "inline" && e.key === "Escape") {
393
+ e.preventDefault();
394
+ e.stopPropagation();
493
395
  cancelEditing();
396
+ return;
494
397
  }
495
- }
496
- }, [config.hasKeyboardNavigation, editMode, editingRowId, saveNewRow, saveEditing, cancelEditing, resetValidationState, incrementSessionKey]);
497
-
498
- // Render editable cell
499
- var renderEditableCell = (0, _react.useCallback)(function (column, rowData, rowId) {
500
- var isEditing = isRowEditing(rowId);
501
- var fieldName = String(column.field || "");
502
- var widgetType = String(column.editWidgetType || "WmText");
503
- if (isEditing && editMode !== "none") {
504
- var editValue = (0, _lodashEs.get)(editingRowDataRef.current, fieldName) !== undefined ? (0, _lodashEs.get)(editingRowDataRef.current, fieldName) : (0, _lodashEs.get)(rowData, fieldName);
505
- return __jsx(_components.EditableCell, {
506
- key: "edit-cell-".concat(fieldName, "-").concat(sessionKey),
507
- column: column,
508
- rowData: rowData,
509
- rowId: rowId,
510
- fieldName: fieldName,
511
- widgetType: widgetType,
512
- editValue: editValue,
513
- fieldValidationErrorsRef: fieldValidationErrorsRef,
514
- cellUpdateCallbacksRef: cellUpdateCallbacksRef,
515
- fieldRefs: fieldRefs,
516
- renderFormWidget: renderFormWidget,
517
- updateFieldValue: updateFieldValue,
518
- sessionKey: sessionKey,
519
- onKeyDown:
520
- // FIX: Pass onKeyDown for both inline and quickedit modes
521
- // Inline mode now supports Enter/Escape keys
522
- editMode === "inline" || config.hasKeyboardNavigation ? function (e) {
523
- return handleKeyDown(e, rowId);
524
- } : undefined,
525
- editMode: editMode
526
- });
527
- }
528
- return __jsx(_react["default"].Fragment, null);
529
- }, [isRowEditing, editMode, renderFormWidget, updateFieldValue, sessionKey, handleKeyDown, config.hasKeyboardNavigation]);
530
-
531
- // Handle row click
532
- var handleRowClick = (0, _react.useCallback)(function (rowData, rowId) {
533
- if (!config.startEditOnRowClick) return;
534
-
535
- // If not editing this row, start editing
536
- if (!isRowEditing(rowId) && (editMode === "quickedit" || editMode === "inline" ? (0, _lodashEs.every)(validationState.fieldValidationErrors.current, function (error) {
537
- return error === false;
538
- }) : true)) {
539
- startEditing(rowData, rowId);
540
- }
541
- }, [config.startEditOnRowClick, isRowEditing, startEditing]);
542
-
543
- // Handle add new row click
544
- var handleAddNewRowClick = (0, _react.useCallback)(function () {
398
+ if (!config.hasKeyboardNavigation || editMode !== "quickedit") return;
399
+ const isFromNewRow = sourceRowId === "new-row";
400
+ const isEditingRow = editingRowId !== null && !isFromNewRow;
401
+ if (e.key === "Enter" && !e.shiftKey) {
402
+ e.preventDefault();
403
+ e.stopPropagation();
404
+ isFromNewRow ? saveNewRow() : saveEditing();
405
+ } else if (e.key === "Escape") {
406
+ e.preventDefault();
407
+ e.stopPropagation();
408
+ if (isFromNewRow) {
409
+ newRowDataRef.current = {};
410
+ resetValidationState("new-row");
411
+ incrementSessionKey();
412
+ } else if (isEditingRow) {
413
+ cancelEditing();
414
+ }
415
+ }
416
+ },
417
+ [
418
+ config.hasKeyboardNavigation,
419
+ editMode,
420
+ editingRowId,
421
+ saveNewRow,
422
+ saveEditing,
423
+ cancelEditing,
424
+ resetValidationState,
425
+ incrementSessionKey
426
+ ]
427
+ );
428
+ const renderEditableCell = useCallback(
429
+ (column, rowData, rowId) => {
430
+ const isEditing = isRowEditing(rowId);
431
+ const fieldName = String(column.field || "");
432
+ const widgetType = String(column.editWidgetType || "WmText");
433
+ if (isEditing && editMode !== "none") {
434
+ const editValue = get(editingRowDataRef.current, fieldName) !== void 0 ? get(editingRowDataRef.current, fieldName) : get(rowData, fieldName);
435
+ return /* @__PURE__ */ jsx(
436
+ EditableCell,
437
+ {
438
+ column,
439
+ rowData,
440
+ rowId,
441
+ fieldName,
442
+ widgetType,
443
+ editValue,
444
+ fieldValidationErrorsRef,
445
+ cellUpdateCallbacksRef,
446
+ fieldRefs,
447
+ renderFormWidget,
448
+ updateFieldValue,
449
+ sessionKey,
450
+ onKeyDown: (
451
+ // FIX: Pass onKeyDown for both inline and quickedit modes
452
+ // Inline mode now supports Enter/Escape keys
453
+ editMode === "inline" || config.hasKeyboardNavigation ? (e) => handleKeyDown(e, rowId) : void 0
454
+ ),
455
+ editMode
456
+ },
457
+ `edit-cell-${fieldName}-${sessionKey}`
458
+ );
459
+ }
460
+ return /* @__PURE__ */ jsx(Fragment, {});
461
+ },
462
+ [
463
+ isRowEditing,
464
+ editMode,
465
+ renderFormWidget,
466
+ updateFieldValue,
467
+ sessionKey,
468
+ handleKeyDown,
469
+ config.hasKeyboardNavigation
470
+ ]
471
+ );
472
+ const handleRowClick = useCallback(
473
+ (rowData, rowId) => {
474
+ if (!config.startEditOnRowClick) return;
475
+ if (!isRowEditing(rowId) && (editMode === "quickedit" || editMode === "inline" ? every(validationState.fieldValidationErrors.current, (error) => error === false) : true)) {
476
+ startEditing(rowData, rowId);
477
+ }
478
+ },
479
+ [config.startEditOnRowClick, isRowEditing, startEditing]
480
+ );
481
+ const handleAddNewRowClick = useCallback(() => {
545
482
  if (editMode !== "inline") {
546
483
  console.warn("Add new row is not available for this edit mode.");
547
484
  return;
548
485
  }
549
-
550
- // Cancel any existing editing
551
486
  if (editingRowId) {
552
487
  setEditingRowId(null);
553
488
  }
554
-
555
- // If already adding a new row, reset everything first
556
489
  if (isAddingNewRow) {
557
490
  setIsAddingNewRow(false);
558
491
  resetEditingData();
559
492
  resetValidationState();
560
493
  }
561
-
562
- // Initialize with default values
563
- var initialData = {};
564
- wmTableColumns.forEach(function (column) {
565
- if (column.defaultvalue !== undefined && column.defaultvalue !== null && column.defaultvalue !== "") {
494
+ const initialData = {};
495
+ wmTableColumns.forEach((column) => {
496
+ if (column.defaultvalue !== void 0 && column.defaultvalue !== null && column.defaultvalue !== "") {
566
497
  initialData[column.field] = column.defaultvalue;
567
498
  }
568
499
  });
569
-
570
- // Start new row operation
571
500
  setIsAddingNewRow(true);
572
501
  editingRowDataRef.current = initialData;
573
502
  resetValidationState();
574
503
  incrementSessionKey();
575
- }, [editMode, editingRowId, isAddingNewRow, wmTableColumns, resetValidationState, setEditingRowId, setIsAddingNewRow, incrementSessionKey, resetEditingData]);
576
-
577
- // Render add new row
578
- var renderAddNewRow = (0, _react.useCallback)(function () {
579
- var shouldShowNewRow = editMode === "inline" && isAddingNewRow || editMode === "quickedit" && config.showNewRowFormByDefault;
504
+ }, [
505
+ editMode,
506
+ editingRowId,
507
+ isAddingNewRow,
508
+ wmTableColumns,
509
+ resetValidationState,
510
+ setEditingRowId,
511
+ setIsAddingNewRow,
512
+ incrementSessionKey,
513
+ resetEditingData
514
+ ]);
515
+ const renderAddNewRow = useCallback(() => {
516
+ const shouldShowNewRow = editMode === "inline" && isAddingNewRow || editMode === "quickedit" && config.showNewRowFormByDefault;
580
517
  if (!shouldShowNewRow) return null;
581
-
582
- // Determine which data ref to use
583
- var dataRef = editMode === "quickedit" ? newRowDataRef : editingRowDataRef;
584
- var onKeyDownHandler = config.hasKeyboardNavigation ? function (e) {
585
- return handleKeyDown(e, "new-row");
586
- } : undefined;
587
-
588
- // Wrapper function to render EditableCell
589
- var renderCell = function renderCell(column, fieldName, widgetType, editValue, rowId) {
590
- return __jsx(_components.EditableCell, {
591
- key: "new-row-cell-".concat(fieldName, "-").concat(sessionKey),
592
- column: column,
593
- rowData: {},
594
- rowId: rowId,
595
- fieldName: fieldName,
596
- widgetType: widgetType,
597
- editValue: editValue,
598
- fieldValidationErrorsRef: fieldValidationErrorsRef,
599
- cellUpdateCallbacksRef: cellUpdateCallbacksRef,
600
- fieldRefs: fieldRefs,
601
- renderFormWidget: renderFormWidget,
602
- updateFieldValue: updateFieldValue,
603
- sessionKey: sessionKey,
604
- onKeyDown: onKeyDownHandler,
605
- editMode: editMode
606
- });
518
+ const dataRef = editMode === "quickedit" ? newRowDataRef : editingRowDataRef;
519
+ const onKeyDownHandler = config.hasKeyboardNavigation ? (e) => handleKeyDown(e, "new-row") : void 0;
520
+ const renderCell = (column, fieldName, widgetType, editValue, rowId) => {
521
+ return /* @__PURE__ */ jsx(
522
+ EditableCell,
523
+ {
524
+ column,
525
+ rowData: {},
526
+ rowId,
527
+ fieldName,
528
+ widgetType,
529
+ editValue,
530
+ fieldValidationErrorsRef,
531
+ cellUpdateCallbacksRef,
532
+ fieldRefs,
533
+ renderFormWidget,
534
+ updateFieldValue,
535
+ sessionKey,
536
+ onKeyDown: onKeyDownHandler,
537
+ editMode
538
+ },
539
+ `new-row-cell-${fieldName}-${sessionKey}`
540
+ );
607
541
  };
608
- return __jsx(_AddNewRow.AddNewRow, {
609
- isAddingNewRow: true,
610
- editMode: editMode,
611
- wmTableColumns: wmTableColumns,
612
- rowActions: rowActions,
613
- showrowindex: showrowindex,
614
- radioselect: radioselect,
615
- multiselect: multiselect,
616
- sessionKey: sessionKey,
617
- editingRowData: dataRef.current,
618
- renderEditableCell: renderCell,
619
- onKeyDown: onKeyDownHandler,
620
- handleSave: editMode === "quickedit" ? saveNewRow : saveEditing,
621
- handleCancel: function handleCancel() {
622
- if (editMode === "quickedit") {
623
- newRowDataRef.current = {};
624
- resetValidationState("new-row");
625
- incrementSessionKey();
626
- } else {
627
- cancelEditing();
628
- }
629
- },
630
- listener: listener,
631
- hasRowExpansion: hasRowExpansion,
632
- expansionPosition: expansionPosition
633
- });
634
- }, [editMode, isAddingNewRow, config.showNewRowFormByDefault, config.hasKeyboardNavigation, wmTableColumns, rowActions, showrowindex, radioselect, multiselect, renderFormWidget, updateFieldValue, handleKeyDown, saveNewRow, saveEditing, cancelEditing, resetValidationState, incrementSessionKey, listener, sessionKey, hasRowExpansion, expansionPosition]);
542
+ return /* @__PURE__ */ jsx(
543
+ AddNewRow,
544
+ {
545
+ isAddingNewRow: true,
546
+ editMode,
547
+ wmTableColumns,
548
+ rowActions,
549
+ showrowindex,
550
+ radioselect,
551
+ multiselect,
552
+ sessionKey,
553
+ editingRowData: dataRef.current,
554
+ renderEditableCell: renderCell,
555
+ onKeyDown: onKeyDownHandler,
556
+ handleSave: editMode === "quickedit" ? saveNewRow : saveEditing,
557
+ handleCancel: () => {
558
+ if (editMode === "quickedit") {
559
+ newRowDataRef.current = {};
560
+ resetValidationState("new-row");
561
+ incrementSessionKey();
562
+ } else {
563
+ cancelEditing();
564
+ }
565
+ },
566
+ listener,
567
+ hasRowExpansion,
568
+ expansionPosition
569
+ }
570
+ );
571
+ }, [
572
+ editMode,
573
+ isAddingNewRow,
574
+ config.showNewRowFormByDefault,
575
+ config.hasKeyboardNavigation,
576
+ wmTableColumns,
577
+ rowActions,
578
+ showrowindex,
579
+ radioselect,
580
+ multiselect,
581
+ renderFormWidget,
582
+ updateFieldValue,
583
+ handleKeyDown,
584
+ saveNewRow,
585
+ saveEditing,
586
+ cancelEditing,
587
+ resetValidationState,
588
+ incrementSessionKey,
589
+ listener,
590
+ sessionKey,
591
+ hasRowExpansion,
592
+ expansionPosition
593
+ ]);
635
594
  return {
636
- editingRowId: editingRowId,
595
+ editingRowId,
637
596
  editingRowData: editingRowDataRef.current,
638
- isRowEditing: isRowEditing,
639
- startEditing: startEditing,
640
- cancelEditing: cancelEditing,
641
- saveEditing: saveEditing,
642
- updateFieldValue: updateFieldValue,
643
- renderEditableCell: renderEditableCell,
644
- handleRowClick: handleRowClick,
645
- handleKeyDown: handleKeyDown,
646
- fieldRefs: fieldRefs,
647
- isAddingNewRow: isAddingNewRow,
648
- handleAddNewRowClick: handleAddNewRowClick,
649
- renderAddNewRow: renderAddNewRow
597
+ isRowEditing,
598
+ startEditing,
599
+ cancelEditing,
600
+ saveEditing,
601
+ updateFieldValue,
602
+ renderEditableCell,
603
+ handleRowClick,
604
+ handleKeyDown,
605
+ fieldRefs,
606
+ isAddingNewRow,
607
+ handleAddNewRowClick,
608
+ renderAddNewRow
650
609
  };
651
- };
610
+ };
611
+ export {
612
+ useTableEdit
613
+ };