@wavemaker-ai/react-runtime 1.0.0-rc.647502 → 1.0.0-rc.647565

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (574) hide show
  1. package/.npmignore +4 -0
  2. package/actions/base-action.js +12 -29
  3. package/actions/login-action.js +35 -52
  4. package/actions/logout-action.js +21 -38
  5. package/actions/navigation-action.js +251 -346
  6. package/actions/notification-action.js +121 -149
  7. package/actions/timer-action.js +95 -151
  8. package/actions/toast-provider.js +62 -76
  9. package/actions/toast.js +95 -91
  10. package/actions/toast.service.js +59 -79
  11. package/actions/types/index.js +6 -9
  12. package/components/advanced/carousel/index.js +358 -366
  13. package/components/advanced/carousel/props.js +0 -5
  14. package/components/advanced/carousel/template.js +102 -80
  15. package/components/advanced/login/index.js +227 -285
  16. package/components/advanced/login/props.js +0 -5
  17. package/components/advanced/marquee/index.js +169 -163
  18. package/components/advanced/marquee/props.js +0 -5
  19. package/components/basic/anchor/index.js +207 -187
  20. package/components/basic/anchor/props.js +0 -5
  21. package/components/basic/audio/index.js +110 -72
  22. package/components/basic/audio/props.js +0 -5
  23. package/components/basic/html/index.js +163 -203
  24. package/components/basic/html/props.js +0 -5
  25. package/components/basic/html/utils.js +30 -28
  26. package/components/basic/icon/index.js +98 -84
  27. package/components/basic/icon/props.js +0 -5
  28. package/components/basic/iframe/iframe.utils.js +7 -16
  29. package/components/basic/iframe/index.js +97 -103
  30. package/components/basic/iframe/props.js +0 -5
  31. package/components/basic/label/index.js +156 -134
  32. package/components/basic/label/props.js +0 -5
  33. package/components/basic/message/index.js +129 -113
  34. package/components/basic/message/props.js +0 -5
  35. package/components/basic/picture/index.js +156 -127
  36. package/components/basic/picture/props.js +0 -5
  37. package/components/basic/progress-bar/index.js +240 -176
  38. package/components/basic/progress-bar/props.js +5 -31
  39. package/components/basic/progress-circle/index.js +166 -183
  40. package/components/basic/progress-circle/props.js +14 -34
  41. package/components/basic/richtexteditor/index.js +430 -396
  42. package/components/basic/richtexteditor/props.js +0 -5
  43. package/components/basic/search/index.js +812 -931
  44. package/components/basic/search/props.js +0 -5
  45. package/components/basic/search/providers.js +233 -380
  46. package/components/basic/spinner/index.js +210 -200
  47. package/components/basic/spinner/props.js +4 -22
  48. package/components/basic/tile/index.js +73 -81
  49. package/components/basic/tile/props.js +0 -5
  50. package/components/basic/tree/Components/TreeNodeComponent.js +238 -170
  51. package/components/basic/tree/hooks/useTreePartialNodeApi.js +143 -135
  52. package/components/basic/tree/index.js +378 -454
  53. package/components/basic/tree/props.js +0 -5
  54. package/components/basic/tree/utils.js +129 -185
  55. package/components/basic/video/index.js +161 -107
  56. package/components/basic/video/props.js +0 -5
  57. package/components/chart/index.js +42 -50
  58. package/components/chart/props.js +31 -37
  59. package/components/chart/src/ChartRenderer.js +172 -154
  60. package/components/chart/src/chart.js +391 -213
  61. package/components/chart/src/chartStyles.generated.js +6 -14
  62. package/components/chart/src/chartUtils.js +228 -272
  63. package/components/chart/src/constants.d.ts +13 -0
  64. package/components/chart/src/constants.js +316 -90
  65. package/components/chart/src/d3Setup.js +11 -30
  66. package/components/chart/src/dataUtils.js +362 -446
  67. package/components/chart/src/formatUtils.js +47 -38
  68. package/components/chart/src/index.js +11 -19
  69. package/components/chart/src/nvd3Source.generated.js +5 -13
  70. package/components/chart/src/pieDonutResponsiveLayout.d.ts +5 -0
  71. package/components/chart/src/pieDonutResponsiveLayout.js +76 -96
  72. package/components/chart/src/types.js +0 -5
  73. package/components/common/AppSpinner.js +17 -33
  74. package/components/common/app-spinner.js +11 -22
  75. package/components/common/customTemplate/index.d.ts +3 -0
  76. package/components/common/customTemplate/index.js +6 -0
  77. package/components/common/customTemplate/props.d.ts +20 -0
  78. package/components/common/customTemplate/props.js +0 -0
  79. package/components/common/customTemplate/template.d.ts +3 -0
  80. package/components/common/customTemplate/template.js +27 -0
  81. package/components/common/customTemplate/useCustomTemplate.d.ts +8 -0
  82. package/components/common/customTemplate/useCustomTemplate.js +17 -0
  83. package/components/common/customTemplate/utils.d.ts +6 -0
  84. package/components/common/customTemplate/utils.js +12 -0
  85. package/components/common/index.js +4 -12
  86. package/components/constants.js +81 -77
  87. package/components/container/accordion/accordion-pane/index.js +105 -118
  88. package/components/container/accordion/accordion-pane/props.js +5 -21
  89. package/components/container/accordion/index.js +225 -243
  90. package/components/container/accordion/props.js +5 -16
  91. package/components/container/index.js +214 -150
  92. package/components/container/layout-grid/grid-column/index.js +68 -43
  93. package/components/container/layout-grid/grid-column/props.js +0 -5
  94. package/components/container/layout-grid/grid-row/index.js +12 -29
  95. package/components/container/layout-grid/grid-row/props.js +0 -5
  96. package/components/container/layout-grid/index.js +53 -38
  97. package/components/container/layout-grid/props.js +0 -5
  98. package/components/container/linear-layout/index.js +56 -60
  99. package/components/container/linear-layout/linear-layout-item/index.js +43 -47
  100. package/components/container/linear-layout/linear-layout-item/props.js +0 -5
  101. package/components/container/linear-layout/props.js +0 -5
  102. package/components/container/panel/components/panel-content/index.js +7 -16
  103. package/components/container/panel/components/panel-header/index.js +166 -146
  104. package/components/container/panel/components/panel-header/props.js +0 -5
  105. package/components/container/panel/hooks.js +76 -102
  106. package/components/container/panel/index.js +289 -252
  107. package/components/container/panel/props.js +0 -5
  108. package/components/container/props.js +0 -5
  109. package/components/container/repeat-template/index.js +65 -44
  110. package/components/container/repeat-template/props.js +0 -5
  111. package/components/container/tabs/index.js +517 -526
  112. package/components/container/tabs/props.js +5 -28
  113. package/components/container/tabs/tab-pane/index.js +105 -100
  114. package/components/container/tabs/tab-pane/props.js +0 -5
  115. package/components/container/tabs/utils.js +30 -35
  116. package/components/container/wizard/WizardContext.js +9 -11
  117. package/components/container/wizard/components/StepComponents.js +76 -99
  118. package/components/container/wizard/components/WizardStep.js +107 -85
  119. package/components/container/wizard/index.js +791 -921
  120. package/components/container/wizard/props.js +0 -5
  121. package/components/container/wizard/utils.js +97 -131
  122. package/components/container/wizard/wizard-action/index.js +41 -81
  123. package/components/container/wizard/wizard-step/index.js +140 -120
  124. package/components/data/card/card-actions/index.js +13 -31
  125. package/components/data/card/card-content/index.js +27 -36
  126. package/components/data/card/card-footer/index.js +13 -31
  127. package/components/data/card/index.js +192 -199
  128. package/components/data/card/props.js +0 -5
  129. package/components/data/form/base-form/constant.js +5 -8
  130. package/components/data/form/base-form/hooks/index.js +26 -77
  131. package/components/data/form/base-form/hooks/useFormDataSync.js +106 -212
  132. package/components/data/form/base-form/hooks/useFormOperations.js +109 -161
  133. package/components/data/form/base-form/hooks/useFormSubmission.js +220 -280
  134. package/components/data/form/base-form/hooks/useFormValidation.js +119 -168
  135. package/components/data/form/base-form/hooks/useParentFormRelationship.js +67 -103
  136. package/components/data/form/base-form/index.js +531 -646
  137. package/components/data/form/base-form/props.js +74 -151
  138. package/components/data/form/base-form/utils.js +210 -323
  139. package/components/data/form/dynamic-fields/constant.js +43 -53
  140. package/components/data/form/dynamic-fields/index.js +135 -144
  141. package/components/data/form/dynamic-fields/props.js +0 -5
  142. package/components/data/form/dynamic-fields/utils.js +99 -158
  143. package/components/data/form/form-action/index.js +107 -85
  144. package/components/data/form/form-body/index.js +52 -26
  145. package/components/data/form/form-context.js +43 -59
  146. package/components/data/form/form-controller/hooks/index.js +43 -57
  147. package/components/data/form/form-controller/props.js +5 -8
  148. package/components/data/form/form-controller/utils.js +54 -49
  149. package/components/data/form/form-controller/validation-contrustor.js +203 -426
  150. package/components/data/form/form-controller/withFormController.js +319 -269
  151. package/components/data/form/form-dynamic-section/index.js +47 -41
  152. package/components/data/form/form-dynamic-section/props.js +0 -5
  153. package/components/data/form/form-field/base-field.js +97 -109
  154. package/components/data/form/form-field/index.js +91 -82
  155. package/components/data/form/form-field/props.js +0 -5
  156. package/components/data/form/form-footer/index.js +52 -25
  157. package/components/data/form/form-header/index.js +61 -58
  158. package/components/data/form/index.js +95 -74
  159. package/components/data/form/props.js +0 -5
  160. package/components/data/list/components/GroupHeader.js +34 -33
  161. package/components/data/list/components/GroupedListItems.js +108 -104
  162. package/components/data/list/components/ListContainer.js +22 -27
  163. package/components/data/list/components/ListDND.js +193 -185
  164. package/components/data/list/components/ListHeader.js +32 -49
  165. package/components/data/list/components/ListItem.js +153 -146
  166. package/components/data/list/components/ListItemWithTemplate.js +87 -105
  167. package/components/data/list/components/ListItems.js +180 -194
  168. package/components/data/list/components/ListPagination.js +127 -153
  169. package/components/data/list/components/LoadMoreButton.js +25 -33
  170. package/components/data/list/components/NoDataMessage.js +9 -22
  171. package/components/data/list/components/StandardListItems.js +79 -85
  172. package/components/data/list/components/index.js +31 -119
  173. package/components/data/list/components/props.js +0 -5
  174. package/components/data/list/hooks/index.js +22 -75
  175. package/components/data/list/hooks/props.js +0 -5
  176. package/components/data/list/hooks/useCurrentPageItems.js +20 -38
  177. package/components/data/list/hooks/useGroupedData.js +19 -33
  178. package/components/data/list/hooks/useListData.js +17 -47
  179. package/components/data/list/hooks/useListEffects.js +168 -237
  180. package/components/data/list/hooks/useListEventHandlers.js +301 -285
  181. package/components/data/list/hooks/useListPagination.js +90 -136
  182. package/components/data/list/hooks/useListState.js +49 -91
  183. package/components/data/list/hooks/useListStateManager.js +104 -159
  184. package/components/data/list/hooks/usePaginatedGroupedData.js +74 -110
  185. package/components/data/list/index.d.ts +1 -0
  186. package/components/data/list/index.js +579 -621
  187. package/components/data/list/props.d.ts +4 -0
  188. package/components/data/list/props.js +0 -5
  189. package/components/data/list/templates/media-template.js +29 -50
  190. package/components/data/list/utils/constants.js +20 -32
  191. package/components/data/list/utils/list-helpers.d.ts +2 -1
  192. package/components/data/list/utils/list-helpers.js +71 -115
  193. package/components/data/list/utils/list-widget-methods.js +56 -76
  194. package/components/data/list/utils/widget-instance-utils.js +20 -57
  195. package/components/data/live-filter/index.js +219 -271
  196. package/components/data/live-filter/props.js +5 -12
  197. package/components/data/live-form/index.js +68 -91
  198. package/components/data/live-form/props.js +5 -12
  199. package/components/data/pagination/components/BasicPagination.js +124 -104
  200. package/components/data/pagination/components/ClassicPagination.js +167 -190
  201. package/components/data/pagination/components/InlinePagination.js +97 -98
  202. package/components/data/pagination/components/LoadingComponent.js +17 -30
  203. package/components/data/pagination/components/PageSizeSelector.js +176 -169
  204. package/components/data/pagination/components/PagerNavigation.js +84 -105
  205. package/components/data/pagination/components/TotalRecords.js +48 -47
  206. package/components/data/pagination/components/index.js +14 -47
  207. package/components/data/pagination/components/props.js +0 -5
  208. package/components/data/pagination/hooks/index.js +6 -19
  209. package/components/data/pagination/hooks/props.js +0 -5
  210. package/components/data/pagination/hooks/useNavigationSize.js +12 -21
  211. package/components/data/pagination/hooks/usePagination.js +702 -905
  212. package/components/data/pagination/index.js +336 -389
  213. package/components/data/table/components/AddNewRow.js +122 -154
  214. package/components/data/table/components/EditableCell.js +68 -75
  215. package/components/data/table/components/FieldValidationError.js +19 -20
  216. package/components/data/table/components/RowCells.js +97 -80
  217. package/components/data/table/components/RowExpansionButton.js +43 -39
  218. package/components/data/table/components/SummaryCell.js +54 -88
  219. package/components/data/table/components/SummaryRow.js +45 -52
  220. package/components/data/table/components/SummaryRowFooter.js +35 -42
  221. package/components/data/table/components/TableBody.js +222 -218
  222. package/components/data/table/components/TableDataRow.js +113 -106
  223. package/components/data/table/components/TableFilters.js +391 -390
  224. package/components/data/table/components/TableFooterActions.js +25 -32
  225. package/components/data/table/components/TableHeader.js +460 -435
  226. package/components/data/table/components/TablePanelHeading.js +157 -181
  227. package/components/data/table/components/index.js +27 -95
  228. package/components/data/table/hooks/index.js +21 -230
  229. package/components/data/table/hooks/use-edited-rows.js +59 -94
  230. package/components/data/table/hooks/useCellState.js +58 -83
  231. package/components/data/table/hooks/useCustomExpressionColumns.js +65 -86
  232. package/components/data/table/hooks/useDynamicColumns.js +59 -92
  233. package/components/data/table/hooks/useEditingState.js +30 -41
  234. package/components/data/table/hooks/useFormWidget.js +163 -172
  235. package/components/data/table/hooks/usePaginationState.js +67 -77
  236. package/components/data/table/hooks/usePanelStructure.js +47 -41
  237. package/components/data/table/hooks/useResponsiveColumns.js +14 -20
  238. package/components/data/table/hooks/useRowExpansion.js +131 -127
  239. package/components/data/table/hooks/useRowHandlers.js +56 -69
  240. package/components/data/table/hooks/useRowSelection.js +249 -329
  241. package/components/data/table/hooks/useServerSideSorting.js +109 -175
  242. package/components/data/table/hooks/useTableColumns.js +322 -331
  243. package/components/data/table/hooks/useTableData.js +111 -166
  244. package/components/data/table/hooks/useTableEdit.js +526 -564
  245. package/components/data/table/hooks/useTableEffects.js +60 -107
  246. package/components/data/table/hooks/useTableFilter.js +244 -237
  247. package/components/data/table/hooks/useTableInitialization.js +44 -76
  248. package/components/data/table/hooks/useTableState.js +39 -61
  249. package/components/data/table/hooks/useTableStateManager.js +295 -468
  250. package/components/data/table/index.js +1553 -1713
  251. package/components/data/table/live-table/index.js +157 -219
  252. package/components/data/table/props.js +0 -5
  253. package/components/data/table/table-action/index.js +97 -75
  254. package/components/data/table/table-column/index.js +48 -42
  255. package/components/data/table/table-group/index.js +7 -25
  256. package/components/data/table/table-row/index.js +63 -55
  257. package/components/data/table/table-row-action/index.js +102 -77
  258. package/components/data/table/utils/buildSelectionColumns.js +86 -137
  259. package/components/data/table/utils/columnBuilder.js +116 -158
  260. package/components/data/table/utils/columnProxy.js +48 -66
  261. package/components/data/table/utils/columnWidthDistribution.js +40 -64
  262. package/components/data/table/utils/constants.js +92 -40
  263. package/components/data/table/utils/crud-handlers.js +292 -473
  264. package/components/data/table/utils/dynamic-columns.js +99 -144
  265. package/components/data/table/utils/groupHeaderUtils.js +36 -61
  266. package/components/data/table/utils/index.d.ts +8 -5
  267. package/components/data/table/utils/index.js +419 -639
  268. package/components/data/table/utils/renderDisplayCell.js +127 -169
  269. package/components/data/table/utils/script-page-size-broadcast.js +17 -29
  270. package/components/data/table/utils/selectionUtils.js +59 -113
  271. package/components/data/table/utils/table-helpers.js +38 -74
  272. package/components/data/table/utils/validation.js +35 -78
  273. package/components/data/table/utils/widgetMapping.d.ts +5 -0
  274. package/components/data/table/utils/widgetMapping.js +41 -0
  275. package/components/data/types.js +112 -112
  276. package/components/data/utils/field-data-utils.js +38 -42
  277. package/components/data/utils/filter-field-util.js +42 -44
  278. package/components/data/utils/index.js +112 -111
  279. package/components/dialogs/alert-dialog/index.js +83 -78
  280. package/components/dialogs/alert-dialog/props.js +0 -5
  281. package/components/dialogs/confirm-dialog/index.js +102 -92
  282. package/components/dialogs/confirm-dialog/props.js +0 -5
  283. package/components/dialogs/dialog/index.js +93 -69
  284. package/components/dialogs/dialog/props.js +0 -5
  285. package/components/dialogs/dialog-actions/index.js +12 -26
  286. package/components/dialogs/dialog-actions/props.js +0 -5
  287. package/components/dialogs/dialog-body/index.js +13 -30
  288. package/components/dialogs/dialog-body/props.js +0 -5
  289. package/components/dialogs/dialog-content/index.js +48 -41
  290. package/components/dialogs/dialog-content/props.js +0 -5
  291. package/components/dialogs/dialog-header/index.js +88 -101
  292. package/components/dialogs/dialog-header/props.js +0 -5
  293. package/components/dialogs/iframe-dialog/index.js +136 -128
  294. package/components/dialogs/iframe-dialog/props.js +0 -5
  295. package/components/dialogs/index.js +104 -101
  296. package/components/dialogs/login-dialog/index.js +285 -347
  297. package/components/dialogs/login-dialog/props.js +0 -5
  298. package/components/dialogs/page-dialog/index.js +95 -86
  299. package/components/dialogs/page-dialog/props.js +0 -5
  300. package/components/dialogs/props.js +0 -5
  301. package/components/dialogs/withDialogWrapper.js +110 -83
  302. package/components/form/button/index.js +296 -245
  303. package/components/form/button/props.js +0 -5
  304. package/components/form/button-group/index.js +80 -69
  305. package/components/form/button-group/props.js +0 -5
  306. package/components/input/calendar/index.js +409 -362
  307. package/components/input/calendar/props.js +0 -5
  308. package/components/input/calendar/utils.js +164 -172
  309. package/components/input/chips/SortableChip/index.js +109 -100
  310. package/components/input/chips/SortableChip/props.js +0 -5
  311. package/components/input/chips/index.js +663 -570
  312. package/components/input/chips/props.js +0 -5
  313. package/components/input/chips/utils.js +131 -122
  314. package/components/input/color-picker/index.js +536 -594
  315. package/components/input/color-picker/props.js +0 -5
  316. package/components/input/composite/index.js +71 -110
  317. package/components/input/composite/props.js +0 -5
  318. package/components/input/currency/index.js +277 -224
  319. package/components/input/currency/props.js +0 -5
  320. package/components/input/default/checkbox/index.js +329 -250
  321. package/components/input/default/checkbox/props.js +0 -5
  322. package/components/input/default/checkboxset/index.d.ts +2 -0
  323. package/components/input/default/checkboxset/index.js +529 -446
  324. package/components/input/default/checkboxset/props.d.ts +4 -0
  325. package/components/input/default/checkboxset/props.js +0 -5
  326. package/components/input/default/checkboxset/utils.js +15 -25
  327. package/components/input/default/radioset/index.d.ts +2 -0
  328. package/components/input/default/radioset/index.js +409 -350
  329. package/components/input/default/radioset/props.d.ts +6 -0
  330. package/components/input/default/radioset/props.js +0 -5
  331. package/components/input/default/switch/index.js +494 -458
  332. package/components/input/default/switch/prop.js +0 -5
  333. package/components/input/epoch/date/components/DatePickerPopover.js +242 -193
  334. package/components/input/epoch/date/index.js +638 -518
  335. package/components/input/epoch/date/props.js +0 -5
  336. package/components/input/epoch/date/styled.js +61 -70
  337. package/components/input/epoch/date/utils.js +67 -115
  338. package/components/input/epoch/datetime/index.js +758 -695
  339. package/components/input/epoch/datetime/props.js +0 -5
  340. package/components/input/epoch/datetime/utils.js +121 -186
  341. package/components/input/epoch/time/index.js +441 -415
  342. package/components/input/epoch/time/props.js +0 -5
  343. package/components/input/epoch/time/utils.js +101 -112
  344. package/components/input/fileupload/Utils.js +70 -97
  345. package/components/input/fileupload/components/ListItems.js +132 -130
  346. package/components/input/fileupload/components/MultiUpload.js +80 -77
  347. package/components/input/fileupload/components/SingleUpload.js +57 -57
  348. package/components/input/fileupload/index.js +253 -178
  349. package/components/input/fileupload/props.js +0 -5
  350. package/components/input/fileupload/useFileUpload.js +209 -258
  351. package/components/input/number/index.js +434 -393
  352. package/components/input/number/props.js +0 -5
  353. package/components/input/rating/index.js +401 -394
  354. package/components/input/rating/props.js +0 -5
  355. package/components/input/select/index.js +408 -463
  356. package/components/input/select/props.js +0 -5
  357. package/components/input/slider/index.js +339 -332
  358. package/components/input/slider/props.js +0 -5
  359. package/components/input/text/index.d.ts +3 -3
  360. package/components/input/text/index.js +438 -475
  361. package/components/input/text/props.d.ts +1 -1
  362. package/components/input/text/props.js +0 -5
  363. package/components/input/text/util.js +82 -222
  364. package/components/input/textarea/index.js +322 -358
  365. package/components/input/textarea/props.js +0 -5
  366. package/components/input/upload/index.js +135 -131
  367. package/components/input/upload/props.js +0 -5
  368. package/components/input/util/index.js +9 -11
  369. package/components/layout/footer/index.js +12 -35
  370. package/components/layout/footer/props.js +0 -5
  371. package/components/layout/header/index.js +12 -38
  372. package/components/layout/header/props.js +0 -5
  373. package/components/layout/leftnav/index.js +38 -44
  374. package/components/layout/leftnav/props.js +0 -5
  375. package/components/layout/rightnav/index.js +12 -36
  376. package/components/layout/rightnav/props.js +0 -5
  377. package/components/layout/topnav/index.js +24 -38
  378. package/components/layout/topnav/props.js +0 -5
  379. package/components/navbar/index.js +119 -98
  380. package/components/navbar/nav/index.js +236 -232
  381. package/components/navbar/nav/props.js +0 -5
  382. package/components/navbar/nav-item/index.js +74 -65
  383. package/components/navbar/nav-item/props.js +0 -5
  384. package/components/navigation/breadcrumb/index.js +38 -61
  385. package/components/navigation/breadcrumb/props.js +0 -5
  386. package/components/navigation/menu/components/ListItems.js +76 -67
  387. package/components/navigation/menu/constants.js +27 -42
  388. package/components/navigation/menu/hooks/useHoverState.hook.js +20 -47
  389. package/components/navigation/menu/hooks/useKeyboardMovements.hook.js +34 -28
  390. package/components/navigation/menu/hooks/useTransformedDataset.hook.js +21 -14
  391. package/components/navigation/menu/index.js +911 -846
  392. package/components/navigation/menu/props.js +0 -5
  393. package/components/navigation/menu/utils/action-task.js +6 -9
  394. package/components/navigation/menu/utils/role-filter.js +41 -56
  395. package/components/navigation/popover/index.js +191 -205
  396. package/components/navigation/popover/props.js +5 -8
  397. package/components/page/content/index.js +9 -31
  398. package/components/page/content/props.js +0 -5
  399. package/components/page/error-boundary/index.js +115 -105
  400. package/components/page/error-boundary/props.js +0 -5
  401. package/components/page/index.js +84 -102
  402. package/components/page/page-content/index.js +21 -30
  403. package/components/page/page-content/props.js +0 -5
  404. package/components/page/partial/index.js +50 -45
  405. package/components/page/partial/props.js +0 -5
  406. package/components/page/partial-container/index.js +81 -107
  407. package/components/page/partial-container/props.d.ts +1 -1
  408. package/components/page/partial-container/props.js +0 -5
  409. package/components/page/props.js +0 -5
  410. package/components/page/toast-container/index.js +20 -41
  411. package/components/page/toast-container/props.js +0 -5
  412. package/components/prefab/container/index.js +60 -53
  413. package/components/prefab/container/props.js +0 -5
  414. package/components/prefab/index.js +76 -61
  415. package/components/prefab/props.js +0 -5
  416. package/context/AppContext.d.ts +1 -1
  417. package/context/AppContext.js +17 -18
  418. package/context/AppSpinnerProvider.js +19 -34
  419. package/context/LayoutProvider.js +54 -57
  420. package/context/LocalizationProvider.js +34 -49
  421. package/context/PrefabContext.js +68 -119
  422. package/context/WidgetProvider.js +160 -166
  423. package/core/app-config.js +0 -1
  424. package/core/app.service.js +200 -327
  425. package/core/appVariablesStore.js +10 -15
  426. package/core/appstore.js +37 -53
  427. package/core/constants/currency-constant.js +81 -83
  428. package/core/constants/events.js +34 -44
  429. package/core/constants/index.js +21 -31
  430. package/core/dialog.service.js +52 -72
  431. package/core/event-notifier.js +94 -131
  432. package/core/formatter/array-formatters.js +18 -32
  433. package/core/formatter/date-formatters.js +140 -204
  434. package/core/formatter/index.js +64 -117
  435. package/core/formatter/number-formatters.js +115 -159
  436. package/core/formatter/security-formatters.js +233 -283
  437. package/core/formatter/string-formatters.js +23 -45
  438. package/core/formatter/types.js +12 -18
  439. package/core/formatters.js +6 -24
  440. package/core/proxy-service.js +242 -306
  441. package/core/script-registry.js +87 -134
  442. package/core/security.service.js +8 -11
  443. package/core/util/compare.js +13 -25
  444. package/core/util/dom.js +32 -63
  445. package/core/util/index.d.ts +5 -0
  446. package/core/util/index.js +95 -95
  447. package/core/util/safe-is-equal.js +42 -94
  448. package/core/util/security.js +114 -153
  449. package/core/util/utils.d.ts +8 -1
  450. package/core/util/utils.js +124 -132
  451. package/core/widget-observer.js +34 -61
  452. package/higherOrder/BaseApp.js +327 -500
  453. package/higherOrder/BaseAppProps.js +0 -5
  454. package/higherOrder/BaseDateTime.js +277 -231
  455. package/higherOrder/BasePage.js +479 -735
  456. package/higherOrder/BasePartial.js +87 -114
  457. package/higherOrder/BasePrefab.js +190 -206
  458. package/higherOrder/DataNav.js +287 -302
  459. package/higherOrder/helper.js +62 -48
  460. package/higherOrder/props.js +0 -5
  461. package/higherOrder/withBaseWrapper.js +123 -168
  462. package/higherOrder/withStandalone.js +28 -26
  463. package/hooks/useAccess.js +113 -289
  464. package/hooks/useAppConfig.js +15 -40
  465. package/hooks/useAuth.js +256 -495
  466. package/hooks/useDataSourceSubscription.d.ts +3 -3
  467. package/hooks/useDataSourceSubscription.js +99 -109
  468. package/hooks/useDebounce.js +28 -56
  469. package/hooks/useDeviceVisibility.js +14 -23
  470. package/hooks/useHttp.d.ts +1 -0
  471. package/hooks/useHttp.js +318 -493
  472. package/libs/index.js +4 -13
  473. package/libs/prefab/index.js +6 -20
  474. package/mui-config/theme-provider.js +9 -17
  475. package/mui-config/theme.js +6 -9
  476. package/package-lock.json +808 -3177
  477. package/package.json +3 -19
  478. package/providers/AppProviders.js +21 -24
  479. package/runtime-dynamic/App.js +65 -93
  480. package/runtime-dynamic/app-initializer.js +207 -400
  481. package/runtime-dynamic/components/ErrorBoundary.js +59 -76
  482. package/runtime-dynamic/components/PageWrapper.js +23 -35
  483. package/runtime-dynamic/components/PrefabPreview.js +40 -69
  484. package/runtime-dynamic/components/partial-content.d.ts +2 -3
  485. package/runtime-dynamic/components/partial-content.js +66 -48
  486. package/runtime-dynamic/components/prefab-content.js +37 -30
  487. package/runtime-dynamic/components/use-dynamic-component.js +62 -150
  488. package/runtime-dynamic/factories/build-base-page-like-component.js +44 -58
  489. package/runtime-dynamic/factories/dynamic-component.d.ts +9 -0
  490. package/runtime-dynamic/factories/dynamic-component.js +83 -0
  491. package/runtime-dynamic/factories/prefab-factory.js +60 -81
  492. package/runtime-dynamic/factories/startup-info.js +12 -25
  493. package/runtime-dynamic/factories/utils.d.ts +1 -9
  494. package/runtime-dynamic/factories/utils.js +47 -130
  495. package/runtime-dynamic/index.js +56 -191
  496. package/runtime-dynamic/main.js +42 -70
  497. package/runtime-dynamic/preview-mode.js +14 -29
  498. package/runtime-dynamic/preview-navigation.js +21 -30
  499. package/runtime-dynamic/preview-path.d.ts +5 -0
  500. package/runtime-dynamic/preview-path.js +13 -0
  501. package/runtime-dynamic/preview-resource-base.js +15 -31
  502. package/runtime-dynamic/registry/component-registry.js +269 -334
  503. package/runtime-dynamic/registry/custom-widget-registry.js +11 -15
  504. package/runtime-dynamic/registry/index.js +24 -63
  505. package/runtime-dynamic/registry/store.d.ts +1 -0
  506. package/runtime-dynamic/registry/store.js +18 -23
  507. package/runtime-dynamic/routes.js +53 -81
  508. package/runtime-dynamic/services/app-extension-provider.js +17 -44
  509. package/runtime-dynamic/services/autolayout-inject.d.ts +4 -0
  510. package/runtime-dynamic/services/autolayout-inject.js +27 -0
  511. package/runtime-dynamic/services/cache.js +27 -33
  512. package/runtime-dynamic/services/compile-render.d.ts +9 -0
  513. package/runtime-dynamic/services/compile-render.js +142 -0
  514. package/runtime-dynamic/services/component-ref-provider.js +70 -124
  515. package/runtime-dynamic/services/css-scoping.js +27 -28
  516. package/runtime-dynamic/services/fragment-url.js +37 -50
  517. package/runtime-dynamic/services/index.js +48 -152
  518. package/runtime-dynamic/services/markup-transpiler.d.ts +2 -2
  519. package/runtime-dynamic/services/markup-transpiler.js +39 -231
  520. package/runtime-dynamic/services/prefab-resources.js +42 -130
  521. package/runtime-dynamic/services/resource-manager.d.ts +2 -1
  522. package/runtime-dynamic/services/resource-manager.js +32 -63
  523. package/runtime-dynamic/services/script-executor.js +50 -61
  524. package/runtime-dynamic/services/variable-factory.js +141 -184
  525. package/runtime-dynamic/services/variable-registry.js +69 -115
  526. package/runtime-dynamic/services/variable-transpiler.js +73 -103
  527. package/runtime-dynamic/shims/next-image.js +79 -50
  528. package/runtime-dynamic/shims/next-link.js +58 -32
  529. package/runtime-dynamic/shims/next-navigation.js +17 -34
  530. package/runtime-dynamic/utils/index.d.ts +2 -0
  531. package/runtime-dynamic/utils/index.js +22 -24
  532. package/store/bindActions/i18nActions.js +16 -18
  533. package/store/index.js +29 -35
  534. package/store/middleware/navigationMiddleware.js +25 -45
  535. package/store/middleware/pendingTabNavigationIntentMiddleware.js +20 -25
  536. package/store/slices/appConfigSlice.js +65 -94
  537. package/store/slices/authSlice.js +317 -471
  538. package/store/slices/i18nSlice.js +169 -168
  539. package/store/slices/navigationSlice.js +22 -20
  540. package/store/util/resolve-path.d.ts +1 -0
  541. package/store/util/resolve-path.js +7 -0
  542. package/store/viewport.service.js +150 -194
  543. package/types/index.js +10 -15
  544. package/utils/attr.js +198 -41
  545. package/utils/custom-expression/index.js +55 -151
  546. package/utils/custom-expression/parser.js +106 -182
  547. package/utils/dataset-util.js +113 -154
  548. package/utils/eval-expression.js +10 -19
  549. package/utils/form-state.util.js +60 -118
  550. package/utils/form-utils.js +49 -190
  551. package/utils/format-util.js +113 -184
  552. package/utils/layoutsize-util.js +11 -17
  553. package/utils/lib-error-skipper.js +54 -52
  554. package/utils/page-params-util.js +50 -40
  555. package/utils/pending-tab-navigation-intent.js +7 -17
  556. package/utils/resource-url.js +8 -19
  557. package/utils/state-persistance.js +136 -253
  558. package/utils/style-utils.d.ts +2 -0
  559. package/utils/style-utils.js +25 -74
  560. package/utils/transformedDataset-utils.js +353 -381
  561. package/utils/widget-cleanup-util.js +42 -74
  562. package/utils/widgets.js +19 -31
  563. package/variables/base-variable.js +117 -166
  564. package/variables/constants.js +5 -8
  565. package/variables/crud-variable.js +150 -181
  566. package/variables/live-variable.d.ts +1 -1
  567. package/variables/live-variable.js +140 -174
  568. package/variables/metadata.service.js +74 -116
  569. package/variables/model-variable.js +68 -78
  570. package/variables/service-variable.js +171 -285
  571. package/wm-namespace.js +11 -14
  572. package/components/chart/src/css.d.js +0 -1
  573. package/tsconfig.declaration.tsbuildinfo +0 -1
  574. package/types/global.d.js +0 -3
@@ -1,529 +1,453 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
- var _typeof = require("@babel/runtime/helpers/typeof");
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
7
- });
8
- exports["default"] = exports.WmTree = void 0;
9
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
10
- var _react = _interopRequireWildcard(require("react"));
11
- var _clsx = _interopRequireDefault(require("clsx"));
12
- var _withBaseWrapper = require("@wavemaker-ai/react-runtime/higherOrder/withBaseWrapper");
13
- var _isArray = _interopRequireDefault(require("lodash-es/isArray"));
14
- var _isEmpty = _interopRequireDefault(require("lodash-es/isEmpty"));
15
- var _isEqual = _interopRequireDefault(require("lodash-es/isEqual"));
16
- var _isObject = _interopRequireDefault(require("lodash-es/isObject"));
17
- var _isString = _interopRequireDefault(require("lodash-es/isString"));
18
- var _transformedDatasetUtils = require("@wavemaker-ai/react-runtime/utils/transformedDataset-utils");
19
- var _Box = _interopRequireDefault(require("@mui/material/Box"));
20
- var _TreeNodeComponent = _interopRequireDefault(require("./Components/TreeNodeComponent"));
21
- var _utils = require("./utils");
22
- 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); }
23
- var __jsx = _react["default"].createElement;
24
- 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; }
25
- 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; }
26
- var DEFAULT_CLASS = "app-tree";
27
- var DEFAULT_TREE_ICON_CLASS = "plus-minus";
28
- var WmTree = exports.WmTree = function WmTree(props) {
29
- var _className$includes, _className$includes2;
30
- var _props$dataset = props.dataset,
31
- dataset = _props$dataset === void 0 ? "node1, node2, node3" : _props$dataset,
32
- datavalue = props.datavalue,
33
- _props$treeicons = props.treeicons,
34
- treeicons = _props$treeicons === void 0 ? DEFAULT_TREE_ICON_CLASS : _props$treeicons,
35
- _props$levels = props.levels,
36
- levels = _props$levels === void 0 ? 0 : _props$levels,
37
- _props$nodelabel = props.nodelabel,
38
- nodelabel = _props$nodelabel === void 0 ? "" : _props$nodelabel,
39
- _props$nodeicon = props.nodeicon,
40
- nodeicon = _props$nodeicon === void 0 ? "" : _props$nodeicon,
41
- _props$nodechildren = props.nodechildren,
42
- nodechildren = _props$nodechildren === void 0 ? "" : _props$nodechildren,
43
- _props$nodeid = props.nodeid,
44
- nodeid = _props$nodeid === void 0 ? "" : _props$nodeid,
45
- _props$nodeaction = props.nodeaction,
46
- nodeaction = _props$nodeaction === void 0 ? "" : _props$nodeaction,
47
- _props$nodeclick = props.nodeclick,
48
- nodeclick = _props$nodeclick === void 0 ? "none" : _props$nodeclick,
49
- _props$tabindex = props.tabindex,
50
- tabindex = _props$tabindex === void 0 ? 0 : _props$tabindex,
51
- _props$name = props.name,
52
- name = _props$name === void 0 ? "treeview" : _props$name,
53
- className = props.className,
54
- _props$orderby = props.orderby,
55
- orderby = _props$orderby === void 0 ? "" : _props$orderby,
56
- onExpand = props.onExpand,
57
- onCollapse = props.onCollapse,
58
- onSelect = props.onSelect,
59
- onCheck = props.onCheck,
60
- _props$horizontalalig = props.horizontalalign,
61
- horizontalalign = _props$horizontalalig === void 0 ? "left" : _props$horizontalalig,
62
- listener = props.listener,
63
- width = props.width,
64
- height = props.height,
65
- template = props.template;
66
-
67
- // Combined class for both props.class and props.className
68
- var isCheckboxTree = (_className$includes = className === null || className === void 0 ? void 0 : className.includes("Checkbox")) !== null && _className$includes !== void 0 ? _className$includes : false;
69
- var isRadioTree = (_className$includes2 = className === null || className === void 0 ? void 0 : className.includes("Radio")) !== null && _className$includes2 !== void 0 ? _className$includes2 : false;
70
-
71
- // Component state
72
- var _useState = (0, _react.useState)([]),
73
- treeNodes = _useState[0],
74
- setTreeNodes = _useState[1];
75
- var _useState2 = (0, _react.useState)(null),
76
- selectedItem = _useState2[0],
77
- setSelectedItem = _useState2[1];
78
- var _useState3 = (0, _react.useState)(null),
79
- radioSelectedNodeId = _useState3[0],
80
- setRadioSelectedNodeId = _useState3[1];
81
-
82
- /** Latest tree stale `treeNodes` re rendering ref */
83
- var treeNodesRef = (0, _react.useRef)([]);
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 { jsx } from "react/jsx-runtime";
21
+ import { useState, useEffect, useMemo, useCallback, useRef } from "react";
22
+ import clsx from "clsx";
23
+ import { withBaseWrapper } from "../../../higherOrder/withBaseWrapper";
24
+ import isArray from "lodash-es/isArray";
25
+ import isEmpty from "lodash-es/isEmpty";
26
+ import isEqual from "lodash-es/isEqual";
27
+ import isObject from "lodash-es/isObject";
28
+ import isString from "lodash-es/isString";
29
+ import { getOrderedDataset } from "../../../utils/transformedDataset-utils";
30
+ import Box from "@mui/material/Box";
31
+ import TreeNodeComponent from "./Components/TreeNodeComponent";
32
+ import {
33
+ processNode,
34
+ generateUniqueNodeId,
35
+ findNodeById,
36
+ toggleExpansionInTree,
37
+ isTreeNodeDisabled
38
+ } from "./utils";
39
+ import { useCustomTemplate } from "../../common/customTemplate";
40
+ const DEFAULT_CLASS = "app-tree";
41
+ const DEFAULT_TREE_ICON_CLASS = "plus-minus";
42
+ const WmTree = (props) => {
43
+ var _a, _b;
44
+ const {
45
+ dataset = "node1, node2, node3",
46
+ datavalue,
47
+ treeicons = DEFAULT_TREE_ICON_CLASS,
48
+ levels = 0,
49
+ nodelabel = "",
50
+ nodeicon = "",
51
+ nodechildren = "",
52
+ nodeid = "",
53
+ nodeaction = "",
54
+ nodeclick = "none",
55
+ tabindex = 0,
56
+ name = "treeview",
57
+ className,
58
+ orderby = "",
59
+ onExpand,
60
+ onCollapse,
61
+ onSelect,
62
+ onCheck,
63
+ horizontalalign = "left",
64
+ listener,
65
+ width,
66
+ height,
67
+ template
68
+ } = props;
69
+ const isCheckboxTree = (_a = className == null ? void 0 : className.includes("Checkbox")) != null ? _a : false;
70
+ const isRadioTree = (_b = className == null ? void 0 : className.includes("Radio")) != null ? _b : false;
71
+ const [treeNodes, setTreeNodes] = useState([]);
72
+ const [selectedItem, setSelectedItem] = useState(null);
73
+ const [radioSelectedNodeId, setRadioSelectedNodeId] = useState(null);
74
+ const { templateName, setTemplate } = useCustomTemplate({ content: template, name });
75
+ const treeNodesRef = useRef([]);
84
76
  treeNodesRef.current = treeNodes;
85
-
86
- // Unique ID generator for ensuring nodeId uniqueness
87
- var usedNodeIds = (0, _react.useRef)(new Set());
88
-
89
- // Function to get nodes from string input
90
- var getNodesFromString = (0, _react.useCallback)(function (value) {
91
- if (!value) return [];
92
- return value.split(",").map(function (item, index) {
93
- return {
77
+ const usedNodeIds = useRef(/* @__PURE__ */ new Set());
78
+ const getNodesFromString = useCallback(
79
+ (value) => {
80
+ if (!value) return [];
81
+ return value.split(",").map((item, index) => ({
94
82
  name: item.trim(),
95
83
  label: item.trim(),
96
- nodeId: "string_node_".concat(index, "_").concat(item.trim()),
97
- tId: "".concat(name, "_string_node_").concat(index, "_").concat(item.trim()),
98
- data: {
99
- label: item.trim()
100
- },
84
+ nodeId: `string_node_${index}_${item.trim()}`,
85
+ tId: `${name}_string_node_${index}_${item.trim()}`,
86
+ data: { label: item.trim() },
101
87
  children: [],
102
88
  open: levels > 0,
103
89
  checked: false
90
+ }));
91
+ },
92
+ [levels, name]
93
+ );
94
+ const getNodes = useCallback(
95
+ (newVal) => {
96
+ usedNodeIds.current.clear();
97
+ const processNodeOptions = {
98
+ levels,
99
+ nodelabel,
100
+ nodeicon,
101
+ nodechildren,
102
+ nodeid,
103
+ generateUniqueNodeId: (baseId) => generateUniqueNodeId(baseId, usedNodeIds.current)
104
104
  };
105
- });
106
- }, [levels, name]);
107
-
108
- // Get initial nodes from dataset
109
- var getNodes = (0, _react.useCallback)(function (newVal) {
110
- usedNodeIds.current.clear();
111
- var processNodeOptions = {
112
- levels: levels,
113
- nodelabel: nodelabel,
114
- nodeicon: nodeicon,
115
- nodechildren: nodechildren,
116
- nodeid: nodeid,
117
- generateUniqueNodeId: function generateUniqueNodeId(baseId) {
118
- return (0, _utils.generateUniqueNodeId)(baseId, usedNodeIds.current);
105
+ if (isArray(newVal)) {
106
+ const ordered = orderby ? getOrderedDataset(newVal, orderby) : newVal;
107
+ return ordered.map(
108
+ (item, index) => processNode(item, 0, void 0, ordered, index, name, processNodeOptions)
109
+ );
110
+ } else if (isObject(newVal) && newVal !== null) {
111
+ return [processNode(newVal, 0, void 0, [newVal], 0, name, processNodeOptions)];
112
+ } else if (isString(newVal) && !isEmpty(newVal)) {
113
+ return getNodesFromString(newVal.trim());
119
114
  }
120
- };
121
- if ((0, _isArray["default"])(newVal)) {
122
- var ordered = orderby ? (0, _transformedDatasetUtils.getOrderedDataset)(newVal, orderby) : newVal;
123
- return ordered.map(function (item, index) {
124
- return (0, _utils.processNode)(item, 0, undefined, ordered, index, name, processNodeOptions);
125
- });
126
- } else if ((0, _isObject["default"])(newVal) && newVal !== null) {
127
- return [(0, _utils.processNode)(newVal, 0, undefined, [newVal], 0, name, processNodeOptions)];
128
- } else if ((0, _isString["default"])(newVal) && !(0, _isEmpty["default"])(newVal)) {
129
- return getNodesFromString(newVal.trim());
130
- }
131
- return [];
132
- }, [getNodesFromString, levels, nodelabel, nodeicon, nodechildren, nodeid, name, orderby]);
133
-
134
- // Get path to node (for event callbacks)
135
- var getPath = (0, _react.useCallback)(function (node) {
115
+ return [];
116
+ },
117
+ [getNodesFromString, levels, nodelabel, nodeicon, nodechildren, nodeid, name, orderby]
118
+ );
119
+ const getPath = useCallback((node) => {
136
120
  if (!node) return "";
137
- var path = [];
138
- var currentNode = node;
121
+ const path = [];
122
+ let currentNode = node;
139
123
  while (currentNode) {
140
124
  path.unshift(currentNode.name);
141
125
  currentNode = currentNode.parent;
142
126
  }
143
- return "/".concat(path.join("/"));
127
+ return `/${path.join("/")}`;
144
128
  }, []);
145
- var toggleNodeExpansion = (0, _react.useCallback)(function (event, node) {
146
- var _ev$stopPropagation;
147
- var ev = event !== null && event !== void 0 ? event : {
148
- preventDefault: function preventDefault() {},
149
- stopPropagation: function stopPropagation() {}
150
- };
151
- (_ev$stopPropagation = ev.stopPropagation) === null || _ev$stopPropagation === void 0 || _ev$stopPropagation.call(ev);
152
- var prev = treeNodesRef.current;
153
- var currentTreeNode = (0, _utils.findNodeById)(prev, node.nodeId);
154
- if (!currentTreeNode) return;
155
- if ((0, _utils.isTreeNodeDisabled)(currentTreeNode.data)) return;
156
- var updatedNodes = (0, _utils.toggleExpansionInTree)(prev, node.nodeId);
157
- var after_nodeUpdate = (0, _utils.findNodeById)(updatedNodes, node.nodeId);
158
- treeNodesRef.current = updatedNodes;
159
- setTreeNodes(updatedNodes);
160
- if (after_nodeUpdate && ev && name) {
161
- var path = getPath(after_nodeUpdate);
162
- if (after_nodeUpdate.open) {
163
- if (onExpand) {
164
- onExpand(ev, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], after_nodeUpdate.data, path);
129
+ const toggleNodeExpansion = useCallback(
130
+ (event, node) => {
131
+ var _a2;
132
+ const ev = event != null ? event : {
133
+ preventDefault: () => {
134
+ },
135
+ stopPropagation: () => {
165
136
  }
166
- } else if (onCollapse) {
167
- onCollapse(ev, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], after_nodeUpdate.data, path);
168
- }
169
- }
170
- }, [getPath, name, onCollapse, onExpand]);
171
-
172
- // Handle node selection
173
- var selectNode = (0, _react.useCallback)(function (event, node) {
174
- var _findNodeById, _resolvedTreeNode$chi;
175
- if (!node) return;
176
- var resolvedTreeNode = (_findNodeById = (0, _utils.findNodeById)(treeNodesRef.current, node.nodeId)) !== null && _findNodeById !== void 0 ? _findNodeById : node;
177
- if ((0, _utils.isTreeNodeDisabled)(resolvedTreeNode.data)) return;
178
- setSelectedItem(resolvedTreeNode);
179
- if (event && nodeclick === "expand" && (_resolvedTreeNode$chi = resolvedTreeNode.children) !== null && _resolvedTreeNode$chi !== void 0 && _resolvedTreeNode$chi.length) {
180
- toggleNodeExpansion(event, resolvedTreeNode);
181
- }
182
- if (onSelect && event && name) {
183
- onSelect(event, listener === null || listener === void 0 ? void 0 : listener.Widgets[name], resolvedTreeNode.data, getPath(resolvedTreeNode));
184
- }
185
- }, [name, nodeclick, onSelect, toggleNodeExpansion]);
186
-
187
- // Handle node click (`event` undefined when invoked from partial `node.select()` / programmatic selection)
188
- var handleNodeClick = (0, _react.useCallback)(function (event, node) {
189
- selectNode(event, node);
190
- }, [selectNode]);
191
-
192
- // Handle checkbox toggle
193
- var toggleNodeChecked = (0, _react.useCallback)(function (event, node) {
194
- var _findNodeById2;
195
- event.stopPropagation(); // Prevent triggering node selection
196
-
197
- var resolvedNode = (_findNodeById2 = (0, _utils.findNodeById)(treeNodesRef.current, node.nodeId)) !== null && _findNodeById2 !== void 0 ? _findNodeById2 : node;
198
- if ((0, _utils.isTreeNodeDisabled)(resolvedNode.data)) return;
199
-
200
- // Toggle the checked state
201
- var newCheckedState = !node.checked;
202
-
203
- // Update the tree with cascading effect
204
- var _updateCheckedState = function updateCheckedState(nodes, nodeId, checked) {
205
- return nodes.map(function (node) {
206
- var _node$children2;
207
- if (node.nodeId === nodeId) {
208
- var _node$children;
209
- // Update this node's checked state
210
- var updatedNode = _objectSpread(_objectSpread({}, node), {}, {
211
- checked: checked
212
- });
213
-
214
- // Update all children recursively if any
215
- if ((_node$children = node.children) !== null && _node$children !== void 0 && _node$children.length) {
216
- updatedNode.children = _updateAllChildrenChecked(node.children, checked);
217
- }
218
-
219
- // Also update the data object to maintain consistency
220
- if (updatedNode.data) {
221
- updatedNode.data = _objectSpread(_objectSpread({}, updatedNode.data), {}, {
222
- checked: checked
223
- });
137
+ };
138
+ (_a2 = ev.stopPropagation) == null ? void 0 : _a2.call(ev);
139
+ const prev = treeNodesRef.current;
140
+ const currentTreeNode = findNodeById(prev, node.nodeId);
141
+ if (!currentTreeNode) return;
142
+ if (isTreeNodeDisabled(currentTreeNode.data)) return;
143
+ const updatedNodes = toggleExpansionInTree(prev, node.nodeId);
144
+ const after_nodeUpdate = findNodeById(updatedNodes, node.nodeId);
145
+ treeNodesRef.current = updatedNodes;
146
+ setTreeNodes(updatedNodes);
147
+ if (after_nodeUpdate && ev && name) {
148
+ const path = getPath(after_nodeUpdate);
149
+ if (after_nodeUpdate.open) {
150
+ if (onExpand) {
151
+ onExpand(ev, listener == null ? void 0 : listener.Widgets[name], after_nodeUpdate.data, path);
224
152
  }
225
- return updatedNode;
226
- } else if ((_node$children2 = node.children) !== null && _node$children2 !== void 0 && _node$children2.length) {
227
- // Check if the target node is in the children
228
- var updatedChildren = _updateCheckedState(node.children, nodeId, checked);
229
-
230
- // Check if all children are checked or unchecked to update parent accordingly
231
- var allChildrenChecked = updatedChildren.every(function (child) {
232
- return child.checked;
233
- });
234
- var anyChildChecked = updatedChildren.some(function (child) {
235
- return child.checked;
236
- });
237
- var updatedCheckedState = nodeId !== node.nodeId ? checked ? allChildrenChecked : anyChildChecked ? node.checked : false : node.checked;
238
-
239
- // Update the data object to maintain consistency
240
- var _updatedNode = _objectSpread(_objectSpread({}, node), {}, {
241
- children: updatedChildren,
242
- checked: updatedCheckedState
243
- });
244
- if (_updatedNode.data) {
245
- _updatedNode.data = _objectSpread(_objectSpread({}, _updatedNode.data), {}, {
153
+ } else if (onCollapse) {
154
+ onCollapse(ev, listener == null ? void 0 : listener.Widgets[name], after_nodeUpdate.data, path);
155
+ }
156
+ }
157
+ },
158
+ [getPath, name, onCollapse, onExpand]
159
+ );
160
+ const selectNode = useCallback(
161
+ (event, node) => {
162
+ var _a2, _b2;
163
+ if (!node) return;
164
+ const resolvedTreeNode = (_a2 = findNodeById(treeNodesRef.current, node.nodeId)) != null ? _a2 : node;
165
+ if (isTreeNodeDisabled(resolvedTreeNode.data)) return;
166
+ setSelectedItem(resolvedTreeNode);
167
+ if (event && nodeclick === "expand" && ((_b2 = resolvedTreeNode.children) == null ? void 0 : _b2.length)) {
168
+ toggleNodeExpansion(event, resolvedTreeNode);
169
+ }
170
+ if (onSelect && event && name) {
171
+ onSelect(event, listener == null ? void 0 : listener.Widgets[name], resolvedTreeNode.data, getPath(resolvedTreeNode));
172
+ }
173
+ },
174
+ [name, nodeclick, onSelect, toggleNodeExpansion]
175
+ );
176
+ const handleNodeClick = useCallback(
177
+ (event, node) => {
178
+ selectNode(event, node);
179
+ },
180
+ [selectNode]
181
+ );
182
+ const toggleNodeChecked = useCallback(
183
+ (event, node) => {
184
+ var _a2;
185
+ event.stopPropagation();
186
+ const resolvedNode = (_a2 = findNodeById(treeNodesRef.current, node.nodeId)) != null ? _a2 : node;
187
+ if (isTreeNodeDisabled(resolvedNode.data)) return;
188
+ const newCheckedState = !node.checked;
189
+ const updateCheckedState = (nodes, nodeId, checked) => {
190
+ return nodes.map((node2) => {
191
+ var _a3, _b2;
192
+ if (node2.nodeId === nodeId) {
193
+ const updatedNode = __spreadProps(__spreadValues({}, node2), { checked });
194
+ if ((_a3 = node2.children) == null ? void 0 : _a3.length) {
195
+ updatedNode.children = updateAllChildrenChecked(node2.children, checked);
196
+ }
197
+ if (updatedNode.data) {
198
+ updatedNode.data = __spreadProps(__spreadValues({}, updatedNode.data), { checked });
199
+ }
200
+ return updatedNode;
201
+ } else if ((_b2 = node2.children) == null ? void 0 : _b2.length) {
202
+ const updatedChildren = updateCheckedState(node2.children, nodeId, checked);
203
+ const allChildrenChecked = updatedChildren.every((child) => child.checked);
204
+ const anyChildChecked = updatedChildren.some((child) => child.checked);
205
+ const updatedCheckedState = nodeId !== node2.nodeId ? checked ? allChildrenChecked : anyChildChecked ? node2.checked : false : node2.checked;
206
+ const updatedNode = __spreadProps(__spreadValues({}, node2), {
207
+ children: updatedChildren,
246
208
  checked: updatedCheckedState
247
209
  });
210
+ if (updatedNode.data) {
211
+ updatedNode.data = __spreadProps(__spreadValues({}, updatedNode.data), { checked: updatedCheckedState });
212
+ }
213
+ return updatedNode;
248
214
  }
249
- return _updatedNode;
250
- }
251
- return node;
252
- });
253
- };
254
-
255
- // Helper function to set all children to the same checked state
256
- var _updateAllChildrenChecked = function updateAllChildrenChecked(nodes, checked) {
257
- return nodes.map(function (node) {
258
- var _node$children3;
259
- var updatedNode = _objectSpread(_objectSpread({}, node), {}, {
260
- checked: checked,
261
- children: (_node$children3 = node.children) !== null && _node$children3 !== void 0 && _node$children3.length ? _updateAllChildrenChecked(node.children, checked) : node.children
215
+ return node2;
262
216
  });
263
-
264
- // Update the data object to maintain consistency
265
- if (updatedNode.data) {
266
- updatedNode.data = _objectSpread(_objectSpread({}, updatedNode.data), {}, {
267
- checked: checked
217
+ };
218
+ const updateAllChildrenChecked = (nodes, checked) => {
219
+ return nodes.map((node2) => {
220
+ var _a3;
221
+ const updatedNode = __spreadProps(__spreadValues({}, node2), {
222
+ checked,
223
+ children: ((_a3 = node2.children) == null ? void 0 : _a3.length) ? updateAllChildrenChecked(node2.children, checked) : node2.children
268
224
  });
269
- }
270
- return updatedNode;
271
- });
272
- };
273
- var updatedNodes = _updateCheckedState(treeNodes, node.nodeId, newCheckedState);
274
- setTreeNodes(updatedNodes);
275
- if (onCheck) {
276
- onCheck(event, undefined, node.data, newCheckedState);
277
- }
278
- }, [name, onCheck, treeNodes]);
279
-
280
- // Handle radio button selection
281
- var handleRadioSelect = (0, _react.useCallback)(function (event, node) {
282
- var _findNodeById3;
283
- event.stopPropagation(); // Prevent triggering node selection
284
-
285
- var resolvedNode = (_findNodeById3 = (0, _utils.findNodeById)(treeNodesRef.current, node.nodeId)) !== null && _findNodeById3 !== void 0 ? _findNodeById3 : node;
286
- if ((0, _utils.isTreeNodeDisabled)(resolvedNode.data)) return;
287
-
288
- // Already selected, skip
289
- if (radioSelectedNodeId === node.nodeId) {
290
- return;
291
- }
292
-
293
- // Set new selected radio
294
- setRadioSelectedNodeId(node.nodeId);
295
-
296
- // Update all nodes in the tree to set the correct radio state
297
- var _updateRadioState = function updateRadioState(nodes, selectedNodeId) {
298
- return nodes.map(function (node) {
299
- var _node$children4;
300
- var isChecked = node.nodeId === selectedNodeId;
301
-
302
- // Update this node
303
- var updatedNode = _objectSpread(_objectSpread({}, node), {}, {
304
- checked: isChecked
225
+ if (updatedNode.data) {
226
+ updatedNode.data = __spreadProps(__spreadValues({}, updatedNode.data), { checked });
227
+ }
228
+ return updatedNode;
305
229
  });
306
-
307
- // Update the data object to maintain consistency
308
- if (updatedNode.data) {
309
- updatedNode.data = _objectSpread(_objectSpread({}, updatedNode.data), {}, {
230
+ };
231
+ const updatedNodes = updateCheckedState(treeNodes, node.nodeId, newCheckedState);
232
+ setTreeNodes(updatedNodes);
233
+ if (onCheck) {
234
+ onCheck(event, void 0, node.data, newCheckedState);
235
+ }
236
+ },
237
+ [name, onCheck, treeNodes]
238
+ );
239
+ const handleRadioSelect = useCallback(
240
+ (event, node) => {
241
+ var _a2;
242
+ event.stopPropagation();
243
+ const resolvedNode = (_a2 = findNodeById(treeNodesRef.current, node.nodeId)) != null ? _a2 : node;
244
+ if (isTreeNodeDisabled(resolvedNode.data)) return;
245
+ if (radioSelectedNodeId === node.nodeId) {
246
+ return;
247
+ }
248
+ setRadioSelectedNodeId(node.nodeId);
249
+ const updateRadioState = (nodes, selectedNodeId) => {
250
+ return nodes.map((node2) => {
251
+ var _a3;
252
+ const isChecked = node2.nodeId === selectedNodeId;
253
+ const updatedNode = __spreadProps(__spreadValues({}, node2), {
310
254
  checked: isChecked
311
255
  });
312
- }
313
-
314
- // Update children recursively if any
315
- if ((_node$children4 = node.children) !== null && _node$children4 !== void 0 && _node$children4.length) {
316
- updatedNode.children = _updateRadioState(node.children, selectedNodeId);
317
- }
318
- return updatedNode;
319
- });
320
- };
321
- var updatedNodes = _updateRadioState(treeNodes, node.nodeId);
322
- setTreeNodes(updatedNodes);
323
- if (onCheck) {
324
- onCheck(event, undefined, node.data, true);
325
- }
326
- }, [name, onCheck, radioSelectedNodeId, treeNodes]);
327
-
328
- // Implement programmatic API methods
329
- var selectById = (0, _react.useCallback)(function (nodeId) {
330
- if (!nodeId) {
331
- setSelectedItem(null);
332
- return;
333
- }
334
- var node = (0, _utils.findNodeById)(treeNodes, nodeId);
335
- if (node) {
336
- if ((0, _utils.isTreeNodeDisabled)(node.data)) return;
337
- selectNode(undefined, node);
338
- if (isRadioTree) {
339
- setRadioSelectedNodeId(node.nodeId);
340
- var _updateRadioState2 = function updateRadioState(nodes, selectedNodeId) {
341
- return nodes.map(function (node) {
342
- var _node$children5;
343
- var isChecked = node.nodeId === selectedNodeId;
344
- var updatedNode = _objectSpread(_objectSpread({}, node), {}, {
345
- checked: isChecked
346
- });
347
- if (updatedNode.data) {
348
- updatedNode.data = _objectSpread(_objectSpread({}, updatedNode.data), {}, {
349
- checked: isChecked
350
- });
351
- }
352
- if ((_node$children5 = node.children) !== null && _node$children5 !== void 0 && _node$children5.length) {
353
- updatedNode.children = _updateRadioState2(node.children, selectedNodeId);
354
- }
355
- return updatedNode;
356
- });
357
- };
358
- var updatedNodes = _updateRadioState2(treeNodes, node.nodeId);
359
- setTreeNodes(updatedNodes);
256
+ if (updatedNode.data) {
257
+ updatedNode.data = __spreadProps(__spreadValues({}, updatedNode.data), { checked: isChecked });
258
+ }
259
+ if ((_a3 = node2.children) == null ? void 0 : _a3.length) {
260
+ updatedNode.children = updateRadioState(node2.children, selectedNodeId);
261
+ }
262
+ return updatedNode;
263
+ });
264
+ };
265
+ const updatedNodes = updateRadioState(treeNodes, node.nodeId);
266
+ setTreeNodes(updatedNodes);
267
+ if (onCheck) {
268
+ onCheck(event, void 0, node.data, true);
360
269
  }
361
- var currentNode = node.parent;
362
- var nodesToExpand = [];
363
- while (currentNode) {
364
- nodesToExpand.push(currentNode);
365
- currentNode = currentNode.parent;
270
+ },
271
+ [name, onCheck, radioSelectedNodeId, treeNodes]
272
+ );
273
+ const selectById = useCallback(
274
+ (nodeId) => {
275
+ if (!nodeId) {
276
+ setSelectedItem(null);
277
+ return;
366
278
  }
367
- if (nodesToExpand.length) {
368
- var _updateNodeOpenState = function updateNodeOpenState(nodes, nodesToExpand) {
369
- return nodes.map(function (node) {
370
- var _node$children6;
371
- if (nodesToExpand.some(function (n) {
372
- return n.nodeId === node.nodeId;
373
- })) {
374
- return _objectSpread(_objectSpread({}, node), {}, {
375
- open: true,
376
- children: node.children ? _updateNodeOpenState(node.children, nodesToExpand) : undefined
377
- });
378
- } else if ((_node$children6 = node.children) !== null && _node$children6 !== void 0 && _node$children6.length) {
379
- return _objectSpread(_objectSpread({}, node), {}, {
380
- children: _updateNodeOpenState(node.children, nodesToExpand)
279
+ const node = findNodeById(treeNodes, nodeId);
280
+ if (node) {
281
+ if (isTreeNodeDisabled(node.data)) return;
282
+ selectNode(void 0, node);
283
+ if (isRadioTree) {
284
+ setRadioSelectedNodeId(node.nodeId);
285
+ const updateRadioState = (nodes, selectedNodeId) => {
286
+ return nodes.map((node2) => {
287
+ var _a2;
288
+ const isChecked = node2.nodeId === selectedNodeId;
289
+ const updatedNode = __spreadProps(__spreadValues({}, node2), {
290
+ checked: isChecked
381
291
  });
382
- }
383
- return node;
384
- });
385
- };
386
- var _updatedNodes = _updateNodeOpenState(treeNodes, nodesToExpand);
387
- setTreeNodes(_updatedNodes);
292
+ if (updatedNode.data) {
293
+ updatedNode.data = __spreadProps(__spreadValues({}, updatedNode.data), { checked: isChecked });
294
+ }
295
+ if ((_a2 = node2.children) == null ? void 0 : _a2.length) {
296
+ updatedNode.children = updateRadioState(node2.children, selectedNodeId);
297
+ }
298
+ return updatedNode;
299
+ });
300
+ };
301
+ const updatedNodes = updateRadioState(treeNodes, node.nodeId);
302
+ setTreeNodes(updatedNodes);
303
+ }
304
+ let currentNode = node.parent;
305
+ const nodesToExpand = [];
306
+ while (currentNode) {
307
+ nodesToExpand.push(currentNode);
308
+ currentNode = currentNode.parent;
309
+ }
310
+ if (nodesToExpand.length) {
311
+ const updateNodeOpenState = (nodes, nodesToExpand2) => {
312
+ return nodes.map((node2) => {
313
+ var _a2;
314
+ if (nodesToExpand2.some((n) => n.nodeId === node2.nodeId)) {
315
+ return __spreadProps(__spreadValues({}, node2), {
316
+ open: true,
317
+ children: node2.children ? updateNodeOpenState(node2.children, nodesToExpand2) : void 0
318
+ });
319
+ } else if ((_a2 = node2.children) == null ? void 0 : _a2.length) {
320
+ return __spreadProps(__spreadValues({}, node2), { children: updateNodeOpenState(node2.children, nodesToExpand2) });
321
+ }
322
+ return node2;
323
+ });
324
+ };
325
+ const updatedNodes = updateNodeOpenState(treeNodes, nodesToExpand);
326
+ setTreeNodes(updatedNodes);
327
+ }
388
328
  }
389
- }
390
- }, [isRadioTree, selectNode, treeNodes]);
391
- var deselectById = (0, _react.useCallback)(function () {
329
+ },
330
+ [isRadioTree, selectNode, treeNodes]
331
+ );
332
+ const deselectById = useCallback(() => {
392
333
  setSelectedItem(null);
393
334
  if (isRadioTree) {
394
335
  setRadioSelectedNodeId(null);
395
- var _clearCheckedState = function clearCheckedState(nodes) {
396
- return nodes.map(function (node) {
397
- var _node$children7;
398
- var updatedNode = _objectSpread(_objectSpread({}, node), {}, {
336
+ const clearCheckedState = (nodes) => {
337
+ return nodes.map((node) => {
338
+ var _a2;
339
+ const updatedNode = __spreadProps(__spreadValues({}, node), {
399
340
  checked: false,
400
- children: (_node$children7 = node.children) !== null && _node$children7 !== void 0 && _node$children7.length ? _clearCheckedState(node.children) : node.children
341
+ children: ((_a2 = node.children) == null ? void 0 : _a2.length) ? clearCheckedState(node.children) : node.children
401
342
  });
402
343
  if (updatedNode.data) {
403
- updatedNode.data = _objectSpread(_objectSpread({}, updatedNode.data), {}, {
404
- checked: false
405
- });
344
+ updatedNode.data = __spreadProps(__spreadValues({}, updatedNode.data), { checked: false });
406
345
  }
407
346
  return updatedNode;
408
347
  });
409
348
  };
410
- setTreeNodes(_clearCheckedState(treeNodes));
349
+ setTreeNodes(clearCheckedState(treeNodes));
411
350
  }
412
351
  }, [isRadioTree]);
413
- var sortedTreeNodes = (0, _react.useMemo)(function () {
414
- return treeNodes;
415
- }, [treeNodes]);
416
-
417
- /** Parents often pass a new array reference each render (`dataset={[...]}`); only re-parse when data or shape config actually changes. */
418
- var prevDatasetRef = (0, _react.useRef)(undefined);
419
- var prevGetNodesRef = (0, _react.useRef)(null);
420
-
421
- // Process dataset when it changes
422
- (0, _react.useEffect)(function () {
423
- var getNodesIdentityChanged = prevGetNodesRef.current !== getNodes;
352
+ const sortedTreeNodes = useMemo(() => treeNodes, [treeNodes]);
353
+ const prevDatasetRef = useRef(void 0);
354
+ const prevGetNodesRef = useRef(null);
355
+ useEffect(() => {
356
+ const getNodesIdentityChanged = prevGetNodesRef.current !== getNodes;
424
357
  prevGetNodesRef.current = getNodes;
425
358
  try {
426
- var datasetUnchangedDeep = prevDatasetRef.current !== undefined && (0, _isEqual["default"])(prevDatasetRef.current, dataset);
359
+ const datasetUnchangedDeep = prevDatasetRef.current !== void 0 && isEqual(prevDatasetRef.current, dataset);
427
360
  if (!getNodesIdentityChanged && datasetUnchangedDeep) {
428
361
  return;
429
362
  }
430
363
  prevDatasetRef.current = dataset;
431
- var parsedNodes = getNodes(dataset);
364
+ const parsedNodes = getNodes(dataset);
432
365
  setTreeNodes(parsedNodes);
433
366
  } catch (error) {
434
367
  setTreeNodes([]);
435
368
  }
436
369
  }, [dataset, getNodes]);
437
-
438
- // Handle datavalue changes - following Angular's approach
439
- (0, _react.useEffect)(function () {
370
+ useEffect(() => {
371
+ var _a2;
440
372
  if (!datavalue || !sortedTreeNodes.length) return;
441
373
  if (selectedItem) return;
442
- var targetNode = null;
374
+ let targetNode = null;
443
375
  if (datavalue === "FirstNode") {
444
376
  targetNode = sortedTreeNodes[0];
445
377
  } else if (datavalue === "LastNode") {
446
378
  targetNode = sortedTreeNodes[sortedTreeNodes.length - 1];
447
379
  } else {
448
- targetNode = (0, _utils.findNodeById)(sortedTreeNodes, datavalue);
380
+ targetNode = findNodeById(sortedTreeNodes, datavalue);
449
381
  }
450
- if (targetNode && !(0, _utils.isTreeNodeDisabled)(targetNode.data)) {
451
- var _targetNode$children;
452
- selectNode(undefined, targetNode);
453
- if ((_targetNode$children = targetNode.children) !== null && _targetNode$children !== void 0 && _targetNode$children.length) {
454
- var _updateNodeOpenState2 = function updateNodeOpenState(nodes, targetNodeId) {
455
- return nodes.map(function (node) {
456
- var _node$children8;
382
+ if (targetNode && !isTreeNodeDisabled(targetNode.data)) {
383
+ selectNode(void 0, targetNode);
384
+ if ((_a2 = targetNode.children) == null ? void 0 : _a2.length) {
385
+ const updateNodeOpenState = (nodes, targetNodeId) => {
386
+ return nodes.map((node) => {
387
+ var _a3;
457
388
  if (node.nodeId === targetNodeId) {
458
- return _objectSpread(_objectSpread({}, node), {}, {
389
+ return __spreadProps(__spreadValues({}, node), {
459
390
  open: true,
460
- children: node.children ? _updateNodeOpenState2(node.children, targetNodeId) : undefined
461
- });
462
- } else if ((_node$children8 = node.children) !== null && _node$children8 !== void 0 && _node$children8.length) {
463
- return _objectSpread(_objectSpread({}, node), {}, {
464
- children: _updateNodeOpenState2(node.children, targetNodeId)
391
+ children: node.children ? updateNodeOpenState(node.children, targetNodeId) : void 0
465
392
  });
393
+ } else if ((_a3 = node.children) == null ? void 0 : _a3.length) {
394
+ return __spreadProps(__spreadValues({}, node), { children: updateNodeOpenState(node.children, targetNodeId) });
466
395
  }
467
396
  return node;
468
397
  });
469
398
  };
470
- var updatedNodes = _updateNodeOpenState2(treeNodes, targetNode.nodeId);
399
+ const updatedNodes = updateNodeOpenState(treeNodes, targetNode.nodeId);
471
400
  setTreeNodes(updatedNodes);
472
401
  }
473
402
  }
474
- }, [datavalue, sortedTreeNodes.length, selectedItem, treeNodes, selectNode]); // Added selectNode to dependencies
475
-
476
- //Handled methods
477
- (0, _react.useEffect)(function () {
478
- if (listener !== null && listener !== void 0 && listener.onChange) {
403
+ }, [datavalue, sortedTreeNodes.length, selectedItem, treeNodes, selectNode]);
404
+ useEffect(() => {
405
+ if (listener == null ? void 0 : listener.onChange) {
479
406
  listener.onChange(name, {
480
- selectById: selectById,
481
- deselectById: deselectById
407
+ selectById,
408
+ deselectById,
409
+ setTemplate
482
410
  });
483
411
  }
484
412
  }, [selectById, deselectById]);
485
- return __jsx(_Box["default"], {
486
- component: "ul",
487
- className: (0, _clsx["default"])(DEFAULT_CLASS, className, "ztree", template && "app-tree-custom"),
488
- id: name,
489
- name: name,
490
- tabIndex: tabindex,
491
- style: _objectSpread(_objectSpread({}, props.styles), {}, {
492
- width: width,
493
- height: height,
494
- textAlign: horizontalalign
495
- }),
496
- hidden: props.hidden
497
- }, sortedTreeNodes.length > 0 ? sortedTreeNodes.map(function (node) {
498
- return __jsx(_TreeNodeComponent["default"], {
499
- key: node.nodeId,
500
- node: node,
501
- treeicons: treeicons,
502
- isCheckboxTree: isCheckboxTree,
503
- isRadioTree: isRadioTree,
504
- selectedItem: selectedItem,
505
- handleNodeClick: handleNodeClick,
506
- toggleNodeExpansion: toggleNodeExpansion,
507
- toggleNodeChecked: toggleNodeChecked,
508
- handleRadioSelect: handleRadioSelect,
509
- treeName: name,
510
- template: template || undefined,
511
- listener: listener
512
- });
513
- }) : __jsx("li", {
514
- className: "wm-tree-empty-message"
515
- }, "No tree data available"));
413
+ return /* @__PURE__ */ jsx(
414
+ Box,
415
+ {
416
+ component: "ul",
417
+ className: clsx(DEFAULT_CLASS, className, "ztree", template && "app-tree-custom"),
418
+ id: name,
419
+ name,
420
+ tabIndex: tabindex,
421
+ style: __spreadProps(__spreadValues({}, props.styles), {
422
+ width,
423
+ height,
424
+ textAlign: horizontalalign
425
+ }),
426
+ hidden: props.hidden,
427
+ children: sortedTreeNodes.length > 0 ? sortedTreeNodes.map((node) => /* @__PURE__ */ jsx(
428
+ TreeNodeComponent,
429
+ {
430
+ node,
431
+ treeicons,
432
+ isCheckboxTree,
433
+ isRadioTree,
434
+ selectedItem,
435
+ handleNodeClick,
436
+ toggleNodeExpansion,
437
+ toggleNodeChecked,
438
+ handleRadioSelect,
439
+ treeName: name,
440
+ template: template || templateName,
441
+ listener
442
+ },
443
+ node.nodeId
444
+ )) : /* @__PURE__ */ jsx("li", { className: "wm-tree-empty-message", children: "No tree data available" })
445
+ }
446
+ );
516
447
  };
517
448
  WmTree.displayName = "WmTree";
518
-
519
- /**
520
- * The WmTree component is used to display hierarchical data in a tree structure.
521
- * It supports node selection, expansion/collapse, and checkbox/radio modes.
522
- *
523
- * - [Playground](https://react-components.wavemaker.ai/?path=/story/basic-tree--showcase)
524
- *
525
- * - [Docs](https://react-components.wavemaker.ai/?path=/story/basic-tree--docs)
526
- *
527
- * @param props - {@link WmTreeProps}
528
- */
529
- var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WmTree);
449
+ var tree_default = withBaseWrapper(WmTree);
450
+ export {
451
+ WmTree,
452
+ tree_default as default
453
+ };