@wavemaker-ai/react-runtime 1.0.0-rc.647502 → 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,102 +1,141 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof3 = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = void 0;
9
- var _react = _interopRequireWildcard(require("react"));
10
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
12
- var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
14
- var _reactHookForm = require("react-hook-form");
15
- var _clsx = _interopRequireDefault(require("clsx"));
16
- var _WidgetProvider = require("@wavemaker-ai/react-runtime/context/WidgetProvider");
17
- var _formContext = require("@wavemaker-ai/react-runtime/components/data/form/form-context");
18
- var _utils = require("./utils");
19
- var _hooks = require("./hooks");
20
- var _excluded = ["formRef", "formKey", "name", "datavalue", "maxDataValue", "isMaxWidget", "defaultvalue", "validators", "asyncValidators", "required", "maxchars", "minvalue", "maxvalue", "regexp", "validationmessage", "customValidationMsg", "setValidationMessage", "hint", "type", "observe", "onBlur", "fieldName", "standalone"];
21
- function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
22
- var __jsx = _react["default"].createElement;
23
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
24
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
25
- // HOC function
26
- var withFormController = function withFormController(WrappedComponent) {
27
- var WithFormControllerComponent = /*#__PURE__*/(0, _react.memo)(function (props) {
28
- var propsFormRef = props.formRef,
29
- formKey = props.formKey,
30
- name = props.name,
31
- datavalue = props.datavalue,
32
- maxDataValue = props.maxDataValue,
33
- isMaxWidgetProp = props.isMaxWidget,
34
- defaultvalue = props.defaultvalue,
35
- _props$validators = props.validators,
36
- validators = _props$validators === void 0 ? [] : _props$validators,
37
- asyncValidators = props.asyncValidators,
38
- required = props.required,
39
- maxchars = props.maxchars,
40
- minvalue = props.minvalue,
41
- maxvalue = props.maxvalue,
42
- regexp = props.regexp,
43
- validationmessage = props.validationmessage,
44
- customValidationMsg = props.customValidationMsg,
45
- setValidationMessage = props.setValidationMessage,
46
- hint = props.hint,
47
- type = props.type,
48
- observe = props.observe,
49
- onBlur = props.onBlur,
50
- fieldName = props.fieldName,
51
- _props$standalone = props.standalone,
52
- standalone = _props$standalone === void 0 ? false : _props$standalone,
53
- wrappedComponentProps = (0, _objectWithoutProperties2["default"])(props, _excluded);
54
-
55
- // State and refs
56
- var _useState = (0, _react.useState)(false),
57
- touched = _useState[0],
58
- setTouched = _useState[1];
59
- var fieldRef = (0, _react.useRef)(null);
60
- var observeRef = (0, _react.useRef)(observe);
61
- var isInitialMountRef = (0, _react.useRef)(true);
62
- var hasEverBeenTouchedRef = (0, _react.useRef)(false);
63
-
64
- // Context and proxy setup
65
- var inputFieldName = fieldName || name;
66
- var contextFormRef = (0, _formContext.useFormContext)();
67
- var formRef = propsFormRef || contextFormRef;
68
- var fieldProxy = (0, _WidgetProvider.useWidgetProxy)(name, standalone);
69
- var form = (0, _WidgetProvider.useWidgetProxy)(formRef === null || formRef === void 0 ? void 0 : formRef.name, standalone);
70
-
71
- // Normalize isMaxWidget - handle string "true" from markup
72
- var isMaxWidget = isMaxWidgetProp === true || isMaxWidgetProp === "true" || isMaxWidgetProp === "{true}";
73
-
74
- // For max widgets, use a modified formKey to differentiate from min widget
75
- // This allows both widgets to coexist in the form while maintaining the same base field name
76
- var effectiveFormKey = isMaxWidget && formKey ? "".concat(formKey, "_maxWidget") : formKey || inputFieldName;
77
-
78
- // Use maxdatavalue when isMaxWidget is true, otherwise use datavalue
79
- var effectiveDataValue = isMaxWidget ? maxDataValue !== undefined ? maxDataValue : datavalue : datavalue;
80
-
81
- // Form properties
82
- var trigger = formRef === null || formRef === void 0 ? void 0 : formRef.trigger;
83
- var validationType = (form === null || form === void 0 ? void 0 : form.validationtype) || (formRef === null || formRef === void 0 ? void 0 : formRef.validationtype) || "default";
84
-
85
- // Custom hooks
86
- (0, _hooks.useFormRegistration)(name, fieldProxy, contextFormRef);
87
- // For max widgets: only sync maxdatavalue (don't sync datavalue as it shouldn't change)
88
- // For regular widgets: sync datavalue
89
- (0, _hooks.useDefaultValueSync)(defaultvalue, datavalue, fieldRef);
90
- // ignoring min/max range validation for Radioset and Checkboxset widgets
91
- var widget = WrappedComponent === null || WrappedComponent === void 0 ? void 0 : WrappedComponent.displayName;
92
- var ignoreRange = ["WmRadioset", "WmCheckboxset"].includes(widget !== null && widget !== void 0 ? widget : "");
93
- var validationRules = (0, _hooks.useValidationRules)(validationType, validators, asyncValidators, required, maxchars, regexp, validationmessage, ignoreRange ? undefined : minvalue, ignoreRange ? undefined : maxvalue, form, customValidationMsg);
94
- var rules = {
95
- required: required,
96
- maxchars: maxchars,
97
- regexp: regexp,
98
- minvalue: minvalue,
99
- maxvalue: maxvalue,
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ var __objRest = (source, exclude) => {
21
+ var target = {};
22
+ for (var prop in source)
23
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
24
+ target[prop] = source[prop];
25
+ if (source != null && __getOwnPropSymbols)
26
+ for (var prop of __getOwnPropSymbols(source)) {
27
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
28
+ target[prop] = source[prop];
29
+ }
30
+ return target;
31
+ };
32
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
33
+ import { Controller } from "react-hook-form";
34
+ import clsx from "clsx";
35
+ import { useCallback, memo, useRef, useEffect, useState } from "react";
36
+ import { useWidgetProxy } from "../../../../context/WidgetProvider";
37
+ import { useFormContext } from "../form-context";
38
+ import {
39
+ extractDynamicValidationProps,
40
+ processFieldValue,
41
+ getErrorState,
42
+ shouldShowErrorMessage
43
+ } from "./utils";
44
+ import {
45
+ useFormRegistration,
46
+ useDefaultValueSync,
47
+ useValidationRules,
48
+ useHTMLValidationProps
49
+ } from "./hooks";
50
+ const withFormController = (WrappedComponent) => {
51
+ const WithFormControllerComponent = memo((props) => {
52
+ const _a = props, {
53
+ formRef: propsFormRef,
54
+ formKey,
55
+ name,
56
+ datavalue,
57
+ maxDataValue,
58
+ isMaxWidget: isMaxWidgetProp,
59
+ defaultvalue,
60
+ validators = [],
61
+ asyncValidators,
62
+ required,
63
+ maxchars,
64
+ minvalue,
65
+ maxvalue,
66
+ regexp,
67
+ validationmessage,
68
+ customValidationMsg,
69
+ setValidationMessage,
70
+ hint,
71
+ type,
72
+ observe,
73
+ onBlur,
74
+ fieldName,
75
+ standalone = false
76
+ } = _a, wrappedComponentProps = __objRest(_a, [
77
+ "formRef",
78
+ "formKey",
79
+ "name",
80
+ "datavalue",
81
+ "maxDataValue",
82
+ "isMaxWidget",
83
+ "defaultvalue",
84
+ "validators",
85
+ "asyncValidators",
86
+ "required",
87
+ "maxchars",
88
+ "minvalue",
89
+ "maxvalue",
90
+ "regexp",
91
+ "validationmessage",
92
+ "customValidationMsg",
93
+ "setValidationMessage",
94
+ "hint",
95
+ "type",
96
+ "observe",
97
+ "onBlur",
98
+ "fieldName",
99
+ "standalone"
100
+ ]);
101
+ const [touched, setTouched] = useState(false);
102
+ const fieldRef = useRef(null);
103
+ const observeRef = useRef(observe);
104
+ const isInitialMountRef = useRef(true);
105
+ const hasEverBeenTouchedRef = useRef(false);
106
+ const inputFieldName = fieldName || name;
107
+ const contextFormRef = useFormContext();
108
+ const formRef = propsFormRef || contextFormRef;
109
+ const fieldProxy = useWidgetProxy(name, standalone);
110
+ const form = useWidgetProxy(formRef == null ? void 0 : formRef.name, standalone);
111
+ const isMaxWidget = isMaxWidgetProp === true || isMaxWidgetProp === "true" || isMaxWidgetProp === "{true}";
112
+ const effectiveFormKey = isMaxWidget && formKey ? `${formKey}_maxWidget` : formKey || inputFieldName;
113
+ const effectiveDataValue = isMaxWidget ? maxDataValue !== void 0 ? maxDataValue : datavalue : datavalue;
114
+ const trigger = formRef == null ? void 0 : formRef.trigger;
115
+ const validationType = (form == null ? void 0 : form.validationtype) || (formRef == null ? void 0 : formRef.validationtype) || "default";
116
+ useFormRegistration(name, fieldProxy, contextFormRef);
117
+ useDefaultValueSync(defaultvalue, datavalue, fieldRef);
118
+ const widget = WrappedComponent == null ? void 0 : WrappedComponent.displayName;
119
+ const ignoreRange = ["WmRadioset", "WmCheckboxset"].includes(widget != null ? widget : "");
120
+ const validationRules = useValidationRules(
121
+ validationType,
122
+ validators,
123
+ asyncValidators,
124
+ required,
125
+ maxchars,
126
+ regexp,
127
+ validationmessage,
128
+ ignoreRange ? void 0 : minvalue,
129
+ ignoreRange ? void 0 : maxvalue,
130
+ form,
131
+ customValidationMsg
132
+ );
133
+ const rules = {
134
+ required,
135
+ maxchars,
136
+ regexp,
137
+ minvalue,
138
+ maxvalue,
100
139
  excludedays: props.excludedays,
101
140
  excludedates: props.excludedates,
102
141
  mintime: props.mintime,
@@ -104,41 +143,40 @@ var withFormController = function withFormController(WrappedComponent) {
104
143
  mindate: props.mindate,
105
144
  maxdate: props.maxdate
106
145
  };
107
- var extractedValidatorProps = (0, _utils.extractDynamicValidationProps)(validators || [], rules);
108
- var htmlValidationProps = (0, _hooks.useHTMLValidationProps)(validationType, required, maxchars, regexp);
109
-
110
- // Update observeRef when observe changes
111
- (0, _react.useEffect)(function () {
146
+ const extractedValidatorProps = extractDynamicValidationProps(validators || [], rules);
147
+ const htmlValidationProps = useHTMLValidationProps(validationType, required, maxchars, regexp);
148
+ useEffect(() => {
112
149
  observeRef.current = observe;
113
150
  }, [observe]);
114
-
115
- // Destroy widget when component unmounts
116
- (0, _react.useEffect)(function () {
117
- return function () {
151
+ useEffect(() => {
152
+ return () => {
118
153
  if (props.destroy) {
119
- props.destroy([props.name, effectiveFormKey, "".concat(effectiveFormKey, "_formWidget"), "".concat(effectiveFormKey, "_formLabel")]);
154
+ props.destroy([
155
+ props.name,
156
+ effectiveFormKey,
157
+ `${effectiveFormKey}_formWidget`,
158
+ `${effectiveFormKey}_formLabel`
159
+ ]);
120
160
  }
121
161
  };
122
162
  }, [effectiveFormKey]);
123
-
124
- // Track if field has ever been touched
125
- (0, _react.useEffect)(function () {
163
+ useEffect(() => {
126
164
  if (touched && !hasEverBeenTouchedRef.current) {
127
165
  hasEverBeenTouchedRef.current = true;
128
166
  }
129
167
  }, [touched]);
130
- (0, _react.useEffect)(function () {
168
+ useEffect(() => {
131
169
  if (isInitialMountRef.current) {
132
170
  isInitialMountRef.current = false;
133
171
  return;
134
172
  }
135
- var hasBeenTouchedOrSubmitted = hasEverBeenTouchedRef.current || (formRef === null || formRef === void 0 ? void 0 : formRef.submitCount) && formRef.submitCount > 0;
173
+ const hasBeenTouchedOrSubmitted = hasEverBeenTouchedRef.current || (formRef == null ? void 0 : formRef.submitCount) && formRef.submitCount > 0;
136
174
  if (trigger && effectiveFormKey && hasBeenTouchedOrSubmitted) {
137
175
  trigger(effectiveFormKey);
138
176
  }
139
177
  }, [validationmessage]);
140
- var customMsgInitialRef = (0, _react.useRef)(true);
141
- (0, _react.useEffect)(function () {
178
+ const customMsgInitialRef = useRef(true);
179
+ useEffect(() => {
142
180
  if (customMsgInitialRef.current) {
143
181
  customMsgInitialRef.current = false;
144
182
  return;
@@ -147,163 +185,175 @@ var withFormController = function withFormController(WrappedComponent) {
147
185
  trigger(effectiveFormKey);
148
186
  }
149
187
  }, [customValidationMsg]);
150
-
151
- // Event handlers
152
- var createOnChangeHandler = (0, _react.useCallback)(function (field) {
153
- return function (e, componentProps, newValue, oldValue, isValid) {
154
- var _props$onChange;
155
- var valueToSet;
156
- if (newValue !== undefined) {
157
- valueToSet = newValue;
158
- } else if (e && e.target) {
159
- valueToSet = e.target.value;
160
- } else if (e !== undefined) {
161
- valueToSet = e;
162
- }
163
-
164
- // If the incoming value is an object and we have a datafield, extract the value
165
- if (valueToSet && (0, _typeof2["default"])(valueToSet) === "object" && !Array.isArray(valueToSet) && props.datafield && props.datafield !== "All Fields") {
166
- valueToSet = valueToSet[props.datafield];
167
- }
168
- if (type === "number") {
169
- field.onChange(valueToSet === "" || valueToSet === null ? "" : valueToSet);
170
- } else {
171
- field.onChange(valueToSet);
172
- }
173
- if (isValid === false) {
174
- return;
175
- }
176
- (_props$onChange = props.onChange) === null || _props$onChange === void 0 || _props$onChange.call(props, e, componentProps, newValue, oldValue);
177
- };
178
- }, [type, props.datafield]);
179
- var createOnBlurHandler = (0, _react.useCallback)(function (field, fieldState) {
180
- return function (e) {
181
- var _observeRef$current;
182
- setTouched(true);
183
- field.onBlur();
184
- var shouldTriggerValidation = validationType === "html" && trigger && !!fieldState.error || validationType !== "none" && ((_observeRef$current = observeRef.current) === null || _observeRef$current === void 0 ? void 0 : _observeRef$current.length) && trigger;
185
- if (shouldTriggerValidation) {
186
- setTimeout(function () {
187
- trigger(effectiveFormKey);
188
- });
189
- }
190
- onBlur === null || onBlur === void 0 || onBlur(e);
191
- };
192
- }, [trigger, formKey, inputFieldName, onBlur, validationType]);
193
-
194
- // Render without Controller if no formRef
195
- if (!(formRef !== null && formRef !== void 0 && formRef.control) || props.ignoreInForm) {
196
- return __jsx(WrappedComponent, props);
197
- }
198
- return __jsx(_reactHookForm.Controller, {
199
- control: formRef.control,
200
- name: effectiveFormKey,
201
- rules: validationRules,
202
- defaultValue: effectiveDataValue !== undefined ? effectiveDataValue : defaultvalue,
203
- render: function render(_ref) {
204
- var _fieldState$error;
205
- var field = _ref.field,
206
- fieldState = _ref.fieldState;
207
- // Store field reference for external updates
208
- fieldRef.current = field;
209
-
210
- // Process field value and get error state
211
- var processedValue = (0, _utils.processFieldValue)(field.value, type, props.datafield);
212
- var errorState = (0, _utils.getErrorState)(fieldState, validationType, touched);
213
-
214
- // Determine the value to use with proper fallback chain
215
- // Priority: field.value (if not undefined) -> datavalue (if not undefined) -> defaultvalue
216
- var valueToUse;
217
- if (processedValue !== undefined) {
218
- valueToUse = processedValue;
219
- } else {
220
- valueToUse = defaultvalue;
221
- }
222
-
223
- // Build controlled props
224
- // For max widgets: use max-prefixed properties (maxdatavalue, maxvalue, maxdisplayValue)
225
- // For regular widgets: use regular properties (datavalue, value, displayValue)
226
- var effectiveValue = processedValue !== undefined ? processedValue : defaultvalue;
227
- var displayValueStr = effectiveValue !== null && effectiveValue !== undefined ? effectiveValue.toString() : "";
228
-
229
- // For max widgets: use max-prefixed properties, keep regular properties unchanged
230
- // For regular widgets: use regular properties
231
- var maxWidgetProps = isMaxWidget ? {
232
- datavalue: props.datavalue !== undefined ? props.datavalue : undefined,
233
- // Keep original, don't update
234
- value: props.value !== undefined ? props.value : undefined,
235
- // Keep original, don't update
236
- displayValue: props.displayValue !== undefined ? props.displayValue : undefined,
237
- // Keep original, don't update
238
- maxDataValue: effectiveValue,
239
- // Update max-prefixed properties
240
- maxdisplayValue: displayValueStr
241
- } : {
242
- // For regular widgets: use regular properties
243
- datavalue: valueToUse,
244
- value: valueToUse,
245
- displayValue: displayValueStr,
246
- maxvalue: props.maxvalue !== undefined ? props.maxvalue : undefined // Keep original, don't update
247
- };
248
- var controlledProps = _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, props), extractedValidatorProps), validationType === "html" ? htmlValidationProps : {}), maxWidgetProps), {}, {
249
- isMaxWidget: isMaxWidget,
250
- // Ensure isMaxWidget is passed through
251
- onChange: createOnChangeHandler(field),
252
- onBlur: createOnBlurHandler(field, fieldState),
253
- ref: field.ref
254
- }, errorState), {}, {
255
- required: validationType === "html" || !propsFormRef ? required : extractedValidatorProps.required || required,
256
- isControlled: true,
257
- formfield: true,
258
- fieldName: inputFieldName,
259
- name: name,
260
- isRequiredLabel: validationType === "html" || !propsFormRef ? required : extractedValidatorProps.required || required,
261
- className: (0, _clsx["default"])(wrappedComponentProps.className, {
262
- hidden: contextFormRef === null || contextFormRef === void 0 ? void 0 : contextFormRef.isViewMode
263
- })
264
- });
265
- return __jsx(_react["default"].Fragment, null, __jsx(WrappedComponent, (0, _extends2["default"])({}, controlledProps, {
266
- dataset: props.dataset,
267
- displayfield: props.displayfield
268
- })), __jsx("span", {
269
- style: {
270
- alignSelf: "flex-start"
271
- },
272
- className: "form-control-static app-label",
273
- hidden: !(contextFormRef !== null && contextFormRef !== void 0 && contextFormRef.isViewMode)
274
- }, function () {
275
- var value = controlledProps.datavalue;
276
- if (value && (0, _typeof2["default"])(value) === "object") {
277
- if (props.datafield || props.displayfield) {
278
- value = value[props.datafield || props.displayfield];
279
- } else {
280
- value = JSON.stringify(value);
281
- }
188
+ const createOnChangeHandler = useCallback(
189
+ (field) => {
190
+ return (e, componentProps, newValue, oldValue, isValid) => {
191
+ var _a2;
192
+ let valueToSet;
193
+ if (newValue !== void 0) {
194
+ valueToSet = newValue;
195
+ } else if (e && e.target) {
196
+ valueToSet = e.target.value;
197
+ } else if (e !== void 0) {
198
+ valueToSet = e;
199
+ }
200
+ if (valueToSet && typeof valueToSet === "object" && !Array.isArray(valueToSet) && props.datafield && props.datafield !== "All Fields") {
201
+ valueToSet = valueToSet[props.datafield];
202
+ }
203
+ if (type === "number") {
204
+ field.onChange(valueToSet === "" || valueToSet === null ? "" : valueToSet);
205
+ } else {
206
+ field.onChange(valueToSet);
207
+ }
208
+ if (isValid === false) {
209
+ return;
282
210
  }
283
- return value;
284
- }()), hint && !(0, _utils.shouldShowErrorMessage)(validationType, fieldState, touched) && __jsx("p", {
285
- className: "help-block",
286
- "aria-hidden": "true",
287
- role: "alert",
288
- "aria-live": "polite",
289
- style: {
290
- textAlign: "start",
291
- width: "100%"
211
+ (_a2 = props.onChange) == null ? void 0 : _a2.call(props, e, componentProps, newValue, oldValue);
212
+ };
213
+ },
214
+ [type, props.datafield]
215
+ );
216
+ const createOnBlurHandler = useCallback(
217
+ (field, fieldState) => {
218
+ return (e) => {
219
+ var _a2;
220
+ setTouched(true);
221
+ field.onBlur();
222
+ const shouldTriggerValidation = validationType === "html" && trigger && !!fieldState.error || validationType !== "none" && ((_a2 = observeRef.current) == null ? void 0 : _a2.length) && trigger;
223
+ if (shouldTriggerValidation) {
224
+ setTimeout(() => {
225
+ trigger(effectiveFormKey);
226
+ });
292
227
  }
293
- }, hint), (0, _utils.shouldShowErrorMessage)(validationType, fieldState, touched) && __jsx("p", {
294
- className: "help-block text-danger",
295
- "aria-hidden": "false",
296
- role: "alert",
297
- "aria-live": "assertive",
298
- style: {
299
- textAlign: "start",
300
- width: "100%"
228
+ onBlur == null ? void 0 : onBlur(e);
229
+ };
230
+ },
231
+ [trigger, formKey, inputFieldName, onBlur, validationType]
232
+ );
233
+ if (!(formRef == null ? void 0 : formRef.control) || props.ignoreInForm) {
234
+ return /* @__PURE__ */ jsx(WrappedComponent, __spreadValues({}, props));
235
+ }
236
+ return /* @__PURE__ */ jsx(
237
+ Controller,
238
+ {
239
+ control: formRef.control,
240
+ name: effectiveFormKey,
241
+ rules: validationRules,
242
+ defaultValue: effectiveDataValue !== void 0 ? effectiveDataValue : defaultvalue,
243
+ render: ({ field, fieldState }) => {
244
+ var _a2;
245
+ fieldRef.current = field;
246
+ const processedValue = processFieldValue(field.value, type, props.datafield);
247
+ const errorState = getErrorState(fieldState, validationType, touched);
248
+ let valueToUse;
249
+ if (processedValue !== void 0) {
250
+ valueToUse = processedValue;
251
+ } else {
252
+ valueToUse = defaultvalue;
301
253
  }
302
- }, (_fieldState$error = fieldState.error) === null || _fieldState$error === void 0 ? void 0 : _fieldState$error.message));
254
+ const effectiveValue = processedValue !== void 0 ? processedValue : defaultvalue;
255
+ const displayValueStr = effectiveValue !== null && effectiveValue !== void 0 ? effectiveValue.toString() : "";
256
+ const maxWidgetProps = isMaxWidget ? {
257
+ datavalue: props.datavalue !== void 0 ? props.datavalue : void 0,
258
+ // Keep original, don't update
259
+ value: props.value !== void 0 ? props.value : void 0,
260
+ // Keep original, don't update
261
+ displayValue: props.displayValue !== void 0 ? props.displayValue : void 0,
262
+ // Keep original, don't update
263
+ maxDataValue: effectiveValue,
264
+ // Update max-prefixed properties
265
+ maxdisplayValue: displayValueStr
266
+ } : {
267
+ // For regular widgets: use regular properties
268
+ datavalue: valueToUse,
269
+ value: valueToUse,
270
+ displayValue: displayValueStr,
271
+ maxvalue: props.maxvalue !== void 0 ? props.maxvalue : void 0
272
+ // Keep original, don't update
273
+ };
274
+ const controlledProps = __spreadProps(__spreadValues(__spreadProps(__spreadValues(__spreadValues(__spreadValues(__spreadValues({}, props), extractedValidatorProps), validationType === "html" ? htmlValidationProps : {}), maxWidgetProps), {
275
+ isMaxWidget,
276
+ // Ensure isMaxWidget is passed through
277
+ onChange: createOnChangeHandler(field),
278
+ onBlur: createOnBlurHandler(field, fieldState),
279
+ ref: field.ref
280
+ }), errorState), {
281
+ required: validationType === "html" || !propsFormRef ? required : extractedValidatorProps.required || required,
282
+ isControlled: true,
283
+ formfield: true,
284
+ fieldName: inputFieldName,
285
+ name,
286
+ isRequiredLabel: validationType === "html" || !propsFormRef ? required : extractedValidatorProps.required || required,
287
+ className: clsx(wrappedComponentProps.className, {
288
+ hidden: contextFormRef == null ? void 0 : contextFormRef.isViewMode
289
+ })
290
+ });
291
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
292
+ /* @__PURE__ */ jsx(
293
+ WrappedComponent,
294
+ __spreadProps(__spreadValues({}, controlledProps), {
295
+ dataset: props.dataset,
296
+ displayfield: props.displayfield
297
+ })
298
+ ),
299
+ /* @__PURE__ */ jsx(
300
+ "span",
301
+ {
302
+ style: {
303
+ alignSelf: "flex-start"
304
+ },
305
+ className: "form-control-static app-label",
306
+ hidden: !(contextFormRef == null ? void 0 : contextFormRef.isViewMode),
307
+ children: (() => {
308
+ let value = controlledProps.datavalue;
309
+ if (value && typeof value === "object") {
310
+ if (props.datafield || props.displayfield) {
311
+ value = value[props.datafield || props.displayfield];
312
+ } else {
313
+ value = JSON.stringify(value);
314
+ }
315
+ }
316
+ return value;
317
+ })()
318
+ }
319
+ ),
320
+ hint && !shouldShowErrorMessage(validationType, fieldState, touched) && /* @__PURE__ */ jsx(
321
+ "p",
322
+ {
323
+ className: "help-block",
324
+ "aria-hidden": "true",
325
+ role: "alert",
326
+ "aria-live": "polite",
327
+ style: {
328
+ textAlign: "start",
329
+ width: "100%"
330
+ },
331
+ children: hint
332
+ }
333
+ ),
334
+ shouldShowErrorMessage(validationType, fieldState, touched) && /* @__PURE__ */ jsx(
335
+ "p",
336
+ {
337
+ className: "help-block text-danger",
338
+ "aria-hidden": "false",
339
+ role: "alert",
340
+ "aria-live": "assertive",
341
+ style: {
342
+ textAlign: "start",
343
+ width: "100%"
344
+ },
345
+ children: (_a2 = fieldState.error) == null ? void 0 : _a2.message
346
+ }
347
+ )
348
+ ] });
349
+ }
303
350
  }
304
- });
351
+ );
305
352
  });
306
- WithFormControllerComponent.displayName = "withFormController(".concat(WrappedComponent.displayName || WrappedComponent.name || "Component", ")");
353
+ WithFormControllerComponent.displayName = `withFormController(${WrappedComponent.displayName || WrappedComponent.name || "Component"})`;
307
354
  return WithFormControllerComponent;
308
355
  };
309
- var _default = exports["default"] = withFormController;
356
+ var withFormController_default = withFormController;
357
+ export {
358
+ withFormController_default as default
359
+ };