robobyte-front-builder 1.0.19 → 1.0.23

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 (520) hide show
  1. package/INTEGRATION.md +1586 -0
  2. package/README.md +928 -0
  3. package/RoboByteBuilder_User_Manual.docx +0 -0
  4. package/next.config.js +19 -48
  5. package/package.json +42 -86
  6. package/src/context/BuilderContext.jsx +191 -7
  7. package/src/context/SystemContext.js +2 -2
  8. package/src/hooks/useGlobalStore.js +36 -0
  9. package/src/hooks/useTimerEngine.js +54 -0
  10. package/src/lib/index.js +11 -3
  11. package/src/lib/layouts/BlankLayout.jsx +13 -0
  12. package/src/lib/providers/RoboByteFrontBuilderProvider.jsx +61 -7
  13. package/src/lib/themes/builderTheme.js +41 -0
  14. package/src/pages/_app.js +32 -134
  15. package/src/pages/api/ai.js +107 -0
  16. package/src/pages/builders/report/index.js +1 -0
  17. package/src/pages/builders/report/list/index.js +1 -0
  18. package/src/pages/builders/report/viewer/index.js +1 -0
  19. package/src/pages/index.js +88 -37
  20. package/src/pages/printBuilder/index.jsx +263 -0
  21. package/src/pages/printBuilder/layouts/index.jsx +298 -0
  22. package/src/pages/reportModule/reportBuilder/index.js +8 -6
  23. package/src/pages/reportModule/reportBuilder/reportViewer/index.js +92 -25
  24. package/src/pages/reportModule/reportBuilder/reports/index.js +3 -5
  25. package/src/pages/reportModule/reportBuilder/reportsPermissions/index.js +2 -3
  26. package/src/pages/viewBuilder/index.jsx +117 -32
  27. package/src/pages/viewBuilder/views/index.js +3 -3
  28. package/src/pages/viewer/[id]/index.js +2 -1
  29. package/src/services/DeleteService.js +31 -60
  30. package/src/services/Endpoints/PrintLayoutEndpoints.js +42 -0
  31. package/src/services/Endpoints/ReportBuilderEndpoints.js +7 -7
  32. package/src/services/Endpoints.js +2 -0
  33. package/src/services/GetService.js +33 -54
  34. package/src/services/PatchService.js +38 -65
  35. package/src/services/PostService.js +37 -63
  36. package/src/services/UpdateService.js +39 -65
  37. package/src/services/builderHelper/actionExecutor.js +141 -25
  38. package/src/services/builderHelper/builderHelper.js +92 -0
  39. package/src/services/builderHelper/colorSchema.js +95 -0
  40. package/src/services/builderHelper/iconResolver.js +50 -0
  41. package/src/services/builderHelper/jsExecutor.js +212 -46
  42. package/src/services/builderHelper/nodeFactory.js +32 -15
  43. package/src/services/builderHelper/numberFormat.js +123 -0
  44. package/src/services/builderHelper/resolveProps.js +73 -4
  45. package/src/services/builderHelper/thresholdEngine.js +77 -0
  46. package/src/services/builderHelper/tree.js +31 -0
  47. package/src/services/components/agGridAutoComplete.js +5 -9
  48. package/src/services/config.js +9 -1
  49. package/src/services/globalStore.js +80 -0
  50. package/src/services/helper/multiSelectEditor.js +5 -9
  51. package/src/services/helper/multiSelectEditorByBuilder.js +5 -9
  52. package/src/services/reportData/fetchReportData.js +69 -28
  53. package/src/services/routerRef.js +35 -0
  54. package/src/services/sessionLog.js +171 -0
  55. package/src/views/ConfirmDialog.js +2 -2
  56. package/src/views/builder/JSEditor.js +105 -107
  57. package/src/views/builder/SessionLogDialog.jsx +350 -0
  58. package/src/views/builder/UnsavedChangesGuard.jsx +103 -0
  59. package/src/views/builder/inspector/Inspector.jsx +6 -9
  60. package/src/views/builder/inspector/Tabs/ComponentActionsTab.jsx +7 -13
  61. package/src/views/builder/inspector/Tabs/MainTab.jsx +143 -25
  62. package/src/views/builder/inspector/Tabs/RulesTab.jsx +9 -24
  63. package/src/views/builder/inspector/Tabs/StyleTab.jsx +9 -24
  64. package/src/views/builder/inspector/definitions/autocomplete/main.js +4 -6
  65. package/src/views/builder/inspector/definitions/banner/actions.js +7 -0
  66. package/src/views/builder/inspector/definitions/banner/main.js +22 -0
  67. package/src/views/builder/inspector/definitions/banner/rules.js +1 -0
  68. package/src/views/builder/inspector/definitions/banner/style.js +1 -0
  69. package/src/views/builder/inspector/definitions/breadcrumb/main.js +43 -6
  70. package/src/views/builder/inspector/definitions/button/main.js +11 -12
  71. package/src/views/builder/inspector/definitions/button/style.js +18 -30
  72. package/src/views/builder/inspector/definitions/checkbox/actions.js +3 -1
  73. package/src/views/builder/inspector/definitions/checkbox/main.js +4 -6
  74. package/src/views/builder/inspector/definitions/common/main.js +13 -2
  75. package/src/views/builder/inspector/definitions/dataGrid/main.js +23 -0
  76. package/src/views/builder/inspector/definitions/dataTableViewer/main.js +46 -0
  77. package/src/views/builder/inspector/definitions/datepicker/actions.js +3 -1
  78. package/src/views/builder/inspector/definitions/datepicker/main.js +6 -14
  79. package/src/views/builder/inspector/definitions/dialog/main.js +36 -0
  80. package/src/views/builder/inspector/definitions/dropdown/main.js +5 -8
  81. package/src/views/builder/inspector/definitions/excelUpload/actions.js +23 -0
  82. package/src/views/builder/inspector/definitions/excelUpload/main.js +17 -0
  83. package/src/views/builder/inspector/definitions/excelUpload/rules.js +1 -0
  84. package/src/views/builder/inspector/definitions/excelUpload/style.js +45 -0
  85. package/src/views/builder/inspector/definitions/header/main.js +10 -1
  86. package/src/views/builder/inspector/definitions/index.js +106 -19
  87. package/src/views/builder/inspector/definitions/input/actions.js +4 -1
  88. package/src/views/builder/inspector/definitions/input/main.js +20 -11
  89. package/src/views/builder/inspector/definitions/kpi/avatarGroup.js +22 -0
  90. package/src/views/builder/inspector/definitions/kpi/badge.js +17 -0
  91. package/src/views/builder/inspector/definitions/kpi/bulletChart.js +47 -0
  92. package/src/views/builder/inspector/definitions/kpi/chart.js +55 -0
  93. package/src/views/builder/inspector/definitions/kpi/colorScale.js +60 -0
  94. package/src/views/builder/inspector/definitions/kpi/comparisonBars.js +41 -0
  95. package/src/views/builder/inspector/definitions/kpi/countdown.js +46 -0
  96. package/src/views/builder/inspector/definitions/kpi/donut.js +51 -0
  97. package/src/views/builder/inspector/definitions/kpi/funnel.js +25 -0
  98. package/src/views/builder/inspector/definitions/kpi/gauge.js +39 -0
  99. package/src/views/builder/inspector/definitions/kpi/heatmapGrid.js +96 -0
  100. package/src/views/builder/inspector/definitions/kpi/iconBox.js +20 -0
  101. package/src/views/builder/inspector/definitions/kpi/metric.js +45 -0
  102. package/src/views/builder/inspector/definitions/kpi/rating.js +27 -0
  103. package/src/views/builder/inspector/definitions/kpi/statusDot.js +18 -0
  104. package/src/views/builder/inspector/definitions/kpi/stepStage.js +65 -0
  105. package/src/views/builder/inspector/definitions/kpi/tagList.js +32 -0
  106. package/src/views/builder/inspector/definitions/kpi/timeline.js +80 -0
  107. package/src/views/builder/inspector/definitions/kpi/trend.js +20 -0
  108. package/src/views/builder/inspector/definitions/label/main.js +10 -1
  109. package/src/views/builder/inspector/definitions/layout/main.js +27 -3
  110. package/src/views/builder/inspector/definitions/number/main.js +6 -14
  111. package/src/views/builder/inspector/definitions/pageNumber/main.js +21 -0
  112. package/src/views/builder/inspector/definitions/popover/main.js +71 -0
  113. package/src/views/builder/inspector/definitions/radio/main.js +5 -8
  114. package/src/views/builder/inspector/definitions/repeater/main.js +31 -0
  115. package/src/views/builder/inspector/definitions/reportViewer/main.js +28 -1
  116. package/src/views/builder/inspector/definitions/richtext/main.js +5 -8
  117. package/src/views/builder/inspector/definitions/signature/main.js +4 -1
  118. package/src/views/builder/inspector/definitions/tag/main.js +5 -8
  119. package/src/views/builder/inspector/definitions/textarea/actions.js +4 -1
  120. package/src/views/builder/inspector/definitions/textarea/main.js +5 -7
  121. package/src/views/builder/inspector/definitions/time/main.js +5 -8
  122. package/src/views/builder/inspector/definitions/toggle/main.js +5 -19
  123. package/src/views/builder/inspector/definitions/treeView/main.js +61 -0
  124. package/src/views/builder/inspector/definitions/viewRenderer/main.js +53 -0
  125. package/src/views/builder/inspector/definitions/wizard/main.js +68 -0
  126. package/src/views/builder/inspector/definitions/wizard-step/main.js +25 -0
  127. package/src/views/builder/inspector/fields/ActionsConfigEditor.jsx +426 -0
  128. package/src/views/builder/inspector/fields/ColorSchemaField.jsx +140 -0
  129. package/src/views/builder/inspector/fields/ColumnFunctionEditor.jsx +238 -0
  130. package/src/views/builder/inspector/fields/ColumnMappingEditor.jsx +105 -0
  131. package/src/views/builder/inspector/fields/ColumnsConfigEditor.jsx +506 -0
  132. package/src/views/builder/inspector/fields/DonutRingsEditorField.jsx +337 -0
  133. package/src/views/builder/inspector/fields/ExtraColsEditor.jsx +618 -0
  134. package/src/views/builder/inspector/fields/FunctionHelpPopover.jsx +295 -0
  135. package/src/views/builder/inspector/fields/IconEditor.jsx +64 -0
  136. package/src/views/builder/inspector/fields/KpiActionField.jsx +223 -0
  137. package/src/views/builder/inspector/fields/MarkersEditorField.jsx +173 -0
  138. package/src/views/builder/inspector/fields/SelectEditor.jsx +9 -5
  139. package/src/views/builder/inspector/fields/SeriesEditorField.jsx +363 -0
  140. package/src/views/builder/inspector/fields/TableColumnsEditor.jsx +104 -0
  141. package/src/views/builder/inspector/fields/ThresholdsEditor.jsx +247 -0
  142. package/src/views/builder/inspector/fields/ValueFunctionsRefPanel.jsx +217 -0
  143. package/src/views/builder/inspector/fields/columnEditorShared.jsx +217 -0
  144. package/src/views/builder/sidebar/Sidebar.jsx +4 -2
  145. package/src/views/builder/sidebar/SidebarTabs.jsx +28 -17
  146. package/src/views/builder/sidebar/tabs/ActionsTab.jsx +7 -3
  147. package/src/views/builder/sidebar/tabs/AiTab/AiPreviewDialog.jsx +193 -0
  148. package/src/views/builder/sidebar/tabs/AiTab/aiProvider.js +53 -0
  149. package/src/views/builder/sidebar/tabs/AiTab/index.jsx +409 -0
  150. package/src/views/builder/sidebar/tabs/AiTab/schemaTransformer.js +167 -0
  151. package/src/views/builder/sidebar/tabs/AiTab/schemaValidator.js +64 -0
  152. package/src/views/builder/sidebar/tabs/AiTab/systemPrompt.js +1151 -0
  153. package/src/views/builder/sidebar/tabs/AiTab/trainingExport.js +131 -0
  154. package/src/views/builder/sidebar/tabs/Components/ComponentsTab.jsx +31 -31
  155. package/src/views/builder/sidebar/tabs/Components/componentCatalog.js +43 -21
  156. package/src/views/builder/sidebar/tabs/Components/printComponentCatalog.js +81 -0
  157. package/src/views/builder/sidebar/tabs/TimersTab.jsx +338 -0
  158. package/src/views/builder/sidebar/tabs/TreeTab.jsx +13 -4
  159. package/src/views/builder/sidebar/tabs/ViewTab.jsx +173 -13
  160. package/src/views/builder/viewer/AdornedLabel.jsx +82 -0
  161. package/src/views/builder/viewer/ComponentRenderer.jsx +98 -24
  162. package/src/views/builder/viewer/DialogsZone.jsx +259 -0
  163. package/src/views/builder/viewer/FieldLabel.jsx +106 -0
  164. package/src/views/builder/viewer/PrintDialog.jsx +481 -0
  165. package/src/views/builder/viewer/ProductionViewer.jsx +80 -5
  166. package/src/views/builder/viewer/Viewer.jsx +106 -8
  167. package/src/views/builder/viewer/ViewerComponentWrapper.jsx +70 -9
  168. package/src/views/builder/viewer/ViewerToolbar.jsx +285 -56
  169. package/src/views/builder/viewer/renderers/AutoCompleteRenderer.jsx +26 -22
  170. package/src/views/builder/viewer/renderers/AvatarGroupRenderer.jsx +112 -0
  171. package/src/views/builder/viewer/renderers/BadgeRenderer.jsx +79 -0
  172. package/src/views/builder/viewer/renderers/BannerRenderer.jsx +62 -0
  173. package/src/views/builder/viewer/renderers/BreadcrumbRenderer.jsx +203 -15
  174. package/src/views/builder/viewer/renderers/BulletChartRenderer.jsx +147 -0
  175. package/src/views/builder/viewer/renderers/ButtonRenderer.jsx +98 -39
  176. package/src/views/builder/viewer/renderers/CardRenderer.jsx +1 -1
  177. package/src/views/builder/viewer/renderers/ChartRenderer.jsx +388 -0
  178. package/src/views/builder/viewer/renderers/CheckboxRenderer.jsx +17 -9
  179. package/src/views/builder/viewer/renderers/ColorScaleRenderer.jsx +300 -0
  180. package/src/views/builder/viewer/renderers/ComparisonBarsRenderer.jsx +133 -0
  181. package/src/views/builder/viewer/renderers/ContainerRenderer.jsx +3 -1
  182. package/src/views/builder/viewer/renderers/CountdownRenderer.jsx +249 -0
  183. package/src/views/builder/viewer/renderers/DataGridRenderer.jsx +380 -0
  184. package/src/views/builder/viewer/renderers/DataTableViewerRenderer.jsx +240 -0
  185. package/src/views/builder/viewer/renderers/DatePickerRenderer.jsx +25 -24
  186. package/src/views/builder/viewer/renderers/DialogRenderer.jsx +327 -0
  187. package/src/views/builder/viewer/renderers/DividerRenderer.jsx +1 -1
  188. package/src/views/builder/viewer/renderers/DonutRenderer.jsx +294 -0
  189. package/src/views/builder/viewer/renderers/DropdownRenderer.jsx +36 -44
  190. package/src/views/builder/viewer/renderers/ExcelUploadRenderer.jsx +639 -0
  191. package/src/views/builder/viewer/renderers/FunnelRenderer.jsx +93 -0
  192. package/src/views/builder/viewer/renderers/GaugeRenderer.jsx +159 -0
  193. package/src/views/builder/viewer/renderers/HeaderRenderer.jsx +31 -9
  194. package/src/views/builder/viewer/renderers/HeatmapGridRenderer.jsx +432 -0
  195. package/src/views/builder/viewer/renderers/IconBoxRenderer.jsx +59 -0
  196. package/src/views/builder/viewer/renderers/ImageRenderer.jsx +1 -1
  197. package/src/views/builder/viewer/renderers/InputRenderer.jsx +75 -18
  198. package/src/views/builder/viewer/renderers/LabelRenderer.jsx +35 -9
  199. package/src/views/builder/viewer/renderers/LayoutCellRenderer.jsx +102 -40
  200. package/src/views/builder/viewer/renderers/LayoutContextMenu.jsx +8 -8
  201. package/src/views/builder/viewer/renderers/LayoutRenderer.jsx +48 -6
  202. package/src/views/builder/viewer/renderers/LinkRenderer.jsx +1 -1
  203. package/src/views/builder/viewer/renderers/MenuRenderer.jsx +2 -2
  204. package/src/views/builder/viewer/renderers/MetricRenderer.jsx +80 -0
  205. package/src/views/builder/viewer/renderers/NumberFormatRenderer.jsx +21 -30
  206. package/src/views/builder/viewer/renderers/PageNumberRenderer.jsx +76 -0
  207. package/src/views/builder/viewer/renderers/PopoverRenderer.jsx +350 -0
  208. package/src/views/builder/viewer/renderers/ProgressCircleRenderer.jsx +1 -1
  209. package/src/views/builder/viewer/renderers/ProgressLineRenderer.jsx +1 -1
  210. package/src/views/builder/viewer/renderers/RadioGroupRenderer.jsx +28 -39
  211. package/src/views/builder/viewer/renderers/RatingRenderer.jsx +80 -0
  212. package/src/views/builder/viewer/renderers/RepeaterRenderer.jsx +297 -38
  213. package/src/views/builder/viewer/renderers/ReportViewerRenderer.jsx +263 -5
  214. package/src/views/builder/viewer/renderers/RichTextRenderer.jsx +60 -66
  215. package/src/views/builder/viewer/renderers/RowActionsCell.jsx +308 -0
  216. package/src/views/builder/viewer/renderers/SignatureRenderer.jsx +33 -62
  217. package/src/views/builder/viewer/renderers/StatusDotRenderer.jsx +75 -0
  218. package/src/views/builder/viewer/renderers/StepStageRenderer.jsx +348 -0
  219. package/src/views/builder/viewer/renderers/TagListRenderer.jsx +115 -0
  220. package/src/views/builder/viewer/renderers/TagPickerRenderer.jsx +31 -45
  221. package/src/views/builder/viewer/renderers/TextAreaRenderer.jsx +25 -18
  222. package/src/views/builder/viewer/renderers/TextRenderer.jsx +7 -1
  223. package/src/views/builder/viewer/renderers/TimePickerRenderer.jsx +25 -24
  224. package/src/views/builder/viewer/renderers/TimelineRenderer.jsx +525 -0
  225. package/src/views/builder/viewer/renderers/ToggleRenderer.jsx +21 -27
  226. package/src/views/builder/viewer/renderers/TreeViewRenderer.jsx +832 -0
  227. package/src/views/builder/viewer/renderers/TrendRenderer.jsx +66 -0
  228. package/src/views/builder/viewer/renderers/ViewRendererRenderer.jsx +315 -0
  229. package/src/views/builder/viewer/renderers/WizardRenderer.jsx +380 -64
  230. package/src/views/builder/viewer/renderers/WizardStepRenderer.jsx +21 -12
  231. package/src/views/builder/viewer/renderers/dataGridComponents.jsx +824 -0
  232. package/src/views/customFilter/CustomFilterDialog.js +1023 -660
  233. package/src/views/customFilter/FixedFilterDialog.js +649 -0
  234. package/src/views/customFilter/SearchFilterDialog.js +248 -0
  235. package/src/views/genericTable/BuilderExpressionParams.js +3 -3
  236. package/src/views/genericTable/ColumnConfiguratorDialog.js +33 -24
  237. package/src/views/genericTable/FixedFilterDialog.js +3 -2
  238. package/src/views/genericTable/FormattingSettingsDialog.js +8 -3
  239. package/src/views/genericTable/SGrid.js +821 -448
  240. package/src/views/genericTable/SearchFilterDialog.js +3 -2
  241. package/src/views/genericTable/cellEditors/autocompleteEditor.js +5 -9
  242. package/src/views/genericTable/convertStringFunctions.js +274 -138
  243. package/src/views/genericTable/statusBar/rowCountStatusBar.js +3 -1
  244. package/src/views/genericTable/updateRefHelpers.js +9 -6
  245. package/src/views/printBuilder/PrintBuilderViewer.jsx +627 -0
  246. package/src/views/printBuilder/PrintPreviewCanvas.jsx +157 -0
  247. package/src/views/rolePermissions/UpdateReportPermissionDialog.js +3 -2
  248. package/src/@core/components/auth/AclGuard.js +0 -55
  249. package/src/@core/components/auth/AuthGuard.js +0 -40
  250. package/src/@core/components/auth/GuestGuard.js +0 -30
  251. package/src/@core/components/custom-inputs/Horizontal.jsx +0 -143
  252. package/src/@core/components/custom-inputs/Image.jsx +0 -78
  253. package/src/@core/components/custom-inputs/Vertical.jsx +0 -113
  254. package/src/@core/components/customizer/index.jsx +0 -470
  255. package/src/@core/components/customizer/styles.module.css +0 -169
  256. package/src/@core/components/mui/Avatar.jsx +0 -41
  257. package/src/@core/components/mui/Badge.jsx +0 -20
  258. package/src/@core/components/mui/IconButton.jsx +0 -74
  259. package/src/@core/components/mui/TabList.jsx +0 -60
  260. package/src/@core/components/option-menu/index.jsx +0 -137
  261. package/src/@core/components/scroll-to-top/index.jsx +0 -43
  262. package/src/@core/components/spinner/index.js +0 -26
  263. package/src/@core/components/window-wrapper/index.js +0 -27
  264. package/src/@core/contexts/settingsContext.jsx +0 -98
  265. package/src/@core/hooks/useBgColor.js +0 -63
  266. package/src/@core/hooks/useImageVariant.js +0 -27
  267. package/src/@core/hooks/useLayoutInit.js +0 -37
  268. package/src/@core/hooks/useObjectCookie.js +0 -18
  269. package/src/@core/hooks/useSettings.jsx +0 -15
  270. package/src/@core/layouts/BlankLayout.js +0 -37
  271. package/src/@core/layouts/BlankLayoutWithAppBar.js +0 -51
  272. package/src/@core/layouts/HorizontalLayout.jsx +0 -151
  273. package/src/@core/layouts/Layout.js +0 -39
  274. package/src/@core/layouts/VerticalLayout.jsx +0 -124
  275. package/src/@core/layouts/components/blank-layout-with-appBar/index.js +0 -115
  276. package/src/@core/layouts/components/horizontal/app-bar-content/index.js +0 -67
  277. package/src/@core/layouts/components/horizontal/navigation/HorizontalNavGroup.js +0 -352
  278. package/src/@core/layouts/components/horizontal/navigation/HorizontalNavItems.js +0 -21
  279. package/src/@core/layouts/components/horizontal/navigation/HorizontalNavLink.js +0 -195
  280. package/src/@core/layouts/components/horizontal/navigation/index.js +0 -31
  281. package/src/@core/layouts/components/shared-components/LanguageDropdown.js +0 -96
  282. package/src/@core/layouts/components/shared-components/ModeToggler.js +0 -32
  283. package/src/@core/layouts/components/shared-components/NotificationDropdown.js +0 -226
  284. package/src/@core/layouts/components/shared-components/UserDropdown.js +0 -177
  285. package/src/@core/layouts/components/shared-components/footer/FooterContent.js +0 -46
  286. package/src/@core/layouts/components/shared-components/footer/index.js +0 -61
  287. package/src/@core/layouts/components/vertical/appBar/index.js +0 -74
  288. package/src/@core/layouts/components/vertical/navigation/Drawer.js +0 -122
  289. package/src/@core/layouts/components/vertical/navigation/VerticalNavGroup.js +0 -435
  290. package/src/@core/layouts/components/vertical/navigation/VerticalNavHeader.js +0 -180
  291. package/src/@core/layouts/components/vertical/navigation/VerticalNavItems.js +0 -26
  292. package/src/@core/layouts/components/vertical/navigation/VerticalNavLink.js +0 -258
  293. package/src/@core/layouts/components/vertical/navigation/VerticalNavSectionTitle.js +0 -102
  294. package/src/@core/layouts/components/vertical/navigation/index.js +0 -169
  295. package/src/@core/layouts/utils.js +0 -69
  296. package/src/@core/styles/Table.module.css +0 -93
  297. package/src/@core/styles/horizontal/menuItemStyles.js +0 -100
  298. package/src/@core/styles/horizontal/menuRootStyles.js +0 -19
  299. package/src/@core/styles/libs/fullcalendar/index.js +0 -461
  300. package/src/@core/styles/libs/keen-slider/index.js +0 -111
  301. package/src/@core/styles/libs/react-apexcharts/index.js +0 -107
  302. package/src/@core/styles/libs/react-cleave/index.js +0 -33
  303. package/src/@core/styles/libs/react-credit-cards/index.js +0 -11
  304. package/src/@core/styles/libs/react-datepicker/index.js +0 -388
  305. package/src/@core/styles/libs/react-draft-wysiwyg/index.js +0 -144
  306. package/src/@core/styles/libs/react-dropzone/index.js +0 -76
  307. package/src/@core/styles/libs/react-hot-toast/index.js +0 -37
  308. package/src/@core/styles/libs/recharts/index.js +0 -47
  309. package/src/@core/styles/stepper.js +0 -103
  310. package/src/@core/styles/vertical/menuItemStyles.js +0 -138
  311. package/src/@core/styles/vertical/menuSectionStyles.js +0 -54
  312. package/src/@core/styles/vertical/navigationCustomStyles.js +0 -62
  313. package/src/@core/svg/ContentCompact.jsx +0 -17
  314. package/src/@core/svg/ContentWide.jsx +0 -17
  315. package/src/@core/svg/DirectionLtr.jsx +0 -93
  316. package/src/@core/svg/DirectionRtl.jsx +0 -93
  317. package/src/@core/svg/LayoutCollapsed.jsx +0 -59
  318. package/src/@core/svg/LayoutHorizontal.jsx +0 -42
  319. package/src/@core/svg/LayoutVertical.jsx +0 -59
  320. package/src/@core/svg/Logo.jsx +0 -76
  321. package/src/@core/svg/SkinBordered.jsx +0 -54
  322. package/src/@core/svg/SkinDefault.jsx +0 -59
  323. package/src/@core/tailwind/plugin.js +0 -78
  324. package/src/@core/theme/ThemeComponent.js +0 -63
  325. package/src/@core/theme/ThemeOptions.js +0 -71
  326. package/src/@core/theme/breakpoints/index.js +0 -11
  327. package/src/@core/theme/colorSchemes.js +0 -326
  328. package/src/@core/theme/customShadows.js +0 -11
  329. package/src/@core/theme/globalStyles.js +0 -81
  330. package/src/@core/theme/index.js +0 -42
  331. package/src/@core/theme/overrides/accordion.js +0 -51
  332. package/src/@core/theme/overrides/accordion.jsx +0 -85
  333. package/src/@core/theme/overrides/alerts.js +0 -110
  334. package/src/@core/theme/overrides/alerts.jsx +0 -180
  335. package/src/@core/theme/overrides/autocomplete.js +0 -14
  336. package/src/@core/theme/overrides/autocomplete.jsx +0 -68
  337. package/src/@core/theme/overrides/avatar.js +0 -38
  338. package/src/@core/theme/overrides/avatars.js +0 -27
  339. package/src/@core/theme/overrides/backdrop.js +0 -22
  340. package/src/@core/theme/overrides/badges.js +0 -16
  341. package/src/@core/theme/overrides/breadcrumbs.js +0 -11
  342. package/src/@core/theme/overrides/button-group.js +0 -84
  343. package/src/@core/theme/overrides/button.js +0 -93
  344. package/src/@core/theme/overrides/buttonGroup.js +0 -9
  345. package/src/@core/theme/overrides/card.js +0 -83
  346. package/src/@core/theme/overrides/checkbox.jsx +0 -95
  347. package/src/@core/theme/overrides/chip.js +0 -72
  348. package/src/@core/theme/overrides/dataGrid.js +0 -114
  349. package/src/@core/theme/overrides/dateTimePicker.js +0 -65
  350. package/src/@core/theme/overrides/dialog.js +0 -120
  351. package/src/@core/theme/overrides/divider.js +0 -13
  352. package/src/@core/theme/overrides/drawer.js +0 -20
  353. package/src/@core/theme/overrides/fab.js +0 -13
  354. package/src/@core/theme/overrides/form-control-label.js +0 -19
  355. package/src/@core/theme/overrides/icon-button.js +0 -145
  356. package/src/@core/theme/overrides/index.js +0 -103
  357. package/src/@core/theme/overrides/input.js +0 -72
  358. package/src/@core/theme/overrides/link.js +0 -9
  359. package/src/@core/theme/overrides/list.js +0 -44
  360. package/src/@core/theme/overrides/menu.js +0 -25
  361. package/src/@core/theme/overrides/pagination.js +0 -41
  362. package/src/@core/theme/overrides/paper.js +0 -9
  363. package/src/@core/theme/overrides/popover.js +0 -16
  364. package/src/@core/theme/overrides/progress.js +0 -38
  365. package/src/@core/theme/overrides/radio.jsx +0 -80
  366. package/src/@core/theme/overrides/rating.js +0 -16
  367. package/src/@core/theme/overrides/rating.jsx +0 -32
  368. package/src/@core/theme/overrides/select.js +0 -19
  369. package/src/@core/theme/overrides/select.jsx +0 -52
  370. package/src/@core/theme/overrides/slider.js +0 -97
  371. package/src/@core/theme/overrides/snackbar.js +0 -19
  372. package/src/@core/theme/overrides/switch.js +0 -73
  373. package/src/@core/theme/overrides/switches.js +0 -25
  374. package/src/@core/theme/overrides/table-pagination.js +0 -39
  375. package/src/@core/theme/overrides/table.js +0 -81
  376. package/src/@core/theme/overrides/tabs.js +0 -30
  377. package/src/@core/theme/overrides/timeline.js +0 -80
  378. package/src/@core/theme/overrides/toggle-button.js +0 -33
  379. package/src/@core/theme/overrides/toggleButton.js +0 -16
  380. package/src/@core/theme/overrides/tooltip.js +0 -21
  381. package/src/@core/theme/overrides/typography.js +0 -13
  382. package/src/@core/theme/palette/index.js +0 -107
  383. package/src/@core/theme/shadows/index.js +0 -61
  384. package/src/@core/theme/shadows.js +0 -12
  385. package/src/@core/theme/spacing/index.js +0 -3
  386. package/src/@core/theme/spacing.js +0 -5
  387. package/src/@core/theme/typography/index.js +0 -65
  388. package/src/@core/theme/typography.js +0 -84
  389. package/src/@core/utils/create-emotion-cache.js +0 -5
  390. package/src/@core/utils/hex-to-rgba.js +0 -11
  391. package/src/@core/utils/serverHelpers.js +0 -45
  392. package/src/@menu/components/RouterLink.jsx +0 -18
  393. package/src/@menu/components/horizontal-menu/HorizontalNav.jsx +0 -88
  394. package/src/@menu/components/horizontal-menu/Menu.jsx +0 -83
  395. package/src/@menu/components/horizontal-menu/MenuButton.jsx +0 -100
  396. package/src/@menu/components/horizontal-menu/MenuItem.jsx +0 -183
  397. package/src/@menu/components/horizontal-menu/SubMenu.jsx +0 -418
  398. package/src/@menu/components/horizontal-menu/SubMenuContent.jsx +0 -41
  399. package/src/@menu/components/horizontal-menu/VerticalNavInHorizontal.jsx +0 -20
  400. package/src/@menu/components/vertical-menu/Menu.jsx +0 -161
  401. package/src/@menu/components/vertical-menu/MenuButton.jsx +0 -95
  402. package/src/@menu/components/vertical-menu/MenuItem.jsx +0 -180
  403. package/src/@menu/components/vertical-menu/MenuSection.jsx +0 -124
  404. package/src/@menu/components/vertical-menu/NavCollapseIcons.jsx +0 -70
  405. package/src/@menu/components/vertical-menu/NavHeader.jsx +0 -39
  406. package/src/@menu/components/vertical-menu/SubMenu.jsx +0 -420
  407. package/src/@menu/components/vertical-menu/SubMenuContent.jsx +0 -101
  408. package/src/@menu/components/vertical-menu/VerticalNav.jsx +0 -216
  409. package/src/@menu/contexts/horizontalNavContext.jsx +0 -29
  410. package/src/@menu/contexts/verticalNavContext.jsx +0 -65
  411. package/src/@menu/defaultConfigs.js +0 -12
  412. package/src/@menu/hooks/useHorizontalMenu.jsx +0 -19
  413. package/src/@menu/hooks/useHorizontalNav.jsx +0 -19
  414. package/src/@menu/hooks/useMediaQuery.jsx +0 -29
  415. package/src/@menu/hooks/useVerticalMenu.jsx +0 -19
  416. package/src/@menu/hooks/useVerticalNav.jsx +0 -19
  417. package/src/@menu/horizontal-menu/index.jsx +0 -8
  418. package/src/@menu/styles/StyledBackdrop.jsx +0 -15
  419. package/src/@menu/styles/StyledMenuIcon.jsx +0 -12
  420. package/src/@menu/styles/StyledMenuLabel.jsx +0 -16
  421. package/src/@menu/styles/StyledMenuPrefix.jsx +0 -10
  422. package/src/@menu/styles/StyledMenuSectionLabel.jsx +0 -21
  423. package/src/@menu/styles/StyledMenuSuffix.jsx +0 -10
  424. package/src/@menu/styles/StyledSubMenuContent.jsx +0 -43
  425. package/src/@menu/styles/horizontal/StyledHorizontalMenu.jsx +0 -13
  426. package/src/@menu/styles/horizontal/StyledHorizontalMenuItem.jsx +0 -26
  427. package/src/@menu/styles/horizontal/StyledHorizontalNav.jsx +0 -11
  428. package/src/@menu/styles/horizontal/StyledHorizontalNavExpandIcon.jsx +0 -33
  429. package/src/@menu/styles/horizontal/StyledHorizontalSubMenuContent.jsx +0 -18
  430. package/src/@menu/styles/horizontal/StyledHorizontalSubMenuContentWrapper.jsx +0 -10
  431. package/src/@menu/styles/horizontal/horizontalUl.module.css +0 -15
  432. package/src/@menu/styles/styles.module.css +0 -5
  433. package/src/@menu/styles/vertical/StyledVerticalMenu.jsx +0 -16
  434. package/src/@menu/styles/vertical/StyledVerticalMenuItem.jsx +0 -28
  435. package/src/@menu/styles/vertical/StyledVerticalMenuSection.jsx +0 -23
  436. package/src/@menu/styles/vertical/StyledVerticalNav.jsx +0 -67
  437. package/src/@menu/styles/vertical/StyledVerticalNavBgColorContainer.jsx +0 -15
  438. package/src/@menu/styles/vertical/StyledVerticalNavContainer.jsx +0 -23
  439. package/src/@menu/styles/vertical/StyledVerticalNavExpandIcon.jsx +0 -25
  440. package/src/@menu/styles/vertical/verticalNavBgImage.module.css +0 -10
  441. package/src/@menu/svg/ChevronRight.jsx +0 -9
  442. package/src/@menu/svg/Close.jsx +0 -12
  443. package/src/@menu/svg/RadioCircle.jsx +0 -12
  444. package/src/@menu/svg/RadioCircleMarked.jsx +0 -13
  445. package/src/@menu/utils/menuClasses.js +0 -44
  446. package/src/@menu/utils/menuUtils.jsx +0 -145
  447. package/src/@menu/vertical-menu/index.jsx +0 -11
  448. package/src/configs/acl.js +0 -115
  449. package/src/configs/auth.js +0 -5
  450. package/src/configs/aws-exports.js +0 -30
  451. package/src/configs/firebase.js +0 -25
  452. package/src/configs/i18n.js +0 -34
  453. package/src/configs/primaryColorConfig.js +0 -35
  454. package/src/configs/themeConfig.js +0 -44
  455. package/src/layouts/UserLayout.js +0 -94
  456. package/src/layouts/UserThemeOptions.js +0 -191
  457. package/src/layouts/components/Direction.js +0 -30
  458. package/src/layouts/components/HtmlTooltip.js +0 -15
  459. package/src/layouts/components/Translations.js +0 -11
  460. package/src/layouts/components/UserDropdown.js +0 -217
  461. package/src/layouts/components/UserIcon.js +0 -40
  462. package/src/layouts/components/acl/Can.js +0 -6
  463. package/src/layouts/components/acl/CanViewNavGroup.js +0 -36
  464. package/src/layouts/components/acl/CanViewNavLink.js +0 -17
  465. package/src/layouts/components/acl/CanViewNavSectionTitle.js +0 -17
  466. package/src/layouts/components/horizontal/AppBarContent.js +0 -39
  467. package/src/layouts/components/horizontal/ServerSideNavItems.js +0 -44
  468. package/src/layouts/components/mui/StepperComps.js +0 -55
  469. package/src/layouts/components/vertical/AppBarContent.js +0 -35
  470. package/src/layouts/components/vertical/ServerSideNavItems.js +0 -44
  471. package/src/libs/ApexCharts.jsx +0 -5
  472. package/src/libs/ReactPlayer.jsx +0 -5
  473. package/src/libs/Recharts.jsx +0 -4
  474. package/src/libs/auth.js +0 -124
  475. package/src/libs/styles/AppFullCalendar.js +0 -505
  476. package/src/libs/styles/AppKeenSlider.js +0 -116
  477. package/src/libs/styles/AppReactApexCharts.jsx +0 -110
  478. package/src/libs/styles/AppReactDatepicker.jsx +0 -470
  479. package/src/libs/styles/AppReactDropzone.js +0 -76
  480. package/src/libs/styles/AppReactToastify.jsx +0 -108
  481. package/src/libs/styles/AppRecharts.js +0 -55
  482. package/src/libs/styles/inputOtp.module.css +0 -39
  483. package/src/libs/styles/tiptapEditor.css +0 -72
  484. package/src/navigation/horizontal/index.js +0 -246
  485. package/src/navigation/vertical/index.js +0 -253
  486. package/src/pages/401.js +0 -70
  487. package/src/pages/404.js +0 -67
  488. package/src/pages/500.js +0 -68
  489. package/src/pages/[slug].js +0 -115
  490. package/src/pages/_document.js +0 -72
  491. package/src/pages/api/navigation/regenerate-registry.js +0 -116
  492. package/src/pages/api/navigation/save.js +0 -218
  493. package/src/pages/authModule/acl/index.js +0 -48
  494. package/src/pages/authModule/forgot-password/index.js +0 -228
  495. package/src/pages/authModule/permissions/rolePermissions/[id]/rolePermissionsUser/index.js +0 -392
  496. package/src/pages/authModule/permissions/rolePermissions/index.js +0 -343
  497. package/src/pages/authModule/permissions/systemPermissions/index.js +0 -354
  498. package/src/pages/authModule/privacy/index.js +0 -721
  499. package/src/pages/authModule/users/index.js +0 -210
  500. package/src/pages/login/index.js +0 -328
  501. package/src/pages/mainHome/index.js +0 -181
  502. package/src/views/builder/inspector/definitions/cell/main.js +0 -4
  503. package/src/views/builder/inspector/definitions/column/main.js +0 -9
  504. package/src/views/builder/inspector/definitions/column-group/main.js +0 -18
  505. package/src/views/builder/inspector/definitions/header-cell/main.js +0 -5
  506. package/src/views/builder/inspector/definitions/table/main.js +0 -9
  507. package/src/views/builder/viewer/renderers/CellRenderer.jsx +0 -71
  508. package/src/views/builder/viewer/renderers/ColumnGroupRenderer.jsx +0 -96
  509. package/src/views/builder/viewer/renderers/ColumnRenderer.jsx +0 -71
  510. package/src/views/builder/viewer/renderers/HeaderCellRenderer.jsx +0 -78
  511. package/src/views/builder/viewer/renderers/TabRenderer.jsx +0 -82
  512. package/src/views/builder/viewer/renderers/TableRenderer.jsx +0 -92
  513. package/src/views/pages/auth/FooterIllustrationsV2.js +0 -40
  514. package/src/views/pages/misc/FooterIllustrations.js +0 -47
  515. package/src/views/pages/misc/muiTable/CustomPagination.js +0 -34
  516. package/src/views/pages/users/UserManageDialog.js +0 -283
  517. package/src/views/pages/users/UserViewPage.js +0 -199
  518. package/src/views/users/AddUserNameDialog.js +0 -162
  519. package/src/views/users/ContactManage.js +0 -449
  520. package/src/views/users/ResetPasswordDialog.js +0 -242
@@ -1,87 +1,403 @@
1
- import { Box, Stepper, Step, StepLabel, Button } from '@mui/material'
2
- import { useState } from 'react'
1
+ import { useState, useEffect, useCallback, useRef } from 'react'
2
+ import {
3
+ Box, Stepper, Step, StepLabel, StepContent, StepButton,
4
+ Button, Typography, Alert, LinearProgress, Chip, IconButton, Tooltip,
5
+ } from '@mui/material'
6
+ import AddIcon from '@mui/icons-material/Add'
7
+ import DeleteOutlineIcon from '@mui/icons-material/DeleteOutline'
3
8
  import ViewerComponentWrapper from '../ViewerComponentWrapper'
4
9
  import ComponentRenderer from '../ComponentRenderer'
5
- import DropZone from '../DropZone'
6
10
  import { resolveProps } from 'services/builderHelper/resolveProps'
11
+ import { executeJSCode } from 'services/builderHelper/jsExecutor'
7
12
  import { createNode } from 'services/builderHelper/nodeFactory'
8
- import { insertIntoTreeAtIndex, moveNodeInTree } from 'services/builderHelper/tree'
13
+ import { insertIntoTreeAtIndex, removeFromTree } from 'services/builderHelper/tree'
14
+
15
+ // ─────────────────────────────────────────────────────────────────────────────
9
16
 
10
17
  export default function WizardRenderer({ node, viewerContext }) {
11
- const { data, form, isEditMode, builderContext } = viewerContext
12
- const main = resolveProps(node, 'main', { form, data })
13
- const [activeStep, setActiveStep] = useState(0)
18
+ const {
19
+ data, form, setData, dataRef, reportRefs, openDialog, closeDialog,
20
+ isEditMode, builderContext,
21
+ pageData, pageSetData, pageDataRef, pageReportRefs,
22
+ } = viewerContext
23
+
24
+ const resolveCtx = useRef({})
25
+ resolveCtx.current = {
26
+ form, data, setData,
27
+ dataRef: dataRef?.current ?? {},
28
+ reportRefs: reportRefs?.current ?? {},
29
+ openDialog: openDialog ?? (() => {}),
30
+ closeDialog: closeDialog ?? (() => {}),
31
+ }
14
32
 
15
- const steps = node.children || []
33
+ const main = resolveProps(node, 'main', resolveCtx.current)
16
34
 
17
- const handleNext = () => setActiveStep((prev) => prev + 1)
18
- const handleBack = () => setActiveStep((prev) => prev - 1)
35
+ // All direct children are steps — no type filter needed (wizard only contains wizard-steps)
36
+ const steps = node.children ?? []
19
37
 
20
- const handleDropAtIndex = index => e => {
21
- if (!isEditMode || !builderContext) return
22
- e.preventDefault()
23
- e.stopPropagation()
38
+ // ── Config ──────────────────────────────────────────────────────────────────
39
+ const orientation = main.orientation || 'horizontal'
40
+ const altLabel = main.variant === 'alternativeLabel'
41
+ const linear = main.linear !== false
42
+ const hideNav = !!main.hideNavigation
43
+ const backLabel = main.backLabel || 'Back'
44
+ const nextLabel = main.nextLabel || 'Next'
45
+ const finishLabel = main.finishLabel || 'Finish'
46
+ const nextColor = main.nextColor || 'primary'
47
+ const nextVariant = main.nextVariant || 'contained'
48
+ const backColor = main.backColor || 'inherit'
49
+ const backVariant = main.backVariant || 'text'
24
50
 
25
- try {
26
- const nodeId = e.dataTransfer.getData('application/builder-node-id')
27
- if (nodeId) {
28
- builderContext.setSchema(prev => ({
29
- ...prev,
30
- root: moveNodeInTree(prev.root, nodeId, node.id, index)
31
- }))
32
- builderContext.setSelectedId(nodeId)
33
- builderContext.setDraggingNodeId(null)
34
- return
51
+ // ── Step index state ────────────────────────────────────────────────────────
52
+ const controlled = main.activeStep != null && !isNaN(Number(main.activeStep))
53
+ const [internal, setInternal] = useState(0)
54
+ const clamp = useCallback(n => Math.max(0, Math.min(n, Math.max(0, steps.length - 1))), [steps.length])
55
+ const activeStep = controlled ? clamp(Number(main.activeStep)) : clamp(internal)
56
+
57
+ // Edit mode: track which step tab is selected for preview
58
+ const [editTab, setEditTab] = useState(0)
59
+
60
+ // Completed / error state
61
+ const [completed, setCompleted] = useState({})
62
+ const [stepError, setStepError] = useState(null)
63
+ const [loading, setLoading] = useState(false)
64
+
65
+ // ── Navigation ref — stable functions for extraVars injection ──────────────
66
+ const nav = useRef({})
67
+
68
+ const execCtx = useCallback(() => ({
69
+ ...resolveCtx.current,
70
+ pageData, pageSetData, pageDataRef, pageReportRefs,
71
+ }), [data, form]) // eslint-disable-line
72
+
73
+ // ── Core navigate ───────────────────────────────────────────────────────────
74
+ const navigate = useCallback(async (to, direction) => {
75
+ const from = activeStep
76
+ const safe = clamp(to)
77
+ if (safe === from && direction !== 'enter') return
78
+
79
+ setStepError(null)
80
+
81
+ // wizard-level onStepChange
82
+ if (main.onStepChange) {
83
+ try {
84
+ await executeJSCode(main.onStepChange, {
85
+ ...execCtx(),
86
+ extraVars: { from, to: safe, direction, ...nav.current },
87
+ })
88
+ } catch (e) { console.error('[Wizard] onStepChange:', e) }
89
+ }
90
+
91
+ if (controlled) {
92
+ setData?.(prev => ({ ...prev, [main.key || 'wizardStep']: safe }))
93
+ } else {
94
+ setInternal(safe)
95
+ }
96
+
97
+ // target step onEnter
98
+ const target = steps[safe]
99
+ if (target) {
100
+ const sm = resolveProps(target, 'main', resolveCtx.current)
101
+ if (sm.onEnter) {
102
+ try {
103
+ await executeJSCode(sm.onEnter, {
104
+ ...execCtx(),
105
+ extraVars: { stepIndex: safe, ...nav.current },
106
+ })
107
+ } catch (e) { console.error('[Wizard] onEnter:', e) }
35
108
  }
109
+ }
110
+ }, [activeStep, clamp, controlled, main, steps, execCtx, setData])
36
111
 
37
- const componentData = e.dataTransfer.getData('application/builder-component')
38
- if (componentData) {
39
- const component = JSON.parse(componentData)
40
- const newNode = createNode(component.type)
41
- builderContext.setSchema(prev => ({
42
- ...prev,
43
- root: insertIntoTreeAtIndex(prev.root, node.id, newNode, index)
44
- }))
45
- builderContext.setSelectedId(newNode.id)
46
- builderContext.setDraggingNodeId(null)
112
+ nav.current = {
113
+ goToStep: (n) => navigate(n, 'jump'),
114
+ nextStep: () => navigate(activeStep + 1, 'next'),
115
+ prevStep: () => navigate(activeStep - 1, 'back'),
116
+ }
117
+
118
+ // ── Handle Next / Finish ────────────────────────────────────────────────────
119
+ const handleNext = useCallback(async () => {
120
+ if (loading) return
121
+ setStepError(null)
122
+
123
+ const current = steps[activeStep]
124
+ if (current) {
125
+ const sm = resolveProps(current, 'main', resolveCtx.current)
126
+ if (sm.onNext) {
127
+ setLoading(true)
128
+ try {
129
+ const result = await executeJSCode(sm.onNext, {
130
+ ...execCtx(),
131
+ extraVars: { stepIndex: activeStep, ...nav.current },
132
+ })
133
+ if (result === false) { setLoading(false); return }
134
+ if (typeof result === 'string') { setStepError(result); setLoading(false); return }
135
+ } catch (e) { console.error('[Wizard] onNext:', e); setLoading(false); return }
136
+ setLoading(false)
137
+ }
138
+ }
139
+
140
+ setCompleted(prev => ({ ...prev, [activeStep]: true }))
141
+
142
+ // Last step → onFinish
143
+ if (activeStep >= steps.length - 1) {
144
+ if (main.onFinish) {
145
+ setLoading(true)
146
+ try {
147
+ await executeJSCode(main.onFinish, {
148
+ ...execCtx(),
149
+ extraVars: { stepIndex: activeStep, ...nav.current },
150
+ })
151
+ } catch (e) { console.error('[Wizard] onFinish:', e) }
152
+ finally { setLoading(false) }
47
153
  }
48
- } catch (err) {
49
- builderContext.setDraggingNodeId(null)
50
- console.error(err)
154
+ return
51
155
  }
156
+
157
+ navigate(activeStep + 1, 'next')
158
+ }, [loading, steps, activeStep, main, execCtx, navigate])
159
+
160
+ const handleBack = useCallback(() => {
161
+ setStepError(null)
162
+ navigate(activeStep - 1, 'back')
163
+ }, [activeStep, navigate])
164
+
165
+ // Fire onEnter for initial step on first mount (runtime only)
166
+ const didMount = useRef(false)
167
+ useEffect(() => {
168
+ if (isEditMode || didMount.current || steps.length === 0) return
169
+ didMount.current = true
170
+ const step = steps[0]
171
+ const sm = resolveProps(step, 'main', resolveCtx.current)
172
+ if (sm.onEnter) {
173
+ executeJSCode(sm.onEnter, {
174
+ ...execCtx(),
175
+ extraVars: { stepIndex: 0, ...nav.current },
176
+ }).catch(e => console.error('[Wizard] initial onEnter:', e))
177
+ }
178
+ }, []) // eslint-disable-line
179
+
180
+ // ── Child context — wizard nav injected for child components ───────────────
181
+ const childContext = { ...viewerContext, ...nav.current, wizardStep: activeStep, wizardTotal: steps.length }
182
+
183
+ // ── Step label helper ───────────────────────────────────────────────────────
184
+ const stepLabel = (stepNode, idx) => {
185
+ try {
186
+ const m = resolveProps(stepNode, 'main', resolveCtx.current)
187
+ return m.label || `Step ${idx + 1}`
188
+ } catch { return `Step ${idx + 1}` }
52
189
  }
53
190
 
54
- return (
55
- <ViewerComponentWrapper node={node} viewerContext={viewerContext}>
56
- <Box sx={{ width: '100%' }}>
57
- <Stepper activeStep={activeStep} orientation={main.orientation || 'horizontal'}>
58
- {steps.map((child, index) => (
59
- <Step key={child.id}>
60
- <StepLabel>{child.props?.main?.label || `Step ${index + 1}`}</StepLabel>
61
- </Step>
62
- ))}
63
- {isEditMode && <DropZone onDrop={handleDropAtIndex(steps.length)} isEditMode={isEditMode} />}
64
- </Stepper>
65
- <Box sx={{ mt: 2, mb: 1, minHeight: 100 }}>
66
- {steps.length > 0 ? (
67
- <Box key={steps[activeStep].id}>
68
- <ComponentRenderer node={steps[activeStep]} viewerContext={viewerContext} />
191
+ const stepProp = (stepNode, prop) => {
192
+ try {
193
+ const m = resolveProps(stepNode, 'main', resolveCtx.current)
194
+ return m[prop]
195
+ } catch { return undefined }
196
+ }
197
+
198
+ // ── Add / remove step helpers (edit mode) ──────────────────────────────────
199
+ const handleAddStep = useCallback(() => {
200
+ if (!builderContext) return
201
+ const newStep = createNode('wizard-step')
202
+ builderContext.setSchema(prev => ({
203
+ ...prev,
204
+ root: insertIntoTreeAtIndex(prev.root, node.id, newStep, steps.length),
205
+ }))
206
+ setEditTab(steps.length)
207
+ builderContext.setSelectedId(newStep.id)
208
+ }, [builderContext, node.id, steps.length])
209
+
210
+ const handleRemoveStep = useCallback((stepId, stepIdx) => {
211
+ if (!builderContext) return
212
+ builderContext.setSchema(prev => ({
213
+ ...prev,
214
+ root: removeFromTree(prev.root, stepId),
215
+ }))
216
+ setEditTab(prev => Math.max(0, prev >= stepIdx ? prev - 1 : prev))
217
+ }, [builderContext])
218
+
219
+ // ══════════════════════════════════════════════════════════════════════════
220
+ // EDIT MODE — tab strip + step content panel
221
+ // ══════════════════════════════════════════════════════════════════════════
222
+ if (isEditMode) {
223
+ const safeTab = Math.min(editTab, Math.max(0, steps.length - 1))
224
+
225
+ return (
226
+ <ViewerComponentWrapper node={node} viewerContext={viewerContext}>
227
+ <Box sx={{ width: '100%' }}>
228
+
229
+ {/* ── Step tabs + Add button ── */}
230
+ <Box sx={{ display: 'flex', alignItems: 'center', gap: 0.5, flexWrap: 'wrap', mb: 1 }}>
231
+ {steps.map((s, i) => (
232
+ <Chip
233
+ key={s.id}
234
+ label={`${i + 1}. ${stepLabel(s, i)}`}
235
+ size='small'
236
+ onClick={() => { setEditTab(i); builderContext?.setSelectedId(s.id) }}
237
+ onDelete={steps.length > 1 ? () => handleRemoveStep(s.id, i) : undefined}
238
+ deleteIcon={<DeleteOutlineIcon sx={{ fontSize: '14px !important' }} />}
239
+ color={safeTab === i ? 'primary' : 'default'}
240
+ variant={safeTab === i ? 'filled' : 'outlined'}
241
+ sx={{ cursor: 'pointer', fontSize: 11 }}
242
+ />
243
+ ))}
244
+
245
+ {/* "+ Step" button */}
246
+ <Tooltip title='Add step'>
247
+ <IconButton
248
+ size='small'
249
+ onClick={handleAddStep}
250
+ sx={{ border: '1px dashed', borderColor: 'divider', borderRadius: 1, p: '2px' }}
251
+ >
252
+ <AddIcon sx={{ fontSize: 16 }} />
253
+ </IconButton>
254
+ </Tooltip>
255
+ </Box>
256
+
257
+ {/* ── Active step content ── */}
258
+ {steps.length === 0 ? (
259
+ <Box sx={{
260
+ border: '1px dashed #ccc', borderRadius: 1, p: 2,
261
+ color: 'text.disabled', textAlign: 'center', fontSize: 13,
262
+ }}>
263
+ Click <strong>+</strong> to add your first step
69
264
  </Box>
70
265
  ) : (
71
- <Box sx={{ textAlign: 'center', color: 'text.disabled', py: 2 }}>
72
- {isEditMode ? 'Drop wizard-steps here' : 'No steps'}
73
- </Box>
266
+ <Box sx={{ border: '1px solid', borderColor: 'divider', borderRadius: 1, p: 1.5, minHeight: 80 }}>
267
+ <ComponentRenderer
268
+ key={steps[safeTab]?.id}
269
+ node={steps[safeTab]}
270
+ viewerContext={childContext}
271
+ />
272
+ </Box>
74
273
  )}
75
274
  </Box>
76
- <Box sx={{ display: 'flex', flexDirection: 'row', pt: 2 }}>
77
- <Button color="inherit" disabled={activeStep === 0} onClick={handleBack} sx={{ mr: 1 }}>
78
- Back
79
- </Button>
80
- <Box sx={{ flex: '1 1 auto' }} />
81
- <Button onClick={handleNext} disabled={activeStep === steps.length - 1}>
82
- {activeStep === steps.length - 1 ? 'Finish' : 'Next'}
83
- </Button>
84
- </Box>
275
+ </ViewerComponentWrapper>
276
+ )
277
+ }
278
+
279
+ // ══════════════════════════════════════════════════════════════════════════
280
+ // RUNTIME MODE
281
+ // ══════════════════════════════════════════════════════════════════════════
282
+
283
+ // ── Stepper ────────────────────────────────────────────────────────────────
284
+ const StepperEl = (
285
+ <Stepper
286
+ activeStep={activeStep}
287
+ orientation={orientation}
288
+ alternativeLabel={altLabel && orientation === 'horizontal'}
289
+ nonLinear={!linear}
290
+ >
291
+ {steps.map((stepNode, idx) => {
292
+ const label = stepLabel(stepNode, idx)
293
+ const description = stepProp(stepNode, 'description')
294
+ const optional = stepProp(stepNode, 'optional')
295
+ const isCompleted = stepProp(stepNode, 'completed') ?? completed[idx] ?? false
296
+ const isError = !!stepProp(stepNode, 'error')
297
+
298
+ const optionalEl = optional
299
+ ? <Typography variant='caption'>Optional</Typography>
300
+ : description
301
+ ? <Typography variant='caption'>{description}</Typography>
302
+ : undefined
303
+
304
+ const labelEl = (
305
+ <StepLabel error={isError} optional={optionalEl}>
306
+ {label}
307
+ </StepLabel>
308
+ )
309
+
310
+ // Vertical: content and nav inline inside each step
311
+ if (orientation === 'vertical') {
312
+ return (
313
+ <Step key={stepNode.id} completed={isCompleted}>
314
+ {!linear
315
+ ? <StepButton onClick={() => navigate(idx, 'jump')}>{label}</StepButton>
316
+ : labelEl
317
+ }
318
+ <StepContent>
319
+ <ComponentRenderer node={stepNode} viewerContext={childContext} />
320
+ {!hideNav && (
321
+ <Box sx={{ mt: 2, display: 'flex', gap: 1 }}>
322
+ <Button size='small' disabled={idx === 0 || loading}
323
+ variant={backVariant !== 'text' ? backVariant : 'text'}
324
+ color={backColor !== 'inherit' ? backColor : 'inherit'}
325
+ onClick={handleBack}>{backLabel}</Button>
326
+ <Button size='small' disabled={loading}
327
+ variant={nextVariant} color={nextColor !== 'inherit' ? nextColor : 'inherit'}
328
+ onClick={handleNext}>
329
+ {idx === steps.length - 1 ? finishLabel : nextLabel}
330
+ </Button>
331
+ </Box>
332
+ )}
333
+ </StepContent>
334
+ </Step>
335
+ )
336
+ }
337
+
338
+ // Horizontal
339
+ return (
340
+ <Step key={stepNode.id} completed={isCompleted}>
341
+ {!linear
342
+ ? <StepButton onClick={() => navigate(idx, 'jump')}>{label}</StepButton>
343
+ : labelEl
344
+ }
345
+ </Step>
346
+ )
347
+ })}
348
+ </Stepper>
349
+ )
350
+
351
+ return (
352
+ <ViewerComponentWrapper node={node} viewerContext={viewerContext}>
353
+ <Box sx={{ width: '100%' }}>
354
+ {StepperEl}
355
+
356
+ {/* Horizontal: active step content below stepper */}
357
+ {orientation === 'horizontal' && steps.length > 0 && (
358
+ <Box sx={{ mt: 2, mb: 1, minHeight: 80 }}>
359
+ <ComponentRenderer
360
+ key={steps[activeStep]?.id}
361
+ node={steps[activeStep]}
362
+ viewerContext={childContext}
363
+ />
364
+ </Box>
365
+ )}
366
+
367
+ {orientation === 'horizontal' && steps.length === 0 && (
368
+ <Box sx={{ textAlign: 'center', color: 'text.disabled', py: 3 }}>No steps</Box>
369
+ )}
370
+
371
+ {/* Validation error */}
372
+ {stepError && (
373
+ <Alert severity='error' onClose={() => setStepError(null)} sx={{ mt: 1 }}>
374
+ {stepError}
375
+ </Alert>
376
+ )}
377
+
378
+ {/* Horizontal nav buttons */}
379
+ {orientation === 'horizontal' && !hideNav && steps.length > 0 && (
380
+ <Box sx={{ display: 'flex', alignItems: 'center', pt: 2 }}>
381
+ <Button
382
+ variant={backVariant !== 'text' ? backVariant : 'text'}
383
+ color={backColor !== 'inherit' ? backColor : 'inherit'}
384
+ disabled={activeStep === 0 || loading}
385
+ onClick={handleBack}
386
+ >
387
+ {backLabel}
388
+ </Button>
389
+ <Box sx={{ flex: 1 }} />
390
+ {loading && <LinearProgress sx={{ width: 60, mr: 2, alignSelf: 'center' }} />}
391
+ <Button
392
+ variant={nextVariant}
393
+ color={nextColor !== 'inherit' ? nextColor : 'inherit'}
394
+ disabled={loading}
395
+ onClick={handleNext}
396
+ >
397
+ {activeStep >= steps.length - 1 ? finishLabel : nextLabel}
398
+ </Button>
399
+ </Box>
400
+ )}
85
401
  </Box>
86
402
  </ViewerComponentWrapper>
87
403
  )
@@ -2,39 +2,44 @@ import { Box } from '@mui/material'
2
2
  import ViewerComponentWrapper from '../ViewerComponentWrapper'
3
3
  import ComponentRenderer from '../ComponentRenderer'
4
4
  import DropZone from '../DropZone'
5
- import { resolveProps } from 'services/builderHelper/resolveProps'
6
5
  import { createNode } from 'services/builderHelper/nodeFactory'
7
6
  import { insertIntoTreeAtIndex, moveNodeInTree } from 'services/builderHelper/tree'
8
7
 
8
+ // WizardStepRenderer — renders the CONTENT of one wizard step.
9
+ //
10
+ // The parent WizardRenderer is responsible for:
11
+ // - showing/hiding this step based on activeStep
12
+ // - resolving step-level props (label, description, completed, error, onEnter, onNext)
13
+ //
14
+ // This renderer just provides a drop zone for child components.
15
+ // It receives wizard navigation helpers (goToStep, nextStep, prevStep) from
16
+ // viewerContext if placed inside a WizardRenderer.
17
+
9
18
  export default function WizardStepRenderer({ node, viewerContext }) {
10
- const { data, form, isEditMode, builderContext } = viewerContext
11
- // main is resolved by parent or child depending on usage,
12
- // but here we just need to render children
19
+ const { isEditMode, builderContext } = viewerContext
13
20
 
14
21
  const handleDropAtIndex = index => e => {
15
22
  if (!isEditMode || !builderContext) return
16
23
  e.preventDefault()
17
24
  e.stopPropagation()
18
-
19
25
  try {
20
26
  const nodeId = e.dataTransfer.getData('application/builder-node-id')
21
27
  if (nodeId) {
22
28
  builderContext.setSchema(prev => ({
23
29
  ...prev,
24
- root: moveNodeInTree(prev.root, nodeId, node.id, index)
30
+ root: moveNodeInTree(prev.root, nodeId, node.id, index),
25
31
  }))
26
32
  builderContext.setSelectedId(nodeId)
27
33
  builderContext.setDraggingNodeId(null)
28
34
  return
29
35
  }
30
-
31
36
  const componentData = e.dataTransfer.getData('application/builder-component')
32
37
  if (componentData) {
33
38
  const component = JSON.parse(componentData)
34
39
  const newNode = createNode(component.type)
35
40
  builderContext.setSchema(prev => ({
36
41
  ...prev,
37
- root: insertIntoTreeAtIndex(prev.root, node.id, newNode, index)
42
+ root: insertIntoTreeAtIndex(prev.root, node.id, newNode, index),
38
43
  }))
39
44
  builderContext.setSelectedId(newNode.id)
40
45
  builderContext.setDraggingNodeId(null)
@@ -47,22 +52,26 @@ export default function WizardStepRenderer({ node, viewerContext }) {
47
52
 
48
53
  return (
49
54
  <ViewerComponentWrapper node={node} viewerContext={viewerContext}>
50
- <Box sx={{ minHeight: 48 }}>
55
+ <Box sx={{ minHeight: 48, py: 0.5 }}>
51
56
  {node.children?.length > 0 ? (
52
57
  <>
53
58
  {node.children.map((child, index) => (
54
59
  <Box key={child.id}>
55
- {isEditMode && <DropZone onDrop={handleDropAtIndex(index)} isEditMode={isEditMode} />}
60
+ {isEditMode && (
61
+ <DropZone onDrop={handleDropAtIndex(index)} isEditMode={isEditMode} />
62
+ )}
56
63
  <ComponentRenderer node={child} viewerContext={viewerContext} />
57
64
  </Box>
58
65
  ))}
59
- {isEditMode && <DropZone onDrop={handleDropAtIndex(node.children.length)} isEditMode={isEditMode} />}
66
+ {isEditMode && (
67
+ <DropZone onDrop={handleDropAtIndex(node.children.length)} isEditMode={isEditMode} />
68
+ )}
60
69
  </>
61
70
  ) : (
62
71
  <>
63
72
  {isEditMode && <DropZone onDrop={handleDropAtIndex(0)} isEditMode={isEditMode} />}
64
73
  <Box sx={{ fontSize: 12, color: 'text.disabled', textAlign: 'center', py: 1 }}>
65
- {isEditMode ? 'Drop components for this step' : 'Empty step'}
74
+ {isEditMode ? 'Drop components for this step' : ''}
66
75
  </Box>
67
76
  </>
68
77
  )}