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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (574) hide show
  1. package/.npmignore +4 -0
  2. package/actions/base-action.js +12 -29
  3. package/actions/login-action.js +35 -52
  4. package/actions/logout-action.js +21 -38
  5. package/actions/navigation-action.js +251 -346
  6. package/actions/notification-action.js +121 -149
  7. package/actions/timer-action.js +95 -151
  8. package/actions/toast-provider.js +62 -76
  9. package/actions/toast.js +95 -91
  10. package/actions/toast.service.js +59 -79
  11. package/actions/types/index.js +6 -9
  12. package/components/advanced/carousel/index.js +358 -366
  13. package/components/advanced/carousel/props.js +0 -5
  14. package/components/advanced/carousel/template.js +102 -80
  15. package/components/advanced/login/index.js +227 -285
  16. package/components/advanced/login/props.js +0 -5
  17. package/components/advanced/marquee/index.js +169 -163
  18. package/components/advanced/marquee/props.js +0 -5
  19. package/components/basic/anchor/index.js +207 -187
  20. package/components/basic/anchor/props.js +0 -5
  21. package/components/basic/audio/index.js +110 -72
  22. package/components/basic/audio/props.js +0 -5
  23. package/components/basic/html/index.js +163 -203
  24. package/components/basic/html/props.js +0 -5
  25. package/components/basic/html/utils.js +30 -28
  26. package/components/basic/icon/index.js +98 -84
  27. package/components/basic/icon/props.js +0 -5
  28. package/components/basic/iframe/iframe.utils.js +7 -16
  29. package/components/basic/iframe/index.js +97 -103
  30. package/components/basic/iframe/props.js +0 -5
  31. package/components/basic/label/index.js +156 -134
  32. package/components/basic/label/props.js +0 -5
  33. package/components/basic/message/index.js +129 -113
  34. package/components/basic/message/props.js +0 -5
  35. package/components/basic/picture/index.js +156 -127
  36. package/components/basic/picture/props.js +0 -5
  37. package/components/basic/progress-bar/index.js +240 -176
  38. package/components/basic/progress-bar/props.js +5 -31
  39. package/components/basic/progress-circle/index.js +166 -183
  40. package/components/basic/progress-circle/props.js +14 -34
  41. package/components/basic/richtexteditor/index.js +430 -396
  42. package/components/basic/richtexteditor/props.js +0 -5
  43. package/components/basic/search/index.js +812 -931
  44. package/components/basic/search/props.js +0 -5
  45. package/components/basic/search/providers.js +233 -380
  46. package/components/basic/spinner/index.js +210 -200
  47. package/components/basic/spinner/props.js +4 -22
  48. package/components/basic/tile/index.js +73 -81
  49. package/components/basic/tile/props.js +0 -5
  50. package/components/basic/tree/Components/TreeNodeComponent.js +238 -170
  51. package/components/basic/tree/hooks/useTreePartialNodeApi.js +143 -135
  52. package/components/basic/tree/index.js +378 -454
  53. package/components/basic/tree/props.js +0 -5
  54. package/components/basic/tree/utils.js +129 -185
  55. package/components/basic/video/index.js +161 -107
  56. package/components/basic/video/props.js +0 -5
  57. package/components/chart/index.js +42 -50
  58. package/components/chart/props.js +31 -37
  59. package/components/chart/src/ChartRenderer.js +172 -154
  60. package/components/chart/src/chart.js +391 -213
  61. package/components/chart/src/chartStyles.generated.js +6 -14
  62. package/components/chart/src/chartUtils.js +228 -272
  63. package/components/chart/src/constants.d.ts +13 -0
  64. package/components/chart/src/constants.js +316 -90
  65. package/components/chart/src/d3Setup.js +11 -30
  66. package/components/chart/src/dataUtils.js +362 -446
  67. package/components/chart/src/formatUtils.js +47 -38
  68. package/components/chart/src/index.js +11 -19
  69. package/components/chart/src/nvd3Source.generated.js +5 -13
  70. package/components/chart/src/pieDonutResponsiveLayout.d.ts +5 -0
  71. package/components/chart/src/pieDonutResponsiveLayout.js +76 -96
  72. package/components/chart/src/types.js +0 -5
  73. package/components/common/AppSpinner.js +17 -33
  74. package/components/common/app-spinner.js +11 -22
  75. package/components/common/customTemplate/index.d.ts +3 -0
  76. package/components/common/customTemplate/index.js +6 -0
  77. package/components/common/customTemplate/props.d.ts +20 -0
  78. package/components/common/customTemplate/props.js +0 -0
  79. package/components/common/customTemplate/template.d.ts +3 -0
  80. package/components/common/customTemplate/template.js +27 -0
  81. package/components/common/customTemplate/useCustomTemplate.d.ts +8 -0
  82. package/components/common/customTemplate/useCustomTemplate.js +17 -0
  83. package/components/common/customTemplate/utils.d.ts +6 -0
  84. package/components/common/customTemplate/utils.js +12 -0
  85. package/components/common/index.js +4 -12
  86. package/components/constants.js +81 -77
  87. package/components/container/accordion/accordion-pane/index.js +105 -118
  88. package/components/container/accordion/accordion-pane/props.js +5 -21
  89. package/components/container/accordion/index.js +225 -243
  90. package/components/container/accordion/props.js +5 -16
  91. package/components/container/index.js +214 -150
  92. package/components/container/layout-grid/grid-column/index.js +68 -43
  93. package/components/container/layout-grid/grid-column/props.js +0 -5
  94. package/components/container/layout-grid/grid-row/index.js +12 -29
  95. package/components/container/layout-grid/grid-row/props.js +0 -5
  96. package/components/container/layout-grid/index.js +53 -38
  97. package/components/container/layout-grid/props.js +0 -5
  98. package/components/container/linear-layout/index.js +56 -60
  99. package/components/container/linear-layout/linear-layout-item/index.js +43 -47
  100. package/components/container/linear-layout/linear-layout-item/props.js +0 -5
  101. package/components/container/linear-layout/props.js +0 -5
  102. package/components/container/panel/components/panel-content/index.js +7 -16
  103. package/components/container/panel/components/panel-header/index.js +166 -146
  104. package/components/container/panel/components/panel-header/props.js +0 -5
  105. package/components/container/panel/hooks.js +76 -102
  106. package/components/container/panel/index.js +289 -252
  107. package/components/container/panel/props.js +0 -5
  108. package/components/container/props.js +0 -5
  109. package/components/container/repeat-template/index.js +65 -44
  110. package/components/container/repeat-template/props.js +0 -5
  111. package/components/container/tabs/index.js +517 -526
  112. package/components/container/tabs/props.js +5 -28
  113. package/components/container/tabs/tab-pane/index.js +105 -100
  114. package/components/container/tabs/tab-pane/props.js +0 -5
  115. package/components/container/tabs/utils.js +30 -35
  116. package/components/container/wizard/WizardContext.js +9 -11
  117. package/components/container/wizard/components/StepComponents.js +76 -99
  118. package/components/container/wizard/components/WizardStep.js +107 -85
  119. package/components/container/wizard/index.js +791 -921
  120. package/components/container/wizard/props.js +0 -5
  121. package/components/container/wizard/utils.js +97 -131
  122. package/components/container/wizard/wizard-action/index.js +41 -81
  123. package/components/container/wizard/wizard-step/index.js +140 -120
  124. package/components/data/card/card-actions/index.js +13 -31
  125. package/components/data/card/card-content/index.js +27 -36
  126. package/components/data/card/card-footer/index.js +13 -31
  127. package/components/data/card/index.js +192 -199
  128. package/components/data/card/props.js +0 -5
  129. package/components/data/form/base-form/constant.js +5 -8
  130. package/components/data/form/base-form/hooks/index.js +26 -77
  131. package/components/data/form/base-form/hooks/useFormDataSync.js +106 -212
  132. package/components/data/form/base-form/hooks/useFormOperations.js +109 -161
  133. package/components/data/form/base-form/hooks/useFormSubmission.js +220 -280
  134. package/components/data/form/base-form/hooks/useFormValidation.js +119 -168
  135. package/components/data/form/base-form/hooks/useParentFormRelationship.js +67 -103
  136. package/components/data/form/base-form/index.js +531 -646
  137. package/components/data/form/base-form/props.js +74 -151
  138. package/components/data/form/base-form/utils.js +210 -323
  139. package/components/data/form/dynamic-fields/constant.js +43 -53
  140. package/components/data/form/dynamic-fields/index.js +135 -144
  141. package/components/data/form/dynamic-fields/props.js +0 -5
  142. package/components/data/form/dynamic-fields/utils.js +99 -158
  143. package/components/data/form/form-action/index.js +107 -85
  144. package/components/data/form/form-body/index.js +52 -26
  145. package/components/data/form/form-context.js +43 -59
  146. package/components/data/form/form-controller/hooks/index.js +43 -57
  147. package/components/data/form/form-controller/props.js +5 -8
  148. package/components/data/form/form-controller/utils.js +54 -49
  149. package/components/data/form/form-controller/validation-contrustor.js +203 -426
  150. package/components/data/form/form-controller/withFormController.js +319 -269
  151. package/components/data/form/form-dynamic-section/index.js +47 -41
  152. package/components/data/form/form-dynamic-section/props.js +0 -5
  153. package/components/data/form/form-field/base-field.js +97 -109
  154. package/components/data/form/form-field/index.js +91 -82
  155. package/components/data/form/form-field/props.js +0 -5
  156. package/components/data/form/form-footer/index.js +52 -25
  157. package/components/data/form/form-header/index.js +61 -58
  158. package/components/data/form/index.js +95 -74
  159. package/components/data/form/props.js +0 -5
  160. package/components/data/list/components/GroupHeader.js +34 -33
  161. package/components/data/list/components/GroupedListItems.js +108 -104
  162. package/components/data/list/components/ListContainer.js +22 -27
  163. package/components/data/list/components/ListDND.js +193 -185
  164. package/components/data/list/components/ListHeader.js +32 -49
  165. package/components/data/list/components/ListItem.js +153 -146
  166. package/components/data/list/components/ListItemWithTemplate.js +87 -105
  167. package/components/data/list/components/ListItems.js +180 -194
  168. package/components/data/list/components/ListPagination.js +127 -153
  169. package/components/data/list/components/LoadMoreButton.js +25 -33
  170. package/components/data/list/components/NoDataMessage.js +9 -22
  171. package/components/data/list/components/StandardListItems.js +79 -85
  172. package/components/data/list/components/index.js +31 -119
  173. package/components/data/list/components/props.js +0 -5
  174. package/components/data/list/hooks/index.js +22 -75
  175. package/components/data/list/hooks/props.js +0 -5
  176. package/components/data/list/hooks/useCurrentPageItems.js +20 -38
  177. package/components/data/list/hooks/useGroupedData.js +19 -33
  178. package/components/data/list/hooks/useListData.js +17 -47
  179. package/components/data/list/hooks/useListEffects.js +168 -237
  180. package/components/data/list/hooks/useListEventHandlers.js +301 -285
  181. package/components/data/list/hooks/useListPagination.js +90 -136
  182. package/components/data/list/hooks/useListState.js +49 -91
  183. package/components/data/list/hooks/useListStateManager.js +104 -159
  184. package/components/data/list/hooks/usePaginatedGroupedData.js +74 -110
  185. package/components/data/list/index.d.ts +1 -0
  186. package/components/data/list/index.js +579 -621
  187. package/components/data/list/props.d.ts +4 -0
  188. package/components/data/list/props.js +0 -5
  189. package/components/data/list/templates/media-template.js +29 -50
  190. package/components/data/list/utils/constants.js +20 -32
  191. package/components/data/list/utils/list-helpers.d.ts +2 -1
  192. package/components/data/list/utils/list-helpers.js +71 -115
  193. package/components/data/list/utils/list-widget-methods.js +56 -76
  194. package/components/data/list/utils/widget-instance-utils.js +20 -57
  195. package/components/data/live-filter/index.js +219 -271
  196. package/components/data/live-filter/props.js +5 -12
  197. package/components/data/live-form/index.js +68 -91
  198. package/components/data/live-form/props.js +5 -12
  199. package/components/data/pagination/components/BasicPagination.js +124 -104
  200. package/components/data/pagination/components/ClassicPagination.js +167 -190
  201. package/components/data/pagination/components/InlinePagination.js +97 -98
  202. package/components/data/pagination/components/LoadingComponent.js +17 -30
  203. package/components/data/pagination/components/PageSizeSelector.js +176 -169
  204. package/components/data/pagination/components/PagerNavigation.js +84 -105
  205. package/components/data/pagination/components/TotalRecords.js +48 -47
  206. package/components/data/pagination/components/index.js +14 -47
  207. package/components/data/pagination/components/props.js +0 -5
  208. package/components/data/pagination/hooks/index.js +6 -19
  209. package/components/data/pagination/hooks/props.js +0 -5
  210. package/components/data/pagination/hooks/useNavigationSize.js +12 -21
  211. package/components/data/pagination/hooks/usePagination.js +702 -905
  212. package/components/data/pagination/index.js +336 -389
  213. package/components/data/table/components/AddNewRow.js +122 -154
  214. package/components/data/table/components/EditableCell.js +68 -75
  215. package/components/data/table/components/FieldValidationError.js +19 -20
  216. package/components/data/table/components/RowCells.js +97 -80
  217. package/components/data/table/components/RowExpansionButton.js +43 -39
  218. package/components/data/table/components/SummaryCell.js +54 -88
  219. package/components/data/table/components/SummaryRow.js +45 -52
  220. package/components/data/table/components/SummaryRowFooter.js +35 -42
  221. package/components/data/table/components/TableBody.js +222 -218
  222. package/components/data/table/components/TableDataRow.js +113 -106
  223. package/components/data/table/components/TableFilters.js +391 -390
  224. package/components/data/table/components/TableFooterActions.js +25 -32
  225. package/components/data/table/components/TableHeader.js +460 -435
  226. package/components/data/table/components/TablePanelHeading.js +157 -181
  227. package/components/data/table/components/index.js +27 -95
  228. package/components/data/table/hooks/index.js +21 -230
  229. package/components/data/table/hooks/use-edited-rows.js +59 -94
  230. package/components/data/table/hooks/useCellState.js +58 -83
  231. package/components/data/table/hooks/useCustomExpressionColumns.js +65 -86
  232. package/components/data/table/hooks/useDynamicColumns.js +59 -92
  233. package/components/data/table/hooks/useEditingState.js +30 -41
  234. package/components/data/table/hooks/useFormWidget.js +163 -172
  235. package/components/data/table/hooks/usePaginationState.js +67 -77
  236. package/components/data/table/hooks/usePanelStructure.js +47 -41
  237. package/components/data/table/hooks/useResponsiveColumns.js +14 -20
  238. package/components/data/table/hooks/useRowExpansion.js +131 -127
  239. package/components/data/table/hooks/useRowHandlers.js +56 -69
  240. package/components/data/table/hooks/useRowSelection.js +249 -329
  241. package/components/data/table/hooks/useServerSideSorting.js +109 -175
  242. package/components/data/table/hooks/useTableColumns.js +322 -331
  243. package/components/data/table/hooks/useTableData.js +111 -166
  244. package/components/data/table/hooks/useTableEdit.js +526 -564
  245. package/components/data/table/hooks/useTableEffects.js +60 -107
  246. package/components/data/table/hooks/useTableFilter.js +244 -237
  247. package/components/data/table/hooks/useTableInitialization.js +44 -76
  248. package/components/data/table/hooks/useTableState.js +39 -61
  249. package/components/data/table/hooks/useTableStateManager.js +295 -468
  250. package/components/data/table/index.js +1553 -1713
  251. package/components/data/table/live-table/index.js +157 -219
  252. package/components/data/table/props.js +0 -5
  253. package/components/data/table/table-action/index.js +97 -75
  254. package/components/data/table/table-column/index.js +48 -42
  255. package/components/data/table/table-group/index.js +7 -25
  256. package/components/data/table/table-row/index.js +63 -55
  257. package/components/data/table/table-row-action/index.js +102 -77
  258. package/components/data/table/utils/buildSelectionColumns.js +86 -137
  259. package/components/data/table/utils/columnBuilder.js +116 -158
  260. package/components/data/table/utils/columnProxy.js +48 -66
  261. package/components/data/table/utils/columnWidthDistribution.js +40 -64
  262. package/components/data/table/utils/constants.js +92 -40
  263. package/components/data/table/utils/crud-handlers.js +292 -473
  264. package/components/data/table/utils/dynamic-columns.js +99 -144
  265. package/components/data/table/utils/groupHeaderUtils.js +36 -61
  266. package/components/data/table/utils/index.d.ts +8 -5
  267. package/components/data/table/utils/index.js +419 -639
  268. package/components/data/table/utils/renderDisplayCell.js +127 -169
  269. package/components/data/table/utils/script-page-size-broadcast.js +17 -29
  270. package/components/data/table/utils/selectionUtils.js +59 -113
  271. package/components/data/table/utils/table-helpers.js +38 -74
  272. package/components/data/table/utils/validation.js +35 -78
  273. package/components/data/table/utils/widgetMapping.d.ts +5 -0
  274. package/components/data/table/utils/widgetMapping.js +41 -0
  275. package/components/data/types.js +112 -112
  276. package/components/data/utils/field-data-utils.js +38 -42
  277. package/components/data/utils/filter-field-util.js +42 -44
  278. package/components/data/utils/index.js +112 -111
  279. package/components/dialogs/alert-dialog/index.js +83 -78
  280. package/components/dialogs/alert-dialog/props.js +0 -5
  281. package/components/dialogs/confirm-dialog/index.js +102 -92
  282. package/components/dialogs/confirm-dialog/props.js +0 -5
  283. package/components/dialogs/dialog/index.js +93 -69
  284. package/components/dialogs/dialog/props.js +0 -5
  285. package/components/dialogs/dialog-actions/index.js +12 -26
  286. package/components/dialogs/dialog-actions/props.js +0 -5
  287. package/components/dialogs/dialog-body/index.js +13 -30
  288. package/components/dialogs/dialog-body/props.js +0 -5
  289. package/components/dialogs/dialog-content/index.js +48 -41
  290. package/components/dialogs/dialog-content/props.js +0 -5
  291. package/components/dialogs/dialog-header/index.js +88 -101
  292. package/components/dialogs/dialog-header/props.js +0 -5
  293. package/components/dialogs/iframe-dialog/index.js +136 -128
  294. package/components/dialogs/iframe-dialog/props.js +0 -5
  295. package/components/dialogs/index.js +104 -101
  296. package/components/dialogs/login-dialog/index.js +285 -347
  297. package/components/dialogs/login-dialog/props.js +0 -5
  298. package/components/dialogs/page-dialog/index.js +95 -86
  299. package/components/dialogs/page-dialog/props.js +0 -5
  300. package/components/dialogs/props.js +0 -5
  301. package/components/dialogs/withDialogWrapper.js +110 -83
  302. package/components/form/button/index.js +296 -245
  303. package/components/form/button/props.js +0 -5
  304. package/components/form/button-group/index.js +80 -69
  305. package/components/form/button-group/props.js +0 -5
  306. package/components/input/calendar/index.js +409 -362
  307. package/components/input/calendar/props.js +0 -5
  308. package/components/input/calendar/utils.js +164 -172
  309. package/components/input/chips/SortableChip/index.js +109 -100
  310. package/components/input/chips/SortableChip/props.js +0 -5
  311. package/components/input/chips/index.js +663 -570
  312. package/components/input/chips/props.js +0 -5
  313. package/components/input/chips/utils.js +131 -122
  314. package/components/input/color-picker/index.js +536 -594
  315. package/components/input/color-picker/props.js +0 -5
  316. package/components/input/composite/index.js +71 -110
  317. package/components/input/composite/props.js +0 -5
  318. package/components/input/currency/index.js +277 -224
  319. package/components/input/currency/props.js +0 -5
  320. package/components/input/default/checkbox/index.js +329 -250
  321. package/components/input/default/checkbox/props.js +0 -5
  322. package/components/input/default/checkboxset/index.d.ts +2 -0
  323. package/components/input/default/checkboxset/index.js +529 -446
  324. package/components/input/default/checkboxset/props.d.ts +4 -0
  325. package/components/input/default/checkboxset/props.js +0 -5
  326. package/components/input/default/checkboxset/utils.js +15 -25
  327. package/components/input/default/radioset/index.d.ts +2 -0
  328. package/components/input/default/radioset/index.js +409 -350
  329. package/components/input/default/radioset/props.d.ts +6 -0
  330. package/components/input/default/radioset/props.js +0 -5
  331. package/components/input/default/switch/index.js +494 -458
  332. package/components/input/default/switch/prop.js +0 -5
  333. package/components/input/epoch/date/components/DatePickerPopover.js +242 -193
  334. package/components/input/epoch/date/index.js +638 -518
  335. package/components/input/epoch/date/props.js +0 -5
  336. package/components/input/epoch/date/styled.js +61 -70
  337. package/components/input/epoch/date/utils.js +67 -115
  338. package/components/input/epoch/datetime/index.js +758 -695
  339. package/components/input/epoch/datetime/props.js +0 -5
  340. package/components/input/epoch/datetime/utils.js +121 -186
  341. package/components/input/epoch/time/index.js +441 -415
  342. package/components/input/epoch/time/props.js +0 -5
  343. package/components/input/epoch/time/utils.js +101 -112
  344. package/components/input/fileupload/Utils.js +70 -97
  345. package/components/input/fileupload/components/ListItems.js +132 -130
  346. package/components/input/fileupload/components/MultiUpload.js +80 -77
  347. package/components/input/fileupload/components/SingleUpload.js +57 -57
  348. package/components/input/fileupload/index.js +253 -178
  349. package/components/input/fileupload/props.js +0 -5
  350. package/components/input/fileupload/useFileUpload.js +209 -258
  351. package/components/input/number/index.js +434 -393
  352. package/components/input/number/props.js +0 -5
  353. package/components/input/rating/index.js +401 -394
  354. package/components/input/rating/props.js +0 -5
  355. package/components/input/select/index.js +408 -463
  356. package/components/input/select/props.js +0 -5
  357. package/components/input/slider/index.js +339 -332
  358. package/components/input/slider/props.js +0 -5
  359. package/components/input/text/index.d.ts +3 -3
  360. package/components/input/text/index.js +438 -475
  361. package/components/input/text/props.d.ts +1 -1
  362. package/components/input/text/props.js +0 -5
  363. package/components/input/text/util.js +82 -222
  364. package/components/input/textarea/index.js +322 -358
  365. package/components/input/textarea/props.js +0 -5
  366. package/components/input/upload/index.js +135 -131
  367. package/components/input/upload/props.js +0 -5
  368. package/components/input/util/index.js +9 -11
  369. package/components/layout/footer/index.js +12 -35
  370. package/components/layout/footer/props.js +0 -5
  371. package/components/layout/header/index.js +12 -38
  372. package/components/layout/header/props.js +0 -5
  373. package/components/layout/leftnav/index.js +38 -44
  374. package/components/layout/leftnav/props.js +0 -5
  375. package/components/layout/rightnav/index.js +12 -36
  376. package/components/layout/rightnav/props.js +0 -5
  377. package/components/layout/topnav/index.js +24 -38
  378. package/components/layout/topnav/props.js +0 -5
  379. package/components/navbar/index.js +119 -98
  380. package/components/navbar/nav/index.js +236 -232
  381. package/components/navbar/nav/props.js +0 -5
  382. package/components/navbar/nav-item/index.js +74 -65
  383. package/components/navbar/nav-item/props.js +0 -5
  384. package/components/navigation/breadcrumb/index.js +38 -61
  385. package/components/navigation/breadcrumb/props.js +0 -5
  386. package/components/navigation/menu/components/ListItems.js +76 -67
  387. package/components/navigation/menu/constants.js +27 -42
  388. package/components/navigation/menu/hooks/useHoverState.hook.js +20 -47
  389. package/components/navigation/menu/hooks/useKeyboardMovements.hook.js +34 -28
  390. package/components/navigation/menu/hooks/useTransformedDataset.hook.js +21 -14
  391. package/components/navigation/menu/index.js +911 -846
  392. package/components/navigation/menu/props.js +0 -5
  393. package/components/navigation/menu/utils/action-task.js +6 -9
  394. package/components/navigation/menu/utils/role-filter.js +41 -56
  395. package/components/navigation/popover/index.js +191 -205
  396. package/components/navigation/popover/props.js +5 -8
  397. package/components/page/content/index.js +9 -31
  398. package/components/page/content/props.js +0 -5
  399. package/components/page/error-boundary/index.js +115 -105
  400. package/components/page/error-boundary/props.js +0 -5
  401. package/components/page/index.js +84 -102
  402. package/components/page/page-content/index.js +21 -30
  403. package/components/page/page-content/props.js +0 -5
  404. package/components/page/partial/index.js +50 -45
  405. package/components/page/partial/props.js +0 -5
  406. package/components/page/partial-container/index.js +81 -107
  407. package/components/page/partial-container/props.d.ts +1 -1
  408. package/components/page/partial-container/props.js +0 -5
  409. package/components/page/props.js +0 -5
  410. package/components/page/toast-container/index.js +20 -41
  411. package/components/page/toast-container/props.js +0 -5
  412. package/components/prefab/container/index.js +60 -53
  413. package/components/prefab/container/props.js +0 -5
  414. package/components/prefab/index.js +76 -61
  415. package/components/prefab/props.js +0 -5
  416. package/context/AppContext.d.ts +1 -1
  417. package/context/AppContext.js +17 -18
  418. package/context/AppSpinnerProvider.js +19 -34
  419. package/context/LayoutProvider.js +54 -57
  420. package/context/LocalizationProvider.js +34 -49
  421. package/context/PrefabContext.js +68 -119
  422. package/context/WidgetProvider.js +160 -166
  423. package/core/app-config.js +0 -1
  424. package/core/app.service.js +200 -327
  425. package/core/appVariablesStore.js +10 -15
  426. package/core/appstore.js +37 -53
  427. package/core/constants/currency-constant.js +81 -83
  428. package/core/constants/events.js +34 -44
  429. package/core/constants/index.js +21 -31
  430. package/core/dialog.service.js +52 -72
  431. package/core/event-notifier.js +94 -131
  432. package/core/formatter/array-formatters.js +18 -32
  433. package/core/formatter/date-formatters.js +140 -204
  434. package/core/formatter/index.js +64 -117
  435. package/core/formatter/number-formatters.js +115 -159
  436. package/core/formatter/security-formatters.js +233 -283
  437. package/core/formatter/string-formatters.js +23 -45
  438. package/core/formatter/types.js +12 -18
  439. package/core/formatters.js +6 -24
  440. package/core/proxy-service.js +242 -306
  441. package/core/script-registry.js +87 -134
  442. package/core/security.service.js +8 -11
  443. package/core/util/compare.js +13 -25
  444. package/core/util/dom.js +32 -63
  445. package/core/util/index.d.ts +5 -0
  446. package/core/util/index.js +95 -95
  447. package/core/util/safe-is-equal.js +42 -94
  448. package/core/util/security.js +114 -153
  449. package/core/util/utils.d.ts +8 -1
  450. package/core/util/utils.js +124 -132
  451. package/core/widget-observer.js +34 -61
  452. package/higherOrder/BaseApp.js +327 -500
  453. package/higherOrder/BaseAppProps.js +0 -5
  454. package/higherOrder/BaseDateTime.js +277 -231
  455. package/higherOrder/BasePage.js +479 -735
  456. package/higherOrder/BasePartial.js +87 -114
  457. package/higherOrder/BasePrefab.js +190 -206
  458. package/higherOrder/DataNav.js +287 -302
  459. package/higherOrder/helper.js +62 -48
  460. package/higherOrder/props.js +0 -5
  461. package/higherOrder/withBaseWrapper.js +123 -168
  462. package/higherOrder/withStandalone.js +28 -26
  463. package/hooks/useAccess.js +113 -289
  464. package/hooks/useAppConfig.js +15 -40
  465. package/hooks/useAuth.js +256 -495
  466. package/hooks/useDataSourceSubscription.d.ts +3 -3
  467. package/hooks/useDataSourceSubscription.js +99 -109
  468. package/hooks/useDebounce.js +28 -56
  469. package/hooks/useDeviceVisibility.js +14 -23
  470. package/hooks/useHttp.d.ts +1 -0
  471. package/hooks/useHttp.js +318 -493
  472. package/libs/index.js +4 -13
  473. package/libs/prefab/index.js +6 -20
  474. package/mui-config/theme-provider.js +9 -17
  475. package/mui-config/theme.js +6 -9
  476. package/package-lock.json +822 -3191
  477. package/package.json +3 -19
  478. package/providers/AppProviders.js +21 -24
  479. package/runtime-dynamic/App.js +65 -93
  480. package/runtime-dynamic/app-initializer.js +207 -400
  481. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  482. package/runtime-dynamic/components/PageWrapper.js +23 -35
  483. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  484. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  485. package/runtime-dynamic/components/partial-content.js +66 -48
  486. package/runtime-dynamic/components/prefab-content.js +37 -30
  487. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  488. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  489. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  490. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  491. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  492. package/runtime-dynamic/factories/startup-info.js +12 -25
  493. package/runtime-dynamic/factories/utils.d.ts +1 -9
  494. package/runtime-dynamic/factories/utils.js +47 -130
  495. package/runtime-dynamic/index.js +56 -191
  496. package/runtime-dynamic/main.js +42 -70
  497. package/runtime-dynamic/preview-mode.js +14 -29
  498. package/runtime-dynamic/preview-navigation.js +21 -30
  499. package/runtime-dynamic/preview-path.d.ts +5 -0
  500. package/runtime-dynamic/preview-path.js +13 -0
  501. package/runtime-dynamic/preview-resource-base.js +15 -31
  502. package/runtime-dynamic/registry/component-registry.js +269 -334
  503. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  504. package/runtime-dynamic/registry/index.js +24 -63
  505. package/runtime-dynamic/registry/store.d.ts +1 -0
  506. package/runtime-dynamic/registry/store.js +18 -23
  507. package/runtime-dynamic/routes.js +53 -81
  508. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  509. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  510. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  511. package/runtime-dynamic/services/cache.js +27 -33
  512. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  513. package/runtime-dynamic/services/compile-render.js +142 -0
  514. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  515. package/runtime-dynamic/services/css-scoping.js +27 -28
  516. package/runtime-dynamic/services/fragment-url.js +37 -50
  517. package/runtime-dynamic/services/index.js +48 -152
  518. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  519. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  520. package/runtime-dynamic/services/prefab-resources.js +42 -130
  521. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  522. package/runtime-dynamic/services/resource-manager.js +32 -63
  523. package/runtime-dynamic/services/script-executor.js +50 -61
  524. package/runtime-dynamic/services/variable-factory.js +141 -184
  525. package/runtime-dynamic/services/variable-registry.js +69 -115
  526. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  527. package/runtime-dynamic/shims/next-image.js +79 -50
  528. package/runtime-dynamic/shims/next-link.js +58 -32
  529. package/runtime-dynamic/shims/next-navigation.js +17 -34
  530. package/runtime-dynamic/utils/index.d.ts +2 -0
  531. package/runtime-dynamic/utils/index.js +22 -24
  532. package/store/bindActions/i18nActions.js +16 -18
  533. package/store/index.js +29 -35
  534. package/store/middleware/navigationMiddleware.js +25 -45
  535. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  536. package/store/slices/appConfigSlice.js +65 -94
  537. package/store/slices/authSlice.js +317 -471
  538. package/store/slices/i18nSlice.js +169 -168
  539. package/store/slices/navigationSlice.js +22 -20
  540. package/store/util/resolve-path.d.ts +1 -0
  541. package/store/util/resolve-path.js +7 -0
  542. package/store/viewport.service.js +150 -194
  543. package/types/index.js +10 -15
  544. package/utils/attr.js +198 -41
  545. package/utils/custom-expression/index.js +55 -151
  546. package/utils/custom-expression/parser.js +106 -182
  547. package/utils/dataset-util.js +113 -154
  548. package/utils/eval-expression.js +10 -19
  549. package/utils/form-state.util.js +60 -118
  550. package/utils/form-utils.js +49 -190
  551. package/utils/format-util.js +113 -184
  552. package/utils/layoutsize-util.js +11 -17
  553. package/utils/lib-error-skipper.js +54 -52
  554. package/utils/page-params-util.js +50 -40
  555. package/utils/pending-tab-navigation-intent.js +7 -17
  556. package/utils/resource-url.js +8 -19
  557. package/utils/state-persistance.js +136 -253
  558. package/utils/style-utils.d.ts +2 -0
  559. package/utils/style-utils.js +25 -74
  560. package/utils/transformedDataset-utils.js +353 -381
  561. package/utils/widget-cleanup-util.js +42 -74
  562. package/utils/widgets.js +19 -31
  563. package/variables/base-variable.js +117 -166
  564. package/variables/constants.js +5 -8
  565. package/variables/crud-variable.js +150 -181
  566. package/variables/live-variable.d.ts +1 -1
  567. package/variables/live-variable.js +140 -174
  568. package/variables/metadata.service.js +74 -116
  569. package/variables/model-variable.js +68 -78
  570. package/variables/service-variable.js +171 -285
  571. package/wm-namespace.js +11 -14
  572. package/components/chart/src/css.d.js +0 -1
  573. package/tsconfig.declaration.tsbuildinfo +0 -1
  574. package/types/global.d.js +0 -3
@@ -1,556 +1,547 @@
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.useTabsContext = exports["default"] = exports.WmTabs = void 0;
9
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
- var _react = _interopRequireWildcard(require("react"));
12
- var _clsx = _interopRequireDefault(require("clsx"));
13
- var _isEqual = _interopRequireDefault(require("lodash-es/isEqual"));
14
- var _tabs = require("@base-ui-components/react/tabs");
15
- var _Typography = _interopRequireDefault(require("@mui/material/Typography"));
16
- var _withBaseWrapper = _interopRequireDefault(require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper"));
17
- var _tabPane = _interopRequireDefault(require("@wavemaker-ai/react-runtime/components/container/tabs/tab-pane"));
18
- var _props = require("./props");
19
- var _statePersistance = require("@wavemaker-ai/react-runtime/utils/state-persistance");
20
- var _isArray = _interopRequireDefault(require("lodash-es/isArray"));
21
- var _utils = require("./utils");
22
- var _pendingTabNavigationIntent = require("@wavemaker-ai/react-runtime/utils/pending-tab-navigation-intent");
23
- function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
24
- var __jsx = _react["default"].createElement;
25
- function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
26
- function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
27
- var DEFAULT_CLASS = "nav nav-tabs";
28
- var PANE_HEADER_PROP_KEYS = ["name", "title", "disabled", "show", "paneicon", "badgevalue", "badgetype", "className", "onHeaderclick", "onHeaderClick"];
29
- var getPaneHeaderProps = function getPaneHeaderProps(props) {
30
- return {
31
- name: props === null || props === void 0 ? void 0 : props.name,
32
- title: props === null || props === void 0 ? void 0 : props.title,
33
- disabled: props === null || props === void 0 ? void 0 : props.disabled,
34
- show: props === null || props === void 0 ? void 0 : props.show,
35
- paneicon: props === null || props === void 0 ? void 0 : props.paneicon,
36
- badgevalue: props === null || props === void 0 ? void 0 : props.badgevalue,
37
- badgetype: props === null || props === void 0 ? void 0 : props.badgetype,
38
- className: props === null || props === void 0 ? void 0 : props.className,
39
- onHeaderclick: props === null || props === void 0 ? void 0 : props.onHeaderclick,
40
- onHeaderClick: props === null || props === void 0 ? void 0 : props.onHeaderClick
41
- };
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;
42
18
  };
43
- var arePaneHeaderPropsEqual = function arePaneHeaderPropsEqual() {
44
- var prev = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
45
- var next = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
46
- return PANE_HEADER_PROP_KEYS.every(function (key) {
47
- return Object.is(prev[key], next[key]);
48
- });
19
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
21
+ import { createElement } from "react";
22
+ import React, {
23
+ createContext,
24
+ memo,
25
+ useCallback,
26
+ useContext,
27
+ useEffect,
28
+ useMemo,
29
+ useRef,
30
+ useState
31
+ } from "react";
32
+ import clsx from "clsx";
33
+ import isEqual from "lodash-es/isEqual";
34
+ import { Tabs } from "@base-ui-components/react/tabs";
35
+ import Typography from "@mui/material/Typography";
36
+ import withBaseWrapper from "../../../higherOrder/withBaseWrapper";
37
+ import WmTabPane from "./tab-pane";
38
+ import { DEFAULT_PROPS } from "./props";
39
+ import {
40
+ getWidgetState,
41
+ setWidgetState
42
+ } from "../../../utils/state-persistance";
43
+ import isArray from "lodash-es/isArray";
44
+ import { filterVisibleChildren, handleRemovePane } from "./utils";
45
+ import { getPendingTabNavigationIntent } from "../../../utils/pending-tab-navigation-intent";
46
+ const DEFAULT_CLASS = "nav nav-tabs";
47
+ const PANE_HEADER_PROP_KEYS = [
48
+ "name",
49
+ "title",
50
+ "disabled",
51
+ "show",
52
+ "paneicon",
53
+ "badgevalue",
54
+ "badgetype",
55
+ "className",
56
+ "onHeaderclick",
57
+ "onHeaderClick"
58
+ ];
59
+ const getPaneHeaderProps = (props) => ({
60
+ name: props == null ? void 0 : props.name,
61
+ title: props == null ? void 0 : props.title,
62
+ disabled: props == null ? void 0 : props.disabled,
63
+ show: props == null ? void 0 : props.show,
64
+ paneicon: props == null ? void 0 : props.paneicon,
65
+ badgevalue: props == null ? void 0 : props.badgevalue,
66
+ badgetype: props == null ? void 0 : props.badgetype,
67
+ className: props == null ? void 0 : props.className,
68
+ onHeaderclick: props == null ? void 0 : props.onHeaderclick,
69
+ onHeaderClick: props == null ? void 0 : props.onHeaderClick
70
+ });
71
+ const arePaneHeaderPropsEqual = (prev = {}, next = {}) => {
72
+ return PANE_HEADER_PROP_KEYS.every((key) => Object.is(prev[key], next[key]));
49
73
  };
50
-
51
- // Helper function to check if a component is WmTabPane
52
- var isTabPaneComponent = function isTabPaneComponent(child) {
53
- var _child$type;
54
- var displayName = child === null || child === void 0 || (_child$type = child.type) === null || _child$type === void 0 || (_child$type = _child$type.type) === null || _child$type === void 0 ? void 0 : _child$type.displayName;
74
+ const isTabPaneComponent = (child) => {
75
+ var _a, _b;
76
+ const displayName = (_b = (_a = child == null ? void 0 : child.type) == null ? void 0 : _a.type) == null ? void 0 : _b.displayName;
55
77
  return displayName && (displayName.includes("WmTabpane") || displayName.includes("WmTabPane"));
56
78
  };
57
- var TabsContext = /*#__PURE__*/(0, _react.createContext)({
79
+ const TabsContext = createContext({
58
80
  selectedIndex: 0,
59
- setSelectedIndex: function setSelectedIndex() {},
60
- tabsContainerName: undefined,
61
- updatePaneHeader: function updatePaneHeader() {}
81
+ setSelectedIndex: () => {
82
+ },
83
+ tabsContainerName: void 0,
84
+ updatePaneHeader: () => {
85
+ }
62
86
  });
63
- var useTabsContext = exports.useTabsContext = function useTabsContext() {
64
- return (0, _react.useContext)(TabsContext);
87
+ const useTabsContext = () => {
88
+ return useContext(TabsContext);
65
89
  };
66
- var WmTabs = exports.WmTabs = /*#__PURE__*/(0, _react.memo)(function (Props) {
67
- var props = _objectSpread(_objectSpread({}, _props.DEFAULT_PROPS), Props);
68
-
69
- // Destructure all used props
70
- var defaultpaneindex = props.defaultpaneindex,
71
- statehandler = props.statehandler,
72
- name = props.name,
73
- listener = props.listener,
74
- type = props.type,
75
- dataset = props.dataset,
76
- children = props.children,
77
- render = props.render,
78
- iconposition = props.iconposition,
79
- _props$tabsposition = props.tabsposition,
80
- tabsposition = _props$tabsposition === void 0 ? "top" : _props$tabsposition,
81
- justified = props.justified,
82
- nodatamessage = props.nodatamessage,
83
- styles = props.styles,
84
- className = props.className,
85
- onChange = props.onChange;
86
-
87
- // Pending tab from NavigateTo (cross-page); mirrored from Redux via store middleware so this works without Provider
88
- var initialPendingTabRef = (0, _react.useRef)((0, _pendingTabNavigationIntent.getPendingTabNavigationIntent)());
89
- var Widgets = listener === null || listener === void 0 ? void 0 : listener.Widgets;
90
- var panesCount = (0, _react.useRef)(0);
91
- var prevSelectedIndex = (0, _react.useRef)(null);
92
-
93
- // Initialize selectedIndex to the pending tab index if a navigation target is set,
94
- // so the first render shows the correct tab without flashing through tab 0.
95
- var _useState = (0, _react.useState)(function () {
96
- var pendingTab = initialPendingTabRef.current;
90
+ const WmTabs = memo(
91
+ (Props) => {
92
+ const props = __spreadValues(__spreadValues({}, DEFAULT_PROPS), Props);
93
+ const {
94
+ defaultpaneindex,
95
+ statehandler,
96
+ name,
97
+ listener,
98
+ type,
99
+ dataset,
100
+ children,
101
+ render,
102
+ iconposition,
103
+ tabsposition = "top",
104
+ justified,
105
+ nodatamessage,
106
+ styles,
107
+ className,
108
+ onChange
109
+ } = props;
110
+ const initialPendingTabRef = useRef(getPendingTabNavigationIntent());
111
+ const Widgets = listener == null ? void 0 : listener.Widgets;
112
+ const panesCount = useRef(0);
113
+ const prevSelectedIndex = useRef(null);
114
+ const [selectedIndex, setSelectedIndex] = useState(() => {
115
+ const pendingTab = initialPendingTabRef.current;
97
116
  if (pendingTab && children) {
98
- var visibleChildren = (0, _utils.filterVisibleChildren)(children, new Set());
99
- var matchIndex = visibleChildren.findIndex(function (c) {
100
- var _c$props;
101
- return (c === null || c === void 0 || (_c$props = c.props) === null || _c$props === void 0 ? void 0 : _c$props.name) === pendingTab;
117
+ const visibleChildren = filterVisibleChildren(children, /* @__PURE__ */ new Set());
118
+ const matchIndex = visibleChildren.findIndex((c) => {
119
+ var _a;
120
+ return ((_a = c == null ? void 0 : c.props) == null ? void 0 : _a.name) === pendingTab;
102
121
  });
103
122
  if (matchIndex !== -1) return matchIndex;
104
123
  }
105
124
  return defaultpaneindex || 0;
106
- }),
107
- selectedIndex = _useState[0],
108
- setSelectedIndex = _useState[1];
109
- var currentSelectedIndex = (0, _react.useRef)(selectedIndex);
110
- var _useState2 = (0, _react.useState)(new Set()),
111
- hiddenTabNames = _useState2[0],
112
- setHiddenTabNames = _useState2[1];
113
- var _useState3 = (0, _react.useState)({}),
114
- paneHeaderOverrides = _useState3[0],
115
- setPaneHeaderOverrides = _useState3[1];
116
- // Track which tab indices have been rendered at least once (for dynamic tabs)
117
- var _useState4 = (0, _react.useState)(new Set([selectedIndex])),
118
- renderedTabIndices = _useState4[0],
119
- setRenderedTabIndices = _useState4[1];
120
- var updatePaneHeader = (0, _react.useCallback)(function (paneName, headerProps) {
121
- if (!paneName) return;
122
- var nextHeaderProps = getPaneHeaderProps(headerProps);
123
- setPaneHeaderOverrides(function (prev) {
124
- var prevHeaderProps = prev[paneName];
125
- if (arePaneHeaderPropsEqual(prevHeaderProps, nextHeaderProps)) {
126
- return prev;
127
- }
128
- return _objectSpread(_objectSpread({}, prev), {}, (0, _defineProperty2["default"])({}, paneName, nextHeaderProps));
129
125
  });
130
- }, []);
131
-
132
- // Keep currentSelectedIndex ref in sync with state
133
- (0, _react.useEffect)(function () {
134
- currentSelectedIndex.current = selectedIndex;
135
- }, [selectedIndex]);
136
-
137
- // Track which tabs have been rendered (for dynamic tabs to maintain state)
138
- (0, _react.useEffect)(function () {
139
- if (type === "dynamic" && (dataset === null || dataset === void 0 ? void 0 : dataset.length) > 0) {
140
- setRenderedTabIndices(function (prev) {
141
- var newSet = new Set(prev);
142
- if (selectedIndex >= 0 && selectedIndex < dataset.length) {
143
- newSet.add(selectedIndex);
126
+ const currentSelectedIndex = useRef(selectedIndex);
127
+ const [hiddenTabNames, setHiddenTabNames] = useState(/* @__PURE__ */ new Set());
128
+ const [paneHeaderOverrides, setPaneHeaderOverrides] = useState(
129
+ {}
130
+ );
131
+ const [renderedTabIndices, setRenderedTabIndices] = useState(
132
+ /* @__PURE__ */ new Set([selectedIndex])
133
+ );
134
+ const updatePaneHeader = useCallback((paneName, headerProps) => {
135
+ if (!paneName) return;
136
+ const nextHeaderProps = getPaneHeaderProps(headerProps);
137
+ setPaneHeaderOverrides((prev2) => {
138
+ const prevHeaderProps = prev2[paneName];
139
+ if (arePaneHeaderPropsEqual(prevHeaderProps, nextHeaderProps)) {
140
+ return prev2;
144
141
  }
145
- return newSet;
146
- });
147
- }
148
- }, [selectedIndex, type, dataset]);
149
-
150
- // Helper function to change tab with proper state management
151
- var changeTab = function changeTab(newIndex) {
152
- if (newIndex >= 0 && newIndex < panesCount.current && newIndex !== currentSelectedIndex.current) {
153
- prevSelectedIndex.current = currentSelectedIndex.current;
154
- setSelectedIndex(newIndex);
155
- saveStateToStorage(newIndex);
156
- return true;
157
- }
158
- return false;
159
- };
160
-
161
- // go to previous tab - using useCallback to ensure fresh closure
162
- var prev = _react["default"].useCallback(function () {
163
- var currentIndex = currentSelectedIndex.current;
164
- var targetIndex = currentIndex - 1;
165
- if (targetIndex >= 0) {
166
- changeTab(targetIndex);
167
- } else {
168
- // Wrap around to the last tab when at the first tab
169
- changeTab(panesCount.current - 1);
170
- }
171
- }, []);
172
-
173
- // go to next tab - using useCallback to ensure fresh closure
174
- var next = _react["default"].useCallback(function () {
175
- var currentIndex = currentSelectedIndex.current;
176
- var targetIndex = currentIndex + 1;
177
- if (targetIndex < panesCount.current) {
178
- changeTab(targetIndex);
179
- } else {
180
- // Wrap around to the first tab when at the last tab
181
- changeTab(0);
182
- }
183
- }, []);
184
-
185
- // go to specific tab - using useCallback to ensure fresh closure
186
- // Accepts 1-based index (1 = first tab, 2 = second tab, etc.)
187
- var _goToTab = _react["default"].useCallback(function (tabNumber) {
188
- // Convert from 1-based to 0-based index
189
- var index = tabNumber - 1;
190
-
191
- // Validate the tab number is within valid range
192
- if (tabNumber >= 1 && tabNumber <= panesCount.current && index !== currentSelectedIndex.current) {
193
- changeTab(index);
194
- }
195
- }, []);
196
-
197
- // get the active tab name for a given index
198
- var getActiveTabNameByIndex = _react["default"].useCallback(function (currentIndex) {
199
- var _activeChild$props;
200
- if (type === "dynamic" && (dataset === null || dataset === void 0 ? void 0 : dataset.length) > 0) {
201
- var _dataset$currentIndex;
202
- return ((_dataset$currentIndex = dataset[currentIndex]) === null || _dataset$currentIndex === void 0 ? void 0 : _dataset$currentIndex.name) || null;
203
- }
204
-
205
- // For static tabs, compute from visible children
206
- var visibleChildren = (0, _utils.filterVisibleChildren)(children, hiddenTabNames);
207
- var activeChild = visibleChildren[currentIndex];
208
- return (activeChild === null || activeChild === void 0 || (_activeChild$props = activeChild.props) === null || _activeChild$props === void 0 ? void 0 : _activeChild$props.name) || null;
209
- }, [type, dataset, children, hiddenTabNames]);
210
-
211
- // get the active tab widget from listener
212
- var getActiveTab = _react["default"].useCallback(function () {
213
- var _listener$Widgets;
214
- var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : currentSelectedIndex.current;
215
- var activeTabName = getActiveTabNameByIndex(index);
216
- return activeTabName ? listener === null || listener === void 0 || (_listener$Widgets = listener.Widgets) === null || _listener$Widgets === void 0 ? void 0 : _listener$Widgets[activeTabName] : null;
217
- }, [getActiveTabNameByIndex, listener]);
218
- var updateListener = function updateListener() {
219
- var activeIndex = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : currentSelectedIndex.current;
220
- if (listener && listener.onChange) {
221
- listener.onChange(name, {
222
- prev: prev,
223
- next: next,
224
- activeTab: getActiveTab(activeIndex),
225
- panes: {
226
- length: panesCount.current
227
- },
228
- goToTab: function goToTab(tabNumber) {
229
- _goToTab(tabNumber);
230
- },
231
- getActiveTabIndex: function getActiveTabIndex() {
232
- return currentSelectedIndex.current;
233
- },
234
- removePane: function removePane(TabName) {
235
- (0, _utils.handleRemovePane)({
236
- type: type,
237
- dataset: dataset,
238
- children: children,
239
- hiddenTabNames: hiddenTabNames,
240
- TabName: TabName,
241
- selectedIndex: selectedIndex,
242
- currentSelectedIndex: currentSelectedIndex,
243
- panesCountRef: panesCount,
244
- setHiddenTabNames: setHiddenTabNames,
245
- setSelectedIndex: setSelectedIndex,
246
- saveStateToStorage: saveStateToStorage
247
- });
248
- }
249
- });
250
- }
251
- };
252
- var getLatestTabsWidget = function getLatestTabsWidget(activeIndex) {
253
- var _listener$Widgets2;
254
- var registeredTabsWidget = name ? listener === null || listener === void 0 || (_listener$Widgets2 = listener.Widgets) === null || _listener$Widgets2 === void 0 ? void 0 : _listener$Widgets2[name] : null;
255
- return _objectSpread(_objectSpread({}, registeredTabsWidget || props), {}, {
256
- activeTab: getActiveTab(activeIndex)
257
- });
258
- };
259
-
260
- // register the methods
261
- (0, _react.useEffect)(function () {
262
- updateListener();
263
- }, [prev, next, _goToTab]); // Add dependencies to ensure fresh functions
264
-
265
- // State handler functions
266
- var getStateFromStorage = function getStateFromStorage() {
267
- if (!statehandler || statehandler === "none") return null;
268
- return (0, _statePersistance.getWidgetState)({
269
- name: name,
270
- type: "tabs",
271
- storage: statehandler
272
- });
273
- };
274
- var saveStateToStorage = function saveStateToStorage(index) {
275
- if (!statehandler || statehandler === "none") return;
276
- (0, _statePersistance.setWidgetState)({
277
- name: name,
278
- type: "tabs",
279
- storage: statehandler
280
- }, String(index));
281
- };
282
- (0, _react.useEffect)(function () {
283
- // If a tab was targeted via navigation (NavigateTo action with tabName),
284
- // honour that selection and skip the default/saved-state logic entirely.
285
- var pendingTab = initialPendingTabRef.current;
286
- if (pendingTab && children) {
287
- var visibleChildren = (0, _utils.filterVisibleChildren)(children, new Set());
288
- var matchIndex = visibleChildren.findIndex(function (c) {
289
- var _c$props2;
290
- return (c === null || c === void 0 || (_c$props2 = c.props) === null || _c$props2 === void 0 ? void 0 : _c$props2.name) === pendingTab;
142
+ return __spreadProps(__spreadValues({}, prev2), {
143
+ [paneName]: nextHeaderProps
144
+ });
291
145
  });
292
- if (matchIndex !== -1) {
293
- setSelectedIndex(matchIndex);
294
- currentSelectedIndex.current = matchIndex;
295
- return;
146
+ }, []);
147
+ useEffect(() => {
148
+ currentSelectedIndex.current = selectedIndex;
149
+ }, [selectedIndex]);
150
+ useEffect(() => {
151
+ if (type === "dynamic" && (dataset == null ? void 0 : dataset.length) > 0) {
152
+ setRenderedTabIndices((prev2) => {
153
+ const newSet = new Set(prev2);
154
+ if (selectedIndex >= 0 && selectedIndex < dataset.length) {
155
+ newSet.add(selectedIndex);
156
+ }
157
+ return newSet;
158
+ });
296
159
  }
297
- }
298
- var targetIndex = defaultpaneindex || 0;
299
-
300
- // Try to restore from state handler first
301
- var savedState = getStateFromStorage();
302
- if (savedState) {
303
- targetIndex = savedState;
304
- } else {
305
- // Convert defaultpaneindex to number if it's a string
306
- if (defaultpaneindex !== undefined) {
307
- var parsedIndex = parseInt(defaultpaneindex.toString(), 10);
308
- targetIndex = isNaN(parsedIndex) ? 0 : parsedIndex;
160
+ }, [selectedIndex, type, dataset]);
161
+ const changeTab = (newIndex) => {
162
+ if (newIndex >= 0 && newIndex < panesCount.current && newIndex !== currentSelectedIndex.current) {
163
+ prevSelectedIndex.current = currentSelectedIndex.current;
164
+ setSelectedIndex(newIndex);
165
+ saveStateToStorage(newIndex);
166
+ return true;
309
167
  }
310
- }
311
- setSelectedIndex(targetIndex);
312
- currentSelectedIndex.current = targetIndex;
313
- // Don't set prevSelectedIndex here as it should remain null for initial state
314
- }, [defaultpaneindex, statehandler, name]);
315
-
316
- // ============================================================================
317
- // Rendering Helpers
318
- // ============================================================================
319
-
320
- var handleTabHeaderClick = _react["default"].useCallback(function (e, item, index) {
321
- if (item !== null && item !== void 0 && item.disabled) {
322
- return;
323
- }
324
- if (item !== null && item !== void 0 && item.onHeaderclick) {
325
- item.onHeaderclick(e, Widgets === null || Widgets === void 0 ? void 0 : Widgets[name], index);
326
- }
327
- }, [Widgets, name]);
328
- var renderTabHeader = _react["default"].useCallback(function (item, index) {
329
- return __jsx(_tabs.Tabs.Tab, (0, _extends2["default"])({}, item, {
330
- title: item.title || item.name || "Tab ".concat(index + 1),
331
- name: item.name || "Tab ".concat(index + 1),
332
- key: index,
333
- value: index,
334
- id: "tab-".concat(index),
335
- "aria-controls": "tabpanel-".concat(index),
336
- disabled: item === null || item === void 0 ? void 0 : item.disabled,
337
- className: (0, _clsx["default"])("tab-header", item.className, {
338
- active: selectedIndex === index,
339
- disabled: item === null || item === void 0 ? void 0 : item.disabled
340
- }),
341
- hidden: item.show === false,
342
- role: "tab",
343
- "aria-selected": selectedIndex === index,
344
- tabIndex: selectedIndex === index ? 0 : -1,
345
- render: function render(prop) {
346
- return __jsx("li", prop, __jsx("div", {
347
- className: (0, _clsx["default"])("tab-heading", "wm-tabs-heading", {
348
- "wm-tabs-heading-disabled": item.disabled
349
- }),
350
- "icon-position": iconposition || "left",
351
- title: item.title || item.name || "Tab ".concat(index + 1),
352
- "aria-selected": selectedIndex === index,
353
- "aria-disabled": item.disabled,
354
- "aria-hidden": item.show === false,
355
- "aria-controls": "tabpanel-".concat(index),
356
- onClick: function onClick(e) {
357
- return handleTabHeaderClick(e, item, index);
168
+ return false;
169
+ };
170
+ const prev = React.useCallback(() => {
171
+ const currentIndex = currentSelectedIndex.current;
172
+ const targetIndex = currentIndex - 1;
173
+ if (targetIndex >= 0) {
174
+ changeTab(targetIndex);
175
+ } else {
176
+ changeTab(panesCount.current - 1);
177
+ }
178
+ }, []);
179
+ const next = React.useCallback(() => {
180
+ const currentIndex = currentSelectedIndex.current;
181
+ const targetIndex = currentIndex + 1;
182
+ if (targetIndex < panesCount.current) {
183
+ changeTab(targetIndex);
184
+ } else {
185
+ changeTab(0);
186
+ }
187
+ }, []);
188
+ const goToTab = React.useCallback((tabNumber) => {
189
+ const index = tabNumber - 1;
190
+ if (tabNumber >= 1 && tabNumber <= panesCount.current && index !== currentSelectedIndex.current) {
191
+ changeTab(index);
192
+ }
193
+ }, []);
194
+ const getActiveTabNameByIndex = React.useCallback(
195
+ (currentIndex) => {
196
+ var _a, _b;
197
+ if (type === "dynamic" && (dataset == null ? void 0 : dataset.length) > 0) {
198
+ return ((_a = dataset[currentIndex]) == null ? void 0 : _a.name) || null;
199
+ }
200
+ const visibleChildren = filterVisibleChildren(children, hiddenTabNames);
201
+ const activeChild = visibleChildren[currentIndex];
202
+ return ((_b = activeChild == null ? void 0 : activeChild.props) == null ? void 0 : _b.name) || null;
203
+ },
204
+ [type, dataset, children, hiddenTabNames]
205
+ );
206
+ const getActiveTab = React.useCallback(
207
+ (index = currentSelectedIndex.current) => {
208
+ var _a;
209
+ const activeTabName = getActiveTabNameByIndex(index);
210
+ return activeTabName ? (_a = listener == null ? void 0 : listener.Widgets) == null ? void 0 : _a[activeTabName] : null;
211
+ },
212
+ [getActiveTabNameByIndex, listener]
213
+ );
214
+ const updateListener = (activeIndex = currentSelectedIndex.current) => {
215
+ if (listener && listener.onChange) {
216
+ listener.onChange(name, {
217
+ prev,
218
+ next,
219
+ activeTab: getActiveTab(activeIndex),
220
+ panes: { length: panesCount.current },
221
+ goToTab: (tabNumber) => {
222
+ goToTab(tabNumber);
223
+ },
224
+ getActiveTabIndex: () => {
225
+ return currentSelectedIndex.current;
226
+ },
227
+ removePane: (TabName) => {
228
+ handleRemovePane({
229
+ type,
230
+ dataset,
231
+ children,
232
+ hiddenTabNames,
233
+ TabName,
234
+ selectedIndex,
235
+ currentSelectedIndex,
236
+ panesCountRef: panesCount,
237
+ setHiddenTabNames,
238
+ setSelectedIndex,
239
+ saveStateToStorage
240
+ });
358
241
  }
359
- }, item.paneicon && __jsx("i", {
360
- className: "app-icon ".concat(item.paneicon)
361
- }), __jsx(_Typography["default"], {
362
- variant: "body2",
363
- component: "span"
364
- }, item.title || item.name || "Tab ".concat(index + 1)), item.badgevalue && __jsx(_Typography["default"], {
365
- variant: "body2",
366
- component: "span",
367
- className: "label label-".concat(item.badgetype || "default")
368
- }, item.badgevalue)));
242
+ });
369
243
  }
370
- }));
371
- }, [selectedIndex, iconposition, handleTabHeaderClick]);
372
- var renderDynamicTabs = _react["default"].useCallback(function () {
373
- if (!(dataset !== null && dataset !== void 0 && dataset.length)) return null;
374
- var headers = [];
375
- var tabIndex = 0;
376
- var addTabHeader = function addTabHeader(itemProps) {
377
- var paneName = itemProps === null || itemProps === void 0 ? void 0 : itemProps.name;
378
- var latestWidgetState = paneName ? (Widgets === null || Widgets === void 0 ? void 0 : Widgets[paneName]) || {} : {};
379
- var headerOverrides = paneName ? paneHeaderOverrides[paneName] || {} : {};
380
- var resolvedItemProps = _objectSpread(_objectSpread(_objectSpread({}, itemProps), latestWidgetState), headerOverrides);
381
- headers.push(__jsx(_react["default"].Fragment, {
382
- key: tabIndex
383
- }, renderTabHeader(resolvedItemProps, tabIndex)));
384
- tabIndex++;
385
244
  };
386
- dataset.forEach(function (item, index) {
387
- if (render) {
388
- var _rendered$props;
389
- var rendered = render(item, index, dataset);
390
- var _children = rendered === null || rendered === void 0 || (_rendered$props = rendered.props) === null || _rendered$props === void 0 ? void 0 : _rendered$props.children;
391
- if ((0, _isArray["default"])(_children)) {
392
- _children.filter(isTabPaneComponent).forEach(function (child) {
393
- return addTabHeader(child.props);
394
- });
395
- } else if (_children !== null && _children !== void 0 && _children.props) {
396
- addTabHeader(_children.props);
245
+ const getLatestTabsWidget = (activeIndex) => {
246
+ var _a;
247
+ const registeredTabsWidget = name ? (_a = listener == null ? void 0 : listener.Widgets) == null ? void 0 : _a[name] : null;
248
+ return __spreadProps(__spreadValues({}, registeredTabsWidget || props), {
249
+ activeTab: getActiveTab(activeIndex)
250
+ });
251
+ };
252
+ useEffect(() => {
253
+ updateListener();
254
+ }, [prev, next, goToTab]);
255
+ const getStateFromStorage = () => {
256
+ if (!statehandler || statehandler === "none") return null;
257
+ return getWidgetState({ name, type: "tabs", storage: statehandler });
258
+ };
259
+ const saveStateToStorage = (index) => {
260
+ if (!statehandler || statehandler === "none") return;
261
+ setWidgetState({ name, type: "tabs", storage: statehandler }, String(index));
262
+ };
263
+ useEffect(() => {
264
+ const pendingTab = initialPendingTabRef.current;
265
+ if (pendingTab && children) {
266
+ const visibleChildren = filterVisibleChildren(children, /* @__PURE__ */ new Set());
267
+ const matchIndex = visibleChildren.findIndex((c) => {
268
+ var _a;
269
+ return ((_a = c == null ? void 0 : c.props) == null ? void 0 : _a.name) === pendingTab;
270
+ });
271
+ if (matchIndex !== -1) {
272
+ setSelectedIndex(matchIndex);
273
+ currentSelectedIndex.current = matchIndex;
274
+ return;
397
275
  }
276
+ }
277
+ let targetIndex = defaultpaneindex || 0;
278
+ const savedState = getStateFromStorage();
279
+ if (savedState) {
280
+ targetIndex = savedState;
398
281
  } else {
399
- addTabHeader(item);
282
+ if (defaultpaneindex !== void 0) {
283
+ const parsedIndex = parseInt(defaultpaneindex.toString(), 10);
284
+ targetIndex = isNaN(parsedIndex) ? 0 : parsedIndex;
285
+ }
400
286
  }
401
- });
402
- panesCount.current = tabIndex;
403
- return headers;
404
- }, [dataset, render, renderTabHeader, Widgets, paneHeaderOverrides]);
405
- var renderStaticTabs = _react["default"].useCallback(function () {
406
- // Consider only panes with show !== false and not hidden via internal state
407
- var visibleChildren = (0, _utils.filterVisibleChildren)(children, hiddenTabNames);
408
- panesCount.current = visibleChildren.length;
409
- return visibleChildren.map(function (child, index) {
410
- var _child$props;
411
- if (!child) return null;
412
- var paneName = child === null || child === void 0 || (_child$props = child.props) === null || _child$props === void 0 ? void 0 : _child$props.name;
413
- var latestWidgetState = paneName ? (Widgets === null || Widgets === void 0 ? void 0 : Widgets[paneName]) || {} : {};
414
- var headerOverrides = paneName ? paneHeaderOverrides[paneName] || {} : {};
415
- var itemProps = _objectSpread(_objectSpread(_objectSpread({}, child.props), latestWidgetState), headerOverrides);
416
- return __jsx(_react["default"].Fragment, {
417
- key: index
418
- }, renderTabHeader(itemProps, index));
419
- });
420
- }, [children, renderTabHeader, hiddenTabNames, Widgets, paneHeaderOverrides]);
421
- var renderTabs = _react["default"].useMemo(function () {
422
- return type === "dynamic" && (dataset === null || dataset === void 0 ? void 0 : dataset.length) > 0 ? renderDynamicTabs() : renderStaticTabs();
423
- }, [type, dataset, renderDynamicTabs, renderStaticTabs]);
424
- var tabsContextValue = (0, _react.useMemo)(function () {
425
- return {
426
- selectedIndex: selectedIndex,
427
- setSelectedIndex: setSelectedIndex,
428
- tabsContainerName: name,
429
- updatePaneHeader: updatePaneHeader
430
- };
431
- }, [selectedIndex, name, updatePaneHeader]);
432
-
433
- // for vertical tabs, we need to set the flex direction to row
434
- var orientation = tabsposition === "left" || tabsposition === "right" ? "vertical" : "horizontal";
435
- var renderTabPanels = function renderTabPanels() {
436
- if (type === "dynamic" && (dataset === null || dataset === void 0 ? void 0 : dataset.length) > 0) {
437
- // Render all previously visited tabs, but hide inactive ones to maintain state
438
- return Array.from(renderedTabIndices).filter(function (index) {
439
- return index >= 0 && index < dataset.length;
440
- }).map(function (index) {
441
- var item = dataset[index];
442
- var isActive = selectedIndex === index;
443
- return __jsx(_react["default"].Fragment, {
444
- key: index
445
- }, render ? __jsx(_react["default"].Fragment, null, render(item, index, dataset, isActive)) : __jsx(_tabPane["default"], (0, _extends2["default"])({}, item, {
287
+ setSelectedIndex(targetIndex);
288
+ currentSelectedIndex.current = targetIndex;
289
+ }, [defaultpaneindex, statehandler, name]);
290
+ const handleTabHeaderClick = React.useCallback(
291
+ (e, item, index) => {
292
+ if (item == null ? void 0 : item.disabled) {
293
+ return;
294
+ }
295
+ if (item == null ? void 0 : item.onHeaderclick) {
296
+ item.onHeaderclick(e, Widgets == null ? void 0 : Widgets[name], index);
297
+ }
298
+ },
299
+ [Widgets, name]
300
+ );
301
+ const renderTabHeader = React.useCallback(
302
+ (item, index) => /* @__PURE__ */ createElement(
303
+ Tabs.Tab,
304
+ __spreadProps(__spreadValues({}, item), {
305
+ title: item.title || item.name || `Tab ${index + 1}`,
306
+ name: item.name || `Tab ${index + 1}`,
446
307
  key: index,
447
- value: selectedIndex,
448
- listener: listener // Pass the updated listener context
449
- ,
450
- className: (0, _clsx["default"])("tab-pane", {
451
- active: isActive,
452
- disabled: item.disabled,
453
- hidden: item.show === false
308
+ value: index,
309
+ id: `tab-${index}`,
310
+ "aria-controls": `tabpanel-${index}`,
311
+ disabled: item == null ? void 0 : item.disabled,
312
+ className: clsx("tab-header", item.className, {
313
+ active: selectedIndex === index,
314
+ disabled: item == null ? void 0 : item.disabled
454
315
  }),
455
- index: index
456
- })));
316
+ hidden: item.show === false,
317
+ role: "tab",
318
+ "aria-selected": selectedIndex === index,
319
+ tabIndex: selectedIndex === index ? 0 : -1,
320
+ render: (prop) => /* @__PURE__ */ jsx("li", __spreadProps(__spreadValues({}, prop), { children: /* @__PURE__ */ jsxs(
321
+ "div",
322
+ {
323
+ className: clsx("tab-heading", "wm-tabs-heading", {
324
+ "wm-tabs-heading-disabled": item.disabled
325
+ }),
326
+ "icon-position": iconposition || "left",
327
+ title: item.title || item.name || `Tab ${index + 1}`,
328
+ "aria-selected": selectedIndex === index,
329
+ "aria-disabled": item.disabled,
330
+ "aria-hidden": item.show === false,
331
+ "aria-controls": `tabpanel-${index}`,
332
+ onClick: (e) => handleTabHeaderClick(e, item, index),
333
+ children: [
334
+ item.paneicon && /* @__PURE__ */ jsx("i", { className: `app-icon ${item.paneicon}` }),
335
+ /* @__PURE__ */ jsx(Typography, { variant: "body2", component: "span", children: item.title || item.name || `Tab ${index + 1}` }),
336
+ item.badgevalue && /* @__PURE__ */ jsx(
337
+ Typography,
338
+ {
339
+ variant: "body2",
340
+ component: "span",
341
+ className: `label label-${item.badgetype || "default"}`,
342
+ children: item.badgevalue
343
+ }
344
+ )
345
+ ]
346
+ }
347
+ ) }))
348
+ })
349
+ ),
350
+ [selectedIndex, iconposition, handleTabHeaderClick]
351
+ );
352
+ const renderDynamicTabs = React.useCallback(() => {
353
+ if (!(dataset == null ? void 0 : dataset.length)) return null;
354
+ const headers = [];
355
+ let tabIndex = 0;
356
+ const addTabHeader = (itemProps) => {
357
+ const paneName = itemProps == null ? void 0 : itemProps.name;
358
+ const latestWidgetState = paneName ? (Widgets == null ? void 0 : Widgets[paneName]) || {} : {};
359
+ const headerOverrides = paneName ? paneHeaderOverrides[paneName] || {} : {};
360
+ const resolvedItemProps = __spreadValues(__spreadValues(__spreadValues({}, itemProps), latestWidgetState), headerOverrides);
361
+ headers.push(
362
+ /* @__PURE__ */ jsx(React.Fragment, { children: renderTabHeader(resolvedItemProps, tabIndex) }, tabIndex)
363
+ );
364
+ tabIndex++;
365
+ };
366
+ dataset.forEach((item, index) => {
367
+ var _a;
368
+ if (render) {
369
+ const rendered = render(item, index, dataset);
370
+ const children2 = (_a = rendered == null ? void 0 : rendered.props) == null ? void 0 : _a.children;
371
+ if (isArray(children2)) {
372
+ children2.filter(isTabPaneComponent).forEach((child) => addTabHeader(child.props));
373
+ } else if (children2 == null ? void 0 : children2.props) {
374
+ addTabHeader(children2.props);
375
+ }
376
+ } else {
377
+ addTabHeader(item);
378
+ }
457
379
  });
458
- }
459
-
460
- // For static tabs, render only visible panes with corrected indices
461
- // so they match the sequential header indices assigned by renderStaticTabs
462
- var visibleChildren = (0, _utils.filterVisibleChildren)(children, hiddenTabNames);
463
- return visibleChildren.map(function (child, idx) {
464
- if (!(child !== null && child !== void 0 && child.props)) return child;
465
- if (child.props.index === idx) return child;
466
- return /*#__PURE__*/_react["default"].cloneElement(child, {
467
- index: idx
380
+ panesCount.current = tabIndex;
381
+ return headers;
382
+ }, [dataset, render, renderTabHeader, Widgets, paneHeaderOverrides]);
383
+ const renderStaticTabs = React.useCallback(() => {
384
+ const visibleChildren = filterVisibleChildren(children, hiddenTabNames);
385
+ panesCount.current = visibleChildren.length;
386
+ return visibleChildren.map((child, index) => {
387
+ var _a;
388
+ if (!child) return null;
389
+ const paneName = (_a = child == null ? void 0 : child.props) == null ? void 0 : _a.name;
390
+ const latestWidgetState = paneName ? (Widgets == null ? void 0 : Widgets[paneName]) || {} : {};
391
+ const headerOverrides = paneName ? paneHeaderOverrides[paneName] || {} : {};
392
+ const itemProps = __spreadValues(__spreadValues(__spreadValues({}, child.props), latestWidgetState), headerOverrides);
393
+ return /* @__PURE__ */ jsx(React.Fragment, { children: renderTabHeader(itemProps, index) }, index);
468
394
  });
395
+ }, [children, renderTabHeader, hiddenTabNames, Widgets, paneHeaderOverrides]);
396
+ const renderTabs = React.useMemo(() => {
397
+ return type === "dynamic" && (dataset == null ? void 0 : dataset.length) > 0 ? renderDynamicTabs() : renderStaticTabs();
398
+ }, [type, dataset, renderDynamicTabs, renderStaticTabs]);
399
+ const tabsContextValue = useMemo(
400
+ () => ({
401
+ selectedIndex,
402
+ setSelectedIndex,
403
+ tabsContainerName: name,
404
+ updatePaneHeader
405
+ }),
406
+ [selectedIndex, name, updatePaneHeader]
407
+ );
408
+ const orientation = tabsposition === "left" || tabsposition === "right" ? "vertical" : "horizontal";
409
+ const renderTabPanels = () => {
410
+ if (type === "dynamic" && (dataset == null ? void 0 : dataset.length) > 0) {
411
+ return Array.from(renderedTabIndices).filter((index) => index >= 0 && index < dataset.length).map((index) => {
412
+ const item = dataset[index];
413
+ const isActive = selectedIndex === index;
414
+ return /* @__PURE__ */ jsx(React.Fragment, { children: render ? /* @__PURE__ */ jsx(Fragment, { children: render(item, index, dataset, isActive) }) : /* @__PURE__ */ createElement(
415
+ WmTabPane,
416
+ __spreadProps(__spreadValues({}, item), {
417
+ key: index,
418
+ value: selectedIndex,
419
+ listener,
420
+ className: clsx("tab-pane", {
421
+ active: isActive,
422
+ disabled: item.disabled,
423
+ hidden: item.show === false
424
+ }),
425
+ index
426
+ })
427
+ ) }, index);
428
+ });
429
+ }
430
+ const visibleChildren = filterVisibleChildren(children, hiddenTabNames);
431
+ return visibleChildren.map((child, idx) => {
432
+ if (!(child == null ? void 0 : child.props)) return child;
433
+ if (child.props.index === idx) return child;
434
+ return React.cloneElement(child, { index: idx });
435
+ });
436
+ };
437
+ if (type === "dynamic" && (dataset == null ? void 0 : dataset.length) <= 0) {
438
+ return /* @__PURE__ */ jsx("div", { children: nodatamessage });
439
+ }
440
+ const contentFirst = tabsposition === "right" || tabsposition === "bottom";
441
+ return /* @__PURE__ */ jsx(TabsContext.Provider, { value: tabsContextValue, children: /* @__PURE__ */ jsx(
442
+ Tabs.Root,
443
+ __spreadProps(__spreadValues({
444
+ style: styles
445
+ }, { name, tabsposition }), {
446
+ value: selectedIndex,
447
+ onValueChange: (value) => {
448
+ const newIndex = value;
449
+ const oldIndex = currentSelectedIndex.current;
450
+ prevSelectedIndex.current = oldIndex;
451
+ currentSelectedIndex.current = newIndex;
452
+ setSelectedIndex(newIndex);
453
+ saveStateToStorage(newIndex);
454
+ updateListener(newIndex);
455
+ onChange == null ? void 0 : onChange(null, getLatestTabsWidget(newIndex), newIndex, oldIndex);
456
+ },
457
+ orientation,
458
+ className: clsx("app-tabs clearfix", className, {
459
+ vertical: orientation === "vertical",
460
+ justified,
461
+ inverted: contentFirst
462
+ }),
463
+ children: contentFirst ? /* @__PURE__ */ jsxs(Fragment, { children: [
464
+ /* @__PURE__ */ jsx(
465
+ "div",
466
+ {
467
+ className: clsx("tab-content", "wm-tabs-content", {
468
+ "tab-stacked": orientation === "vertical",
469
+ "tab-justified": justified,
470
+ "wm-tabs-content-vertical": orientation === "vertical"
471
+ }),
472
+ children: renderTabPanels()
473
+ }
474
+ ),
475
+ /* @__PURE__ */ jsx(
476
+ Tabs.List,
477
+ {
478
+ className: clsx(DEFAULT_CLASS, {
479
+ "nav-stacked": orientation === "vertical",
480
+ "nav-justified": justified
481
+ }),
482
+ role: "tablist",
483
+ render: (props2, state) => {
484
+ return /* @__PURE__ */ jsx("ul", __spreadProps(__spreadValues({}, props2), { children: renderTabs }));
485
+ }
486
+ }
487
+ )
488
+ ] }) : /* @__PURE__ */ jsxs(Fragment, { children: [
489
+ /* @__PURE__ */ jsx(
490
+ Tabs.List,
491
+ {
492
+ className: clsx(DEFAULT_CLASS, {
493
+ "nav-stacked": orientation === "vertical",
494
+ "nav-justified": justified
495
+ }),
496
+ role: "tablist",
497
+ render: (props2, state) => {
498
+ return /* @__PURE__ */ jsx("ul", __spreadProps(__spreadValues({}, props2), { children: renderTabs }));
499
+ }
500
+ }
501
+ ),
502
+ /* @__PURE__ */ jsx(
503
+ "div",
504
+ {
505
+ className: clsx("tab-content", "wm-tabs-content", {
506
+ "tab-stacked": orientation === "vertical",
507
+ "tab-justified": justified,
508
+ "wm-tabs-content-vertical": orientation === "vertical"
509
+ }),
510
+ children: renderTabPanels()
511
+ }
512
+ )
513
+ ] })
514
+ })
515
+ ) });
516
+ },
517
+ (prev, next) => {
518
+ const keys = [
519
+ "dataset",
520
+ "defaultpaneindex",
521
+ "justified",
522
+ "tabsposition",
523
+ "nodatamessage",
524
+ "statehandler",
525
+ "autotabactivation",
526
+ "transition",
527
+ "type",
528
+ "iconposition",
529
+ "render",
530
+ "selectedindex",
531
+ "children"
532
+ ];
533
+ return keys.every((key) => {
534
+ if (key === "children") {
535
+ return prev[key] === next[key];
536
+ }
537
+ return isEqual(prev[key], next[key]);
469
538
  });
470
- };
471
- if (type === "dynamic" && (dataset === null || dataset === void 0 ? void 0 : dataset.length) <= 0) {
472
- return __jsx("div", null, nodatamessage);
473
539
  }
474
- // moves tab list to end for right/bottom (appendNode), so content is first in DOM.
475
- var contentFirst = tabsposition === "right" || tabsposition === "bottom";
476
- return __jsx(TabsContext.Provider, {
477
- value: tabsContextValue
478
- }, __jsx(_tabs.Tabs.Root, {
479
- style: styles,
480
- name: name,
481
- tabsposition: tabsposition,
482
- value: selectedIndex,
483
- onValueChange: function onValueChange(value) {
484
- var newIndex = value;
485
- var oldIndex = currentSelectedIndex.current;
486
-
487
- // Update refs and state
488
- prevSelectedIndex.current = oldIndex;
489
- currentSelectedIndex.current = newIndex;
490
- setSelectedIndex(newIndex);
491
- saveStateToStorage(newIndex);
492
-
493
- // Publish activeTab before external handlers read wm.Widgets[name].activeTab.
494
- updateListener(newIndex);
495
- onChange === null || onChange === void 0 || onChange(null, getLatestTabsWidget(newIndex), newIndex, oldIndex);
496
- },
497
- orientation: orientation,
498
- className: (0, _clsx["default"])("app-tabs clearfix", className, {
499
- vertical: orientation === "vertical",
500
- justified: justified,
501
- inverted: contentFirst
502
- })
503
- }, contentFirst ? __jsx(_react["default"].Fragment, null, __jsx("div", {
504
- className: (0, _clsx["default"])("tab-content", "wm-tabs-content", {
505
- "tab-stacked": orientation === "vertical",
506
- "tab-justified": justified,
507
- "wm-tabs-content-vertical": orientation === "vertical"
508
- })
509
- }, renderTabPanels()), __jsx(_tabs.Tabs.List, {
510
- className: (0, _clsx["default"])(DEFAULT_CLASS, {
511
- "nav-stacked": orientation === "vertical",
512
- "nav-justified": justified
513
- }),
514
- role: "tablist",
515
- render: function render(props, state) {
516
- return __jsx("ul", props, renderTabs);
517
- }
518
- })) : __jsx(_react["default"].Fragment, null, __jsx(_tabs.Tabs.List, {
519
- className: (0, _clsx["default"])(DEFAULT_CLASS, {
520
- "nav-stacked": orientation === "vertical",
521
- "nav-justified": justified
522
- }),
523
- role: "tablist",
524
- render: function render(props, state) {
525
- return __jsx("ul", props, renderTabs);
526
- }
527
- }), __jsx("div", {
528
- className: (0, _clsx["default"])("tab-content", "wm-tabs-content", {
529
- "tab-stacked": orientation === "vertical",
530
- "tab-justified": justified,
531
- "wm-tabs-content-vertical": orientation === "vertical"
532
- })
533
- }, renderTabPanels()))));
534
- }, function (prev, next) {
535
- var keys = ["dataset", "defaultpaneindex", "justified", "tabsposition", "nodatamessage", "statehandler", "autotabactivation", "transition", "type", "iconposition", "render", "selectedindex", "children"];
536
- return keys.every(function (key) {
537
- // Never deep-compare children; treat as referential bcz the children will have listener props attached cause infinite comparion.
538
- if (key === "children") {
539
- return prev[key] === next[key];
540
- }
541
- return (0, _isEqual["default"])(prev[key], next[key]);
542
- });
543
- });
540
+ );
544
541
  WmTabs.displayName = "WmTabs";
545
-
546
- /**
547
- * The WmTabs component displays tabbed content with support for static
548
- * (children) and dynamic (dataset) modes with state persistence.
549
- *
550
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/containers-tabs--showcase)
551
- *
552
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/containers-tabs--docs)
553
- *
554
- * @param props - {@link WmTabsProps}
555
- */
556
- var _default = exports["default"] = (0, _withBaseWrapper["default"])(WmTabs);
542
+ var tabs_default = withBaseWrapper(WmTabs);
543
+ export {
544
+ WmTabs,
545
+ tabs_default as default,
546
+ useTabsContext
547
+ };