@wavemaker-ai/react-runtime 1.0.0-rc.312 → 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 (571) 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 +210 -155
  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.js +92 -98
  446. package/core/util/safe-is-equal.js +42 -94
  447. package/core/util/security.js +114 -153
  448. package/core/util/utils.d.ts +4 -1
  449. package/core/util/utils.js +88 -159
  450. package/core/widget-observer.js +34 -61
  451. package/higherOrder/BaseApp.js +327 -502
  452. package/higherOrder/BaseAppProps.js +0 -5
  453. package/higherOrder/BaseDateTime.js +277 -231
  454. package/higherOrder/BasePage.js +479 -735
  455. package/higherOrder/BasePartial.js +87 -114
  456. package/higherOrder/BasePrefab.js +190 -206
  457. package/higherOrder/DataNav.js +287 -302
  458. package/higherOrder/helper.js +62 -48
  459. package/higherOrder/props.js +0 -5
  460. package/higherOrder/withBaseWrapper.js +123 -168
  461. package/higherOrder/withStandalone.js +28 -26
  462. package/hooks/useAccess.js +113 -289
  463. package/hooks/useAppConfig.js +15 -40
  464. package/hooks/useAuth.js +256 -495
  465. package/hooks/useDataSourceSubscription.d.ts +3 -3
  466. package/hooks/useDataSourceSubscription.js +99 -109
  467. package/hooks/useDebounce.js +28 -56
  468. package/hooks/useDeviceVisibility.js +14 -23
  469. package/hooks/useHttp.d.ts +1 -0
  470. package/hooks/useHttp.js +318 -493
  471. package/libs/index.js +4 -13
  472. package/libs/prefab/index.js +6 -20
  473. package/mui-config/theme-provider.js +9 -17
  474. package/mui-config/theme.js +6 -9
  475. package/package-lock.json +815 -3206
  476. package/package.json +3 -19
  477. package/providers/AppProviders.js +21 -24
  478. package/runtime-dynamic/App.js +65 -93
  479. package/runtime-dynamic/app-initializer.js +193 -411
  480. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  481. package/runtime-dynamic/components/PageWrapper.js +23 -35
  482. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  483. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  484. package/runtime-dynamic/components/partial-content.js +66 -45
  485. package/runtime-dynamic/components/prefab-content.js +37 -30
  486. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  487. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  488. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  489. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  490. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  491. package/runtime-dynamic/factories/startup-info.js +12 -25
  492. package/runtime-dynamic/factories/utils.d.ts +1 -9
  493. package/runtime-dynamic/factories/utils.js +47 -129
  494. package/runtime-dynamic/index.js +56 -191
  495. package/runtime-dynamic/main.js +42 -70
  496. package/runtime-dynamic/preview-mode.js +14 -29
  497. package/runtime-dynamic/preview-navigation.js +21 -30
  498. package/runtime-dynamic/preview-path.d.ts +5 -0
  499. package/runtime-dynamic/preview-path.js +13 -0
  500. package/runtime-dynamic/preview-resource-base.js +15 -31
  501. package/runtime-dynamic/registry/component-registry.js +269 -334
  502. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  503. package/runtime-dynamic/registry/index.js +24 -63
  504. package/runtime-dynamic/registry/store.d.ts +1 -0
  505. package/runtime-dynamic/registry/store.js +18 -23
  506. package/runtime-dynamic/routes.js +53 -81
  507. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  508. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  509. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  510. package/runtime-dynamic/services/cache.js +27 -33
  511. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  512. package/runtime-dynamic/services/compile-render.js +142 -0
  513. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  514. package/runtime-dynamic/services/css-scoping.js +23 -28
  515. package/runtime-dynamic/services/fragment-url.js +37 -50
  516. package/runtime-dynamic/services/index.js +48 -152
  517. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  518. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  519. package/runtime-dynamic/services/prefab-resources.js +40 -118
  520. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  521. package/runtime-dynamic/services/resource-manager.js +32 -63
  522. package/runtime-dynamic/services/script-executor.js +50 -61
  523. package/runtime-dynamic/services/variable-factory.js +141 -184
  524. package/runtime-dynamic/services/variable-registry.js +69 -115
  525. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  526. package/runtime-dynamic/shims/next-image.js +79 -50
  527. package/runtime-dynamic/shims/next-link.js +58 -32
  528. package/runtime-dynamic/shims/next-navigation.js +17 -34
  529. package/runtime-dynamic/utils/index.js +15 -30
  530. package/store/bindActions/i18nActions.js +16 -18
  531. package/store/index.js +29 -35
  532. package/store/middleware/navigationMiddleware.js +25 -45
  533. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  534. package/store/slices/appConfigSlice.js +65 -94
  535. package/store/slices/authSlice.js +317 -471
  536. package/store/slices/i18nSlice.js +169 -168
  537. package/store/slices/navigationSlice.js +22 -20
  538. package/store/util/resolve-path.d.ts +1 -0
  539. package/store/util/resolve-path.js +7 -0
  540. package/store/viewport.service.js +150 -194
  541. package/types/index.js +10 -15
  542. package/utils/attr.js +198 -41
  543. package/utils/custom-expression/index.js +55 -151
  544. package/utils/custom-expression/parser.js +106 -182
  545. package/utils/dataset-util.js +113 -154
  546. package/utils/eval-expression.js +10 -19
  547. package/utils/form-state.util.js +60 -118
  548. package/utils/form-utils.js +49 -190
  549. package/utils/format-util.js +113 -184
  550. package/utils/layoutsize-util.js +11 -17
  551. package/utils/lib-error-skipper.js +54 -52
  552. package/utils/page-params-util.js +50 -40
  553. package/utils/pending-tab-navigation-intent.js +7 -17
  554. package/utils/resource-url.js +8 -19
  555. package/utils/state-persistance.js +136 -253
  556. package/utils/style-utils.js +24 -78
  557. package/utils/transformedDataset-utils.js +353 -381
  558. package/utils/widget-cleanup-util.js +42 -74
  559. package/utils/widgets.js +19 -31
  560. package/variables/base-variable.js +117 -166
  561. package/variables/constants.js +5 -8
  562. package/variables/crud-variable.js +150 -181
  563. package/variables/live-variable.d.ts +1 -1
  564. package/variables/live-variable.js +140 -174
  565. package/variables/metadata.service.js +74 -116
  566. package/variables/model-variable.js +68 -78
  567. package/variables/service-variable.js +171 -285
  568. package/wm-namespace.js +11 -14
  569. package/components/chart/src/css.d.js +0 -1
  570. package/tsconfig.declaration.tsbuildinfo +0 -1
  571. package/types/global.d.js +0 -3
@@ -1,317 +1,259 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = void 0;
9
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
12
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
- var _react = _interopRequireWildcard(require("react"));
14
- var _styles = require("@mui/material/styles");
15
- var _Box = _interopRequireDefault(require("@mui/material/Box"));
16
- var _lodashEs = require("lodash-es");
17
- var _withBaseWrapper = require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper");
18
- var _message = require("@wavemaker-ai/react-runtime/components/basic/message");
19
- var _formUtils = require("@wavemaker-ai/react-runtime/utils/form-utils");
20
- var _excluded = ["name", "show", "errormessage", "children", "className", "styles", "invokeEventCallback", "appLocale", "onSubmit", "onBeforerender", "onSuccess", "onError", "listener", "eventSource"];
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" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
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
- // Constants
26
- var DEFAULT_CLASS = "app-login";
27
-
28
- // Styled Components
29
- var StyledLoginContainer = (0, _styles.styled)(_Box["default"])(function (_ref) {
30
- var theme = _ref.theme;
31
- return {
32
- "&.app-login": {
33
- display: "block",
34
- position: "relative"
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]);
35
16
  }
36
- };
37
- });
38
- var WmLogin = function WmLogin(props) {
39
- var name = props.name,
40
- _props$show = props.show,
41
- show = _props$show === void 0 ? true : _props$show,
42
- errormessage = props.errormessage,
43
- children = props.children,
44
- className = props.className,
45
- styles = props.styles,
46
- invokeEventCallback = props.invokeEventCallback,
47
- appLocale = props.appLocale,
48
- onSubmit = props.onSubmit,
49
- onBeforerender = props.onBeforerender,
50
- onSuccess = props.onSuccess,
51
- onError = props.onError,
52
- listener = props.listener,
53
- eventSource = props.eventSource,
54
- rest = (0, _objectWithoutProperties2["default"])(props, _excluded);
55
-
56
- // State management
57
- var _useState = (0, _react.useState)({
58
- type: "",
59
- caption: "",
60
- show: false
61
- }),
62
- loginMessage = _useState[0],
63
- setLoginMessage = _useState[1];
64
- var _useState2 = (0, _react.useState)(false),
65
- isSubmitting = _useState2[0],
66
- setIsSubmitting = _useState2[1];
67
-
68
- // Refs
69
- var widgetRef = (0, _react.useRef)(null);
70
- var formRef = (0, _react.useRef)(null);
71
- var loginButtonRef = (0, _react.useRef)(null);
72
- var cleanupFunctionsRef = (0, _react.useRef)([]);
73
- (0, _react.useEffect)(function () {
74
- if (listener !== null && listener !== void 0 && listener.onChange && formRef.current && loginButtonRef.current) {
75
- var _listener$Widgets, _listener$Widgets2, _loginButtonRef$curre;
76
- var formProps = (0, _formUtils.getFormProps)(formRef);
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 { jsx, jsxs } from "react/jsx-runtime";
33
+ import { useEffect, useRef, useState, useCallback } from "react";
34
+ import { styled } from "@mui/material/styles";
35
+ import Box from "@mui/material/Box";
36
+ import { includes } from "lodash-es";
37
+ import { withBaseWrapper } from "../../../higherOrder/withBaseWrapper";
38
+ import { WmMessageWithoutWrapper } from "../../basic/message";
39
+ import {
40
+ getFormData,
41
+ getFormProps,
42
+ invokeFormEvent,
43
+ loginErrorMessage
44
+ } from "../../../utils/form-utils";
45
+ const DEFAULT_CLASS = "app-login";
46
+ const StyledLoginContainer = styled(Box)(({ theme }) => ({
47
+ "&.app-login": {
48
+ display: "block",
49
+ position: "relative"
50
+ }
51
+ }));
52
+ const WmLogin = (props) => {
53
+ const _a = props, {
54
+ name,
55
+ show = true,
56
+ errormessage,
57
+ children,
58
+ className,
59
+ styles,
60
+ invokeEventCallback,
61
+ appLocale,
62
+ onSubmit,
63
+ onBeforerender,
64
+ onSuccess,
65
+ onError,
66
+ listener,
67
+ eventSource
68
+ } = _a, rest = __objRest(_a, [
69
+ "name",
70
+ "show",
71
+ "errormessage",
72
+ "children",
73
+ "className",
74
+ "styles",
75
+ "invokeEventCallback",
76
+ "appLocale",
77
+ "onSubmit",
78
+ "onBeforerender",
79
+ "onSuccess",
80
+ "onError",
81
+ "listener",
82
+ "eventSource"
83
+ ]);
84
+ const [loginMessage, setLoginMessage] = useState({
85
+ type: "",
86
+ caption: "",
87
+ show: false
88
+ });
89
+ const [isSubmitting, setIsSubmitting] = useState(false);
90
+ const widgetRef = useRef(null);
91
+ const formRef = useRef(null);
92
+ const loginButtonRef = useRef(null);
93
+ const cleanupFunctionsRef = useRef([]);
94
+ useEffect(() => {
95
+ var _a2, _b, _c;
96
+ if ((listener == null ? void 0 : listener.onChange) && formRef.current && loginButtonRef.current) {
97
+ const formProps = getFormProps(formRef);
77
98
  if (!formProps) return;
78
- var formName = formProps.name;
99
+ const { name: formName } = formProps;
79
100
  listener.onChange(name, {
80
- formCmp: listener === null || listener === void 0 || (_listener$Widgets = listener.Widgets) === null || _listener$Widgets === void 0 ? void 0 : _listener$Widgets[formName],
81
- loginBtnCmp: listener === null || listener === void 0 || (_listener$Widgets2 = listener.Widgets) === null || _listener$Widgets2 === void 0 ? void 0 : _listener$Widgets2[(loginButtonRef === null || loginButtonRef === void 0 || (_loginButtonRef$curre = loginButtonRef.current) === null || _loginButtonRef$curre === void 0 ? void 0 : _loginButtonRef$curre.getAttribute("name")) || "loginButton"]
101
+ formCmp: (_a2 = listener == null ? void 0 : listener.Widgets) == null ? void 0 : _a2[formName],
102
+ loginBtnCmp: (_c = listener == null ? void 0 : listener.Widgets) == null ? void 0 : _c[((_b = loginButtonRef == null ? void 0 : loginButtonRef.current) == null ? void 0 : _b.getAttribute("name")) || "loginButton"]
82
103
  });
83
104
  }
84
105
  }, [formRef.current]);
85
-
86
- // Callback handlers
87
- var onSuccessCB = (0, _react.useCallback)(function () {
88
- var formData = (0, _formUtils.getFormData)(formRef);
89
- (0, _formUtils.invokeFormEvent)(formRef, listener, "onSuccess", new Event("onSuccess"), formData);
106
+ const onSuccessCB = useCallback(() => {
107
+ const formData = getFormData(formRef);
108
+ invokeFormEvent(formRef, listener, "onSuccess", new Event("onSuccess"), formData);
90
109
  setIsSubmitting(false);
91
- invokeEventCallback === null || invokeEventCallback === void 0 || invokeEventCallback("success");
92
- onSuccess === null || onSuccess === void 0 || onSuccess(new Event("success"), widgetRef.current);
110
+ invokeEventCallback == null ? void 0 : invokeEventCallback("success");
111
+ onSuccess == null ? void 0 : onSuccess(new Event("success"), widgetRef.current);
93
112
  }, [invokeEventCallback, onSuccess, listener]);
94
- var onErrorCB = (0, _react.useCallback)(function (error) {
95
- var formData = (0, _formUtils.getFormData)(formRef);
96
- (0, _formUtils.invokeFormEvent)(formRef, listener, "onError", new Event("onError"), formData);
97
- setIsSubmitting(false);
98
- var message = {
99
- type: "error",
100
- caption: (0, _formUtils.loginErrorMessage)(error, appLocale, errormessage),
101
- show: true
102
- };
103
- setLoginMessage(message);
104
- invokeEventCallback === null || invokeEventCallback === void 0 || invokeEventCallback("error");
105
- onError === null || onError === void 0 || onError(new Event("error"), widgetRef.current);
106
- }, [errormessage, appLocale, invokeEventCallback, onError, listener]);
107
- var doLogin = (0, _react.useCallback)(/*#__PURE__*/function () {
108
- var _ref2 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(e) {
109
- var _formRef$current$clea, _formRef$current2;
110
- var formData, _formRef$current$vali, _formRef$current, beforeSubmitResult;
111
- return _regenerator["default"].wrap(function _callee$(_context) {
112
- while (1) switch (_context.prev = _context.next) {
113
- case 0:
114
- if (!(isSubmitting || !formRef.current)) {
115
- _context.next = 2;
116
- break;
117
- }
118
- return _context.abrupt("return");
119
- case 2:
120
- if (eventSource) {
121
- _context.next = 5;
122
- break;
123
- }
124
- console.warn('Default action "loginAction" does not exist. Either create the Action or assign an event to onSubmit of the login widget');
125
- return _context.abrupt("return");
126
- case 5:
127
- handleMessageClose();
128
- formData = (0, _formUtils.getFormData)(formRef); // Check if form is valid
129
- if (formData.isValid) {
130
- _context.next = 10;
131
- break;
132
- }
133
- (_formRef$current$vali = (_formRef$current = formRef.current).validateForm) === null || _formRef$current$vali === void 0 || _formRef$current$vali.call(_formRef$current);
134
- return _context.abrupt("return");
135
- case 10:
136
- _context.next = 12;
137
- return (0, _formUtils.invokeFormEvent)(formRef, listener, "onBeforeSubmit", e, formData);
138
- case 12:
139
- beforeSubmitResult = _context.sent;
140
- if (!(beforeSubmitResult === false)) {
141
- _context.next = 15;
142
- break;
143
- }
144
- return _context.abrupt("return");
145
- case 15:
146
- (_formRef$current$clea = (_formRef$current2 = formRef.current).clearErrors) === null || _formRef$current$clea === void 0 || _formRef$current$clea.call(_formRef$current2);
147
- setIsSubmitting(true);
148
- eventSource.invoke({
149
- formData: formData.values
150
- }, onSuccessCB, onErrorCB);
151
- (0, _formUtils.invokeFormEvent)(formRef, listener, "onSubmit", e || new Event("submit"), formData);
152
- case 19:
153
- case "end":
154
- return _context.stop();
155
- }
156
- }, _callee);
157
- }));
158
- return function (_x) {
159
- return _ref2.apply(this, arguments);
160
- };
161
- }(), [eventSource, listener, onSuccessCB, onErrorCB, isSubmitting]);
162
-
163
- // Cleanup all event listeners
164
- var cleanupEventListeners = (0, _react.useCallback)(function () {
165
- cleanupFunctionsRef.current.forEach(function (cleanup) {
166
- return cleanup();
167
- });
113
+ const onErrorCB = useCallback(
114
+ (error) => {
115
+ const formData = getFormData(formRef);
116
+ invokeFormEvent(formRef, listener, "onError", new Event("onError"), formData);
117
+ setIsSubmitting(false);
118
+ const message = {
119
+ type: "error",
120
+ caption: loginErrorMessage(error, appLocale, errormessage),
121
+ show: true
122
+ };
123
+ setLoginMessage(message);
124
+ invokeEventCallback == null ? void 0 : invokeEventCallback("error");
125
+ onError == null ? void 0 : onError(new Event("error"), widgetRef.current);
126
+ },
127
+ [errormessage, appLocale, invokeEventCallback, onError, listener]
128
+ );
129
+ const doLogin = useCallback(
130
+ async (e) => {
131
+ var _a2, _b, _c, _d;
132
+ if (isSubmitting || !formRef.current) {
133
+ return;
134
+ }
135
+ if (!eventSource) {
136
+ console.warn(
137
+ 'Default action "loginAction" does not exist. Either create the Action or assign an event to onSubmit of the login widget'
138
+ );
139
+ return;
140
+ }
141
+ handleMessageClose();
142
+ const formData = getFormData(formRef);
143
+ if (!formData.isValid) {
144
+ (_b = (_a2 = formRef.current).validateForm) == null ? void 0 : _b.call(_a2);
145
+ return;
146
+ }
147
+ const beforeSubmitResult = await invokeFormEvent(
148
+ formRef,
149
+ listener,
150
+ "onBeforeSubmit",
151
+ e,
152
+ formData
153
+ );
154
+ if (beforeSubmitResult === false) {
155
+ return;
156
+ }
157
+ (_d = (_c = formRef.current).clearErrors) == null ? void 0 : _d.call(_c);
158
+ setIsSubmitting(true);
159
+ eventSource.invoke({ formData: formData.values }, onSuccessCB, onErrorCB);
160
+ invokeFormEvent(formRef, listener, "onSubmit", e || new Event("submit"), formData);
161
+ },
162
+ [eventSource, listener, onSuccessCB, onErrorCB, isSubmitting]
163
+ );
164
+ const cleanupEventListeners = useCallback(() => {
165
+ cleanupFunctionsRef.current.forEach((cleanup) => cleanup());
168
166
  cleanupFunctionsRef.current = [];
169
167
  }, []);
170
-
171
- // Handle message close
172
- var handleMessageClose = (0, _react.useCallback)(function () {
173
- setLoginMessage(function (prev) {
174
- return _objectSpread(_objectSpread({}, prev), {}, {
175
- show: false
176
- });
177
- });
168
+ const handleMessageClose = useCallback(() => {
169
+ setLoginMessage((prev) => __spreadProps(__spreadValues({}, prev), { show: false }));
178
170
  }, []);
179
-
180
- // Handle form submission
181
- var handleFormSubmit = (0, _react.useCallback)(/*#__PURE__*/function () {
182
- var _ref3 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2(e) {
183
- var _widgetRef$current;
184
- return _regenerator["default"].wrap(function _callee2$(_context2) {
185
- while (1) switch (_context2.prev = _context2.next) {
186
- case 0:
187
- e.preventDefault();
188
- e.stopPropagation();
189
- if (!onSubmit) {
190
- _context2.next = 6;
191
- break;
192
- }
193
- onSubmit(e, widgetRef.current);
194
- _context2.next = 9;
195
- break;
196
- case 6:
197
- if ((_widgetRef$current = widgetRef.current) !== null && _widgetRef$current !== void 0 && _widgetRef$current.hasAttribute("submit.event")) {
198
- _context2.next = 9;
199
- break;
200
- }
201
- _context2.next = 9;
202
- return doLogin(e);
203
- case 9:
204
- case "end":
205
- return _context2.stop();
206
- }
207
- }, _callee2);
208
- }));
209
- return function (_x2) {
210
- return _ref3.apply(this, arguments);
211
- };
212
- }(), [onSubmit, doLogin]);
213
-
214
- // Handle login button click
215
- var handleLoginButtonClick = (0, _react.useCallback)(/*#__PURE__*/function () {
216
- var _ref4 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3(event) {
217
- var button, container, hasContainerSubmitEvent, hasButtonClickEvent, hasButtonTapEvent;
218
- return _regenerator["default"].wrap(function _callee3$(_context3) {
219
- while (1) switch (_context3.prev = _context3.next) {
220
- case 0:
221
- event.preventDefault();
222
- event.stopPropagation();
223
- button = event.target;
224
- container = widgetRef.current;
225
- hasContainerSubmitEvent = container === null || container === void 0 ? void 0 : container.hasAttribute("submit.event");
226
- hasButtonClickEvent = button === null || button === void 0 ? void 0 : button.hasAttribute("click.event");
227
- hasButtonTapEvent = button === null || button === void 0 ? void 0 : button.hasAttribute("tap.event"); // If no event is attached, invoke default login action
228
- if (!(!hasContainerSubmitEvent && !hasButtonClickEvent && !hasButtonTapEvent)) {
229
- _context3.next = 10;
230
- break;
231
- }
232
- _context3.next = 10;
233
- return doLogin(event);
234
- case 10:
235
- case "end":
236
- return _context3.stop();
237
- }
238
- }, _callee3);
239
- }));
240
- return function (_x3) {
241
- return _ref4.apply(this, arguments);
242
- };
243
- }(), [doLogin]);
244
-
245
- // Handle beforerender event
246
- (0, _react.useEffect)(function () {
247
- onBeforerender === null || onBeforerender === void 0 || onBeforerender(new Event("beforerender"), widgetRef.current);
171
+ const handleFormSubmit = useCallback(
172
+ async (e) => {
173
+ var _a2;
174
+ e.preventDefault();
175
+ e.stopPropagation();
176
+ if (onSubmit) {
177
+ onSubmit(e, widgetRef.current);
178
+ } else if (!((_a2 = widgetRef.current) == null ? void 0 : _a2.hasAttribute("submit.event"))) {
179
+ await doLogin(e);
180
+ }
181
+ },
182
+ [onSubmit, doLogin]
183
+ );
184
+ const handleLoginButtonClick = useCallback(
185
+ async (event) => {
186
+ event.preventDefault();
187
+ event.stopPropagation();
188
+ const button = event.target;
189
+ const container = widgetRef.current;
190
+ const hasContainerSubmitEvent = container == null ? void 0 : container.hasAttribute("submit.event");
191
+ const hasButtonClickEvent = button == null ? void 0 : button.hasAttribute("click.event");
192
+ const hasButtonTapEvent = button == null ? void 0 : button.hasAttribute("tap.event");
193
+ if (!hasContainerSubmitEvent && !hasButtonClickEvent && !hasButtonTapEvent) {
194
+ await doLogin(event);
195
+ }
196
+ },
197
+ [doLogin]
198
+ );
199
+ useEffect(() => {
200
+ onBeforerender == null ? void 0 : onBeforerender(new Event("beforerender"), widgetRef.current);
248
201
  }, []);
249
-
250
- // Main setup effect
251
- (0, _react.useEffect)(function () {
252
- var container = widgetRef.current;
202
+ useEffect(() => {
203
+ const container = widgetRef.current;
253
204
  if (!container) return;
254
-
255
- // Clear previous event listeners
256
205
  cleanupEventListeners();
257
-
258
- // Find and set form reference
259
- var formElement = container.querySelector("form") || container.querySelector('[role="form"]');
206
+ const formElement = container.querySelector("form") || container.querySelector('[role="form"]');
260
207
  if (formElement) {
261
208
  formRef.current = formElement;
262
-
263
- // Add form submit event listener
264
209
  formElement.addEventListener("submit", handleFormSubmit);
265
- cleanupFunctionsRef.current.push(function () {
210
+ cleanupFunctionsRef.current.push(() => {
266
211
  formElement.removeEventListener("submit", handleFormSubmit);
267
212
  });
268
213
  }
269
-
270
- // Find and setup login button
271
- var buttons = container.querySelectorAll('button, [role="button"]');
272
- var loginButtonFound = false;
273
- buttons.forEach(function (button) {
214
+ const buttons = container.querySelectorAll('button, [role="button"]');
215
+ let loginButtonFound = false;
216
+ buttons.forEach((button) => {
274
217
  if (loginButtonFound) return;
275
- var name = button.getAttribute("name");
276
- var classList = Array.from(button.classList);
277
- if (name === "loginButton" || (0, _lodashEs.includes)(classList, "app-login-button")) {
218
+ const name2 = button.getAttribute("name");
219
+ const classList = Array.from(button.classList);
220
+ if (name2 === "loginButton" || includes(classList, "app-login-button")) {
278
221
  loginButtonFound = true;
279
222
  loginButtonRef.current = button;
280
-
281
- // Add click event listener
282
223
  button.addEventListener("click", handleLoginButtonClick);
283
- cleanupFunctionsRef.current.push(function () {
224
+ cleanupFunctionsRef.current.push(() => {
284
225
  button.removeEventListener("click", handleLoginButtonClick);
285
226
  });
286
227
  }
287
228
  });
288
-
289
- // Return cleanup function
290
229
  return cleanupEventListeners;
291
230
  }, [children, handleFormSubmit, handleLoginButtonClick, cleanupEventListeners]);
292
- return __jsx(StyledLoginContainer, {
293
- ref: widgetRef,
294
- className: "".concat(DEFAULT_CLASS, " ").concat(className || ""),
295
- sx: styles
296
- }, __jsx(_message.WmMessageWithoutWrapper, {
297
- className: "app-login-message",
298
- name: "LoginMessage",
299
- type: loginMessage.type || "info",
300
- caption: loginMessage.caption,
301
- open: loginMessage.show,
302
- close: handleMessageClose,
303
- listener: listener
304
- }), children);
231
+ return /* @__PURE__ */ jsxs(
232
+ StyledLoginContainer,
233
+ {
234
+ ref: widgetRef,
235
+ className: `${DEFAULT_CLASS} ${className || ""}`,
236
+ sx: styles,
237
+ children: [
238
+ /* @__PURE__ */ jsx(
239
+ WmMessageWithoutWrapper,
240
+ {
241
+ className: "app-login-message",
242
+ name: "LoginMessage",
243
+ type: loginMessage.type || "info",
244
+ caption: loginMessage.caption,
245
+ open: loginMessage.show,
246
+ close: handleMessageClose,
247
+ listener
248
+ }
249
+ ),
250
+ children
251
+ ]
252
+ }
253
+ );
305
254
  };
306
255
  WmLogin.displayName = "WmLogin";
307
-
308
- /**
309
- * The WmLogin component provides a standard login interface with form handling.
310
- *
311
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/advanced-login--showcase)
312
- *
313
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/advanced-login--docs)
314
- *
315
- * @param props - {@link WmLoginProps}
316
- */
317
- var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WmLogin);
256
+ var login_default = withBaseWrapper(WmLogin);
257
+ export {
258
+ login_default as default
259
+ };
@@ -1,5 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });