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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (574) hide show
  1. package/.npmignore +4 -0
  2. package/actions/base-action.js +12 -29
  3. package/actions/login-action.js +35 -52
  4. package/actions/logout-action.js +21 -38
  5. package/actions/navigation-action.js +251 -346
  6. package/actions/notification-action.js +121 -149
  7. package/actions/timer-action.js +95 -151
  8. package/actions/toast-provider.js +62 -76
  9. package/actions/toast.js +95 -91
  10. package/actions/toast.service.js +59 -79
  11. package/actions/types/index.js +6 -9
  12. package/components/advanced/carousel/index.js +358 -366
  13. package/components/advanced/carousel/props.js +0 -5
  14. package/components/advanced/carousel/template.js +102 -80
  15. package/components/advanced/login/index.js +227 -285
  16. package/components/advanced/login/props.js +0 -5
  17. package/components/advanced/marquee/index.js +169 -163
  18. package/components/advanced/marquee/props.js +0 -5
  19. package/components/basic/anchor/index.js +207 -187
  20. package/components/basic/anchor/props.js +0 -5
  21. package/components/basic/audio/index.js +110 -72
  22. package/components/basic/audio/props.js +0 -5
  23. package/components/basic/html/index.js +163 -203
  24. package/components/basic/html/props.js +0 -5
  25. package/components/basic/html/utils.js +30 -28
  26. package/components/basic/icon/index.js +98 -84
  27. package/components/basic/icon/props.js +0 -5
  28. package/components/basic/iframe/iframe.utils.js +7 -16
  29. package/components/basic/iframe/index.js +97 -103
  30. package/components/basic/iframe/props.js +0 -5
  31. package/components/basic/label/index.js +156 -134
  32. package/components/basic/label/props.js +0 -5
  33. package/components/basic/message/index.js +129 -113
  34. package/components/basic/message/props.js +0 -5
  35. package/components/basic/picture/index.js +156 -127
  36. package/components/basic/picture/props.js +0 -5
  37. package/components/basic/progress-bar/index.js +240 -176
  38. package/components/basic/progress-bar/props.js +5 -31
  39. package/components/basic/progress-circle/index.js +166 -183
  40. package/components/basic/progress-circle/props.js +14 -34
  41. package/components/basic/richtexteditor/index.js +430 -396
  42. package/components/basic/richtexteditor/props.js +0 -5
  43. package/components/basic/search/index.js +812 -931
  44. package/components/basic/search/props.js +0 -5
  45. package/components/basic/search/providers.js +233 -380
  46. package/components/basic/spinner/index.js +210 -200
  47. package/components/basic/spinner/props.js +4 -22
  48. package/components/basic/tile/index.js +73 -81
  49. package/components/basic/tile/props.js +0 -5
  50. package/components/basic/tree/Components/TreeNodeComponent.js +238 -170
  51. package/components/basic/tree/hooks/useTreePartialNodeApi.js +143 -135
  52. package/components/basic/tree/index.js +378 -454
  53. package/components/basic/tree/props.js +0 -5
  54. package/components/basic/tree/utils.js +129 -185
  55. package/components/basic/video/index.js +161 -107
  56. package/components/basic/video/props.js +0 -5
  57. package/components/chart/index.js +42 -50
  58. package/components/chart/props.js +31 -37
  59. package/components/chart/src/ChartRenderer.js +172 -154
  60. package/components/chart/src/chart.js +391 -213
  61. package/components/chart/src/chartStyles.generated.js +6 -14
  62. package/components/chart/src/chartUtils.js +228 -272
  63. package/components/chart/src/constants.d.ts +13 -0
  64. package/components/chart/src/constants.js +316 -90
  65. package/components/chart/src/d3Setup.js +11 -30
  66. package/components/chart/src/dataUtils.js +362 -446
  67. package/components/chart/src/formatUtils.js +47 -38
  68. package/components/chart/src/index.js +11 -19
  69. package/components/chart/src/nvd3Source.generated.js +5 -13
  70. package/components/chart/src/pieDonutResponsiveLayout.d.ts +5 -0
  71. package/components/chart/src/pieDonutResponsiveLayout.js +76 -96
  72. package/components/chart/src/types.js +0 -5
  73. package/components/common/AppSpinner.js +17 -33
  74. package/components/common/app-spinner.js +11 -22
  75. package/components/common/customTemplate/index.d.ts +3 -0
  76. package/components/common/customTemplate/index.js +6 -0
  77. package/components/common/customTemplate/props.d.ts +20 -0
  78. package/components/common/customTemplate/props.js +0 -0
  79. package/components/common/customTemplate/template.d.ts +3 -0
  80. package/components/common/customTemplate/template.js +27 -0
  81. package/components/common/customTemplate/useCustomTemplate.d.ts +8 -0
  82. package/components/common/customTemplate/useCustomTemplate.js +17 -0
  83. package/components/common/customTemplate/utils.d.ts +6 -0
  84. package/components/common/customTemplate/utils.js +12 -0
  85. package/components/common/index.js +4 -12
  86. package/components/constants.js +81 -77
  87. package/components/container/accordion/accordion-pane/index.js +105 -118
  88. package/components/container/accordion/accordion-pane/props.js +5 -21
  89. package/components/container/accordion/index.js +225 -243
  90. package/components/container/accordion/props.js +5 -16
  91. package/components/container/index.js +214 -150
  92. package/components/container/layout-grid/grid-column/index.js +68 -43
  93. package/components/container/layout-grid/grid-column/props.js +0 -5
  94. package/components/container/layout-grid/grid-row/index.js +12 -29
  95. package/components/container/layout-grid/grid-row/props.js +0 -5
  96. package/components/container/layout-grid/index.js +53 -38
  97. package/components/container/layout-grid/props.js +0 -5
  98. package/components/container/linear-layout/index.js +56 -60
  99. package/components/container/linear-layout/linear-layout-item/index.js +43 -47
  100. package/components/container/linear-layout/linear-layout-item/props.js +0 -5
  101. package/components/container/linear-layout/props.js +0 -5
  102. package/components/container/panel/components/panel-content/index.js +7 -16
  103. package/components/container/panel/components/panel-header/index.js +166 -146
  104. package/components/container/panel/components/panel-header/props.js +0 -5
  105. package/components/container/panel/hooks.js +76 -102
  106. package/components/container/panel/index.js +289 -252
  107. package/components/container/panel/props.js +0 -5
  108. package/components/container/props.js +0 -5
  109. package/components/container/repeat-template/index.js +65 -44
  110. package/components/container/repeat-template/props.js +0 -5
  111. package/components/container/tabs/index.js +517 -526
  112. package/components/container/tabs/props.js +5 -28
  113. package/components/container/tabs/tab-pane/index.js +105 -100
  114. package/components/container/tabs/tab-pane/props.js +0 -5
  115. package/components/container/tabs/utils.js +30 -35
  116. package/components/container/wizard/WizardContext.js +9 -11
  117. package/components/container/wizard/components/StepComponents.js +76 -99
  118. package/components/container/wizard/components/WizardStep.js +107 -85
  119. package/components/container/wizard/index.js +791 -921
  120. package/components/container/wizard/props.js +0 -5
  121. package/components/container/wizard/utils.js +97 -131
  122. package/components/container/wizard/wizard-action/index.js +41 -81
  123. package/components/container/wizard/wizard-step/index.js +140 -120
  124. package/components/data/card/card-actions/index.js +13 -31
  125. package/components/data/card/card-content/index.js +27 -36
  126. package/components/data/card/card-footer/index.js +13 -31
  127. package/components/data/card/index.js +192 -199
  128. package/components/data/card/props.js +0 -5
  129. package/components/data/form/base-form/constant.js +5 -8
  130. package/components/data/form/base-form/hooks/index.js +26 -77
  131. package/components/data/form/base-form/hooks/useFormDataSync.js +106 -212
  132. package/components/data/form/base-form/hooks/useFormOperations.js +109 -161
  133. package/components/data/form/base-form/hooks/useFormSubmission.js +220 -280
  134. package/components/data/form/base-form/hooks/useFormValidation.js +119 -168
  135. package/components/data/form/base-form/hooks/useParentFormRelationship.js +67 -103
  136. package/components/data/form/base-form/index.js +531 -646
  137. package/components/data/form/base-form/props.js +74 -151
  138. package/components/data/form/base-form/utils.js +210 -323
  139. package/components/data/form/dynamic-fields/constant.js +43 -53
  140. package/components/data/form/dynamic-fields/index.js +135 -144
  141. package/components/data/form/dynamic-fields/props.js +0 -5
  142. package/components/data/form/dynamic-fields/utils.js +99 -158
  143. package/components/data/form/form-action/index.js +107 -85
  144. package/components/data/form/form-body/index.js +52 -26
  145. package/components/data/form/form-context.js +43 -59
  146. package/components/data/form/form-controller/hooks/index.js +43 -57
  147. package/components/data/form/form-controller/props.js +5 -8
  148. package/components/data/form/form-controller/utils.js +54 -49
  149. package/components/data/form/form-controller/validation-contrustor.js +203 -426
  150. package/components/data/form/form-controller/withFormController.js +319 -269
  151. package/components/data/form/form-dynamic-section/index.js +47 -41
  152. package/components/data/form/form-dynamic-section/props.js +0 -5
  153. package/components/data/form/form-field/base-field.js +97 -109
  154. package/components/data/form/form-field/index.js +91 -82
  155. package/components/data/form/form-field/props.js +0 -5
  156. package/components/data/form/form-footer/index.js +52 -25
  157. package/components/data/form/form-header/index.js +61 -58
  158. package/components/data/form/index.js +95 -74
  159. package/components/data/form/props.js +0 -5
  160. package/components/data/list/components/GroupHeader.js +34 -33
  161. package/components/data/list/components/GroupedListItems.js +108 -104
  162. package/components/data/list/components/ListContainer.js +22 -27
  163. package/components/data/list/components/ListDND.js +193 -185
  164. package/components/data/list/components/ListHeader.js +32 -49
  165. package/components/data/list/components/ListItem.js +153 -146
  166. package/components/data/list/components/ListItemWithTemplate.js +87 -105
  167. package/components/data/list/components/ListItems.js +180 -194
  168. package/components/data/list/components/ListPagination.js +127 -153
  169. package/components/data/list/components/LoadMoreButton.js +25 -33
  170. package/components/data/list/components/NoDataMessage.js +9 -22
  171. package/components/data/list/components/StandardListItems.js +79 -85
  172. package/components/data/list/components/index.js +31 -119
  173. package/components/data/list/components/props.js +0 -5
  174. package/components/data/list/hooks/index.js +22 -75
  175. package/components/data/list/hooks/props.js +0 -5
  176. package/components/data/list/hooks/useCurrentPageItems.js +20 -38
  177. package/components/data/list/hooks/useGroupedData.js +19 -33
  178. package/components/data/list/hooks/useListData.js +17 -47
  179. package/components/data/list/hooks/useListEffects.js +168 -237
  180. package/components/data/list/hooks/useListEventHandlers.js +301 -285
  181. package/components/data/list/hooks/useListPagination.js +90 -136
  182. package/components/data/list/hooks/useListState.js +49 -91
  183. package/components/data/list/hooks/useListStateManager.js +104 -159
  184. package/components/data/list/hooks/usePaginatedGroupedData.js +74 -110
  185. package/components/data/list/index.d.ts +1 -0
  186. package/components/data/list/index.js +579 -621
  187. package/components/data/list/props.d.ts +4 -0
  188. package/components/data/list/props.js +0 -5
  189. package/components/data/list/templates/media-template.js +29 -50
  190. package/components/data/list/utils/constants.js +20 -32
  191. package/components/data/list/utils/list-helpers.d.ts +2 -1
  192. package/components/data/list/utils/list-helpers.js +71 -115
  193. package/components/data/list/utils/list-widget-methods.js +56 -76
  194. package/components/data/list/utils/widget-instance-utils.js +20 -57
  195. package/components/data/live-filter/index.js +219 -271
  196. package/components/data/live-filter/props.js +5 -12
  197. package/components/data/live-form/index.js +68 -91
  198. package/components/data/live-form/props.js +5 -12
  199. package/components/data/pagination/components/BasicPagination.js +124 -104
  200. package/components/data/pagination/components/ClassicPagination.js +167 -190
  201. package/components/data/pagination/components/InlinePagination.js +97 -98
  202. package/components/data/pagination/components/LoadingComponent.js +17 -30
  203. package/components/data/pagination/components/PageSizeSelector.js +176 -169
  204. package/components/data/pagination/components/PagerNavigation.js +84 -105
  205. package/components/data/pagination/components/TotalRecords.js +48 -47
  206. package/components/data/pagination/components/index.js +14 -47
  207. package/components/data/pagination/components/props.js +0 -5
  208. package/components/data/pagination/hooks/index.js +6 -19
  209. package/components/data/pagination/hooks/props.js +0 -5
  210. package/components/data/pagination/hooks/useNavigationSize.js +12 -21
  211. package/components/data/pagination/hooks/usePagination.js +702 -905
  212. package/components/data/pagination/index.js +336 -389
  213. package/components/data/table/components/AddNewRow.js +122 -154
  214. package/components/data/table/components/EditableCell.js +68 -75
  215. package/components/data/table/components/FieldValidationError.js +19 -20
  216. package/components/data/table/components/RowCells.js +97 -80
  217. package/components/data/table/components/RowExpansionButton.js +43 -39
  218. package/components/data/table/components/SummaryCell.js +54 -88
  219. package/components/data/table/components/SummaryRow.js +45 -52
  220. package/components/data/table/components/SummaryRowFooter.js +35 -42
  221. package/components/data/table/components/TableBody.js +222 -218
  222. package/components/data/table/components/TableDataRow.js +113 -106
  223. package/components/data/table/components/TableFilters.js +391 -390
  224. package/components/data/table/components/TableFooterActions.js +25 -32
  225. package/components/data/table/components/TableHeader.js +460 -435
  226. package/components/data/table/components/TablePanelHeading.js +157 -181
  227. package/components/data/table/components/index.js +27 -95
  228. package/components/data/table/hooks/index.js +21 -230
  229. package/components/data/table/hooks/use-edited-rows.js +59 -94
  230. package/components/data/table/hooks/useCellState.js +58 -83
  231. package/components/data/table/hooks/useCustomExpressionColumns.js +65 -86
  232. package/components/data/table/hooks/useDynamicColumns.js +59 -92
  233. package/components/data/table/hooks/useEditingState.js +30 -41
  234. package/components/data/table/hooks/useFormWidget.js +163 -172
  235. package/components/data/table/hooks/usePaginationState.js +67 -77
  236. package/components/data/table/hooks/usePanelStructure.js +47 -41
  237. package/components/data/table/hooks/useResponsiveColumns.js +14 -20
  238. package/components/data/table/hooks/useRowExpansion.js +131 -127
  239. package/components/data/table/hooks/useRowHandlers.js +56 -69
  240. package/components/data/table/hooks/useRowSelection.js +249 -329
  241. package/components/data/table/hooks/useServerSideSorting.js +109 -175
  242. package/components/data/table/hooks/useTableColumns.js +322 -331
  243. package/components/data/table/hooks/useTableData.js +111 -166
  244. package/components/data/table/hooks/useTableEdit.js +526 -564
  245. package/components/data/table/hooks/useTableEffects.js +60 -107
  246. package/components/data/table/hooks/useTableFilter.js +244 -237
  247. package/components/data/table/hooks/useTableInitialization.js +44 -76
  248. package/components/data/table/hooks/useTableState.js +39 -61
  249. package/components/data/table/hooks/useTableStateManager.js +295 -468
  250. package/components/data/table/index.js +1553 -1713
  251. package/components/data/table/live-table/index.js +157 -219
  252. package/components/data/table/props.js +0 -5
  253. package/components/data/table/table-action/index.js +97 -75
  254. package/components/data/table/table-column/index.js +48 -42
  255. package/components/data/table/table-group/index.js +7 -25
  256. package/components/data/table/table-row/index.js +63 -55
  257. package/components/data/table/table-row-action/index.js +102 -77
  258. package/components/data/table/utils/buildSelectionColumns.js +86 -137
  259. package/components/data/table/utils/columnBuilder.js +116 -158
  260. package/components/data/table/utils/columnProxy.js +48 -66
  261. package/components/data/table/utils/columnWidthDistribution.js +40 -64
  262. package/components/data/table/utils/constants.js +92 -40
  263. package/components/data/table/utils/crud-handlers.js +292 -473
  264. package/components/data/table/utils/dynamic-columns.js +99 -144
  265. package/components/data/table/utils/groupHeaderUtils.js +36 -61
  266. package/components/data/table/utils/index.d.ts +8 -5
  267. package/components/data/table/utils/index.js +419 -639
  268. package/components/data/table/utils/renderDisplayCell.js +127 -169
  269. package/components/data/table/utils/script-page-size-broadcast.js +17 -29
  270. package/components/data/table/utils/selectionUtils.js +59 -113
  271. package/components/data/table/utils/table-helpers.js +38 -74
  272. package/components/data/table/utils/validation.js +35 -78
  273. package/components/data/table/utils/widgetMapping.d.ts +5 -0
  274. package/components/data/table/utils/widgetMapping.js +41 -0
  275. package/components/data/types.js +112 -112
  276. package/components/data/utils/field-data-utils.js +38 -42
  277. package/components/data/utils/filter-field-util.js +42 -44
  278. package/components/data/utils/index.js +112 -111
  279. package/components/dialogs/alert-dialog/index.js +83 -78
  280. package/components/dialogs/alert-dialog/props.js +0 -5
  281. package/components/dialogs/confirm-dialog/index.js +102 -92
  282. package/components/dialogs/confirm-dialog/props.js +0 -5
  283. package/components/dialogs/dialog/index.js +93 -69
  284. package/components/dialogs/dialog/props.js +0 -5
  285. package/components/dialogs/dialog-actions/index.js +12 -26
  286. package/components/dialogs/dialog-actions/props.js +0 -5
  287. package/components/dialogs/dialog-body/index.js +13 -30
  288. package/components/dialogs/dialog-body/props.js +0 -5
  289. package/components/dialogs/dialog-content/index.js +48 -41
  290. package/components/dialogs/dialog-content/props.js +0 -5
  291. package/components/dialogs/dialog-header/index.js +88 -101
  292. package/components/dialogs/dialog-header/props.js +0 -5
  293. package/components/dialogs/iframe-dialog/index.js +136 -128
  294. package/components/dialogs/iframe-dialog/props.js +0 -5
  295. package/components/dialogs/index.js +104 -101
  296. package/components/dialogs/login-dialog/index.js +285 -347
  297. package/components/dialogs/login-dialog/props.js +0 -5
  298. package/components/dialogs/page-dialog/index.js +95 -86
  299. package/components/dialogs/page-dialog/props.js +0 -5
  300. package/components/dialogs/props.js +0 -5
  301. package/components/dialogs/withDialogWrapper.js +110 -83
  302. package/components/form/button/index.js +296 -245
  303. package/components/form/button/props.js +0 -5
  304. package/components/form/button-group/index.js +80 -69
  305. package/components/form/button-group/props.js +0 -5
  306. package/components/input/calendar/index.js +409 -362
  307. package/components/input/calendar/props.js +0 -5
  308. package/components/input/calendar/utils.js +164 -172
  309. package/components/input/chips/SortableChip/index.js +109 -100
  310. package/components/input/chips/SortableChip/props.js +0 -5
  311. package/components/input/chips/index.js +663 -570
  312. package/components/input/chips/props.js +0 -5
  313. package/components/input/chips/utils.js +131 -122
  314. package/components/input/color-picker/index.js +536 -594
  315. package/components/input/color-picker/props.js +0 -5
  316. package/components/input/composite/index.js +71 -110
  317. package/components/input/composite/props.js +0 -5
  318. package/components/input/currency/index.js +277 -224
  319. package/components/input/currency/props.js +0 -5
  320. package/components/input/default/checkbox/index.js +329 -250
  321. package/components/input/default/checkbox/props.js +0 -5
  322. package/components/input/default/checkboxset/index.d.ts +2 -0
  323. package/components/input/default/checkboxset/index.js +529 -446
  324. package/components/input/default/checkboxset/props.d.ts +4 -0
  325. package/components/input/default/checkboxset/props.js +0 -5
  326. package/components/input/default/checkboxset/utils.js +15 -25
  327. package/components/input/default/radioset/index.d.ts +2 -0
  328. package/components/input/default/radioset/index.js +409 -350
  329. package/components/input/default/radioset/props.d.ts +6 -0
  330. package/components/input/default/radioset/props.js +0 -5
  331. package/components/input/default/switch/index.js +494 -458
  332. package/components/input/default/switch/prop.js +0 -5
  333. package/components/input/epoch/date/components/DatePickerPopover.js +242 -193
  334. package/components/input/epoch/date/index.js +638 -518
  335. package/components/input/epoch/date/props.js +0 -5
  336. package/components/input/epoch/date/styled.js +61 -70
  337. package/components/input/epoch/date/utils.js +67 -115
  338. package/components/input/epoch/datetime/index.js +758 -695
  339. package/components/input/epoch/datetime/props.js +0 -5
  340. package/components/input/epoch/datetime/utils.js +121 -186
  341. package/components/input/epoch/time/index.js +441 -415
  342. package/components/input/epoch/time/props.js +0 -5
  343. package/components/input/epoch/time/utils.js +101 -112
  344. package/components/input/fileupload/Utils.js +70 -97
  345. package/components/input/fileupload/components/ListItems.js +132 -130
  346. package/components/input/fileupload/components/MultiUpload.js +80 -77
  347. package/components/input/fileupload/components/SingleUpload.js +57 -57
  348. package/components/input/fileupload/index.js +253 -178
  349. package/components/input/fileupload/props.js +0 -5
  350. package/components/input/fileupload/useFileUpload.js +209 -258
  351. package/components/input/number/index.js +434 -393
  352. package/components/input/number/props.js +0 -5
  353. package/components/input/rating/index.js +401 -394
  354. package/components/input/rating/props.js +0 -5
  355. package/components/input/select/index.js +408 -463
  356. package/components/input/select/props.js +0 -5
  357. package/components/input/slider/index.js +339 -332
  358. package/components/input/slider/props.js +0 -5
  359. package/components/input/text/index.d.ts +3 -3
  360. package/components/input/text/index.js +438 -475
  361. package/components/input/text/props.d.ts +1 -1
  362. package/components/input/text/props.js +0 -5
  363. package/components/input/text/util.js +82 -222
  364. package/components/input/textarea/index.js +322 -358
  365. package/components/input/textarea/props.js +0 -5
  366. package/components/input/upload/index.js +135 -131
  367. package/components/input/upload/props.js +0 -5
  368. package/components/input/util/index.js +9 -11
  369. package/components/layout/footer/index.js +12 -35
  370. package/components/layout/footer/props.js +0 -5
  371. package/components/layout/header/index.js +12 -38
  372. package/components/layout/header/props.js +0 -5
  373. package/components/layout/leftnav/index.js +38 -44
  374. package/components/layout/leftnav/props.js +0 -5
  375. package/components/layout/rightnav/index.js +12 -36
  376. package/components/layout/rightnav/props.js +0 -5
  377. package/components/layout/topnav/index.js +24 -38
  378. package/components/layout/topnav/props.js +0 -5
  379. package/components/navbar/index.js +119 -98
  380. package/components/navbar/nav/index.js +236 -232
  381. package/components/navbar/nav/props.js +0 -5
  382. package/components/navbar/nav-item/index.js +74 -65
  383. package/components/navbar/nav-item/props.js +0 -5
  384. package/components/navigation/breadcrumb/index.js +38 -61
  385. package/components/navigation/breadcrumb/props.js +0 -5
  386. package/components/navigation/menu/components/ListItems.js +76 -67
  387. package/components/navigation/menu/constants.js +27 -42
  388. package/components/navigation/menu/hooks/useHoverState.hook.js +20 -47
  389. package/components/navigation/menu/hooks/useKeyboardMovements.hook.js +34 -28
  390. package/components/navigation/menu/hooks/useTransformedDataset.hook.js +21 -14
  391. package/components/navigation/menu/index.js +911 -846
  392. package/components/navigation/menu/props.js +0 -5
  393. package/components/navigation/menu/utils/action-task.js +6 -9
  394. package/components/navigation/menu/utils/role-filter.js +41 -56
  395. package/components/navigation/popover/index.js +191 -205
  396. package/components/navigation/popover/props.js +5 -8
  397. package/components/page/content/index.js +9 -31
  398. package/components/page/content/props.js +0 -5
  399. package/components/page/error-boundary/index.js +115 -105
  400. package/components/page/error-boundary/props.js +0 -5
  401. package/components/page/index.js +84 -102
  402. package/components/page/page-content/index.js +21 -30
  403. package/components/page/page-content/props.js +0 -5
  404. package/components/page/partial/index.js +50 -45
  405. package/components/page/partial/props.js +0 -5
  406. package/components/page/partial-container/index.js +81 -107
  407. package/components/page/partial-container/props.d.ts +1 -1
  408. package/components/page/partial-container/props.js +0 -5
  409. package/components/page/props.js +0 -5
  410. package/components/page/toast-container/index.js +20 -41
  411. package/components/page/toast-container/props.js +0 -5
  412. package/components/prefab/container/index.js +60 -53
  413. package/components/prefab/container/props.js +0 -5
  414. package/components/prefab/index.js +76 -61
  415. package/components/prefab/props.js +0 -5
  416. package/context/AppContext.d.ts +1 -1
  417. package/context/AppContext.js +17 -18
  418. package/context/AppSpinnerProvider.js +19 -34
  419. package/context/LayoutProvider.js +54 -57
  420. package/context/LocalizationProvider.js +34 -49
  421. package/context/PrefabContext.js +68 -119
  422. package/context/WidgetProvider.js +160 -166
  423. package/core/app-config.js +0 -1
  424. package/core/app.service.js +200 -327
  425. package/core/appVariablesStore.js +10 -15
  426. package/core/appstore.js +37 -53
  427. package/core/constants/currency-constant.js +81 -83
  428. package/core/constants/events.js +34 -44
  429. package/core/constants/index.js +21 -31
  430. package/core/dialog.service.js +52 -72
  431. package/core/event-notifier.js +94 -131
  432. package/core/formatter/array-formatters.js +18 -32
  433. package/core/formatter/date-formatters.js +140 -204
  434. package/core/formatter/index.js +64 -117
  435. package/core/formatter/number-formatters.js +115 -159
  436. package/core/formatter/security-formatters.js +233 -283
  437. package/core/formatter/string-formatters.js +23 -45
  438. package/core/formatter/types.js +12 -18
  439. package/core/formatters.js +6 -24
  440. package/core/proxy-service.js +242 -306
  441. package/core/script-registry.js +87 -134
  442. package/core/security.service.js +8 -11
  443. package/core/util/compare.js +13 -25
  444. package/core/util/dom.js +32 -63
  445. package/core/util/index.d.ts +5 -0
  446. package/core/util/index.js +95 -95
  447. package/core/util/safe-is-equal.js +42 -94
  448. package/core/util/security.js +114 -153
  449. package/core/util/utils.d.ts +8 -1
  450. package/core/util/utils.js +124 -132
  451. package/core/widget-observer.js +34 -61
  452. package/higherOrder/BaseApp.js +327 -500
  453. package/higherOrder/BaseAppProps.js +0 -5
  454. package/higherOrder/BaseDateTime.js +277 -231
  455. package/higherOrder/BasePage.js +479 -735
  456. package/higherOrder/BasePartial.js +87 -114
  457. package/higherOrder/BasePrefab.js +190 -206
  458. package/higherOrder/DataNav.js +287 -302
  459. package/higherOrder/helper.js +62 -48
  460. package/higherOrder/props.js +0 -5
  461. package/higherOrder/withBaseWrapper.js +123 -168
  462. package/higherOrder/withStandalone.js +28 -26
  463. package/hooks/useAccess.js +113 -289
  464. package/hooks/useAppConfig.js +15 -40
  465. package/hooks/useAuth.js +256 -495
  466. package/hooks/useDataSourceSubscription.d.ts +3 -3
  467. package/hooks/useDataSourceSubscription.js +99 -109
  468. package/hooks/useDebounce.js +28 -56
  469. package/hooks/useDeviceVisibility.js +14 -23
  470. package/hooks/useHttp.d.ts +1 -0
  471. package/hooks/useHttp.js +318 -493
  472. package/libs/index.js +4 -13
  473. package/libs/prefab/index.js +6 -20
  474. package/mui-config/theme-provider.js +9 -17
  475. package/mui-config/theme.js +6 -9
  476. package/package-lock.json +822 -3191
  477. package/package.json +3 -19
  478. package/providers/AppProviders.js +21 -24
  479. package/runtime-dynamic/App.js +65 -93
  480. package/runtime-dynamic/app-initializer.js +207 -400
  481. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  482. package/runtime-dynamic/components/PageWrapper.js +23 -35
  483. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  484. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  485. package/runtime-dynamic/components/partial-content.js +66 -48
  486. package/runtime-dynamic/components/prefab-content.js +37 -30
  487. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  488. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  489. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  490. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  491. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  492. package/runtime-dynamic/factories/startup-info.js +12 -25
  493. package/runtime-dynamic/factories/utils.d.ts +1 -9
  494. package/runtime-dynamic/factories/utils.js +47 -130
  495. package/runtime-dynamic/index.js +56 -191
  496. package/runtime-dynamic/main.js +42 -70
  497. package/runtime-dynamic/preview-mode.js +14 -29
  498. package/runtime-dynamic/preview-navigation.js +21 -30
  499. package/runtime-dynamic/preview-path.d.ts +5 -0
  500. package/runtime-dynamic/preview-path.js +13 -0
  501. package/runtime-dynamic/preview-resource-base.js +15 -31
  502. package/runtime-dynamic/registry/component-registry.js +269 -334
  503. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  504. package/runtime-dynamic/registry/index.js +24 -63
  505. package/runtime-dynamic/registry/store.d.ts +1 -0
  506. package/runtime-dynamic/registry/store.js +18 -23
  507. package/runtime-dynamic/routes.js +53 -81
  508. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  509. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  510. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  511. package/runtime-dynamic/services/cache.js +27 -33
  512. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  513. package/runtime-dynamic/services/compile-render.js +142 -0
  514. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  515. package/runtime-dynamic/services/css-scoping.js +27 -28
  516. package/runtime-dynamic/services/fragment-url.js +37 -50
  517. package/runtime-dynamic/services/index.js +48 -152
  518. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  519. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  520. package/runtime-dynamic/services/prefab-resources.js +42 -130
  521. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  522. package/runtime-dynamic/services/resource-manager.js +32 -63
  523. package/runtime-dynamic/services/script-executor.js +50 -61
  524. package/runtime-dynamic/services/variable-factory.js +141 -184
  525. package/runtime-dynamic/services/variable-registry.js +69 -115
  526. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  527. package/runtime-dynamic/shims/next-image.js +79 -50
  528. package/runtime-dynamic/shims/next-link.js +58 -32
  529. package/runtime-dynamic/shims/next-navigation.js +17 -34
  530. package/runtime-dynamic/utils/index.d.ts +2 -0
  531. package/runtime-dynamic/utils/index.js +22 -24
  532. package/store/bindActions/i18nActions.js +16 -18
  533. package/store/index.js +29 -35
  534. package/store/middleware/navigationMiddleware.js +25 -45
  535. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  536. package/store/slices/appConfigSlice.js +65 -94
  537. package/store/slices/authSlice.js +317 -471
  538. package/store/slices/i18nSlice.js +169 -168
  539. package/store/slices/navigationSlice.js +22 -20
  540. package/store/util/resolve-path.d.ts +1 -0
  541. package/store/util/resolve-path.js +7 -0
  542. package/store/viewport.service.js +150 -194
  543. package/types/index.js +10 -15
  544. package/utils/attr.js +198 -41
  545. package/utils/custom-expression/index.js +55 -151
  546. package/utils/custom-expression/parser.js +106 -182
  547. package/utils/dataset-util.js +113 -154
  548. package/utils/eval-expression.js +10 -19
  549. package/utils/form-state.util.js +60 -118
  550. package/utils/form-utils.js +49 -190
  551. package/utils/format-util.js +113 -184
  552. package/utils/layoutsize-util.js +11 -17
  553. package/utils/lib-error-skipper.js +54 -52
  554. package/utils/page-params-util.js +50 -40
  555. package/utils/pending-tab-navigation-intent.js +7 -17
  556. package/utils/resource-url.js +8 -19
  557. package/utils/state-persistance.js +136 -253
  558. package/utils/style-utils.d.ts +2 -0
  559. package/utils/style-utils.js +25 -74
  560. package/utils/transformedDataset-utils.js +353 -381
  561. package/utils/widget-cleanup-util.js +42 -74
  562. package/utils/widgets.js +19 -31
  563. package/variables/base-variable.js +117 -166
  564. package/variables/constants.js +5 -8
  565. package/variables/crud-variable.js +150 -181
  566. package/variables/live-variable.d.ts +1 -1
  567. package/variables/live-variable.js +140 -174
  568. package/variables/metadata.service.js +74 -116
  569. package/variables/model-variable.js +68 -78
  570. package/variables/service-variable.js +171 -285
  571. package/wm-namespace.js +11 -14
  572. package/components/chart/src/css.d.js +0 -1
  573. package/tsconfig.declaration.tsbuildinfo +0 -1
  574. package/types/global.d.js +0 -3
package/hooks/useAuth.js CHANGED
@@ -1,416 +1,235 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- Object.defineProperty(exports, "__esModule", {
5
- value: true
6
- });
7
- exports.useWidgetAccess = exports.usePageAccess = exports.useLogout = exports.useLogin = exports.useCurrentUser = exports.useAuth = exports.useAccess = exports.checkAccessSync = void 0;
8
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
9
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
- var _react = require("react");
12
- var _store = require("../store");
13
- var _authSlice = require("@wavemaker-ai/react-runtime/store/slices/authSlice");
14
- var _includes = _interopRequireDefault(require("lodash-es/includes"));
15
- var _appConfigSlice = require("../store/slices/appConfigSlice");
16
- 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; }
17
- 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; }
18
- var useAuth = exports.useAuth = function useAuth() {
19
- var dispatch = (0, _store.useAppDispatch)();
20
- var _useAppSelector = (0, _store.useAppSelector)(function (state) {
21
- return state.auth;
22
- }),
23
- isLoggedIn = _useAppSelector.isLoggedIn,
24
- loggedInUser = _useAppSelector.loggedInUser,
25
- securityConfig = _useAppSelector.securityConfig,
26
- isPageLoading = _useAppSelector.isPageLoading,
27
- error = _useAppSelector.error;
28
- var handleLogin = /*#__PURE__*/function () {
29
- var _ref = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee(options) {
30
- var loginResponse;
31
- return _regenerator["default"].wrap(function _callee$(_context) {
32
- while (1) switch (_context.prev = _context.next) {
33
- case 0:
34
- _context.prev = 0;
35
- _context.next = 3;
36
- return dispatch((0, _authSlice.login)(options)).unwrap();
37
- case 3:
38
- loginResponse = _context.sent;
39
- return _context.abrupt("return", loginResponse);
40
- case 7:
41
- _context.prev = 7;
42
- _context.t0 = _context["catch"](0);
43
- throw _context.t0;
44
- case 10:
45
- case "end":
46
- return _context.stop();
47
- }
48
- }, _callee, null, [[0, 7]]);
49
- }));
50
- return function handleLogin(_x) {
51
- return _ref.apply(this, arguments);
52
- };
53
- }();
54
- var handleLogout = /*#__PURE__*/function () {
55
- var _ref2 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2(baseURL) {
56
- var logoutResponse;
57
- return _regenerator["default"].wrap(function _callee2$(_context2) {
58
- while (1) switch (_context2.prev = _context2.next) {
59
- case 0:
60
- _context2.prev = 0;
61
- _context2.next = 3;
62
- return dispatch((0, _authSlice.logout)({
63
- baseURL: baseURL
64
- })).unwrap();
65
- case 3:
66
- logoutResponse = _context2.sent;
67
- return _context2.abrupt("return", logoutResponse);
68
- case 7:
69
- _context2.prev = 7;
70
- _context2.t0 = _context2["catch"](0);
71
- return _context2.abrupt("return", _context2.t0);
72
- case 10:
73
- case "end":
74
- return _context2.stop();
75
- }
76
- }, _callee2, null, [[0, 7]]);
77
- }));
78
- return function handleLogout(_x2) {
79
- return _ref2.apply(this, arguments);
80
- };
81
- }();
82
- var checkCanAccessPage = /*#__PURE__*/function () {
83
- var _ref3 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3(pageName) {
84
- var baseUrl;
85
- return _regenerator["default"].wrap(function _callee3$(_context3) {
86
- while (1) switch (_context3.prev = _context3.next) {
87
- case 0:
88
- baseUrl = (securityConfig === null || securityConfig === void 0 ? void 0 : securityConfig.baseUrl) || "";
89
- _context3.next = 3;
90
- return dispatch((0, _authSlice.canAccessPage)({
91
- pageName: pageName
92
- })).unwrap();
93
- case 3:
94
- return _context3.abrupt("return", _context3.sent);
95
- case 4:
96
- case "end":
97
- return _context3.stop();
98
- }
99
- }, _callee3);
100
- }));
101
- return function checkCanAccessPage(_x3) {
102
- return _ref3.apply(this, arguments);
103
- };
104
- }();
105
- var hasAccessToWidget = function hasAccessToWidget(widgetRoles) {
106
- var widgetRolesArr = widgetRoles.split(",");
107
-
108
- // Access the widget when 'Everyone' is chosen
109
- if ((0, _includes["default"])(widgetRolesArr, _authSlice.USER_ROLE.EVERYONE)) {
1
+ var __defProp = Object.defineProperty;
2
+ var __defProps = Object.defineProperties;
3
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
+ var __spreadValues = (a, b) => {
9
+ for (var prop in b || (b = {}))
10
+ if (__hasOwnProp.call(b, prop))
11
+ __defNormalProp(a, prop, b[prop]);
12
+ if (__getOwnPropSymbols)
13
+ for (var prop of __getOwnPropSymbols(b)) {
14
+ if (__propIsEnum.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ }
17
+ return a;
18
+ };
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { useEffect, useState } from "react";
21
+ import { useAppDispatch, useAppSelector } from "../store";
22
+ import {
23
+ loadSecurityInfo,
24
+ login,
25
+ logout,
26
+ canAccessPage,
27
+ checkAccess,
28
+ USER_ROLE,
29
+ navigateToLandingPage,
30
+ setPageLoading
31
+ } from "../store/slices/authSlice";
32
+ import includes from "lodash-es/includes";
33
+ import { getServiceDefinitions } from "../store/slices/appConfigSlice";
34
+ const useAuth = () => {
35
+ const dispatch = useAppDispatch();
36
+ const { isLoggedIn, loggedInUser, securityConfig, isPageLoading, error } = useAppSelector(
37
+ (state) => state.auth
38
+ );
39
+ const handleLogin = async (options) => {
40
+ try {
41
+ const loginResponse = await dispatch(login(options)).unwrap();
42
+ return loginResponse;
43
+ } catch (error2) {
44
+ throw error2;
45
+ }
46
+ };
47
+ const handleLogout = async (baseURL) => {
48
+ try {
49
+ const logoutResponse = await dispatch(logout({ baseURL })).unwrap();
50
+ return logoutResponse;
51
+ } catch (error2) {
52
+ return error2;
53
+ }
54
+ };
55
+ const checkCanAccessPage = async (pageName) => {
56
+ const baseUrl = (securityConfig == null ? void 0 : securityConfig.baseUrl) || "";
57
+ return await dispatch(canAccessPage({ pageName })).unwrap();
58
+ };
59
+ const hasAccessToWidget = (widgetRoles) => {
60
+ const widgetRolesArr = widgetRoles.split(",");
61
+ if (includes(widgetRolesArr, USER_ROLE.EVERYONE)) {
110
62
  return true;
111
63
  }
112
-
113
- // Access the widget when 'Anonymous' is chosen and user is not authenticated
114
- if ((0, _includes["default"])(widgetRolesArr, _authSlice.USER_ROLE.ANONYMOUS) && !(loggedInUser !== null && loggedInUser !== void 0 && loggedInUser.isAuthenticated)) {
64
+ if (includes(widgetRolesArr, USER_ROLE.ANONYMOUS) && !(loggedInUser == null ? void 0 : loggedInUser.isAuthenticated)) {
115
65
  return true;
116
66
  }
117
-
118
- // Access the widget when 'Only Authenticated Users' is chosen and user is authenticated
119
- if ((0, _includes["default"])(widgetRolesArr, _authSlice.USER_ROLE.AUTHENTICATED) && loggedInUser !== null && loggedInUser !== void 0 && loggedInUser.isAuthenticated) {
67
+ if (includes(widgetRolesArr, USER_ROLE.AUTHENTICATED) && (loggedInUser == null ? void 0 : loggedInUser.isAuthenticated)) {
120
68
  return true;
121
69
  }
122
-
123
- // Access the widget when widget role and logged in user role matches
124
- return !!(loggedInUser !== null && loggedInUser !== void 0 && loggedInUser.isAuthenticated) && matchRoles(widgetRolesArr, (loggedInUser === null || loggedInUser === void 0 ? void 0 : loggedInUser.roles) || []);
70
+ return !!(loggedInUser == null ? void 0 : loggedInUser.isAuthenticated) && matchRoles(widgetRolesArr, (loggedInUser == null ? void 0 : loggedInUser.roles) || []);
125
71
  };
126
- var matchRoles = function matchRoles(widgetRoles, userRoles) {
127
- return widgetRoles.some(function (role) {
128
- return (0, _includes["default"])(userRoles, role);
129
- });
72
+ const matchRoles = (widgetRoles, userRoles) => {
73
+ return widgetRoles.some((role) => includes(userRoles, role));
74
+ };
75
+ const getLoggedInUserDetails = async (baseURL) => {
76
+ if (!baseURL) {
77
+ dispatch(setPageLoading(true));
78
+ await dispatch(getServiceDefinitions(baseURL)).unwrap();
79
+ dispatch(setPageLoading(false));
80
+ return Promise.resolve({});
81
+ }
82
+ return await dispatch(loadSecurityInfo(baseURL)).unwrap();
83
+ };
84
+ const authNavigateToLandingPage = async (options) => {
85
+ try {
86
+ await dispatch(navigateToLandingPage(options)).unwrap();
87
+ return true;
88
+ } catch (error2) {
89
+ return error2 || false;
90
+ }
130
91
  };
131
- var getLoggedInUserDetails = /*#__PURE__*/function () {
132
- var _ref4 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee4(baseURL) {
133
- return _regenerator["default"].wrap(function _callee4$(_context4) {
134
- while (1) switch (_context4.prev = _context4.next) {
135
- case 0:
136
- if (baseURL) {
137
- _context4.next = 6;
138
- break;
139
- }
140
- dispatch((0, _authSlice.setPageLoading)(true));
141
- _context4.next = 4;
142
- return dispatch((0, _appConfigSlice.getServiceDefinitions)(baseURL)).unwrap();
143
- case 4:
144
- dispatch((0, _authSlice.setPageLoading)(false));
145
- return _context4.abrupt("return", Promise.resolve({}));
146
- case 6:
147
- _context4.next = 8;
148
- return dispatch((0, _authSlice.loadSecurityInfo)(baseURL)).unwrap();
149
- case 8:
150
- return _context4.abrupt("return", _context4.sent);
151
- case 9:
152
- case "end":
153
- return _context4.stop();
154
- }
155
- }, _callee4);
156
- }));
157
- return function getLoggedInUserDetails(_x4) {
158
- return _ref4.apply(this, arguments);
159
- };
160
- }();
161
- var authNavigateToLandingPage = /*#__PURE__*/function () {
162
- var _ref5 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee5(options) {
163
- return _regenerator["default"].wrap(function _callee5$(_context5) {
164
- while (1) switch (_context5.prev = _context5.next) {
165
- case 0:
166
- _context5.prev = 0;
167
- _context5.next = 3;
168
- return dispatch((0, _authSlice.navigateToLandingPage)(options)).unwrap();
169
- case 3:
170
- return _context5.abrupt("return", true);
171
- case 6:
172
- _context5.prev = 6;
173
- _context5.t0 = _context5["catch"](0);
174
- return _context5.abrupt("return", _context5.t0 || false);
175
- case 9:
176
- case "end":
177
- return _context5.stop();
178
- }
179
- }, _callee5, null, [[0, 6]]);
180
- }));
181
- return function authNavigateToLandingPage(_x5) {
182
- return _ref5.apply(this, arguments);
183
- };
184
- }();
185
92
  return {
186
- isLoggedIn: isLoggedIn,
187
- loggedInUser: loggedInUser,
188
- securityConfig: securityConfig,
189
- isPageLoading: isPageLoading,
190
- error: error,
93
+ isLoggedIn,
94
+ loggedInUser,
95
+ securityConfig,
96
+ isPageLoading,
97
+ error,
191
98
  login: handleLogin,
192
99
  logout: handleLogout,
193
100
  canAccessPage: checkCanAccessPage,
194
- hasAccessToWidget: hasAccessToWidget,
195
- getLoggedInUserDetails: getLoggedInUserDetails,
101
+ hasAccessToWidget,
102
+ getLoggedInUserDetails,
196
103
  navigateToLandingPage: authNavigateToLandingPage
197
104
  };
198
105
  };
199
- var usePageAccess = exports.usePageAccess = function usePageAccess(pageName) {
200
- var dispatch = (0, _store.useAppDispatch)();
201
- var _useAppSelector2 = (0, _store.useAppSelector)(function (state) {
202
- return state.auth;
203
- }),
204
- loggedInUser = _useAppSelector2.loggedInUser;
205
- var _useState = (0, _react.useState)({
206
- hasAccess: false,
207
- loading: true,
208
- currentPage: pageName
209
- }),
210
- state = _useState[0],
211
- setState = _useState[1];
212
- var hasAccess = pageName === state.currentPage ? state.hasAccess : false;
213
- var loading = pageName !== state.currentPage || state.loading;
214
- (0, _react.useEffect)(function () {
215
- // Set loading to true and hasAccess to false immediately for new page
106
+ const usePageAccess = (pageName) => {
107
+ const dispatch = useAppDispatch();
108
+ const { loggedInUser } = useAppSelector((state2) => state2.auth);
109
+ const [state, setState] = useState({
110
+ hasAccess: false,
111
+ loading: true,
112
+ currentPage: pageName
113
+ });
114
+ const hasAccess = pageName === state.currentPage ? state.hasAccess : false;
115
+ const loading = pageName !== state.currentPage || state.loading;
116
+ useEffect(() => {
216
117
  if (pageName !== state.currentPage) {
217
- setState(function (prev) {
218
- return _objectSpread(_objectSpread({}, prev), {}, {
219
- currentPage: pageName,
220
- hasAccess: false,
221
- loading: true
222
- });
223
- });
224
- }
225
- var checkAccess = /*#__PURE__*/function () {
226
- var _ref6 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee6() {
227
- var access;
228
- return _regenerator["default"].wrap(function _callee6$(_context6) {
229
- while (1) switch (_context6.prev = _context6.next) {
230
- case 0:
231
- _context6.prev = 0;
232
- _context6.next = 3;
233
- return dispatch((0, _authSlice.canAccessPage)({
234
- pageName: pageName
235
- })).unwrap();
236
- case 3:
237
- access = _context6.sent;
238
- setState(function (prev) {
239
- if (prev.currentPage !== pageName) return prev;
240
- return _objectSpread(_objectSpread({}, prev), {}, {
241
- hasAccess: access,
242
- loading: false
243
- });
244
- });
245
- _context6.next = 11;
246
- break;
247
- case 7:
248
- _context6.prev = 7;
249
- _context6.t0 = _context6["catch"](0);
250
- console.error("Error checking page access:", _context6.t0);
251
- setState(function (prev) {
252
- if (prev.currentPage !== pageName) return prev;
253
- return _objectSpread(_objectSpread({}, prev), {}, {
254
- hasAccess: false,
255
- loading: false
256
- });
257
- });
258
- case 11:
259
- case "end":
260
- return _context6.stop();
261
- }
262
- }, _callee6, null, [[0, 7]]);
118
+ setState((prev) => __spreadProps(__spreadValues({}, prev), {
119
+ currentPage: pageName,
120
+ hasAccess: false,
121
+ loading: true
263
122
  }));
264
- return function checkAccess() {
265
- return _ref6.apply(this, arguments);
266
- };
267
- }();
268
- checkAccess();
123
+ }
124
+ const checkAccess2 = async () => {
125
+ try {
126
+ const access = await dispatch(canAccessPage({ pageName })).unwrap();
127
+ setState((prev) => {
128
+ if (prev.currentPage !== pageName) return prev;
129
+ return __spreadProps(__spreadValues({}, prev), {
130
+ hasAccess: access,
131
+ loading: false
132
+ });
133
+ });
134
+ } catch (error) {
135
+ console.error("Error checking page access:", error);
136
+ setState((prev) => {
137
+ if (prev.currentPage !== pageName) return prev;
138
+ return __spreadProps(__spreadValues({}, prev), {
139
+ hasAccess: false,
140
+ loading: false
141
+ });
142
+ });
143
+ }
144
+ };
145
+ checkAccess2();
269
146
  }, [pageName, loggedInUser, dispatch]);
270
147
  return {
271
- hasAccess: hasAccess,
272
- loading: loading
148
+ hasAccess,
149
+ loading
273
150
  };
274
151
  };
275
- var useWidgetAccess = exports.useWidgetAccess = function useWidgetAccess(widgetRoles) {
276
- var _useAuth = useAuth(),
277
- hasAccessToWidget = _useAuth.hasAccessToWidget;
152
+ const useWidgetAccess = (widgetRoles) => {
153
+ const { hasAccessToWidget } = useAuth();
278
154
  return hasAccessToWidget(widgetRoles);
279
155
  };
280
- var useAccess = exports.useAccess = function useAccess(name, type) {
281
- var dispatch = (0, _store.useAppDispatch)();
282
- var _useAppSelector3 = (0, _store.useAppSelector)(function (state) {
283
- return state.auth;
284
- }),
285
- loggedInUser = _useAppSelector3.loggedInUser,
286
- securityConfig = _useAppSelector3.securityConfig;
287
- var _useState2 = (0, _react.useState)({
288
- hasAccess: false,
289
- loading: true,
290
- currentItem: "".concat(type, "-").concat(name)
291
- }),
292
- state = _useState2[0],
293
- setState = _useState2[1];
294
- var hasAccess = "".concat(type, "-").concat(name) === state.currentItem ? state.hasAccess : false;
295
- var loading = "".concat(type, "-").concat(name) !== state.currentItem || state.loading;
296
- (0, _react.useEffect)(function () {
297
- // If name is empty, skip access check and mark as not loading
156
+ const useAccess = (name, type) => {
157
+ const dispatch = useAppDispatch();
158
+ const { loggedInUser, securityConfig } = useAppSelector((state2) => state2.auth);
159
+ const [state, setState] = useState({
160
+ hasAccess: false,
161
+ loading: true,
162
+ currentItem: `${type}-${name}`
163
+ });
164
+ const hasAccess = `${type}-${name}` === state.currentItem ? state.hasAccess : false;
165
+ const loading = `${type}-${name}` !== state.currentItem || state.loading;
166
+ useEffect(() => {
298
167
  if (!name) {
299
- setState(function (prev) {
300
- return _objectSpread(_objectSpread({}, prev), {}, {
301
- currentItem: "".concat(type, "-").concat(name),
302
- hasAccess: true,
303
- // Allow access when no name specified
304
- loading: false
305
- });
306
- });
168
+ setState((prev) => __spreadProps(__spreadValues({}, prev), {
169
+ currentItem: `${type}-${name}`,
170
+ hasAccess: true,
171
+ // Allow access when no name specified
172
+ loading: false
173
+ }));
307
174
  return;
308
175
  }
309
-
310
- // Set loading to true and hasAccess to false immediately for new item
311
- var currentItemKey = "".concat(type, "-").concat(name);
176
+ const currentItemKey = `${type}-${name}`;
312
177
  if (currentItemKey !== state.currentItem) {
313
- setState(function (prev) {
314
- return _objectSpread(_objectSpread({}, prev), {}, {
315
- currentItem: currentItemKey,
316
- hasAccess: false,
317
- loading: true
318
- });
319
- });
320
- }
321
- var checkItemAccess = /*#__PURE__*/function () {
322
- var _ref7 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee7() {
323
- var access;
324
- return _regenerator["default"].wrap(function _callee7$(_context7) {
325
- while (1) switch (_context7.prev = _context7.next) {
326
- case 0:
327
- _context7.prev = 0;
328
- _context7.next = 3;
329
- return dispatch((0, _authSlice.checkAccess)({
330
- name: name,
331
- type: type
332
- })).unwrap();
333
- case 3:
334
- access = _context7.sent;
335
- setState(function (prev) {
336
- if (prev.currentItem !== currentItemKey) return prev;
337
- return _objectSpread(_objectSpread({}, prev), {}, {
338
- hasAccess: access,
339
- loading: false
340
- });
341
- });
342
- _context7.next = 11;
343
- break;
344
- case 7:
345
- _context7.prev = 7;
346
- _context7.t0 = _context7["catch"](0);
347
- console.error("Error checking ".concat(type.toLowerCase(), " access:"), _context7.t0);
348
- setState(function (prev) {
349
- if (prev.currentItem !== currentItemKey) return prev;
350
- return _objectSpread(_objectSpread({}, prev), {}, {
351
- hasAccess: false,
352
- loading: false
353
- });
354
- });
355
- case 11:
356
- case "end":
357
- return _context7.stop();
358
- }
359
- }, _callee7, null, [[0, 7]]);
178
+ setState((prev) => __spreadProps(__spreadValues({}, prev), {
179
+ currentItem: currentItemKey,
180
+ hasAccess: false,
181
+ loading: true
360
182
  }));
361
- return function checkItemAccess() {
362
- return _ref7.apply(this, arguments);
363
- };
364
- }();
183
+ }
184
+ const checkItemAccess = async () => {
185
+ try {
186
+ const access = await dispatch(checkAccess({ name, type })).unwrap();
187
+ setState((prev) => {
188
+ if (prev.currentItem !== currentItemKey) return prev;
189
+ return __spreadProps(__spreadValues({}, prev), {
190
+ hasAccess: access,
191
+ loading: false
192
+ });
193
+ });
194
+ } catch (error) {
195
+ console.error(`Error checking ${type.toLowerCase()} access:`, error);
196
+ setState((prev) => {
197
+ if (prev.currentItem !== currentItemKey) return prev;
198
+ return __spreadProps(__spreadValues({}, prev), {
199
+ hasAccess: false,
200
+ loading: false
201
+ });
202
+ });
203
+ }
204
+ };
365
205
  checkItemAccess();
366
206
  }, [name, type, loggedInUser, securityConfig, dispatch]);
367
207
  return {
368
- hasAccess: hasAccess,
369
- loading: loading
208
+ hasAccess,
209
+ loading
370
210
  };
371
211
  };
372
-
373
- /**
374
- * Synchronous access checker for use outside of React components
375
- * @param name - Name of the page or partial
376
- * @param type - Type: 'PAGE' or 'PARTIAL'
377
- * @param authState - Current auth state from Redux store
378
- * @param appConfig - App configuration containing pages and partials
379
- * @returns boolean indicating if access is granted
380
- */
381
- var checkAccessSync = exports.checkAccessSync = function checkAccessSync(name, type, authState, appConfig) {
382
- var _authState$loggedInUs, _authState$loggedInUs2, _authState$securityCo;
383
- var userRoles = (authState === null || authState === void 0 || (_authState$loggedInUs = authState.loggedInUser) === null || _authState$loggedInUs === void 0 ? void 0 : _authState$loggedInUs.roles) || [];
384
- var isAuthenticated = (authState === null || authState === void 0 || (_authState$loggedInUs2 = authState.loggedInUser) === null || _authState$loggedInUs2 === void 0 ? void 0 : _authState$loggedInUs2.isAuthenticated) || false;
385
- var isSecurityEnabled = authState === null || authState === void 0 || (_authState$securityCo = authState.securityConfig) === null || _authState$securityCo === void 0 ? void 0 : _authState$securityCo.isSecurityEnabled;
386
-
387
- // If security is not enabled, allow access to everything
212
+ const checkAccessSync = (name, type, authState, appConfig) => {
213
+ var _a, _b, _c;
214
+ const userRoles = ((_a = authState == null ? void 0 : authState.loggedInUser) == null ? void 0 : _a.roles) || [];
215
+ const isAuthenticated = ((_b = authState == null ? void 0 : authState.loggedInUser) == null ? void 0 : _b.isAuthenticated) || false;
216
+ const isSecurityEnabled = (_c = authState == null ? void 0 : authState.securityConfig) == null ? void 0 : _c.isSecurityEnabled;
388
217
  if (!isSecurityEnabled) {
389
218
  return true;
390
219
  }
391
-
392
- // Get the appropriate config based on type
393
- var configs = type === "PAGE" ? (appConfig === null || appConfig === void 0 ? void 0 : appConfig.pages) || [] : (appConfig === null || appConfig === void 0 ? void 0 : appConfig.partials) || [];
394
-
395
- // Extract only serializable properties for access control (avoid components)
396
- var serializableConfigs = configs.map(function (item) {
397
- return {
398
- name: item.name,
399
- permission: item.permission,
400
- allowedRoles: item.allowedRoles,
401
- type: item.type
402
- };
403
- });
404
- var config = serializableConfigs.find(function (item) {
405
- return item.name.toLowerCase() === name.toLowerCase();
406
- });
407
-
408
- // If no config found, deny access for security
220
+ const configs = type === "PAGE" ? (appConfig == null ? void 0 : appConfig.pages) || [] : (appConfig == null ? void 0 : appConfig.partials) || [];
221
+ const serializableConfigs = configs.map((item) => ({
222
+ name: item.name,
223
+ permission: item.permission,
224
+ allowedRoles: item.allowedRoles,
225
+ type: item.type
226
+ }));
227
+ const config = serializableConfigs.find(
228
+ (item) => item.name.toLowerCase() === name.toLowerCase()
229
+ );
409
230
  if (!config) {
410
231
  return false;
411
232
  }
412
-
413
- // Check permission type
414
233
  switch (config.permission) {
415
234
  case "PermitAll":
416
235
  return true;
@@ -420,149 +239,91 @@ var checkAccessSync = exports.checkAccessSync = function checkAccessSync(name, t
420
239
  if (!isAuthenticated) {
421
240
  return false;
422
241
  }
423
-
424
- // Check if user has any of the required roles
425
- var allowedRoles = config.allowedRoles || [];
242
+ const allowedRoles = config.allowedRoles || [];
426
243
  if (allowedRoles.length === 0) {
427
- // If no roles specified but permission is Role, deny access
428
244
  return false;
429
245
  }
430
- return allowedRoles.some(function (role) {
431
- return userRoles.includes(role);
432
- });
246
+ return allowedRoles.some((role) => userRoles.includes(role));
433
247
  default:
434
- // Unknown permission type, deny access for security
435
248
  return false;
436
249
  }
437
250
  };
438
- var useLogin = exports.useLogin = function useLogin() {
439
- var dispatch = (0, _store.useAppDispatch)();
440
- var _useAppSelector4 = (0, _store.useAppSelector)(function (state) {
441
- return state.auth;
442
- }),
443
- isLoggedIn = _useAppSelector4.isLoggedIn,
444
- error = _useAppSelector4.error;
445
- var _useState3 = (0, _react.useState)(false),
446
- loading = _useState3[0],
447
- setLoading = _useState3[1];
448
- var _useState4 = (0, _react.useState)(null),
449
- loginError = _useState4[0],
450
- setLoginError = _useState4[1];
451
- var handleLogin = /*#__PURE__*/function () {
452
- var _ref8 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee8(options) {
453
- return _regenerator["default"].wrap(function _callee8$(_context8) {
454
- while (1) switch (_context8.prev = _context8.next) {
455
- case 0:
456
- setLoading(true);
457
- setLoginError(null);
458
- _context8.prev = 2;
459
- _context8.next = 5;
460
- return dispatch((0, _authSlice.login)(options)).unwrap();
461
- case 5:
462
- return _context8.abrupt("return", true);
463
- case 8:
464
- _context8.prev = 8;
465
- _context8.t0 = _context8["catch"](2);
466
- setLoginError(_context8.t0 instanceof Error ? _context8.t0.message : "Login failed");
467
- return _context8.abrupt("return", false);
468
- case 12:
469
- _context8.prev = 12;
470
- setLoading(false);
471
- return _context8.finish(12);
472
- case 15:
473
- case "end":
474
- return _context8.stop();
475
- }
476
- }, _callee8, null, [[2, 8, 12, 15]]);
477
- }));
478
- return function handleLogin(_x6) {
479
- return _ref8.apply(this, arguments);
480
- };
481
- }();
251
+ const useLogin = () => {
252
+ const dispatch = useAppDispatch();
253
+ const { isLoggedIn, error } = useAppSelector((state) => state.auth);
254
+ const [loading, setLoading] = useState(false);
255
+ const [loginError, setLoginError] = useState(null);
256
+ const handleLogin = async (options) => {
257
+ setLoading(true);
258
+ setLoginError(null);
259
+ try {
260
+ await dispatch(login(options)).unwrap();
261
+ return true;
262
+ } catch (err) {
263
+ setLoginError(err instanceof Error ? err.message : "Login failed");
264
+ return false;
265
+ } finally {
266
+ setLoading(false);
267
+ }
268
+ };
482
269
  return {
483
- loading: loading,
270
+ loading,
484
271
  error: loginError || error,
485
- isLoggedIn: isLoggedIn,
486
- handleLogin: handleLogin,
487
- clearError: function clearError() {
488
- return setLoginError(null);
489
- }
272
+ isLoggedIn,
273
+ handleLogin,
274
+ clearError: () => setLoginError(null)
490
275
  };
491
276
  };
492
- var useLogout = exports.useLogout = function useLogout() {
493
- var dispatch = (0, _store.useAppDispatch)();
494
- var _useState5 = (0, _react.useState)(false),
495
- loading = _useState5[0],
496
- setLoading = _useState5[1];
497
- var _useState6 = (0, _react.useState)(null),
498
- logoutError = _useState6[0],
499
- setLogoutError = _useState6[1];
500
- var handleLogout = /*#__PURE__*/function () {
501
- var _ref9 = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee9(baseURL) {
502
- return _regenerator["default"].wrap(function _callee9$(_context9) {
503
- while (1) switch (_context9.prev = _context9.next) {
504
- case 0:
505
- setLoading(true);
506
- setLogoutError(null);
507
- _context9.prev = 2;
508
- _context9.next = 5;
509
- return dispatch((0, _authSlice.logout)({
510
- baseURL: baseURL
511
- })).unwrap();
512
- case 5:
513
- return _context9.abrupt("return", true);
514
- case 8:
515
- _context9.prev = 8;
516
- _context9.t0 = _context9["catch"](2);
517
- setLogoutError(_context9.t0 instanceof Error ? _context9.t0.message : "Logout failed");
518
- return _context9.abrupt("return", false);
519
- case 12:
520
- _context9.prev = 12;
521
- setLoading(false);
522
- return _context9.finish(12);
523
- case 15:
524
- case "end":
525
- return _context9.stop();
526
- }
527
- }, _callee9, null, [[2, 8, 12, 15]]);
528
- }));
529
- return function handleLogout(_x7) {
530
- return _ref9.apply(this, arguments);
531
- };
532
- }();
277
+ const useLogout = () => {
278
+ const dispatch = useAppDispatch();
279
+ const [loading, setLoading] = useState(false);
280
+ const [logoutError, setLogoutError] = useState(null);
281
+ const handleLogout = async (baseURL) => {
282
+ setLoading(true);
283
+ setLogoutError(null);
284
+ try {
285
+ await dispatch(logout({ baseURL })).unwrap();
286
+ return true;
287
+ } catch (err) {
288
+ setLogoutError(err instanceof Error ? err.message : "Logout failed");
289
+ return false;
290
+ } finally {
291
+ setLoading(false);
292
+ }
293
+ };
533
294
  return {
534
- loading: loading,
295
+ loading,
535
296
  error: logoutError,
536
- handleLogout: handleLogout,
537
- clearError: function clearError() {
538
- return setLogoutError(null);
539
- }
297
+ handleLogout,
298
+ clearError: () => setLogoutError(null)
540
299
  };
541
300
  };
542
- var useCurrentUser = exports.useCurrentUser = function useCurrentUser() {
543
- var _useAppSelector5 = (0, _store.useAppSelector)(function (state) {
544
- return state.auth;
545
- }),
546
- loggedInUser = _useAppSelector5.loggedInUser,
547
- isLoggedIn = _useAppSelector5.isLoggedIn;
301
+ const useCurrentUser = () => {
302
+ const { loggedInUser, isLoggedIn } = useAppSelector((state) => state.auth);
548
303
  return {
549
304
  user: loggedInUser,
550
- isLoggedIn: isLoggedIn,
551
- hasRole: function hasRole(role) {
305
+ isLoggedIn,
306
+ hasRole: (role) => {
552
307
  if (!loggedInUser || !loggedInUser.roles) return false;
553
308
  return loggedInUser.roles.includes(role);
554
309
  },
555
- hasAnyRole: function hasAnyRole(roles) {
310
+ hasAnyRole: (roles) => {
556
311
  if (!loggedInUser || !loggedInUser.roles) return false;
557
- return roles.some(function (role) {
558
- return loggedInUser.roles.includes(role);
559
- });
312
+ return roles.some((role) => loggedInUser.roles.includes(role));
560
313
  },
561
- hasAllRoles: function hasAllRoles(roles) {
314
+ hasAllRoles: (roles) => {
562
315
  if (!loggedInUser || !loggedInUser.roles) return false;
563
- return roles.every(function (role) {
564
- return loggedInUser.roles.includes(role);
565
- });
316
+ return roles.every((role) => loggedInUser.roles.includes(role));
566
317
  }
567
318
  };
568
- };
319
+ };
320
+ export {
321
+ checkAccessSync,
322
+ useAccess,
323
+ useAuth,
324
+ useCurrentUser,
325
+ useLogin,
326
+ useLogout,
327
+ usePageAccess,
328
+ useWidgetAccess
329
+ };