@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,176 +1,127 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.useFormValidation = useFormValidation;
8
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
9
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
10
- var _react = require("react");
11
- var _lodashEs = require("lodash-es");
12
- var _formUtils = require("../../../../../utils/form-utils");
13
- var _utils = require("../utils");
14
- /**
15
- * Hook for managing form validation and validation messages
16
- *
17
- * Handles:
18
- * - Building validation message objects for fields with errors
19
- * - Exposing validation messages on widget object and formRef
20
- * - Validating fields on submit (including child forms)
21
- * - Focusing on first invalid field
22
- */
23
- function useFormValidation(_ref) {
24
- var formRef = _ref.formRef,
25
- formfields = _ref.formfields,
26
- formReff = _ref.formReff,
27
- control = _ref.control,
28
- trigger = _ref.trigger,
29
- errors = _ref.errors,
30
- formName = _ref.formName,
31
- listener = _ref.listener;
32
- var validationMessagesRef = (0, _react.useRef)([]);
33
-
34
- /**
35
- * Creates a validation message object for a field with errors
36
- */
37
- var addValidationMessage = (0, _react.useCallback)(function (fieldErrors, fieldKey, field, prefix) {
38
- var _field$value;
39
- var errorTypes = (0, _formUtils.getErrorTypes)(fieldErrors);
40
- validationMessagesRef.current.push({
41
- field: fieldKey,
42
- value: (_field$value = field === null || field === void 0 ? void 0 : field.value) !== null && _field$value !== void 0 ? _field$value : field === null || field === void 0 ? void 0 : field.datavalue,
43
- errorType: errorTypes,
44
- message: (field === null || field === void 0 ? void 0 : field.validationmessage) || (fieldErrors === null || fieldErrors === void 0 ? void 0 : fieldErrors.message) || "",
45
- getElement: function getElement() {
46
- var formEl = formRef.current;
47
- if (formEl) {
48
- var fieldEl = formEl.querySelector("[name=\"".concat(fieldKey, "\"]"));
49
- if (fieldEl) {
50
- return fieldEl.closest("[focus-target]") || fieldEl.querySelector("[focus-target]") || fieldEl;
1
+ import { useRef, useCallback } from "react";
2
+ import { last } from "lodash-es";
3
+ import { getErrorTypes, shouldSkipFieldKey } from "../../../../../utils/form-utils";
4
+ import {
5
+ focusOnFirstInvalidField,
6
+ getWidgetFormFields,
7
+ setWidgetValidationMessages
8
+ } from "../utils";
9
+ function useFormValidation({
10
+ formRef,
11
+ formfields,
12
+ formReff,
13
+ control,
14
+ trigger,
15
+ errors,
16
+ formName,
17
+ listener
18
+ }) {
19
+ const validationMessagesRef = useRef([]);
20
+ const addValidationMessage = useCallback(
21
+ (fieldErrors, fieldKey, field, prefix) => {
22
+ var _a;
23
+ const errorTypes = getErrorTypes(fieldErrors);
24
+ validationMessagesRef.current.push({
25
+ field: fieldKey,
26
+ value: (_a = field == null ? void 0 : field.value) != null ? _a : field == null ? void 0 : field.datavalue,
27
+ errorType: errorTypes,
28
+ message: (field == null ? void 0 : field.validationmessage) || (fieldErrors == null ? void 0 : fieldErrors.message) || "",
29
+ getElement: () => {
30
+ const formEl = formRef.current;
31
+ if (formEl) {
32
+ const fieldEl = formEl.querySelector(`[name="${fieldKey}"]`);
33
+ if (fieldEl) {
34
+ return fieldEl.closest("[focus-target]") || fieldEl.querySelector("[focus-target]") || fieldEl;
35
+ }
51
36
  }
52
- }
53
- return null;
54
- },
55
- formName: (0, _lodashEs.last)(prefix.split(".")) || formName || "",
56
- fullyQualifiedFormName: prefix
57
- });
58
- }, [formRef, formName]);
59
-
60
- /**
61
- * Exposes validationMessages on widget object and formRef for external access
62
- */
63
- var exposeValidationMessages = (0, _react.useCallback)(function (validationMessages) {
64
- (0, _utils.setWidgetValidationMessages)(listener, formName, validationMessages);
65
- if (formRef.current) {
66
- formRef.current.validationMessages = validationMessages;
67
- }
68
- }, [formRef, formName]);
69
-
70
- /**
71
- * Gets the form fields to validate and their keys
72
- */
73
- var getFormFieldsForValidation = (0, _react.useCallback)(function () {
74
- var widgetFormFields = (0, _utils.getWidgetFormFields)(listener, formName);
75
- var formFieldsToValidate = widgetFormFields || formfields;
76
- var allFieldKeys = Object.keys(formFieldsToValidate);
77
- var prefix = formName || "";
78
- return {
79
- formFieldsToValidate: formFieldsToValidate,
80
- allFieldKeys: allFieldKeys,
81
- prefix: prefix
82
- };
83
- }, [formName, formfields]);
84
-
85
- /**
86
- * Core validation messages builder that accepts a getFieldError function
87
- */
88
- var buildValidationMessagesCore = (0, _react.useCallback)(function (getFieldError) {
89
- validationMessagesRef.current = [];
90
- var _getFormFieldsForVali = getFormFieldsForValidation(),
91
- formFieldsToValidate = _getFormFieldsForVali.formFieldsToValidate,
92
- allFieldKeys = _getFormFieldsForVali.allFieldKeys,
93
- prefix = _getFormFieldsForVali.prefix;
94
- allFieldKeys.forEach(function (fieldKey) {
95
- if ((0, _formUtils.shouldSkipFieldKey)(fieldKey, allFieldKeys)) return;
96
- var field = formFieldsToValidate[fieldKey];
97
- var fieldErrors = getFieldError(fieldKey, field);
98
- if (fieldErrors) {
99
- addValidationMessage(fieldErrors, fieldKey, field, prefix);
37
+ return null;
38
+ },
39
+ formName: last(prefix.split(".")) || formName || "",
40
+ fullyQualifiedFormName: prefix
41
+ });
42
+ },
43
+ [formRef, formName]
44
+ );
45
+ const exposeValidationMessages = useCallback(
46
+ (validationMessages) => {
47
+ setWidgetValidationMessages(listener, formName, validationMessages);
48
+ if (formRef.current) {
49
+ formRef.current.validationMessages = validationMessages;
100
50
  }
101
- });
102
- return validationMessagesRef.current;
103
- }, [getFormFieldsForValidation, addValidationMessage]);
104
-
105
- /**
106
- * Builds validation messages using react-hook-form's state
107
- */
108
- var buildValidationMessages = (0, _react.useCallback)(function () {
109
- return buildValidationMessagesCore(function (fieldKey) {
110
- var fieldState = control.getFieldState(fieldKey);
111
- return fieldState === null || fieldState === void 0 ? void 0 : fieldState.error;
51
+ },
52
+ [formRef, formName]
53
+ );
54
+ const getFormFieldsForValidation = useCallback(() => {
55
+ const widgetFormFields = getWidgetFormFields(listener, formName);
56
+ const formFieldsToValidate = widgetFormFields || formfields;
57
+ const allFieldKeys = Object.keys(formFieldsToValidate);
58
+ const prefix = formName || "";
59
+ return { formFieldsToValidate, allFieldKeys, prefix };
60
+ }, [formName, formfields]);
61
+ const buildValidationMessagesCore = useCallback(
62
+ (getFieldError) => {
63
+ validationMessagesRef.current = [];
64
+ const { formFieldsToValidate, allFieldKeys, prefix } = getFormFieldsForValidation();
65
+ allFieldKeys.forEach((fieldKey) => {
66
+ if (shouldSkipFieldKey(fieldKey, allFieldKeys)) return;
67
+ const field = formFieldsToValidate[fieldKey];
68
+ const fieldErrors = getFieldError(fieldKey, field);
69
+ if (fieldErrors) {
70
+ addValidationMessage(fieldErrors, fieldKey, field, prefix);
71
+ }
72
+ });
73
+ return validationMessagesRef.current;
74
+ },
75
+ [getFormFieldsForValidation, addValidationMessage]
76
+ );
77
+ const buildValidationMessages = useCallback(() => {
78
+ return buildValidationMessagesCore((fieldKey) => {
79
+ const fieldState = control.getFieldState(fieldKey);
80
+ return fieldState == null ? void 0 : fieldState.error;
112
81
  });
113
82
  }, [buildValidationMessagesCore, control]);
114
-
115
- /**
116
- * Validates all fields on submit, including child forms
117
- * Returns true if all forms are valid
118
- */
119
- var validateFieldsOnSubmit = (0, _react.useCallback)(/*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
120
- var childFormsValid, childForms, validationResults, currentFormValidState, validationMessages, _listener$onChange;
121
- return _regenerator["default"].wrap(function _callee$(_context) {
122
- while (1) switch (_context.prev = _context.next) {
123
- case 0:
124
- // Validate all registered child forms FIRST
125
- // This ensures child form validators run even if parent has errors
126
- childFormsValid = true;
127
- childForms = formReff.current ? Object.values(formReff.current) : [];
128
- if (!childForms.length) {
129
- _context.next = 7;
130
- break;
131
- }
132
- _context.next = 5;
133
- return Promise.all(childForms.map(function (childForm) {
134
- var _childForm$validateFi, _childForm$validateFi2;
135
- return (_childForm$validateFi = childForm === null || childForm === void 0 || (_childForm$validateFi2 = childForm.validateFieldsOnSubmit) === null || _childForm$validateFi2 === void 0 ? void 0 : _childForm$validateFi2.call(childForm)) !== null && _childForm$validateFi !== void 0 ? _childForm$validateFi : Promise.resolve(true);
136
- }));
137
- case 5:
138
- validationResults = _context.sent;
139
- childFormsValid = validationResults.every(Boolean);
140
- case 7:
141
- _context.next = 9;
142
- return trigger();
143
- case 9:
144
- currentFormValidState = _context.sent;
145
- // Build and expose validation messages AFTER trigger
146
- validationMessages = buildValidationMessages();
147
- exposeValidationMessages(validationMessages);
148
-
149
- // If either current form or child forms have errors, focus and return false
150
- if (!(!childFormsValid || !currentFormValidState)) {
151
- _context.next = 16;
152
- break;
153
- }
154
- if (!currentFormValidState) {
155
- listener === null || listener === void 0 || (_listener$onChange = listener.onChange) === null || _listener$onChange === void 0 || _listener$onChange.call(listener, formName, {
156
- valid: false,
157
- errors: errors
158
- });
83
+ const validateFieldsOnSubmit = useCallback(async () => {
84
+ var _a;
85
+ let childFormsValid = true;
86
+ const childForms = formReff.current ? Object.values(formReff.current) : [];
87
+ if (childForms.length) {
88
+ const validationResults = await Promise.all(
89
+ childForms.map(
90
+ (childForm) => {
91
+ var _a2, _b;
92
+ return (_b = (_a2 = childForm == null ? void 0 : childForm.validateFieldsOnSubmit) == null ? void 0 : _a2.call(childForm)) != null ? _b : Promise.resolve(true);
159
93
  }
160
- (0, _utils.focusOnFirstInvalidField)(formRef.current, Object.keys(errors));
161
- return _context.abrupt("return", false);
162
- case 16:
163
- return _context.abrupt("return", true);
164
- case 17:
165
- case "end":
166
- return _context.stop();
94
+ )
95
+ );
96
+ childFormsValid = validationResults.every(Boolean);
97
+ }
98
+ const currentFormValidState = await trigger();
99
+ const validationMessages = buildValidationMessages();
100
+ exposeValidationMessages(validationMessages);
101
+ if (!childFormsValid || !currentFormValidState) {
102
+ if (!currentFormValidState) {
103
+ (_a = listener == null ? void 0 : listener.onChange) == null ? void 0 : _a.call(listener, formName, { valid: false, errors });
167
104
  }
168
- }, _callee);
169
- })), [trigger, buildValidationMessages, exposeValidationMessages, formName, errors, formRef, formReff]);
105
+ focusOnFirstInvalidField(formRef.current, Object.keys(errors));
106
+ return false;
107
+ }
108
+ return true;
109
+ }, [
110
+ trigger,
111
+ buildValidationMessages,
112
+ exposeValidationMessages,
113
+ formName,
114
+ errors,
115
+ formRef,
116
+ formReff
117
+ ]);
170
118
  return {
171
- validationMessagesRef: validationMessagesRef,
172
- validateFieldsOnSubmit: validateFieldsOnSubmit,
173
- buildValidationMessages: buildValidationMessages,
174
- exposeValidationMessages: exposeValidationMessages
119
+ validationMessagesRef,
120
+ validateFieldsOnSubmit,
121
+ buildValidationMessages,
122
+ exposeValidationMessages
175
123
  };
176
- }
124
+ }
125
+ export {
126
+ useFormValidation
127
+ };
@@ -1,127 +1,91 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.useParentFormRelationship = useParentFormRelationship;
7
- var _react = require("react");
8
- var _PrefabContext = require("../../../../../context/PrefabContext");
9
- var _formContext = require("../../form-context");
10
- var _props = require("../props");
11
- /**
12
- * Hook for detecting and managing parent-child form relationships
13
- *
14
- * Supports all nesting scenarios:
15
- * - STANDALONE: Basic form (no parent)
16
- * - DIRECT_CHILD: Form -> Form (direct nesting)
17
- * - LIST_CHILD: Form -> List -> Form (array indexing)
18
- * - PREFAB_CHILD: Form -> Prefab -> Form (context bridging)
19
- * - LIST_PREFAB_CHILD: Form -> List -> Prefab -> Form
20
- */
21
- function useParentFormRelationship(_ref) {
22
- var _prefabContext$formAr;
23
- var name = _ref.name,
24
- propsParentForm = _ref.parentForm,
25
- isParentListRaw = _ref.isParentList,
26
- parentListName = _ref.parentListName,
27
- childdatasetnode = _ref.childdatasetnode,
28
- propsFormArrayIndex = _ref.formArrayIndex;
29
- var prefabContext = (0, _react.useContext)(_PrefabContext.PrefabContext);
30
- var parentFormDataContext = (0, _formContext.useParentFormData)();
31
-
32
- // Parent form can come from props OR PrefabContext
33
- var parentForm = propsParentForm || (prefabContext === null || prefabContext === void 0 ? void 0 : prefabContext.parentForm);
34
-
35
- // isParentList can be boolean OR string "true" from JSX
36
- var isParentList = isParentListRaw === true || isParentListRaw === "true";
37
- var formArrayIndex = propsFormArrayIndex !== undefined ? propsFormArrayIndex : (_prefabContext$formAr = prefabContext === null || prefabContext === void 0 ? void 0 : prefabContext.formArrayIndex) !== null && _prefabContext$formAr !== void 0 ? _prefabContext$formAr : -1;
38
-
39
- // Get parent form's data from context (instance-specific, not shared widget proxy)
40
- var parentFormData = parentForm ? parentFormDataContext === null || parentFormDataContext === void 0 ? void 0 : parentFormDataContext.formdata : undefined;
41
-
42
- // Track the ROOT parent form - all nested forms should emit data to the root
43
- var rootParentForm = (parentFormDataContext === null || parentFormDataContext === void 0 ? void 0 : parentFormDataContext.rootParentForm) || parentForm;
44
-
45
- // Determine the correct data key for child forms
46
- var effectiveChildDatasetNode = (0, _react.useMemo)(function () {
47
- if (!parentForm) return undefined;
48
-
49
- // If this form is inside a list, use parentListName (the array field name)
1
+ import { useMemo, useContext } from "react";
2
+ import { PrefabContext } from "../../../../../context/PrefabContext";
3
+ import { useParentFormData } from "../../form-context";
4
+ import {
5
+ FormType,
6
+ detectFormType,
7
+ getFormTypeConfig
8
+ } from "../props";
9
+ function useParentFormRelationship({
10
+ name,
11
+ parentForm: propsParentForm,
12
+ isParentList: isParentListRaw,
13
+ parentListName,
14
+ childdatasetnode,
15
+ formArrayIndex: propsFormArrayIndex
16
+ }) {
17
+ var _a;
18
+ const prefabContext = useContext(PrefabContext);
19
+ const parentFormDataContext = useParentFormData();
20
+ const parentForm = propsParentForm || (prefabContext == null ? void 0 : prefabContext.parentForm);
21
+ const isParentList = isParentListRaw === true || isParentListRaw === "true";
22
+ const formArrayIndex = propsFormArrayIndex !== void 0 ? propsFormArrayIndex : (_a = prefabContext == null ? void 0 : prefabContext.formArrayIndex) != null ? _a : -1;
23
+ const parentFormData = parentForm ? parentFormDataContext == null ? void 0 : parentFormDataContext.formdata : void 0;
24
+ const rootParentForm = (parentFormDataContext == null ? void 0 : parentFormDataContext.rootParentForm) || parentForm;
25
+ const effectiveChildDatasetNode = useMemo(() => {
26
+ if (!parentForm) return void 0;
50
27
  if (isParentList && parentListName) {
51
28
  return parentListName;
52
29
  }
53
-
54
- // Fall back to childdatasetnode or name
55
30
  return childdatasetnode || name;
56
31
  }, [parentForm, isParentList, parentListName, childdatasetnode, name]);
57
-
58
- // Has explicit parent form relationship via props
59
- var hasDirectChildRelationship = !!(propsParentForm || childdatasetnode);
60
-
61
- // Has context-based relationship (form inside prefab)
62
- var hasPrefabContext = !!(parentFormDataContext !== null && parentFormDataContext !== void 0 && parentFormDataContext.onChildDataChange && parentFormDataContext !== null && parentFormDataContext !== void 0 && parentFormDataContext.parentDataPath && !propsParentForm && !childdatasetnode);
63
-
64
- // Detect form type using the centralized detection logic
65
- var formType = (0, _react.useMemo)(function () {
66
- return (0, _props.detectFormType)({
32
+ const hasDirectChildRelationship = !!(propsParentForm || childdatasetnode);
33
+ const hasPrefabContext = !!((parentFormDataContext == null ? void 0 : parentFormDataContext.onChildDataChange) && (parentFormDataContext == null ? void 0 : parentFormDataContext.parentDataPath) && !propsParentForm && !childdatasetnode);
34
+ const formType = useMemo(() => {
35
+ return detectFormType({
67
36
  hasParentFormProp: !!parentForm && hasDirectChildRelationship,
68
37
  hasChildDatasetNode: !!childdatasetnode,
69
- hasPrefabContext: hasPrefabContext,
38
+ hasPrefabContext,
70
39
  isInList: isParentList
71
40
  });
72
41
  }, [parentForm, hasDirectChildRelationship, childdatasetnode, hasPrefabContext, isParentList]);
73
-
74
- // Get the configuration for this form type
75
- var formTypeConfig = (0, _react.useMemo)(function () {
76
- return (0, _props.getFormTypeConfig)(formType);
77
- }, [formType]);
78
-
79
- // Build the FULL data path for deeply nested forms
80
- var fullDataPath = (0, _react.useMemo)(function () {
81
- // For prefab forms: parentDataPath is already set by BasePrefab
82
- if (formType === _props.FormType.PREFAB_CHILD || formType === _props.FormType.LIST_PREFAB_CHILD) {
83
- var basePath = parentFormDataContext === null || parentFormDataContext === void 0 ? void 0 : parentFormDataContext.parentDataPath;
84
- // For LIST_PREFAB_CHILD (form inside list inside prefab), append the array index
85
- // Guard against undefined basePath to prevent "undefined[0]" strings
86
- if (formType === _props.FormType.LIST_PREFAB_CHILD && isParentList && formArrayIndex >= 0 && basePath) {
87
- return "".concat(basePath, "[").concat(formArrayIndex, "]");
42
+ const formTypeConfig = useMemo(() => getFormTypeConfig(formType), [formType]);
43
+ const fullDataPath = useMemo(() => {
44
+ if (formType === FormType.PREFAB_CHILD || formType === FormType.LIST_PREFAB_CHILD) {
45
+ const basePath = parentFormDataContext == null ? void 0 : parentFormDataContext.parentDataPath;
46
+ if (formType === FormType.LIST_PREFAB_CHILD && isParentList && formArrayIndex >= 0 && basePath) {
47
+ return `${basePath}[${formArrayIndex}]`;
88
48
  }
89
49
  return basePath;
90
50
  }
91
-
92
- // Regular child forms need parentForm prop
93
- if (!parentForm) return undefined;
94
-
95
- // Get parent's data path prefix from context
96
- var parentDataPathPrefix = (parentFormDataContext === null || parentFormDataContext === void 0 ? void 0 : parentFormDataContext.parentDataPath) || "";
97
- var currentPath = "";
51
+ if (!parentForm) return void 0;
52
+ const parentDataPathPrefix = (parentFormDataContext == null ? void 0 : parentFormDataContext.parentDataPath) || "";
53
+ let currentPath = "";
98
54
  if (isParentList && parentListName) {
99
- // For list forms, include the array index
100
- currentPath = formArrayIndex >= 0 ? "".concat(parentListName, "[").concat(formArrayIndex, "]") : parentListName;
55
+ currentPath = formArrayIndex >= 0 ? `${parentListName}[${formArrayIndex}]` : parentListName;
101
56
  } else {
102
- // For regular child forms, use childdatasetnode
103
57
  currentPath = childdatasetnode || name;
104
58
  }
105
-
106
- // Combine parent path with current path
107
59
  if (parentDataPathPrefix) {
108
- return "".concat(parentDataPathPrefix, ".").concat(currentPath);
60
+ return `${parentDataPathPrefix}.${currentPath}`;
109
61
  }
110
62
  return currentPath;
111
- }, [parentForm, formType, isParentList, parentListName, childdatasetnode, name, parentFormDataContext === null || parentFormDataContext === void 0 ? void 0 : parentFormDataContext.parentDataPath, formArrayIndex]);
63
+ }, [
64
+ parentForm,
65
+ formType,
66
+ isParentList,
67
+ parentListName,
68
+ childdatasetnode,
69
+ name,
70
+ parentFormDataContext == null ? void 0 : parentFormDataContext.parentDataPath,
71
+ formArrayIndex
72
+ ]);
112
73
  return {
113
74
  // Form type (new)
114
- formType: formType,
115
- formTypeConfig: formTypeConfig,
75
+ formType,
76
+ formTypeConfig,
116
77
  // Legacy compatibility (can be derived from formType)
117
- parentForm: parentForm,
118
- isParentList: isParentList,
119
- formArrayIndex: formArrayIndex,
120
- effectiveChildDatasetNode: effectiveChildDatasetNode,
121
- fullDataPath: fullDataPath,
122
- hasDirectChildRelationship: hasDirectChildRelationship,
123
- rootParentForm: rootParentForm,
124
- parentFormData: parentFormData,
125
- parentFormDataContext: parentFormDataContext
78
+ parentForm,
79
+ isParentList,
80
+ formArrayIndex,
81
+ effectiveChildDatasetNode,
82
+ fullDataPath,
83
+ hasDirectChildRelationship,
84
+ rootParentForm,
85
+ parentFormData,
86
+ parentFormDataContext
126
87
  };
127
- }
88
+ }
89
+ export {
90
+ useParentFormRelationship
91
+ };