@wavemaker/react-runtime 11.14.1-16.6404

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 (402) hide show
  1. package/actions/base-action.js +32 -0
  2. package/actions/login-action.js +53 -0
  3. package/actions/logout-action.js +41 -0
  4. package/actions/navigation-action.js +145 -0
  5. package/actions/notification-action.js +147 -0
  6. package/actions/timer-action.js +164 -0
  7. package/actions/toast-provider.js +111 -0
  8. package/actions/toast.js +115 -0
  9. package/actions/toast.service.js +94 -0
  10. package/actions/types/index.js +11 -0
  11. package/components/advanced/carousel/index.js +456 -0
  12. package/components/advanced/carousel/props.js +5 -0
  13. package/components/advanced/carousel/template.js +72 -0
  14. package/components/advanced/login/index.js +307 -0
  15. package/components/advanced/login/props.js +5 -0
  16. package/components/advanced/marquee/index.js +158 -0
  17. package/components/advanced/marquee/props.js +5 -0
  18. package/components/basic/anchor/index.js +239 -0
  19. package/components/basic/anchor/props.js +5 -0
  20. package/components/basic/audio/index.js +61 -0
  21. package/components/basic/html/index.js +158 -0
  22. package/components/basic/icon/index.js +85 -0
  23. package/components/basic/iframe/iframe.utils.js +10 -0
  24. package/components/basic/iframe/index.js +95 -0
  25. package/components/basic/label/index.js +139 -0
  26. package/components/basic/message/index.js +120 -0
  27. package/components/basic/message/props.js +5 -0
  28. package/components/basic/picture/index.js +117 -0
  29. package/components/basic/picture/props.js +5 -0
  30. package/components/basic/progress-bar/index.js +168 -0
  31. package/components/basic/progress-bar/props.js +18 -0
  32. package/components/basic/progress-circle/index.js +196 -0
  33. package/components/basic/progress-circle/props.js +16 -0
  34. package/components/basic/richtexteditor/index.js +533 -0
  35. package/components/basic/richtexteditor/props.js +5 -0
  36. package/components/basic/search/index.js +1023 -0
  37. package/components/basic/search/props.js +5 -0
  38. package/components/basic/search/providers.js +350 -0
  39. package/components/basic/spinner/index.js +202 -0
  40. package/components/basic/spinner/props.js +12 -0
  41. package/components/basic/tile/index.js +91 -0
  42. package/components/basic/tree/Components/TreeNodeComponent.js +142 -0
  43. package/components/basic/tree/index.js +503 -0
  44. package/components/basic/tree/props.js +5 -0
  45. package/components/basic/tree/utils.js +154 -0
  46. package/components/basic/video/index.js +85 -0
  47. package/components/basic/video/props.js +5 -0
  48. package/components/chart/components/barColumnChart/index.js +132 -0
  49. package/components/chart/components/barColumnChart/props.js +5 -0
  50. package/components/chart/components/bubbleChart/index.js +176 -0
  51. package/components/chart/components/bubbleChart/props.js +5 -0
  52. package/components/chart/components/chartLegend/components/ClassicLegendItem.js +39 -0
  53. package/components/chart/components/chartLegend/components/FuriousLegendItem.js +81 -0
  54. package/components/chart/components/chartLegend/index.js +69 -0
  55. package/components/chart/components/chartLegend/props.js +5 -0
  56. package/components/chart/components/chartLegend/utils.js +31 -0
  57. package/components/chart/components/chartTooltip/index.js +53 -0
  58. package/components/chart/components/chartTooltip/styles.js +37 -0
  59. package/components/chart/components/chartTooltip/utils.js +23 -0
  60. package/components/chart/components/cumulativeLineChart/index.js +113 -0
  61. package/components/chart/components/cumulativeLineChart/props.js +5 -0
  62. package/components/chart/components/cumulativeLineChart/utils.js +34 -0
  63. package/components/chart/components/index.js +40 -0
  64. package/components/chart/components/lineAreaChart/index.js +140 -0
  65. package/components/chart/components/lineAreaChart/props.js +5 -0
  66. package/components/chart/components/noDataMessage/index.js +27 -0
  67. package/components/chart/components/pieDonutChart/index.js +171 -0
  68. package/components/chart/components/pieDonutChart/props.js +5 -0
  69. package/components/chart/constant.js +72 -0
  70. package/components/chart/index.js +930 -0
  71. package/components/chart/props.js +5 -0
  72. package/components/chart/utils.js +691 -0
  73. package/components/common/AppSpinner.js +36 -0
  74. package/components/common/app-spinner.js +26 -0
  75. package/components/common/index.js +12 -0
  76. package/components/constants.js +1208 -0
  77. package/components/container/accordion/accordion-pane/index.js +108 -0
  78. package/components/container/accordion/accordion-pane/props.js +11 -0
  79. package/components/container/accordion/index.js +232 -0
  80. package/components/container/accordion/props.js +13 -0
  81. package/components/container/alignment-utils.js +183 -0
  82. package/components/container/index.js +188 -0
  83. package/components/container/layout-grid/grid-column/index.js +34 -0
  84. package/components/container/layout-grid/grid-row/index.js +24 -0
  85. package/components/container/layout-grid/index.js +33 -0
  86. package/components/container/linear-layout/index.js +72 -0
  87. package/components/container/linear-layout/linear-layout-item/index.js +43 -0
  88. package/components/container/panel/components/panel-header/index.js +144 -0
  89. package/components/container/panel/components/panel-header/props.js +5 -0
  90. package/components/container/panel/hooks.js +144 -0
  91. package/components/container/panel/index.js +286 -0
  92. package/components/container/panel/props.js +5 -0
  93. package/components/container/props.js +5 -0
  94. package/components/container/tabs/index.js +379 -0
  95. package/components/container/tabs/props.js +20 -0
  96. package/components/container/tabs/tab-pane/index.js +42 -0
  97. package/components/container/tabs/tab-pane/props.js +5 -0
  98. package/components/container/wizard/WizardContext.js +16 -0
  99. package/components/container/wizard/components/StepComponents.js +100 -0
  100. package/components/container/wizard/components/WizardStep.js +89 -0
  101. package/components/container/wizard/index.js +710 -0
  102. package/components/container/wizard/props.js +5 -0
  103. package/components/container/wizard/utils.js +133 -0
  104. package/components/container/wizard/wizard-action/index.js +22 -0
  105. package/components/container/wizard/wizard-step/index.js +94 -0
  106. package/components/data/card/card-actions/index.js +24 -0
  107. package/components/data/card/card-content/index.js +38 -0
  108. package/components/data/card/card-footer/index.js +24 -0
  109. package/components/data/card/index.js +246 -0
  110. package/components/data/card/props.js +5 -0
  111. package/components/data/form/base-form/constant.js +39 -0
  112. package/components/data/form/base-form/index.js +460 -0
  113. package/components/data/form/base-form/props.js +29 -0
  114. package/components/data/form/base-form/utils.js +42 -0
  115. package/components/data/form/dynamic-fields/index.js +196 -0
  116. package/components/data/form/dynamic-fields/props.js +5 -0
  117. package/components/data/form/dynamic-fields/utils.js +237 -0
  118. package/components/data/form/form-action/index.js +71 -0
  119. package/components/data/form/form-body/index.js +26 -0
  120. package/components/data/form/form-context.js +34 -0
  121. package/components/data/form/form-controller/props.js +19 -0
  122. package/components/data/form/form-controller/validation-contrustor.js +313 -0
  123. package/components/data/form/form-controller/withFormController.js +320 -0
  124. package/components/data/form/form-field/base-field.js +138 -0
  125. package/components/data/form/form-field/index.js +36 -0
  126. package/components/data/form/form-field/props.js +5 -0
  127. package/components/data/form/form-footer/index.js +26 -0
  128. package/components/data/form/form-header/index.js +56 -0
  129. package/components/data/form/index.js +39 -0
  130. package/components/data/form/props.js +5 -0
  131. package/components/data/list/components/GroupHeader.js +35 -0
  132. package/components/data/list/components/GroupedListItems.js +98 -0
  133. package/components/data/list/components/ListContainer.js +27 -0
  134. package/components/data/list/components/ListDND.js +241 -0
  135. package/components/data/list/components/ListHeader.js +59 -0
  136. package/components/data/list/components/ListItem.js +148 -0
  137. package/components/data/list/components/ListItemWithTemplate.js +59 -0
  138. package/components/data/list/components/ListItems.js +231 -0
  139. package/components/data/list/components/ListPagination.js +165 -0
  140. package/components/data/list/components/LoadMoreButton.js +39 -0
  141. package/components/data/list/components/NoDataMessage.js +22 -0
  142. package/components/data/list/components/StandardListItems.js +84 -0
  143. package/components/data/list/components/index.js +119 -0
  144. package/components/data/list/components/props.js +5 -0
  145. package/components/data/list/hooks/index.js +75 -0
  146. package/components/data/list/hooks/props.js +5 -0
  147. package/components/data/list/hooks/useCurrentPageItems.js +48 -0
  148. package/components/data/list/hooks/useGroupedData.js +37 -0
  149. package/components/data/list/hooks/useListData.js +60 -0
  150. package/components/data/list/hooks/useListEffects.js +285 -0
  151. package/components/data/list/hooks/useListEventHandlers.js +291 -0
  152. package/components/data/list/hooks/useListPagination.js +168 -0
  153. package/components/data/list/hooks/useListState.js +98 -0
  154. package/components/data/list/hooks/useListStateManager.js +195 -0
  155. package/components/data/list/hooks/usePaginatedGroupedData.js +121 -0
  156. package/components/data/list/index.js +611 -0
  157. package/components/data/list/props.js +5 -0
  158. package/components/data/list/templates/media-template.js +53 -0
  159. package/components/data/list/utils/constants.js +81 -0
  160. package/components/data/list/utils/list-helpers.js +173 -0
  161. package/components/data/list/utils/list-widget-methods.js +114 -0
  162. package/components/data/live-filter/index.js +279 -0
  163. package/components/data/live-filter/props.js +12 -0
  164. package/components/data/live-form/index.js +93 -0
  165. package/components/data/live-form/props.js +16 -0
  166. package/components/data/pagination/components/BasicPagination.js +77 -0
  167. package/components/data/pagination/components/ClassicPagination.js +191 -0
  168. package/components/data/pagination/components/InlinePagination.js +99 -0
  169. package/components/data/pagination/components/LoadingComponent.js +31 -0
  170. package/components/data/pagination/components/PageSizeSelector.js +175 -0
  171. package/components/data/pagination/components/PagerNavigation.js +105 -0
  172. package/components/data/pagination/components/TotalRecords.js +52 -0
  173. package/components/data/pagination/components/index.js +47 -0
  174. package/components/data/pagination/components/props.js +5 -0
  175. package/components/data/pagination/hooks/index.js +19 -0
  176. package/components/data/pagination/hooks/props.js +5 -0
  177. package/components/data/pagination/hooks/useNavigationSize.js +44 -0
  178. package/components/data/pagination/hooks/usePagination.js +796 -0
  179. package/components/data/pagination/index.js +322 -0
  180. package/components/data/table/components/AddNewRow.js +190 -0
  181. package/components/data/table/components/EditableCell.js +91 -0
  182. package/components/data/table/components/FieldValidationError.js +24 -0
  183. package/components/data/table/components/RowExpansionButton.js +74 -0
  184. package/components/data/table/components/TableBody.js +279 -0
  185. package/components/data/table/components/TableFilters.js +325 -0
  186. package/components/data/table/components/TableFooterActions.js +48 -0
  187. package/components/data/table/components/TableHeader.js +174 -0
  188. package/components/data/table/components/TablePanelHeading.js +68 -0
  189. package/components/data/table/components/index.js +74 -0
  190. package/components/data/table/hooks/index.js +219 -0
  191. package/components/data/table/hooks/useCellState.js +117 -0
  192. package/components/data/table/hooks/useDynamicColumns.js +85 -0
  193. package/components/data/table/hooks/useEditingState.js +47 -0
  194. package/components/data/table/hooks/useFormWidget.js +184 -0
  195. package/components/data/table/hooks/usePaginationState.js +60 -0
  196. package/components/data/table/hooks/usePanelStructure.js +40 -0
  197. package/components/data/table/hooks/useResponsiveColumns.js +34 -0
  198. package/components/data/table/hooks/useRowExpansion.js +110 -0
  199. package/components/data/table/hooks/useRowHandlers.js +38 -0
  200. package/components/data/table/hooks/useRowSelection.js +213 -0
  201. package/components/data/table/hooks/useServerSideSorting.js +165 -0
  202. package/components/data/table/hooks/useTableColumns.js +263 -0
  203. package/components/data/table/hooks/useTableData.js +154 -0
  204. package/components/data/table/hooks/useTableEdit.js +467 -0
  205. package/components/data/table/hooks/useTableEffects.js +139 -0
  206. package/components/data/table/hooks/useTableFilter.js +389 -0
  207. package/components/data/table/hooks/useTableInitialization.js +103 -0
  208. package/components/data/table/hooks/useTableState.js +69 -0
  209. package/components/data/table/hooks/useTableStateManager.js +558 -0
  210. package/components/data/table/index.js +1295 -0
  211. package/components/data/table/live-table/index.js +232 -0
  212. package/components/data/table/props.js +5 -0
  213. package/components/data/table/table-action/index.js +78 -0
  214. package/components/data/table/table-column/index.js +35 -0
  215. package/components/data/table/table-row/index.js +49 -0
  216. package/components/data/table/table-row-action/index.js +74 -0
  217. package/components/data/table/utils/buildSelectionColumns.js +173 -0
  218. package/components/data/table/utils/columnBuilder.js +209 -0
  219. package/components/data/table/utils/columnProxy.js +48 -0
  220. package/components/data/table/utils/columnWidthDistribution.js +98 -0
  221. package/components/data/table/utils/constants.js +80 -0
  222. package/components/data/table/utils/crud-handlers.js +518 -0
  223. package/components/data/table/utils/dynamic-columns.js +118 -0
  224. package/components/data/table/utils/index.js +607 -0
  225. package/components/data/table/utils/renderDisplayCell.js +183 -0
  226. package/components/data/table/utils/selectionUtils.js +166 -0
  227. package/components/data/table/utils/table-helpers.js +100 -0
  228. package/components/data/table/utils/validation.js +124 -0
  229. package/components/data/types.js +113 -0
  230. package/components/data/utils/field-data-utils.js +66 -0
  231. package/components/data/utils/filter-field-util.js +81 -0
  232. package/components/data/utils/index.js +216 -0
  233. package/components/dialogs/alert-dialog/index.js +80 -0
  234. package/components/dialogs/confirm-dialog/index.js +105 -0
  235. package/components/dialogs/dialog/index.js +56 -0
  236. package/components/dialogs/dialog-actions/index.js +18 -0
  237. package/components/dialogs/dialog-body/index.js +21 -0
  238. package/components/dialogs/dialog-content/index.js +30 -0
  239. package/components/dialogs/dialog-header/index.js +93 -0
  240. package/components/dialogs/iframe-dialog/index.js +114 -0
  241. package/components/dialogs/index.js +129 -0
  242. package/components/dialogs/login-dialog/index.js +369 -0
  243. package/components/dialogs/login-dialog/props.js +5 -0
  244. package/components/dialogs/page-dialog/index.js +96 -0
  245. package/components/dialogs/withDialogWrapper.js +108 -0
  246. package/components/form/button/index.js +216 -0
  247. package/components/form/button-group/index.js +60 -0
  248. package/components/input/calendar/index.js +546 -0
  249. package/components/input/calendar/props.js +5 -0
  250. package/components/input/calendar/utils.js +340 -0
  251. package/components/input/chips/SortableChip/index.js +115 -0
  252. package/components/input/chips/SortableChip/props.js +5 -0
  253. package/components/input/chips/index.js +488 -0
  254. package/components/input/chips/props.js +5 -0
  255. package/components/input/chips/utils.js +259 -0
  256. package/components/input/color-picker/index.js +678 -0
  257. package/components/input/color-picker/props.js +5 -0
  258. package/components/input/composite/index.js +137 -0
  259. package/components/input/currency/index.js +263 -0
  260. package/components/input/currency/props.js +5 -0
  261. package/components/input/default/checkbox/index.js +230 -0
  262. package/components/input/default/checkbox/props.js +5 -0
  263. package/components/input/default/checkboxset/index.js +476 -0
  264. package/components/input/default/checkboxset/props.js +5 -0
  265. package/components/input/default/radioset/index.js +379 -0
  266. package/components/input/default/radioset/props.js +5 -0
  267. package/components/input/default/switch/index.js +490 -0
  268. package/components/input/default/switch/prop.js +5 -0
  269. package/components/input/epoch/date/components/DatePickerPopover.js +220 -0
  270. package/components/input/epoch/date/index.js +520 -0
  271. package/components/input/epoch/date/props.js +5 -0
  272. package/components/input/epoch/date/styled.js +70 -0
  273. package/components/input/epoch/date/utils.js +108 -0
  274. package/components/input/epoch/datetime/index.js +656 -0
  275. package/components/input/epoch/datetime/props.js +5 -0
  276. package/components/input/epoch/datetime/styled.js +90 -0
  277. package/components/input/epoch/datetime/utils.js +244 -0
  278. package/components/input/epoch/time/index.js +412 -0
  279. package/components/input/epoch/time/props.js +5 -0
  280. package/components/input/epoch/time/utils.js +209 -0
  281. package/components/input/fileupload/Utils.js +134 -0
  282. package/components/input/fileupload/components/ListItems.js +140 -0
  283. package/components/input/fileupload/components/MultiUpload.js +85 -0
  284. package/components/input/fileupload/components/SingleUpload.js +65 -0
  285. package/components/input/fileupload/index.js +170 -0
  286. package/components/input/fileupload/props.js +5 -0
  287. package/components/input/fileupload/useFileUpload.js +400 -0
  288. package/components/input/number/index.js +295 -0
  289. package/components/input/number/props.js +5 -0
  290. package/components/input/rating/index.js +368 -0
  291. package/components/input/rating/props.js +5 -0
  292. package/components/input/select/index.js +344 -0
  293. package/components/input/select/props.js +5 -0
  294. package/components/input/slider/index.js +167 -0
  295. package/components/input/slider/props.js +5 -0
  296. package/components/input/text/index.js +434 -0
  297. package/components/input/text/props.js +5 -0
  298. package/components/input/text/util.js +179 -0
  299. package/components/input/textarea/index.js +347 -0
  300. package/components/input/textarea/props.js +5 -0
  301. package/components/layout/footer/index.js +30 -0
  302. package/components/layout/header/index.js +30 -0
  303. package/components/layout/leftnav/index.js +44 -0
  304. package/components/layout/rightnav/index.js +32 -0
  305. package/components/layout/topnav/index.js +34 -0
  306. package/components/navbar/index.js +41 -0
  307. package/components/navbar/nav/index.js +102 -0
  308. package/components/navbar/nav/props.js +5 -0
  309. package/components/navbar/nav-item/index.js +44 -0
  310. package/components/navigation/breadcrumb/index.js +56 -0
  311. package/components/navigation/breadcrumb/props.js +5 -0
  312. package/components/navigation/menu/components/ListItems.js +66 -0
  313. package/components/navigation/menu/constants.js +101 -0
  314. package/components/navigation/menu/index.js +807 -0
  315. package/components/navigation/menu/props.js +5 -0
  316. package/components/navigation/popover/index.js +209 -0
  317. package/components/navigation/popover/props.js +15 -0
  318. package/components/page/content/index.js +28 -0
  319. package/components/page/error-boundary/index.js +108 -0
  320. package/components/page/index.js +137 -0
  321. package/components/page/page-content/index.js +23 -0
  322. package/components/page/partial/index.js +36 -0
  323. package/components/page/partial-container/index.js +48 -0
  324. package/components/page/props.js +5 -0
  325. package/components/page/toast-container/index.js +33 -0
  326. package/components/prefab/container/index.js +46 -0
  327. package/components/prefab/index.js +67 -0
  328. package/context/AppContext.js +25 -0
  329. package/context/AppSpinnerProvider.js +43 -0
  330. package/context/LocalizationProvider.js +79 -0
  331. package/context/PrefabContext.js +66 -0
  332. package/context/WidgetProvider.js +187 -0
  333. package/core/app-config.js +1 -0
  334. package/core/app.service.js +357 -0
  335. package/core/appVariablesStore.js +20 -0
  336. package/core/appstore.js +88 -0
  337. package/core/constants/currency-constant.js +1071 -0
  338. package/core/constants/events.js +34 -0
  339. package/core/constants/index.js +27 -0
  340. package/core/dialog.service.js +76 -0
  341. package/core/event-notifier.js +151 -0
  342. package/core/formatter/date-formatters.js +222 -0
  343. package/core/formatter/index.js +131 -0
  344. package/core/formatter/number-formatters.js +142 -0
  345. package/core/formatter/security-formatters.js +323 -0
  346. package/core/formatter/string-formatters.js +52 -0
  347. package/core/formatter/types.js +18 -0
  348. package/core/formatters.js +24 -0
  349. package/core/proxy-service.js +412 -0
  350. package/core/script-registry.js +63 -0
  351. package/core/security.service.js +11 -0
  352. package/core/util/common.js +33 -0
  353. package/core/util/dom.js +107 -0
  354. package/core/util/index.js +136 -0
  355. package/core/util/security.js +184 -0
  356. package/core/util/utils.js +189 -0
  357. package/core/widget-observer.js +98 -0
  358. package/higherOrder/BaseApp.js +430 -0
  359. package/higherOrder/BaseAppProps.js +5 -0
  360. package/higherOrder/BaseDateTime.js +251 -0
  361. package/higherOrder/BasePage.js +715 -0
  362. package/higherOrder/BasePartial.js +124 -0
  363. package/higherOrder/BasePrefab.js +145 -0
  364. package/higherOrder/DataNav.js +377 -0
  365. package/higherOrder/helper.js +43 -0
  366. package/higherOrder/props.js +5 -0
  367. package/higherOrder/withBaseWrapper.js +183 -0
  368. package/hooks/useAccess.js +308 -0
  369. package/hooks/useAppConfig.js +42 -0
  370. package/hooks/useAuth.js +562 -0
  371. package/hooks/useDataSourceSubscription.js +125 -0
  372. package/hooks/useDebounce.js +76 -0
  373. package/hooks/useDeviceVisibility.js +49 -0
  374. package/hooks/useHttp.js +338 -0
  375. package/libs/index.js +20 -0
  376. package/mui-config/theme-provider.js +17 -0
  377. package/mui-config/theme.js +371 -0
  378. package/package-lock.json +10177 -0
  379. package/package.json +95 -0
  380. package/store/index.js +33 -0
  381. package/store/middleware/navigationMiddleware.js +48 -0
  382. package/store/slices/appConfigSlice.js +103 -0
  383. package/store/slices/authSlice.js +508 -0
  384. package/store/slices/i18nSlice.js +206 -0
  385. package/types/index.js +15 -0
  386. package/utils/dataset-util.js +174 -0
  387. package/utils/eval-expression.js +32 -0
  388. package/utils/form-state.util.js +140 -0
  389. package/utils/form-utils.js +187 -0
  390. package/utils/format-util.js +260 -0
  391. package/utils/page-params-util.js +24 -0
  392. package/utils/resource-url.js +27 -0
  393. package/utils/state-persistance.js +343 -0
  394. package/utils/style-utils.js +73 -0
  395. package/utils/transformedDataset-utils.js +633 -0
  396. package/utils/widget-cleanup-util.js +84 -0
  397. package/utils/widgets.js +99 -0
  398. package/variables/base-variable.js +173 -0
  399. package/variables/constants.js +27 -0
  400. package/variables/live-variable.js +166 -0
  401. package/variables/model-variable.js +77 -0
  402. package/variables/service-variable.js +307 -0
@@ -0,0 +1,710 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
12
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
13
+ var _react = _interopRequireWildcard(require("react"));
14
+ var _material = require("@mui/material");
15
+ var _clsx = _interopRequireDefault(require("clsx"));
16
+ var _withBaseWrapper = require("@wavemaker/react-runtime/higherOrder/withBaseWrapper");
17
+ var _utils = require("./utils");
18
+ var _WizardContext = _interopRequireDefault(require("./WizardContext"));
19
+ var _wizardStep = _interopRequireDefault(require("./wizard-step"));
20
+ var _WizardStep = require("./components/WizardStep");
21
+ var _form = _interopRequireDefault(require("@wavemaker/react-runtime/components/data/form"));
22
+ var _formUtils = require("@wavemaker/react-runtime/utils/form-utils");
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_CLS = "app-wizard panel clearfix";
28
+ var BODY_CLASS = "app-wizard-body panel-body";
29
+
30
+ // Main Wizard Component
31
+ var WmWizard = /*#__PURE__*/(0, _react.memo)(function (props) {
32
+ var listener = props.listener,
33
+ _props$stepstyle = props.stepstyle,
34
+ stepstyle = _props$stepstyle === void 0 ? "auto" : _props$stepstyle,
35
+ _props$actionsalignme = props.actionsalignment,
36
+ actionsalignment = _props$actionsalignme === void 0 ? "right" : _props$actionsalignme,
37
+ _props$defaultstep = props.defaultstep,
38
+ defaultstep = _props$defaultstep === void 0 ? "none" : _props$defaultstep,
39
+ _props$defaultstepind = props.defaultstepindex,
40
+ defaultstepindex = _props$defaultstepind === void 0 ? 0 : _props$defaultstepind,
41
+ _props$cancelable = props.cancelable,
42
+ cancelable = _props$cancelable === void 0 ? true : _props$cancelable,
43
+ _props$enablenext = props.enablenext,
44
+ enablenext = _props$enablenext === void 0 ? false : _props$enablenext,
45
+ _props$nextbtnlabel = props.nextbtnlabel,
46
+ nextbtnlabel = _props$nextbtnlabel === void 0 ? "Next" : _props$nextbtnlabel,
47
+ _props$previousbtnlab = props.previousbtnlabel,
48
+ previousbtnlabel = _props$previousbtnlab === void 0 ? "Previous" : _props$previousbtnlab,
49
+ _props$donebtnlabel = props.donebtnlabel,
50
+ donebtnlabel = _props$donebtnlabel === void 0 ? "Done" : _props$donebtnlabel,
51
+ _props$cancelbtnlabel = props.cancelbtnlabel,
52
+ cancelbtnlabel = _props$cancelbtnlabel === void 0 ? "Cancel" : _props$cancelbtnlabel,
53
+ _props$type = props.type,
54
+ type = _props$type === void 0 ? "static" : _props$type,
55
+ _props$dataset = props.dataset,
56
+ dataset = _props$dataset === void 0 ? [] : _props$dataset,
57
+ _props$nodatamessage = props.nodatamessage,
58
+ nodatamessage = _props$nodatamessage === void 0 ? "No Data Found" : _props$nodatamessage,
59
+ children = props.children,
60
+ _props$className = props.className,
61
+ className = _props$className === void 0 ? "classic" : _props$className,
62
+ styles = props.styles,
63
+ _props$name = props.name,
64
+ name = _props$name === void 0 ? "" : _props$name,
65
+ onCancel = props.onCancel,
66
+ onDone = props.onDone,
67
+ message = props.message,
68
+ _props$orientation = props.orientation,
69
+ orientation = _props$orientation === void 0 ? "horizontal" : _props$orientation,
70
+ _props$alternativeLab = props.alternativeLabel,
71
+ alternativeLabel = _props$alternativeLab === void 0 ? false : _props$alternativeLab,
72
+ _props$nonLinear = props.nonLinear,
73
+ nonLinear = _props$nonLinear === void 0 ? true : _props$nonLinear,
74
+ connector = props.connector,
75
+ width = props.width,
76
+ height = props.height,
77
+ render = props.render;
78
+ var _useState = (0, _react.useState)([]),
79
+ steps = _useState[0],
80
+ setSteps = _useState[1];
81
+ var _useState2 = (0, _react.useState)(message || {
82
+ caption: "",
83
+ type: ""
84
+ }),
85
+ wizardMessage = _useState2[0],
86
+ setWizardMessage = _useState2[1];
87
+ var _useState3 = (0, _react.useState)(false),
88
+ isInitialized = _useState3[0],
89
+ setIsInitialized = _useState3[1];
90
+ var formRefs = (0, _react.useRef)({});
91
+
92
+ // Create dynamic steps callback
93
+ var createDynamicSteps = (0, _react.useCallback)(function (datasetItems) {
94
+ return datasetItems.map(function (item, index) {
95
+ var stepData = render ? render(item, index, datasetItems) : item;
96
+ var stepProps = stepData.props || {};
97
+ return _objectSpread(_objectSpread({}, stepProps), {}, {
98
+ name: "step_".concat(index),
99
+ title: stepProps.title || "Step ".concat(index + 1),
100
+ show: stepProps.show !== false,
101
+ enableskip: stepData.enableskip || false,
102
+ enableNext: stepData.enableNext !== false,
103
+ enablePrev: stepData.enablePrev !== false,
104
+ enableDone: stepData.enableDone !== false,
105
+ isDone: false,
106
+ done: false,
107
+ active: index === defaultstepindex,
108
+ disabled: false,
109
+ isValid: true,
110
+ isInitialized: false,
111
+ isdynamic: true,
112
+ dynamicStepIndex: index,
113
+ render: stepProps.render
114
+ });
115
+ });
116
+ }, [defaultstepindex]);
117
+
118
+ // Computed properties
119
+ var currentStep = (0, _react.useMemo)(function () {
120
+ return steps.find(function (step) {
121
+ return step.active;
122
+ }) || null;
123
+ }, [steps]);
124
+ var visibleSteps = (0, _react.useMemo)(function () {
125
+ return steps.filter(function (step) {
126
+ return step.show;
127
+ });
128
+ }, [steps]);
129
+ var currentStepIndex = (0, _react.useMemo)(function () {
130
+ if (!currentStep) return -1;
131
+ return visibleSteps.findIndex(function (step) {
132
+ return step.name === currentStep.name;
133
+ });
134
+ }, [currentStep, visibleSteps]);
135
+ var _hasNextStep = (0, _react.useMemo)(function () {
136
+ return currentStepIndex < visibleSteps.length - 1;
137
+ }, [currentStepIndex, visibleSteps]);
138
+ var hasPrevStep = (0, _react.useMemo)(function () {
139
+ return currentStepIndex > 0;
140
+ }, [currentStepIndex]);
141
+ var showDoneBtn = (0, _react.useMemo)(function () {
142
+ return !_hasNextStep && (currentStep === null || currentStep === void 0 ? void 0 : currentStep.enableDone) !== false;
143
+ }, [_hasNextStep, currentStep]);
144
+ var _useState4 = (0, _react.useState)(true),
145
+ isStepValid = _useState4[0],
146
+ setIsStepValid = _useState4[1];
147
+ (0, _react.useEffect)(function () {
148
+ var validateStep = /*#__PURE__*/function () {
149
+ var _ref = (0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee() {
150
+ var currentStepForm, formdata, hasFields, result;
151
+ return _regenerator["default"].wrap(function _callee$(_context) {
152
+ while (1) switch (_context.prev = _context.next) {
153
+ case 0:
154
+ if (currentStep) {
155
+ _context.next = 2;
156
+ break;
157
+ }
158
+ return _context.abrupt("return");
159
+ case 2:
160
+ currentStepForm = formRefs.current[currentStep.name];
161
+ if (currentStepForm) {
162
+ _context.next = 5;
163
+ break;
164
+ }
165
+ return _context.abrupt("return");
166
+ case 5:
167
+ formdata = (0, _formUtils.getFormData)({
168
+ current: currentStepForm
169
+ });
170
+ if (formdata) {
171
+ _context.next = 8;
172
+ break;
173
+ }
174
+ return _context.abrupt("return");
175
+ case 8:
176
+ hasFields = Object.keys(formdata.values || {}).length > 0;
177
+ if (hasFields) {
178
+ _context.next = 12;
179
+ break;
180
+ }
181
+ setIsStepValid(true);
182
+ return _context.abrupt("return");
183
+ case 12:
184
+ _context.next = 14;
185
+ return (0, _formUtils.formValidate)({
186
+ current: currentStepForm
187
+ });
188
+ case 14:
189
+ result = _context.sent;
190
+ setIsStepValid(result);
191
+ case 16:
192
+ case "end":
193
+ return _context.stop();
194
+ }
195
+ }, _callee);
196
+ }));
197
+ return function validateStep() {
198
+ return _ref.apply(this, arguments);
199
+ };
200
+ }();
201
+ validateStep();
202
+ }, [currentStep]);
203
+ var enableNext = (0, _react.useMemo)(function () {
204
+ return enablenext || (currentStep === null || currentStep === void 0 ? void 0 : currentStep.enableNext) !== false && (currentStep === null || currentStep === void 0 ? void 0 : currentStep.isValid) !== false && isStepValid;
205
+ }, [enablenext, currentStep, isStepValid]);
206
+ var enablePrev = (0, _react.useMemo)(function () {
207
+ return (currentStep === null || currentStep === void 0 ? void 0 : currentStep.enablePrev) !== false;
208
+ }, [currentStep]);
209
+ var enableDone = (0, _react.useMemo)(function () {
210
+ return (currentStep === null || currentStep === void 0 ? void 0 : currentStep.enableDone) !== false && (currentStep === null || currentStep === void 0 ? void 0 : currentStep.isValid) !== false && isStepValid;
211
+ }, [currentStep, isStepValid]);
212
+ var isFirstStep = (0, _react.useMemo)(function () {
213
+ return currentStepIndex === 0;
214
+ }, [currentStepIndex]);
215
+ var isLastStep = (0, _react.useMemo)(function () {
216
+ return currentStepIndex === visibleSteps.length - 1;
217
+ }, [currentStepIndex, visibleSteps]);
218
+ var computedStepClass = (0, _react.useMemo)(function () {
219
+ return stepstyle === "justified" ? "justified" : "auto";
220
+ }, [stepstyle]);
221
+
222
+ // Step click handler
223
+ var onStepHeaderClick = (0, _react.useCallback)(function (event, step) {
224
+ if ((step.done || step.isDone || nonLinear && type === "dynamic") && step.show && !step.disabled) {
225
+ setSteps(function (prevSteps) {
226
+ return prevSteps.map(function (s) {
227
+ var stepIndex = prevSteps.findIndex(function (ps) {
228
+ return ps.name === s.name;
229
+ });
230
+ var targetIndex = prevSteps.findIndex(function (ps) {
231
+ return ps.name === step.name;
232
+ });
233
+ return _objectSpread(_objectSpread({}, s), {}, {
234
+ active: s.name === step.name,
235
+ isDone: type === "dynamic" ? stepIndex < targetIndex : stepIndex < targetIndex,
236
+ done: type === "dynamic" ? stepIndex < targetIndex : stepIndex < targetIndex || s.name === step.name && targetIndex > 0,
237
+ disabled: false,
238
+ // Ensure enableNext and isValid are preserved when activating a step
239
+ enableNext: s.name === step.name ? true : s.enableNext,
240
+ isValid: s.name === step.name ? true : s.isValid
241
+ });
242
+ });
243
+ });
244
+ }
245
+ }, [nonLinear, type]);
246
+ var handleStepClick = (0, _react.useCallback)(function (index) {
247
+ var step = visibleSteps[index];
248
+ if (step && step.show && !step.disabled) {
249
+ if (step.done || step.isDone) {
250
+ onStepHeaderClick({}, step);
251
+ }
252
+ }
253
+ }, [visibleSteps, nonLinear, onStepHeaderClick, type]);
254
+
255
+ // Step management functions
256
+ var updateStep = (0, _react.useCallback)(function (stepName, updates) {
257
+ setSteps(function (prevSteps) {
258
+ var stepIndex = prevSteps.findIndex(function (step) {
259
+ return step.name === stepName;
260
+ });
261
+ if (stepIndex === -1) return prevSteps;
262
+ var existing = prevSteps[stepIndex];
263
+ var hasChanges = Object.keys(updates).some(function (key) {
264
+ return existing[key] !== updates[key];
265
+ });
266
+ if (!hasChanges) return prevSteps;
267
+ var newSteps = (0, _toConsumableArray2["default"])(prevSteps);
268
+ newSteps[stepIndex] = _objectSpread(_objectSpread({}, existing), updates);
269
+ return newSteps;
270
+ });
271
+ }, []);
272
+
273
+ // Navigation functions
274
+ var _next = (0, _react.useCallback)(/*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee2() {
275
+ var eventName,
276
+ _currentStep$onSkip,
277
+ response,
278
+ _currentStep$onNext,
279
+ _response,
280
+ _args2 = arguments;
281
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
282
+ while (1) switch (_context2.prev = _context2.next) {
283
+ case 0:
284
+ eventName = _args2.length > 0 && _args2[0] !== undefined ? _args2[0] : "next";
285
+ if (currentStep) {
286
+ _context2.next = 3;
287
+ break;
288
+ }
289
+ return _context2.abrupt("return");
290
+ case 3:
291
+ if (!(eventName === "skip")) {
292
+ _context2.next = 13;
293
+ break;
294
+ }
295
+ response = (_currentStep$onSkip = currentStep.onSkip) === null || _currentStep$onSkip === void 0 ? void 0 : _currentStep$onSkip.call(currentStep, currentStep, currentStep, currentStepIndex);
296
+ if (!(response !== undefined)) {
297
+ _context2.next = 10;
298
+ break;
299
+ }
300
+ _context2.next = 8;
301
+ return (0, _utils.handleNavigation)(response, function () {
302
+ return (0, _utils.extendNextFn)(currentStep, currentStepIndex, visibleSteps, setSteps);
303
+ });
304
+ case 8:
305
+ _context2.next = 11;
306
+ break;
307
+ case 10:
308
+ (0, _utils.extendNextFn)(currentStep, currentStepIndex, visibleSteps, setSteps);
309
+ case 11:
310
+ _context2.next = 24;
311
+ break;
312
+ case 13:
313
+ if (!(currentStep.isValid && eventName === "next")) {
314
+ _context2.next = 23;
315
+ break;
316
+ }
317
+ _response = (_currentStep$onNext = currentStep.onNext) === null || _currentStep$onNext === void 0 ? void 0 : _currentStep$onNext.call(currentStep, currentStep, currentStep, currentStepIndex);
318
+ if (!(_response !== undefined)) {
319
+ _context2.next = 20;
320
+ break;
321
+ }
322
+ _context2.next = 18;
323
+ return (0, _utils.handleNavigation)(_response, function () {
324
+ return (0, _utils.extendNextFn)(currentStep, currentStepIndex, visibleSteps, setSteps);
325
+ });
326
+ case 18:
327
+ _context2.next = 21;
328
+ break;
329
+ case 20:
330
+ (0, _utils.extendNextFn)(currentStep, currentStepIndex, visibleSteps, setSteps);
331
+ case 21:
332
+ _context2.next = 24;
333
+ break;
334
+ case 23:
335
+ if (enablenext && !currentStep.isValid) {
336
+ console.warn("Cannot proceed: current step is invalid");
337
+ } else {
338
+ (0, _utils.extendNextFn)(currentStep, currentStepIndex, visibleSteps, setSteps);
339
+ }
340
+ case 24:
341
+ case "end":
342
+ return _context2.stop();
343
+ }
344
+ }, _callee2);
345
+ })), [currentStep, currentStepIndex, visibleSteps, enablenext]);
346
+ var prev = (0, _react.useCallback)(/*#__PURE__*/(0, _asyncToGenerator2["default"])(/*#__PURE__*/_regenerator["default"].mark(function _callee3() {
347
+ var _currentStep$onPrev;
348
+ var response;
349
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
350
+ while (1) switch (_context3.prev = _context3.next) {
351
+ case 0:
352
+ if (currentStep) {
353
+ _context3.next = 2;
354
+ break;
355
+ }
356
+ return _context3.abrupt("return");
357
+ case 2:
358
+ response = (_currentStep$onPrev = currentStep.onPrev) === null || _currentStep$onPrev === void 0 ? void 0 : _currentStep$onPrev.call(currentStep, currentStep, currentStep, currentStepIndex);
359
+ if (!(response !== undefined)) {
360
+ _context3.next = 8;
361
+ break;
362
+ }
363
+ _context3.next = 6;
364
+ return (0, _utils.handleNavigation)(response, function () {
365
+ return (0, _utils.extendPrevFn)(currentStep, currentStepIndex, visibleSteps, setSteps);
366
+ });
367
+ case 6:
368
+ _context3.next = 9;
369
+ break;
370
+ case 8:
371
+ (0, _utils.extendPrevFn)(currentStep, currentStepIndex, visibleSteps, setSteps);
372
+ case 9:
373
+ case "end":
374
+ return _context3.stop();
375
+ }
376
+ }, _callee3);
377
+ })), [currentStep, currentStepIndex, visibleSteps]);
378
+ var registerStep = (0, _react.useCallback)(function (stepData) {
379
+ setSteps(function (prevSteps) {
380
+ var existingIndex = prevSteps.findIndex(function (step) {
381
+ return step.name === stepData.name;
382
+ });
383
+ if (existingIndex >= 0) {
384
+ var existing = prevSteps[existingIndex];
385
+ var hasChanges = Object.keys(stepData).some(function (key) {
386
+ return existing[key] !== stepData[key];
387
+ });
388
+ if (hasChanges) {
389
+ var newSteps = (0, _toConsumableArray2["default"])(prevSteps);
390
+ newSteps[existingIndex] = _objectSpread(_objectSpread({}, existing), stepData);
391
+ return newSteps;
392
+ }
393
+ return prevSteps;
394
+ }
395
+ return [].concat((0, _toConsumableArray2["default"])(prevSteps), [stepData]);
396
+ });
397
+ }, []);
398
+ var _skip = (0, _react.useCallback)(function () {
399
+ _next("skip");
400
+ }, [_next]);
401
+ var _done = (0, _react.useCallback)(function () {
402
+ if (currentStep) {
403
+ updateStep(currentStep.name, {
404
+ isDone: true,
405
+ done: true
406
+ });
407
+ if (onDone) {
408
+ onDone(currentStep, steps);
409
+ }
410
+ }
411
+ }, [currentStep, updateStep, onDone, steps]);
412
+ var _cancel = (0, _react.useCallback)(function () {
413
+ if (onCancel) {
414
+ onCancel(currentStep, steps);
415
+ }
416
+ }, [onCancel, steps]);
417
+ var _gotoStep = (0, _react.useCallback)(function (step) {
418
+ var _targetStep;
419
+ var gotoStepIndex;
420
+ var targetStep = null;
421
+ if (typeof step === "string") {
422
+ gotoStepIndex = steps.map(function (s) {
423
+ return s.name;
424
+ }).indexOf(step);
425
+ if (gotoStepIndex === -1) {
426
+ console.error("Could not find step '".concat(step, "'"));
427
+ return;
428
+ }
429
+ targetStep = steps[gotoStepIndex];
430
+ } else if (typeof step === "number" && step >= 0) {
431
+ gotoStepIndex = step;
432
+ targetStep = (0, _utils.getStepByIndex)(step, visibleSteps);
433
+ } else {
434
+ console.error("Invalid step name or index provided");
435
+ return;
436
+ }
437
+ if ((_targetStep = targetStep) !== null && _targetStep !== void 0 && _targetStep.show) {
438
+ onStepHeaderClick({}, targetStep);
439
+ } else {
440
+ console.error("The gotoStep function cannot navigate to hidden steps");
441
+ }
442
+ }, [steps, visibleSteps, onStepHeaderClick]);
443
+
444
+ // Initialize default step
445
+ var setDefaultStep = (0, _react.useCallback)(function (step) {
446
+ if (step && step.show) {
447
+ setSteps(function (prevSteps) {
448
+ return prevSteps.map(function (s, index) {
449
+ var stepIndex = prevSteps.findIndex(function (ps) {
450
+ return ps.name === s.name;
451
+ });
452
+ var defaultIndex = prevSteps.findIndex(function (ps) {
453
+ return ps.name === step.name;
454
+ });
455
+ return _objectSpread(_objectSpread({}, s), {}, {
456
+ active: s.name === step.name,
457
+ isDone: false,
458
+ done: stepIndex < defaultIndex,
459
+ isInitialized: s.name === step.name ? true : s.isInitialized,
460
+ // Ensure enableNext and isValid are preserved for the active step
461
+ enableNext: s.name === step.name ? true : s.enableNext,
462
+ isValid: s.name === step.name ? true : s.isValid
463
+ });
464
+ });
465
+ });
466
+ setTimeout(function () {
467
+ if (step.onLoad) {
468
+ var stepIndex = visibleSteps.findIndex(function (s) {
469
+ return s.name === step.name;
470
+ });
471
+ step.onLoad(step, stepIndex);
472
+ }
473
+ }, 100);
474
+ } else {
475
+ var nextValidStep = (0, _utils.getNextValidStep)(0, visibleSteps);
476
+ if (nextValidStep) {
477
+ setDefaultStep(nextValidStep);
478
+ }
479
+ }
480
+ }, [visibleSteps]);
481
+ var updateListener = _react["default"].useCallback(function () {
482
+ if (listener && typeof listener.onChange === "function") {
483
+ listener.onChange(name, {
484
+ hasNextStep: function hasNextStep() {
485
+ return _hasNextStep;
486
+ },
487
+ hasPreviousStep: function hasPreviousStep() {
488
+ return hasPrevStep;
489
+ },
490
+ hasNoNextStep: function hasNoNextStep() {
491
+ return showDoneBtn;
492
+ },
493
+ next: function next() {
494
+ return _next("next");
495
+ },
496
+ previous: function previous() {
497
+ return prev();
498
+ },
499
+ done: function done() {
500
+ return _done();
501
+ },
502
+ cancel: function cancel() {
503
+ return _cancel();
504
+ },
505
+ skip: function skip() {
506
+ return _skip();
507
+ },
508
+ disableNext: function disableNext() {
509
+ return !enableNext;
510
+ },
511
+ disablePrevious: function disablePrevious() {
512
+ return !enablePrev;
513
+ },
514
+ disableDone: function disableDone() {
515
+ return !enableDone;
516
+ },
517
+ cancelable: cancelable,
518
+ nextbtnlabel: nextbtnlabel,
519
+ previousbtnlabel: previousbtnlabel,
520
+ donebtnlabel: donebtnlabel,
521
+ cancelbtnlabel: cancelbtnlabel,
522
+ actionsalignment: actionsalignment,
523
+ skippable: currentStep === null || currentStep === void 0 ? void 0 : currentStep.enableskip,
524
+ getCurrentStepIndex: function getCurrentStepIndex() {
525
+ return currentStepIndex;
526
+ },
527
+ gotoStep: function gotoStep(step) {
528
+ return _gotoStep(step);
529
+ },
530
+ isFirstStep: isFirstStep,
531
+ isLastStep: isLastStep
532
+ });
533
+ }
534
+ }, [_hasNextStep, hasPrevStep, showDoneBtn, enableNext, enablePrev, enableDone, cancelable, currentStep === null || currentStep === void 0 ? void 0 : currentStep.enableskip, nextbtnlabel, previousbtnlabel, donebtnlabel, cancelbtnlabel, actionsalignment, currentStepIndex]);
535
+ (0, _react.useEffect)(function () {
536
+ updateListener();
537
+ }, [updateListener]);
538
+
539
+ // Initialize default step for STATIC wizards only
540
+ (0, _react.useEffect)(function () {
541
+ if (steps.length > 0 && !isInitialized && visibleSteps.length > 0 && type !== "dynamic") {
542
+ var defaultStepRef = null;
543
+ if (defaultstep !== "none") {
544
+ defaultStepRef = (0, _utils.getStepByName)(defaultstep, steps);
545
+ } else if (defaultstepindex >= 0 && defaultstepindex < visibleSteps.length) {
546
+ // CHANGED: Removed type === "dynamic" check and added bounds checking
547
+ // REASON: This effect only runs for static wizards, and bounds checking prevents runtime errors
548
+ defaultStepRef = (0, _utils.getStepByIndex)(defaultstepindex, visibleSteps);
549
+ } else {
550
+ defaultStepRef = (0, _utils.getNextValidStep)(0, visibleSteps);
551
+ }
552
+ if (defaultStepRef) {
553
+ setDefaultStep(defaultStepRef);
554
+ setIsInitialized(true);
555
+ }
556
+ }
557
+ }, [steps.length, visibleSteps.length, defaultstep, defaultstepindex, type, isInitialized, setDefaultStep, visibleSteps]);
558
+ (0, _react.useEffect)(function () {
559
+ if (currentStep !== null && currentStep !== void 0 && currentStep.onLoad) {
560
+ currentStep === null || currentStep === void 0 || currentStep.onLoad(currentStep, currentStepIndex);
561
+ }
562
+ }, [currentStep === null || currentStep === void 0 ? void 0 : currentStep.onLoad]);
563
+
564
+ // Handle dataset changes for dynamic wizard
565
+ (0, _react.useEffect)(function () {
566
+ if (type === "dynamic" && dataset.length > 0) {
567
+ var dynamicSteps = createDynamicSteps(dataset);
568
+ if (defaultstepindex >= 0 && defaultstepindex < dynamicSteps.length) {
569
+ var defaultStep = dynamicSteps[defaultstepindex];
570
+ if (defaultStep && defaultStep.show) {
571
+ var stepsWithDefault = dynamicSteps.map(function (step) {
572
+ return _objectSpread(_objectSpread({}, step), {}, {
573
+ active: step.name === defaultStep.name,
574
+ isDone: false,
575
+ done: step.dynamicStepIndex !== undefined ? step.dynamicStepIndex < defaultstepindex : false
576
+ });
577
+ });
578
+ setSteps(stepsWithDefault);
579
+ setIsInitialized(true); // CHANGED: Mark as initialized immediately
580
+ } else {
581
+ setSteps(dynamicSteps);
582
+ }
583
+ } else {
584
+ setSteps(dynamicSteps);
585
+ }
586
+ }
587
+ }, [type, dataset, createDynamicSteps, defaultstepindex]);
588
+
589
+ // Context value
590
+ var contextValue = (0, _react.useMemo)(function () {
591
+ return {
592
+ steps: steps,
593
+ currentStep: currentStep,
594
+ currentStepIndex: currentStepIndex,
595
+ hasNextStep: _hasNextStep,
596
+ hasPrevStep: hasPrevStep,
597
+ showDoneBtn: showDoneBtn || false,
598
+ enableNext: enableNext || false,
599
+ enablePrev: enablePrev || false,
600
+ enableDone: enableDone || false,
601
+ isFirstStep: isFirstStep,
602
+ isLastStep: isLastStep,
603
+ registerStep: registerStep,
604
+ updateStep: updateStep,
605
+ next: _next,
606
+ prev: prev,
607
+ skip: _skip,
608
+ done: _done,
609
+ cancel: _cancel,
610
+ gotoStep: _gotoStep,
611
+ onStepHeaderClick: onStepHeaderClick,
612
+ addStep: function addStep() {
613
+ return [];
614
+ }
615
+ };
616
+ }, [steps, currentStep, currentStepIndex, _hasNextStep, hasPrevStep, showDoneBtn, enableNext, enablePrev, enableDone, isFirstStep, isLastStep, registerStep, updateStep, _next, prev, _skip, _done, _cancel, _gotoStep, onStepHeaderClick]);
617
+
618
+ // Extract wizard steps from children
619
+ var wizardSteps = [];
620
+ _react["default"].Children.forEach(children, function (child) {
621
+ if (/*#__PURE__*/(0, _react.isValidElement)(child) && child.type === _wizardStep["default"]) {
622
+ wizardSteps.push(child);
623
+ }
624
+ });
625
+
626
+ // If no data in dynamic mode, show no data message
627
+ if (type === "dynamic" && (!dataset || dataset.length === 0)) {
628
+ return __jsx("div", null, nodatamessage);
629
+ }
630
+ return __jsx(_WizardContext["default"].Provider, {
631
+ value: contextValue
632
+ }, __jsx(_material.Box, {
633
+ className: (0, _clsx["default"])(DEFAULT_CLS, className, computedStepClass, {
634
+ classic: className === null || className === void 0 ? void 0 : className.includes("classic"),
635
+ number: className === null || className === void 0 ? void 0 : className.includes("number"),
636
+ dottedstepper: className === null || className === void 0 ? void 0 : className.includes("dottedstepper"),
637
+ "text-inline": className === null || className === void 0 ? void 0 : className.includes("text-inline"),
638
+ iconstepper: className === null || className === void 0 ? void 0 : className.includes("iconstepper")
639
+ }),
640
+ style: _objectSpread(_objectSpread({}, styles), {}, {
641
+ width: width,
642
+ height: height
643
+ })
644
+ }, __jsx(_material.Box, {
645
+ className: "app-wizard-heading"
646
+ }, __jsx(_material.Stepper, {
647
+ activeStep: currentStepIndex,
648
+ orientation: orientation,
649
+ alternativeLabel: alternativeLabel,
650
+ nonLinear: nonLinear,
651
+ connector: connector,
652
+ className: (0, _clsx["default"])("app-wizard-steps", computedStepClass, className, stepstyle === "justified" ? "nav-justified" : "")
653
+ }, steps.map(function (step, index) {
654
+ // Calculate the visible index by counting only visible steps before this one
655
+ var visibleIndex = steps.slice(0, index).filter(function (s) {
656
+ return s.show !== false && s.show !== "false";
657
+ }).length;
658
+ var isCurrentStep = currentStepIndex === visibleIndex && step.show !== false && step.show !== "false";
659
+ return __jsx(_WizardStep.WizardStep, {
660
+ key: step.name,
661
+ step: step,
662
+ index: index,
663
+ className: className,
664
+ nonLinear: nonLinear,
665
+ orientation: orientation,
666
+ onStepClick: handleStepClick,
667
+ current: isCurrentStep
668
+ });
669
+ }))), (orientation === "horizontal" || type === "dynamic") && __jsx(_material.Box, {
670
+ className: BODY_CLASS
671
+ }, wizardMessage.caption && __jsx(_material.Box, {
672
+ component: "p"
673
+ }, __jsx(_material.Typography, {
674
+ variant: "body2",
675
+ color: wizardMessage.type === "error" ? "error" : "textSecondary"
676
+ }, wizardMessage.caption)), steps.map(function (step, index) {
677
+ return __jsx("div", {
678
+ key: step.name,
679
+ ref: function ref(el) {
680
+ if (el) {
681
+ var formElement = el.querySelector("form");
682
+ if (formElement) {
683
+ formRefs.current[step.name] = formElement;
684
+ }
685
+ }
686
+ },
687
+ className: (0, _clsx["default"])("app-wizard-step-container", {
688
+ current: step.active
689
+ })
690
+ }, step.haveForm ? __jsx("div", {
691
+ className: (0, _clsx["default"])("app-wizard-step-content", {
692
+ current: step.active
693
+ })
694
+ }, step.render ? step.render(step, index) : step.children) : __jsx(_form["default"], {
695
+ name: step.name,
696
+ className: (0, _clsx["default"])("app-wizard-step-content", {
697
+ current: step.active
698
+ }),
699
+ listener: listener,
700
+ isInsideWizard: true
701
+ }, step.render ? step.render(step, index) : step.children));
702
+ })), children, type === "static" && wizardSteps.map(function (step, index) {
703
+ var _step$props;
704
+ return /*#__PURE__*/(0, _react.cloneElement)(step, {
705
+ key: ((_step$props = step.props) === null || _step$props === void 0 ? void 0 : _step$props.name) || index
706
+ });
707
+ })));
708
+ });
709
+ WmWizard.displayName = "WmWizard";
710
+ var _default = exports["default"] = (0, _withBaseWrapper.withBaseWrapper)(WmWizard);