@solidxai/core-ui 0.1.5-beta.8 → 0.1.6

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 (300) hide show
  1. package/dist/components/auth/AuthTabs.d.ts +14 -0
  2. package/dist/components/auth/AuthTabs.d.ts.map +1 -0
  3. package/dist/components/auth/AuthTabs.js +19 -0
  4. package/dist/components/auth/AuthTabs.js.map +1 -0
  5. package/dist/components/auth/AuthTabs.tsx +38 -0
  6. package/dist/components/auth/GoogleAuthChecking.d.ts.map +1 -1
  7. package/dist/components/auth/GoogleAuthChecking.js +10 -10
  8. package/dist/components/auth/GoogleAuthChecking.js.map +1 -1
  9. package/dist/components/auth/GoogleAuthChecking.tsx +8 -9
  10. package/dist/components/auth/SolidChangeForcePassword.d.ts.map +1 -1
  11. package/dist/components/auth/SolidChangeForcePassword.js +9 -10
  12. package/dist/components/auth/SolidChangeForcePassword.js.map +1 -1
  13. package/dist/components/auth/SolidChangeForcePassword.tsx +6 -9
  14. package/dist/components/auth/SolidForgotPassword.d.ts.map +1 -1
  15. package/dist/components/auth/SolidForgotPassword.js +8 -8
  16. package/dist/components/auth/SolidForgotPassword.js.map +1 -1
  17. package/dist/components/auth/SolidForgotPassword.tsx +6 -8
  18. package/dist/components/auth/SolidInitialLoginOtp.d.ts.map +1 -1
  19. package/dist/components/auth/SolidInitialLoginOtp.js +57 -57
  20. package/dist/components/auth/SolidInitialLoginOtp.js.map +1 -1
  21. package/dist/components/auth/SolidInitialLoginOtp.tsx +10 -11
  22. package/dist/components/auth/SolidInitiateRegisterOtp.d.ts.map +1 -1
  23. package/dist/components/auth/SolidInitiateRegisterOtp.js +57 -57
  24. package/dist/components/auth/SolidInitiateRegisterOtp.js.map +1 -1
  25. package/dist/components/auth/SolidInitiateRegisterOtp.tsx +10 -11
  26. package/dist/components/auth/SolidLogin.d.ts.map +1 -1
  27. package/dist/components/auth/SolidLogin.js +12 -12
  28. package/dist/components/auth/SolidLogin.js.map +1 -1
  29. package/dist/components/auth/SolidLogin.tsx +11 -16
  30. package/dist/components/auth/SolidRegister.d.ts.map +1 -1
  31. package/dist/components/auth/SolidRegister.js +19 -19
  32. package/dist/components/auth/SolidRegister.js.map +1 -1
  33. package/dist/components/auth/SolidRegister.tsx +18 -23
  34. package/dist/components/auth/SolidResetPassword.d.ts.map +1 -1
  35. package/dist/components/auth/SolidResetPassword.js +15 -15
  36. package/dist/components/auth/SolidResetPassword.js.map +1 -1
  37. package/dist/components/auth/SolidResetPassword.tsx +7 -8
  38. package/dist/components/common/GeneralSettings.d.ts.map +1 -1
  39. package/dist/components/common/GeneralSettings.js +87 -120
  40. package/dist/components/common/GeneralSettings.js.map +1 -1
  41. package/dist/components/common/GeneralSettings.tsx +12 -42
  42. package/dist/components/common/GlobalToast.d.ts +2 -0
  43. package/dist/components/common/GlobalToast.d.ts.map +1 -0
  44. package/dist/components/common/GlobalToast.js +25 -0
  45. package/dist/components/common/GlobalToast.js.map +1 -0
  46. package/dist/components/common/GlobalToast.tsx +25 -0
  47. package/dist/components/common/SolidErrorStatePage.d.ts +12 -0
  48. package/dist/components/common/SolidErrorStatePage.d.ts.map +1 -0
  49. package/dist/components/common/SolidErrorStatePage.js +16 -0
  50. package/dist/components/common/SolidErrorStatePage.js.map +1 -0
  51. package/dist/components/common/SolidErrorStatePage.tsx +55 -0
  52. package/dist/components/common/SolidExport.d.ts.map +1 -1
  53. package/dist/components/common/SolidExport.js +19 -31
  54. package/dist/components/common/SolidExport.js.map +1 -1
  55. package/dist/components/common/SolidExport.tsx +7 -19
  56. package/dist/components/common/SolidFormStepper.d.ts.map +1 -1
  57. package/dist/components/common/SolidFormStepper.js +41 -41
  58. package/dist/components/common/SolidFormStepper.js.map +1 -1
  59. package/dist/components/common/SolidFormStepper.tsx +5 -6
  60. package/dist/components/core/chatter/SolidChatterDateDivider.d.ts.map +1 -1
  61. package/dist/components/core/chatter/SolidChatterDateDivider.js +4 -1
  62. package/dist/components/core/chatter/SolidChatterDateDivider.js.map +1 -1
  63. package/dist/components/core/chatter/SolidChatterDateDivider.tsx +5 -1
  64. package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.d.ts.map +1 -1
  65. package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.js +9 -9
  66. package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.js.map +1 -1
  67. package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.tsx +8 -9
  68. package/dist/components/core/common/SolidAccountSettings/SolidNotifications.d.ts.map +1 -1
  69. package/dist/components/core/common/SolidAccountSettings/SolidNotifications.js +8 -8
  70. package/dist/components/core/common/SolidAccountSettings/SolidNotifications.js.map +1 -1
  71. package/dist/components/core/common/SolidAccountSettings/SolidNotifications.tsx +7 -9
  72. package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.d.ts.map +1 -1
  73. package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.js +11 -11
  74. package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.js.map +1 -1
  75. package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.tsx +10 -11
  76. package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.d.ts.map +1 -1
  77. package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.js +9 -9
  78. package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.js.map +1 -1
  79. package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.tsx +8 -9
  80. package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.d.ts.map +1 -1
  81. package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.js +7 -7
  82. package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.js.map +1 -1
  83. package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.tsx +6 -7
  84. package/dist/components/core/common/SolidGlobalSearchElement.d.ts.map +1 -1
  85. package/dist/components/core/common/SolidGlobalSearchElement.js +78 -21
  86. package/dist/components/core/common/SolidGlobalSearchElement.js.map +1 -1
  87. package/dist/components/core/common/SolidGlobalSearchElement.tsx +65 -10
  88. package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.d.ts.map +1 -1
  89. package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.js +6 -8
  90. package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.js.map +1 -1
  91. package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.tsx +5 -9
  92. package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.d.ts.map +1 -1
  93. package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.js +9 -11
  94. package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.js.map +1 -1
  95. package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.tsx +5 -10
  96. package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.d.ts.map +1 -1
  97. package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.js +5 -6
  98. package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.js.map +1 -1
  99. package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.tsx +5 -8
  100. package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.d.ts.map +1 -1
  101. package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.js +10 -12
  102. package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.js.map +1 -1
  103. package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.tsx +6 -11
  104. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.d.ts.map +1 -1
  105. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.js +11 -6
  106. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.js.map +1 -1
  107. package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.tsx +13 -1
  108. package/dist/components/core/form/SolidFormUserViewLayout.d.ts.map +1 -1
  109. package/dist/components/core/form/SolidFormUserViewLayout.js +7 -8
  110. package/dist/components/core/form/SolidFormUserViewLayout.js.map +1 -1
  111. package/dist/components/core/form/SolidFormUserViewLayout.tsx +5 -7
  112. package/dist/components/core/form/SolidFormView.d.ts.map +1 -1
  113. package/dist/components/core/form/SolidFormView.js +12 -21
  114. package/dist/components/core/form/SolidFormView.js.map +1 -1
  115. package/dist/components/core/form/SolidFormView.tsx +11 -33
  116. package/dist/components/core/form/fields/SolidMediaSingleField.d.ts.map +1 -1
  117. package/dist/components/core/form/fields/SolidMediaSingleField.js +22 -15
  118. package/dist/components/core/form/fields/SolidMediaSingleField.js.map +1 -1
  119. package/dist/components/core/form/fields/SolidMediaSingleField.tsx +14 -2
  120. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.d.ts.map +1 -1
  121. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js +37 -26
  122. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js.map +1 -1
  123. package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.tsx +38 -5
  124. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.d.ts.map +1 -1
  125. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js +11 -11
  126. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js.map +1 -1
  127. package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.tsx +9 -11
  128. package/dist/components/core/kanban/KanbanUserViewLayout.d.ts.map +1 -1
  129. package/dist/components/core/kanban/KanbanUserViewLayout.js +7 -8
  130. package/dist/components/core/kanban/KanbanUserViewLayout.js.map +1 -1
  131. package/dist/components/core/kanban/KanbanUserViewLayout.tsx +4 -6
  132. package/dist/components/core/kanban/SolidKanbanView.d.ts.map +1 -1
  133. package/dist/components/core/kanban/SolidKanbanView.js +5 -7
  134. package/dist/components/core/kanban/SolidKanbanView.js.map +1 -1
  135. package/dist/components/core/kanban/SolidKanbanView.tsx +4 -9
  136. package/dist/components/core/list/PLAN.md +92 -0
  137. package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.d.ts.map +1 -1
  138. package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.js +13 -13
  139. package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.js.map +1 -1
  140. package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.tsx +5 -6
  141. package/dist/components/core/list/SolidDataTable.d.ts +58 -0
  142. package/dist/components/core/list/SolidDataTable.d.ts.map +1 -0
  143. package/dist/components/core/list/SolidDataTable.js +141 -0
  144. package/dist/components/core/list/SolidDataTable.js.map +1 -0
  145. package/dist/components/core/list/SolidDataTable.tsx +314 -0
  146. package/dist/components/core/list/SolidListView.d.ts.map +1 -1
  147. package/dist/components/core/list/SolidListView.js +20 -67
  148. package/dist/components/core/list/SolidListView.js.map +1 -1
  149. package/dist/components/core/list/SolidListView.tsx +9 -76
  150. package/dist/components/core/model/CreateModel.d.ts.map +1 -1
  151. package/dist/components/core/model/CreateModel.js +15 -25
  152. package/dist/components/core/model/CreateModel.js.map +1 -1
  153. package/dist/components/core/model/CreateModel.tsx +12 -32
  154. package/dist/components/core/model/FieldMetaData.d.ts.map +1 -1
  155. package/dist/components/core/model/FieldMetaData.js +6 -17
  156. package/dist/components/core/model/FieldMetaData.js.map +1 -1
  157. package/dist/components/core/model/FieldMetaData.tsx +5 -26
  158. package/dist/components/core/model/ModelMetaData.d.ts.map +1 -1
  159. package/dist/components/core/model/ModelMetaData.js +48 -55
  160. package/dist/components/core/model/ModelMetaData.js.map +1 -1
  161. package/dist/components/core/model/ModelMetaData.tsx +4 -22
  162. package/dist/components/core/module/CreateModule.d.ts.map +1 -1
  163. package/dist/components/core/module/CreateModule.js +42 -44
  164. package/dist/components/core/module/CreateModule.js.map +1 -1
  165. package/dist/components/core/module/CreateModule.tsx +13 -27
  166. package/dist/components/core/module/ModuleListViewData.d.ts.map +1 -1
  167. package/dist/components/core/module/ModuleListViewData.js +11 -7
  168. package/dist/components/core/module/ModuleListViewData.js.map +1 -1
  169. package/dist/components/core/module/ModuleListViewData.tsx +10 -8
  170. package/dist/components/core/solid-ai/SolidAiChat.d.ts +3 -0
  171. package/dist/components/core/solid-ai/SolidAiChat.d.ts.map +1 -0
  172. package/dist/components/core/solid-ai/SolidAiChat.js +1043 -0
  173. package/dist/components/core/solid-ai/SolidAiChat.js.map +1 -0
  174. package/dist/components/core/solid-ai/SolidAiChat.module.css +1339 -0
  175. package/dist/components/core/solid-ai/SolidAiChat.tsx +1237 -0
  176. package/dist/components/core/tree/SolidTreeView.d.ts.map +1 -1
  177. package/dist/components/core/tree/SolidTreeView.js +32 -69
  178. package/dist/components/core/tree/SolidTreeView.js.map +1 -1
  179. package/dist/components/core/tree/SolidTreeView.tsx +8 -47
  180. package/dist/components/core/users/CreateUser.d.ts.map +1 -1
  181. package/dist/components/core/users/CreateUser.js +24 -37
  182. package/dist/components/core/users/CreateUser.js.map +1 -1
  183. package/dist/components/core/users/CreateUser.tsx +8 -46
  184. package/dist/components/core/users/UserListView.d.ts.map +1 -1
  185. package/dist/components/core/users/UserListView.js +9 -16
  186. package/dist/components/core/users/UserListView.js.map +1 -1
  187. package/dist/components/core/users/UserListView.tsx +5 -21
  188. package/dist/components/layout/AdminLayout.d.ts.map +1 -1
  189. package/dist/components/layout/AdminLayout.js +4 -2
  190. package/dist/components/layout/AdminLayout.js.map +1 -1
  191. package/dist/components/layout/AdminLayout.tsx +4 -2
  192. package/dist/components/layout/AdminTopHeader.d.ts +2 -0
  193. package/dist/components/layout/AdminTopHeader.d.ts.map +1 -0
  194. package/dist/components/layout/AdminTopHeader.js +80 -0
  195. package/dist/components/layout/AdminTopHeader.js.map +1 -0
  196. package/dist/components/layout/AdminTopHeader.tsx +165 -0
  197. package/dist/components/layout/AppSidebar.d.ts.map +1 -1
  198. package/dist/components/layout/AppSidebar.js +1 -2
  199. package/dist/components/layout/AppSidebar.js.map +1 -1
  200. package/dist/components/layout/AppSidebar.tsx +0 -2
  201. package/dist/components/layout/Layout.d.ts.map +1 -1
  202. package/dist/components/layout/Layout.js +2 -1
  203. package/dist/components/layout/Layout.js.map +1 -1
  204. package/dist/components/layout/Layout.tsx +2 -0
  205. package/dist/components/layout/SolidAiStudioLayout.d.ts +10 -0
  206. package/dist/components/layout/SolidAiStudioLayout.d.ts.map +1 -0
  207. package/dist/components/layout/SolidAiStudioLayout.js +159 -0
  208. package/dist/components/layout/SolidAiStudioLayout.js.map +1 -0
  209. package/dist/components/layout/SolidAiStudioLayout.tsx +333 -0
  210. package/dist/components/layout/navbar-one.d.ts.map +1 -1
  211. package/dist/components/layout/navbar-one.js +1 -2
  212. package/dist/components/layout/navbar-one.js.map +1 -1
  213. package/dist/components/layout/navbar-one.tsx +0 -2
  214. package/dist/components/layout/navbar-two-menu.d.ts.map +1 -1
  215. package/dist/components/layout/navbar-two-menu.js +50 -24
  216. package/dist/components/layout/navbar-two-menu.js.map +1 -1
  217. package/dist/components/layout/navbar-two-menu.tsx +48 -30
  218. package/dist/components/shad-cn-ui/SolidAutocomplete.d.ts +24 -0
  219. package/dist/components/shad-cn-ui/SolidAutocomplete.d.ts.map +1 -0
  220. package/dist/components/shad-cn-ui/SolidAutocomplete.js +224 -0
  221. package/dist/components/shad-cn-ui/SolidAutocomplete.js.map +1 -0
  222. package/dist/components/shad-cn-ui/SolidAutocomplete.tsx +339 -0
  223. package/dist/components/shad-cn-ui/SolidButton.d.ts +14 -0
  224. package/dist/components/shad-cn-ui/SolidButton.d.ts.map +1 -0
  225. package/dist/components/shad-cn-ui/SolidButton.js +36 -0
  226. package/dist/components/shad-cn-ui/SolidButton.js.map +1 -0
  227. package/dist/components/shad-cn-ui/SolidButton.tsx +54 -0
  228. package/dist/components/shad-cn-ui/SolidInput.d.ts +5 -0
  229. package/dist/components/shad-cn-ui/SolidInput.d.ts.map +1 -0
  230. package/dist/components/shad-cn-ui/SolidInput.js +35 -0
  231. package/dist/components/shad-cn-ui/SolidInput.js.map +1 -0
  232. package/dist/components/shad-cn-ui/SolidInput.tsx +12 -0
  233. package/dist/components/shad-cn-ui/SolidNumberInput.d.ts +10 -0
  234. package/dist/components/shad-cn-ui/SolidNumberInput.d.ts.map +1 -0
  235. package/dist/components/shad-cn-ui/SolidNumberInput.js +33 -0
  236. package/dist/components/shad-cn-ui/SolidNumberInput.js.map +1 -0
  237. package/dist/components/shad-cn-ui/SolidNumberInput.tsx +24 -0
  238. package/dist/components/shad-cn-ui/SolidSelect.d.ts +16 -0
  239. package/dist/components/shad-cn-ui/SolidSelect.d.ts.map +1 -0
  240. package/dist/components/shad-cn-ui/SolidSelect.js +26 -0
  241. package/dist/components/shad-cn-ui/SolidSelect.js.map +1 -0
  242. package/dist/components/shad-cn-ui/SolidSelect.tsx +65 -0
  243. package/dist/components/shad-cn-ui/SolidTabs.d.ts +18 -0
  244. package/dist/components/shad-cn-ui/SolidTabs.d.ts.map +1 -0
  245. package/dist/components/shad-cn-ui/SolidTabs.js +22 -0
  246. package/dist/components/shad-cn-ui/SolidTabs.js.map +1 -0
  247. package/dist/components/shad-cn-ui/SolidTabs.tsx +73 -0
  248. package/dist/components/shad-cn-ui/index.d.ts +7 -0
  249. package/dist/components/shad-cn-ui/index.d.ts.map +1 -0
  250. package/dist/components/shad-cn-ui/index.js +7 -0
  251. package/dist/components/shad-cn-ui/index.js.map +1 -0
  252. package/dist/components/shad-cn-ui/index.ts +6 -0
  253. package/dist/helpers/studioSandbox.d.ts +31 -0
  254. package/dist/helpers/studioSandbox.d.ts.map +1 -0
  255. package/dist/helpers/studioSandbox.js +104 -0
  256. package/dist/helpers/studioSandbox.js.map +1 -0
  257. package/dist/helpers/studioSandbox.ts +117 -0
  258. package/dist/index.d.ts +4 -0
  259. package/dist/index.d.ts.map +1 -1
  260. package/dist/index.js +3 -0
  261. package/dist/index.js.map +1 -1
  262. package/dist/index.ts +4 -0
  263. package/dist/redux/features/solidStudioSlice.d.ts +9 -0
  264. package/dist/redux/features/solidStudioSlice.d.ts.map +1 -0
  265. package/dist/redux/features/solidStudioSlice.js +72 -0
  266. package/dist/redux/features/solidStudioSlice.js.map +1 -0
  267. package/dist/redux/features/solidStudioSlice.ts +78 -0
  268. package/dist/redux/features/toastSlice.d.ts +15 -0
  269. package/dist/redux/features/toastSlice.d.ts.map +1 -0
  270. package/dist/redux/features/toastSlice.js +20 -0
  271. package/dist/redux/features/toastSlice.js.map +1 -0
  272. package/dist/redux/features/toastSlice.ts +35 -0
  273. package/dist/redux/store/defaultStoreConfig.d.ts +1 -0
  274. package/dist/redux/store/defaultStoreConfig.d.ts.map +1 -1
  275. package/dist/redux/store/defaultStoreConfig.js +2 -1
  276. package/dist/redux/store/defaultStoreConfig.js.map +1 -1
  277. package/dist/redux/store/defaultStoreConfig.ts +2 -0
  278. package/dist/resources/images/errors/error-astronaut-404.png +0 -0
  279. package/dist/resources/shadcn-base.css +4171 -0
  280. package/dist/routes/SolidLayoutRegistry.d.ts +51 -0
  281. package/dist/routes/SolidLayoutRegistry.d.ts.map +1 -0
  282. package/dist/routes/SolidLayoutRegistry.js +108 -0
  283. package/dist/routes/SolidLayoutRegistry.js.map +1 -0
  284. package/dist/routes/SolidLayoutRegistry.tsx +157 -0
  285. package/dist/routes/guards/AdminGuard.d.ts +2 -0
  286. package/dist/routes/guards/AdminGuard.d.ts.map +1 -0
  287. package/dist/routes/guards/AdminGuard.js +16 -0
  288. package/dist/routes/guards/AdminGuard.js.map +1 -0
  289. package/dist/routes/guards/AdminGuard.tsx +17 -0
  290. package/dist/routes/pages/studio/StudioHomePage.d.ts +2 -0
  291. package/dist/routes/pages/studio/StudioHomePage.d.ts.map +1 -0
  292. package/dist/routes/pages/studio/StudioHomePage.js +22 -0
  293. package/dist/routes/pages/studio/StudioHomePage.js.map +1 -0
  294. package/dist/routes/pages/studio/StudioHomePage.tsx +106 -0
  295. package/dist/routes/pages/studio/StudioLandingPage.d.ts +2 -0
  296. package/dist/routes/pages/studio/StudioLandingPage.d.ts.map +1 -0
  297. package/dist/routes/pages/studio/StudioLandingPage.js +78 -0
  298. package/dist/routes/pages/studio/StudioLandingPage.js.map +1 -0
  299. package/dist/routes/pages/studio/StudioLandingPage.tsx +320 -0
  300. package/package.json +1 -1
@@ -0,0 +1,333 @@
1
+ import React, { useEffect, useRef, useState } from "react";
2
+ import { useDispatch, useSelector } from "react-redux";
3
+ import { useNavigate, useLocation } from "react-router-dom";
4
+ // import { SolidAiChat } from "../core/solid-ai/SolidAiChat";
5
+ import { exitStudioMode, setStudioView, type StudioView } from "../../redux/features/solidStudioSlice";
6
+ import { useSession } from "../../hooks/useSession";
7
+ import { signOut } from "../../adapters/auth/index";
8
+ import { createPortal } from "react-dom";
9
+ import { enableStudioMode, disableStudioMode } from "../../helpers/studioSandbox";
10
+ import { env } from "../../adapters/env";
11
+
12
+ const HEADER_HEIGHT = "44px";
13
+ const PANEL_WIDTH_DEFAULT = 420;
14
+
15
+ // ── Icons ──────────────────────────────────────────────────────────────────────
16
+
17
+ const StudioIcon = () => (
18
+ <svg width="15" height="15" viewBox="0 0 16 16" fill="none" aria-hidden="true">
19
+ <path d="M2 8a6 6 0 1 1 12 0A6 6 0 0 1 2 8Z" stroke="currentColor" strokeWidth="1.4" />
20
+ <path d="M8 5v3l2 1.5" stroke="currentColor" strokeWidth="1.4" strokeLinecap="round" strokeLinejoin="round" />
21
+ <path d="M8 2V1M8 15v-1M1 8H0M16 8h-1" stroke="currentColor" strokeWidth="1.4" strokeLinecap="round" />
22
+ </svg>
23
+ );
24
+
25
+ const PanelOpenIcon = () => (
26
+ <svg width="15" height="15" viewBox="0 0 16 16" fill="none" aria-hidden="true">
27
+ <rect x="1" y="1" width="14" height="14" rx="2.5" stroke="currentColor" strokeWidth="1.3" />
28
+ <path d="M10 1v14" stroke="currentColor" strokeWidth="1.3" />
29
+ <path d="M12.5 6l1.5 2-1.5 2" stroke="currentColor" strokeWidth="1.2" strokeLinecap="round" strokeLinejoin="round" />
30
+ </svg>
31
+ );
32
+
33
+ const PanelCloseIcon = () => (
34
+ <svg width="15" height="15" viewBox="0 0 16 16" fill="none" aria-hidden="true">
35
+ <rect x="1" y="1" width="14" height="14" rx="2.5" stroke="currentColor" strokeWidth="1.3" />
36
+ <path d="M10 1v14" stroke="currentColor" strokeWidth="1.3" />
37
+ <path d="M13.5 6L12 8l1.5 2" stroke="currentColor" strokeWidth="1.2" strokeLinecap="round" strokeLinejoin="round" />
38
+ </svg>
39
+ );
40
+
41
+ const DotsIcon = () => (
42
+ <svg width="15" height="15" viewBox="0 0 16 16" fill="currentColor" aria-hidden="true">
43
+ <circle cx="8" cy="3" r="1.3" />
44
+ <circle cx="8" cy="8" r="1.3" />
45
+ <circle cx="8" cy="13" r="1.3" />
46
+ </svg>
47
+ );
48
+
49
+ const ExitStudioIcon = () => (
50
+ <svg width="13" height="13" viewBox="0 0 14 14" fill="none" aria-hidden="true">
51
+ <path d="M9.5 4.5 5 9M5 4.5l4.5 4.5" stroke="currentColor" strokeWidth="1.5" strokeLinecap="round" />
52
+ <rect x="1" y="1" width="12" height="12" rx="3" stroke="currentColor" strokeWidth="1.2" />
53
+ </svg>
54
+ );
55
+
56
+ const PreviewIcon = () => (
57
+ <svg width="13" height="13" viewBox="0 0 14 14" fill="none" aria-hidden="true">
58
+ <path d="M1 7s2.5-5 6-5 6 5 6 5-2.5 5-6 5-6-5-6-5Z" stroke="currentColor" strokeWidth="1.3" strokeLinejoin="round" />
59
+ <circle cx="7" cy="7" r="1.8" stroke="currentColor" strokeWidth="1.3" />
60
+ </svg>
61
+ );
62
+
63
+ const LogoutIcon = () => (
64
+ <svg width="13" height="13" viewBox="0 0 14 14" fill="none" aria-hidden="true">
65
+ <path d="M5 2H2.5A1.5 1.5 0 0 0 1 3.5v7A1.5 1.5 0 0 0 2.5 12H5" stroke="currentColor" strokeWidth="1.3" strokeLinecap="round" />
66
+ <path d="M9 4l3 3-3 3M12 7H5" stroke="currentColor" strokeWidth="1.3" strokeLinecap="round" strokeLinejoin="round" />
67
+ </svg>
68
+ );
69
+
70
+ export const ChatIcon = () => (
71
+ <svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2.2" strokeLinecap="round" strokeLinejoin="round">
72
+ <path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z" />
73
+ </svg>
74
+ );
75
+
76
+ // ── SolidStudio ────────────────────────────────────────────────────────────────
77
+ // Single component that renders both the Studio header and the AI panel.
78
+ // Mount this ONCE at the app root via AppEventListener.
79
+ // When studio mode is off it renders nothing.
80
+
81
+ export function SolidStudio() {
82
+ const isStudioMode = useSelector((state: any) => state.solidStudio?.isStudioMode ?? false);
83
+ const studioView = useSelector((state: any) => state.solidStudio?.studioView ?? null) as StudioView;
84
+ const dispatch = useDispatch();
85
+ const navigate = useNavigate();
86
+ const { pathname, search } = useLocation();
87
+ const isOnStudioPage = pathname === "/studio";
88
+ const isPreviewMode = new URLSearchParams(search).get("preview") === "true" || (typeof sessionStorage !== "undefined" && sessionStorage.getItem("solid-preview") === "true");
89
+ const isPreviewable = !isOnStudioPage && pathname !== "/landing";
90
+ const { status } = useSession();
91
+ const isAuthenticated = status === "authenticated";
92
+ const [isPanelOpen, setIsPanelOpen] = useState(true);
93
+ const [panelWidth] = useState(PANEL_WIDTH_DEFAULT);
94
+ const [isDragging] = useState(false);
95
+ const [isMenuOpen, setIsMenuOpen] = useState(false);
96
+ const menuRef = useRef<HTMLDivElement>(null);
97
+
98
+ // Close the 3-dot menu when clicking outside
99
+ useEffect(() => {
100
+ if (!isMenuOpen) return;
101
+ const handler = (e: MouseEvent) => {
102
+ if (menuRef.current && !menuRef.current.contains(e.target as Node)) {
103
+ setIsMenuOpen(false);
104
+ }
105
+ };
106
+ document.addEventListener("mousedown", handler);
107
+ return () => document.removeEventListener("mousedown", handler);
108
+ }, [isMenuOpen]);
109
+
110
+ // Apply sandbox wrapper isolating app root so all fixed/sticky elements shift correctly
111
+ useEffect(() => {
112
+ const active = isStudioMode && isAuthenticated && !isPreviewMode;
113
+
114
+ if (active) {
115
+ enableStudioMode();
116
+ } else {
117
+ disableStudioMode();
118
+ }
119
+
120
+ // CSS variable consumed by sidebar, hotspot, admin-header, shell, main
121
+ document.documentElement.style.setProperty(
122
+ "--solid-studio-header-height",
123
+ active ? HEADER_HEIGHT : "0px"
124
+ );
125
+
126
+ return () => {
127
+ disableStudioMode();
128
+ document.documentElement.style.setProperty("--solid-studio-header-height", "0px");
129
+ };
130
+ }, [isStudioMode, isAuthenticated, isPreviewMode]);
131
+
132
+ // const onDragStart = useCallback((e: React.MouseEvent) => {
133
+ // e.preventDefault();
134
+ // dragStartX.current = e.clientX;
135
+ // dragStartWidth.current = panelWidth;
136
+ // setIsDragging(true);
137
+ // const onMove = (ev: MouseEvent) => {
138
+ // const delta = dragStartX.current - ev.clientX;
139
+ // const next = Math.min(PANEL_WIDTH_MAX, Math.max(PANEL_WIDTH_MIN, dragStartWidth.current + delta));
140
+ // setPanelWidth(next);
141
+ // };
142
+ // const onUp = () => {
143
+ // setIsDragging(false);
144
+ // window.removeEventListener("mousemove", onMove);
145
+ // window.removeEventListener("mouseup", onUp);
146
+ // };
147
+ // window.addEventListener("mousemove", onMove);
148
+ // window.addEventListener("mouseup", onUp);
149
+ // }, [panelWidth]);
150
+
151
+ // Auto-exit studio if the user logs out
152
+ useEffect(() => {
153
+ if (status === "unauthenticated" && isStudioMode) {
154
+ dispatch(exitStudioMode());
155
+ }
156
+ }, [status, isStudioMode, dispatch]);
157
+
158
+ if (!isStudioMode || !isAuthenticated || isPreviewMode) return null;
159
+
160
+ const handleExit = () => {
161
+ setIsMenuOpen(false);
162
+ dispatch(exitStudioMode());
163
+ navigate("/studio");
164
+ };
165
+
166
+ const handleLogout = () => {
167
+ setIsMenuOpen(false);
168
+ dispatch(exitStudioMode());
169
+ signOut({ callbackUrl: "/auth/login" });
170
+ };
171
+
172
+ const handleViewSwitch = (view: StudioView) => {
173
+ dispatch(setStudioView(view));
174
+ navigate(view === "backend" ? "/admin" : "/landing");
175
+ };
176
+
177
+ const studioUI = (
178
+ <div style={{ zIndex: "var(--z-studio)", position: "fixed", top: 0, left: 0, right: 0 }}>
179
+ {/* ── Studio global header ─────────────────────────────────────────────── */}
180
+ <div className="solid-studio-header">
181
+ <button
182
+ type="button"
183
+ className="solid-studio-header-brand"
184
+ onClick={() => navigate("/studio")}
185
+ title="Go to Studio home"
186
+ >
187
+ <StudioIcon />
188
+ <span>SolidX Studio</span>
189
+ <span className="solid-studio-bar-badge">BETA</span>
190
+ </button>
191
+
192
+ <nav className="solid-studio-header-nav">
193
+ <button
194
+ type="button"
195
+ className={`solid-studio-view-btn${studioView === "backend" ? " active" : ""}`}
196
+ onClick={() => handleViewSwitch("backend")}
197
+ >
198
+ Backend
199
+ </button>
200
+ <button
201
+ type="button"
202
+ className={`solid-studio-view-btn${studioView === "frontend" ? " active" : ""}`}
203
+ onClick={() => handleViewSwitch("frontend")}
204
+ >
205
+ Frontend
206
+ </button>
207
+ </nav>
208
+
209
+ <div className="solid-studio-header-actions">
210
+ {/* <button
211
+ type="button"
212
+ className="solid-studio-panel-toggle-btn"
213
+ onClick={() => setIsPanelOpen((o) => !o)}
214
+ title={isPanelOpen ? "Collapse AI panel" : "Expand AI panel"}
215
+ >
216
+ {isPanelOpen ? <PanelCloseIcon /> : <PanelOpenIcon />}
217
+ </button> */}
218
+
219
+ {/* ── 3-dot menu ─────────────────────────────────────────────────── */}
220
+ <div className="solid-studio-menu" ref={menuRef}>
221
+ <button
222
+ type="button"
223
+ className="solid-studio-menu-trigger"
224
+ onClick={() => setIsMenuOpen((o) => !o)}
225
+ title="More options"
226
+ >
227
+ <DotsIcon />
228
+ </button>
229
+ {isMenuOpen && (
230
+ <div className="solid-studio-menu-dropdown">
231
+ {isPreviewable && (
232
+ <button
233
+ type="button"
234
+ className="solid-studio-menu-item"
235
+ onClick={() => {
236
+ setIsMenuOpen(false);
237
+ const params = new URLSearchParams(search);
238
+ params.set("preview", "true");
239
+ window.open(`${pathname}?${params.toString()}`, "_blank");
240
+ }}
241
+ >
242
+ <PreviewIcon />
243
+ Preview page
244
+ </button>
245
+ )}
246
+ {/* {!isOnStudioPage && (
247
+ <button type="button" className="solid-studio-menu-item" onClick={handleExit}>
248
+ <ExitStudioIcon />
249
+ Exit Studio
250
+ </button>
251
+ )} */}
252
+ <button type="button" className="solid-studio-menu-item danger" onClick={handleLogout}>
253
+ <LogoutIcon />
254
+ Logout
255
+ </button>
256
+ </div>
257
+ )}
258
+ </div>
259
+
260
+ <button
261
+ type="button"
262
+ className="solid-studio-menu-trigger"
263
+ style={{ color: "var(--primary-foreground)" }}
264
+ onClick={() => {
265
+ const aiUrl = env("VITE_SOLIDX_AI_URL");
266
+ if (aiUrl) window.open(aiUrl, "_blank");
267
+ }}
268
+ title="Open AI Chat"
269
+ >
270
+ <ChatIcon />
271
+ </button>
272
+ </div>
273
+ </div>
274
+
275
+ {/* ── AI chat panel (commented out — moved to agent-ui) ───────────────── */}
276
+ {/* <div
277
+ className={`solid-studio-panel-fixed${isPanelOpen ? "" : " collapsed"}`}
278
+ style={{ width: `${panelWidth}px` }}
279
+ >
280
+ <div
281
+ className={`solid-studio-resize-handle${isDragging ? " dragging" : ""}`}
282
+ onMouseDown={onDragStart}
283
+ />
284
+ <div className="solid-studio-panel-body">
285
+ <SolidAiChat />
286
+ </div>
287
+ </div> */}
288
+ </div>
289
+ );
290
+
291
+ return typeof document !== "undefined" ? createPortal(studioUI, document.body) : null;
292
+ }
293
+
294
+ // ── PreviewModePersist ─────────────────────────────────────────────────────────
295
+ // Mount once at the app root alongside SolidStudio.
296
+ // sessionStorage is tab-scoped, so preview opened in a new tab stays isolated.
297
+ // Closing the tab is the natural way to exit preview mode.
298
+
299
+ const PREVIEW_KEY = "solid-preview";
300
+
301
+ export function PreviewModePersist() {
302
+ const { pathname, search } = useLocation();
303
+ const navigate = useNavigate();
304
+
305
+ // Activate: when URL has ?preview=true, store it in sessionStorage for this tab
306
+ useEffect(() => {
307
+ const params = new URLSearchParams(search);
308
+ if (params.get("preview") === "true") {
309
+ sessionStorage.setItem(PREVIEW_KEY, "true");
310
+ }
311
+ }, [search]);
312
+
313
+ // Persist: re-inject ?preview=true on every navigation if it was set
314
+ useEffect(() => {
315
+ if (sessionStorage.getItem(PREVIEW_KEY) !== "true") return;
316
+ const params = new URLSearchParams(search);
317
+ if (params.get("preview") === "true") return;
318
+ params.set("preview", "true");
319
+ navigate({ pathname, search: `?${params.toString()}` }, { replace: true });
320
+ }, [pathname, search, navigate]);
321
+
322
+ return null;
323
+ }
324
+
325
+ // ── SolidStudioWrapper ─────────────────────────────────────────────────────────
326
+ // Kept for backwards compatibility. Now a pure pass-through.
327
+ export function SolidStudioWrapper({ children }: { children: React.ReactNode }) {
328
+ return <>{children}</>;
329
+ }
330
+
331
+ // Legacy aliases
332
+ export const SolidAiStudioLayout = SolidStudioWrapper;
333
+ export const SolidStudioPanel = SolidStudio;
@@ -1 +1 @@
1
- {"version":3,"file":"navbar-one.d.ts","sourceRoot":"","sources":["../../../src/components/layout/navbar-one.tsx"],"names":[],"mappings":"AAcA,QAAA,MAAM,SAAS,+CAmNd,CAAC;AAEF,eAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"navbar-one.d.ts","sourceRoot":"","sources":["../../../src/components/layout/navbar-one.tsx"],"names":[],"mappings":"AAaA,QAAA,MAAM,SAAS,+CAkNd,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -1,5 +1,4 @@
1
1
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { ToastContainer } from "../../helpers/ToastContainer";
3
2
  import { useGetSolidMenuBasedOnRoleQuery } from "../../redux/api/solidMenuApi";
4
3
  import { setIsAuthenticated, setUser } from "../../redux/features/userSlice";
5
4
  import { env } from "../../adapters/env";
@@ -59,7 +58,7 @@ var NavbarOne = function () {
59
58
  document.removeEventListener("mousedown", handleClickOutside);
60
59
  };
61
60
  }, [isSearchShow]);
62
- return (_jsxs("div", { className: "flex flex-column md:flex-row justify-content-between navBar", children: [_jsx(ToastContainer, {}), currentMainMenu && (_jsx("div", { children: _jsx("a", { className: visibleNavbar
61
+ return (_jsxs("div", { className: "flex flex-column md:flex-row justify-content-between navBar", children: [currentMainMenu && (_jsx("div", { children: _jsx("a", { className: visibleNavbar
63
62
  ? "navtwo-toggle active-menu-image"
64
63
  : "navtwo-toggle", onClick: handleToggle, children: _jsx("img", { style: { cursor: "pointer" }, src: "/images/menu-toggle.png", alt: "Solid" }) }) })), _jsxs("div", { className: "navBarOne", children: [_jsx("div", { children: _jsx("div", { className: "navbar-menu", children: _jsx(_Fragment, { children: menu && menu.data.length > 0 && menu.data.map(function (m) { return (_jsx("div", { className: "menu-item ".concat(currentMainMenu === m.title ? "active-menu-image" : ""), children: _jsx("a", { onClick: function () { return handleMenu(m); }, children: _jsx("img", { style: { cursor: "pointer", width: '30px' },
65
64
  // src={currentMainMenu === m.title ? `/images/${m.title.toLocaleLowerCase()}-active.svg` : `/images/${m.title.toLocaleLowerCase()}.svg`}
@@ -1 +1 @@
1
- {"version":3,"file":"navbar-one.js","sourceRoot":"","sources":["../../../src/components/layout/navbar-one.tsx"],"names":[],"mappings":"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","sourcesContent":["import { ToastContainer } from \"../../helpers/ToastContainer\";\nimport { useGetSolidMenuBasedOnRoleQuery } from \"../../redux/api/solidMenuApi\";\nimport { setIsAuthenticated, setUser } from \"../../redux/features/userSlice\";\nimport { env } from \"../../adapters/env\";\nimport { useSession } from \"../../hooks/useSession\";\nimport { Button } from \"primereact/button\";\nimport { IconField } from \"primereact/iconfield\";\nimport { InputIcon } from \"primereact/inputicon\";\nimport { InputText } from \"primereact/inputtext\";\nimport { useEffect, useRef, useState } from \"react\";\nimport { useDispatch } from \"react-redux\";\nimport NavbarTwoMenu from \"./navbar-two-menu\";\nimport UserProfileMenu from \"./user-profile-menu\";\n\nconst NavbarOne = () => {\n const dispatch = useDispatch();\n const [visibleNavbar, setVisibleNavbar] = useState(false);\n\n const { data: menu } = useGetSolidMenuBasedOnRoleQuery(\"\");\n\n const [currentMenu, setCurrentMenu] = useState();\n const [currentMainMenu, setCurrentMainMenu] = useState();\n const [searchTerm, setSearchTerm] = useState(\"\");\n\n useEffect(() => {\n if (menu) {\n setCurrentMenu(menu && menu.data.length > 0 && menu.data.filter((m: any) => m.key === env(\"NEXT_PUBLIC_DEFAULT_MENU_KEY\"))[0]?.children);\n setCurrentMainMenu(menu && menu.data.length > 0 && menu.data.filter((m: any) => m.key === env(\"NEXT_PUBLIC_DEFAULT_MENU_KEY\"))[0]?.title)\n }\n }, [menu])\n\n const { data } = useSession();\n\n // const handleToggle = () => setShow(!show);\n const handleToggle = () => setVisibleNavbar(!visibleNavbar);\n const handleMenu = (m: any) => {\n // setShow(true);\n setVisibleNavbar(!visibleNavbar);\n setCurrentMainMenu(m.title);\n setCurrentMenu(m.children);\n };\n\n useEffect(() => {\n if (data) {\n dispatch(setUser(data?.user));\n dispatch(setIsAuthenticated(true));\n }\n }, [data]);\n\n const [isSearchShow, setSearchShow] = useState(false);\n const searchRef = useRef<HTMLDivElement>(null);\n\n const handleClickOutside = (event: any) => {\n if (searchRef.current && !searchRef.current.contains(event.target)) {\n setSearchShow(false);\n }\n };\n\n useEffect(() => {\n if (isSearchShow) {\n document.addEventListener(\"mousedown\", handleClickOutside);\n } else {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n }\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n };\n }, [isSearchShow]);\n\n\n\n return (\n <div className=\"flex flex-column md:flex-row justify-content-between navBar\">\n <ToastContainer />\n\n {/* commented this as this is not working properly @Jenendar to figure this out... */}\n {currentMainMenu && (\n <div>\n <a\n className={\n visibleNavbar\n ? \"navtwo-toggle active-menu-image\"\n : \"navtwo-toggle\"\n }\n onClick={handleToggle}\n >\n <img\n style={{ cursor: \"pointer\" }}\n src={`/images/menu-toggle.png`}\n alt=\"Solid\"\n />\n </a>\n </div>\n )}\n <div className=\"navBarOne\">\n <div>\n <div className=\"navbar-menu\">\n <>\n {menu && menu.data.length > 0 && menu.data.map((m: any) => (\n <div\n key={m.title}\n className={`menu-item ${currentMainMenu === m.title ? \"active-menu-image\" : \"\"}`}\n >\n <a onClick={() => handleMenu(m)}>\n <img\n style={{ cursor: \"pointer\", width: '30px' }}\n // src={currentMainMenu === m.title ? `/images/${m.title.toLocaleLowerCase()}-active.svg` : `/images/${m.title.toLocaleLowerCase()}.svg`}\n // src={`/images/menu/${m.title}.svg`}\n src={m.icon.startsWith(\"/\") ? m.icon : `${env(\"API_URL\")}/${m.icon}`}\n // src={`/images/menu/app-builder.svg`}\n alt=\"Solid\"\n />\n </a>\n </div>\n ))}\n </>\n </div>\n </div>\n <UserProfileMenu></UserProfileMenu>\n </div>\n {currentMenu && (\n <div className={visibleNavbar ? \"show navBarTwo\" : \"hide navBarTwo\"}>\n <div className=\"flex relative justify-content-between align-items-center pt-4 px-3 pb-3 mb-3\">\n <div className=\"absolute bottom-0\" style={{ width: 50, height: 0.8, background: '#d8e2ea' }}></div>\n {!isSearchShow && <div className=\"text-base font-semibold\">{currentMainMenu && currentMainMenu}</div>}\n {isSearchShow === false && <Button outlined icon=\"pi pi-search\" severity=\"secondary\" aria-label=\"Search\" size=\"small\" style={{ maxWidth: 32, maxHeight: 32, border: '1px solid #d1d5db' }}\n onClick={() => setSearchShow(true)}\n />\n }\n {isSearchShow &&\n <div className=\"w-full\" style={{ position: 'relative' }} ref={searchRef}>\n <IconField iconPosition=\"left\">\n <InputIcon className=\"pi pi-search text-sm\"> </InputIcon>\n <InputText placeholder=\"Search\" className=\"small-input text-sm w-full pr-6\" />\n </IconField>\n <div className=\"absolute max-h-1rem\" style={{ top: 5, right: 5 }}>\n <img\n // className=\"absolute right-0 top-0 max-h-1rem\"\n style={{ cursor: \"pointer\", maxHeight: '1.3rem' }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div>\n </div>\n }\n {/* <div className=\"input-icon inputDiv navtwo-searchbox\">\n <i className=\"pi pi-search \" style={{ color: '#8D9199' }}></i>\n <input\n type=\"text\"\n placeholder=\"Jump to.\"\n name=\"lastName\"\n id=\"lastName\"\n onChange={(e) => setSearchTerm(e.target.value)}\n value={searchTerm}\n className=\"\"\n />\n <img\n style={{ cursor: \"pointer\" }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div> */}\n </div>\n {/* <div className=\"flex flex-column md:flex-row navtwo-header justify-content-between\">\n <div className=\"text-sm font-semibold\">{currentMainMenu && currentMainMenu}</div> */}\n {/* <a\n className={\n visibleNavbar\n ? \"navtwo-toggle active-menu-image\"\n : \"navtwo-toggle\"\n }\n onClick={handleToggle}\n >\n <img\n style={{ cursor: \"pointer\" }}\n src={`/images/menu-toggle.png`}\n alt=\"Solid\"\n />\n </a> */}\n {/* </div>\n <div className=\"p-inputgroup\"> */}\n {/* <div className=\"p-inputgroup navtwo-searchbox\">\n \n <span className=\"p-inputgroup-addon\">\n <i className=\"pi pi-search \"></i>\n </span>\n <InputText\n placeholder=\"Search\"\n onChange={e => setSearchTerm(e.target.value)} \n />\n <span className=\"p-inputgroup-addon\">⌘+k</span>\n </div> */}\n {/* <div className=\"input-icon inputDiv navtwo-searchbox\">\n <i className=\"pi pi-search \" style={{ color: '#8D9199' }}></i>\n <input\n type=\"text\"\n placeholder=\"Jump to.\"\n name=\"lastName\"\n id=\"lastName\"\n onChange={(e) => setSearchTerm(e.target.value)}\n value={searchTerm}\n className=\"\"\n />\n <img\n style={{ cursor: \"pointer\" }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div> */}\n\n {/* <Button icon=\"pi pi-search\" className=\"p-button-outlined\" onClick={handleSearch} /> */}\n {/* </div> */}\n\n <div\n className={\n visibleNavbar ? \"navTwoMenuLayout px-2 show\" : \"navTwoMenuLayout hide\"\n }\n >\n <NavbarTwoMenu menuItems={currentMenu}></NavbarTwoMenu>\n </div>\n </div>\n )}\n </div>\n );\n};\n\nexport default NavbarOne;\n"]}
1
+ {"version":3,"file":"navbar-one.js","sourceRoot":"","sources":["../../../src/components/layout/navbar-one.tsx"],"names":[],"mappings":"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","sourcesContent":["import { useGetSolidMenuBasedOnRoleQuery } from \"../../redux/api/solidMenuApi\";\nimport { setIsAuthenticated, setUser } from \"../../redux/features/userSlice\";\nimport { env } from \"../../adapters/env\";\nimport { useSession } from \"../../hooks/useSession\";\nimport { Button } from \"primereact/button\";\nimport { IconField } from \"primereact/iconfield\";\nimport { InputIcon } from \"primereact/inputicon\";\nimport { InputText } from \"primereact/inputtext\";\nimport { useEffect, useRef, useState } from \"react\";\nimport { useDispatch } from \"react-redux\";\nimport NavbarTwoMenu from \"./navbar-two-menu\";\nimport UserProfileMenu from \"./user-profile-menu\";\n\nconst NavbarOne = () => {\n const dispatch = useDispatch();\n const [visibleNavbar, setVisibleNavbar] = useState(false);\n\n const { data: menu } = useGetSolidMenuBasedOnRoleQuery(\"\");\n\n const [currentMenu, setCurrentMenu] = useState();\n const [currentMainMenu, setCurrentMainMenu] = useState();\n const [searchTerm, setSearchTerm] = useState(\"\");\n\n useEffect(() => {\n if (menu) {\n setCurrentMenu(menu && menu.data.length > 0 && menu.data.filter((m: any) => m.key === env(\"NEXT_PUBLIC_DEFAULT_MENU_KEY\"))[0]?.children);\n setCurrentMainMenu(menu && menu.data.length > 0 && menu.data.filter((m: any) => m.key === env(\"NEXT_PUBLIC_DEFAULT_MENU_KEY\"))[0]?.title)\n }\n }, [menu])\n\n const { data } = useSession();\n\n // const handleToggle = () => setShow(!show);\n const handleToggle = () => setVisibleNavbar(!visibleNavbar);\n const handleMenu = (m: any) => {\n // setShow(true);\n setVisibleNavbar(!visibleNavbar);\n setCurrentMainMenu(m.title);\n setCurrentMenu(m.children);\n };\n\n useEffect(() => {\n if (data) {\n dispatch(setUser(data?.user));\n dispatch(setIsAuthenticated(true));\n }\n }, [data]);\n\n const [isSearchShow, setSearchShow] = useState(false);\n const searchRef = useRef<HTMLDivElement>(null);\n\n const handleClickOutside = (event: any) => {\n if (searchRef.current && !searchRef.current.contains(event.target)) {\n setSearchShow(false);\n }\n };\n\n useEffect(() => {\n if (isSearchShow) {\n document.addEventListener(\"mousedown\", handleClickOutside);\n } else {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n }\n\n return () => {\n document.removeEventListener(\"mousedown\", handleClickOutside);\n };\n }, [isSearchShow]);\n\n\n\n return (\n <div className=\"flex flex-column md:flex-row justify-content-between navBar\">\n\n {/* commented this as this is not working properly @Jenendar to figure this out... */}\n {currentMainMenu && (\n <div>\n <a\n className={\n visibleNavbar\n ? \"navtwo-toggle active-menu-image\"\n : \"navtwo-toggle\"\n }\n onClick={handleToggle}\n >\n <img\n style={{ cursor: \"pointer\" }}\n src={`/images/menu-toggle.png`}\n alt=\"Solid\"\n />\n </a>\n </div>\n )}\n <div className=\"navBarOne\">\n <div>\n <div className=\"navbar-menu\">\n <>\n {menu && menu.data.length > 0 && menu.data.map((m: any) => (\n <div\n key={m.title}\n className={`menu-item ${currentMainMenu === m.title ? \"active-menu-image\" : \"\"}`}\n >\n <a onClick={() => handleMenu(m)}>\n <img\n style={{ cursor: \"pointer\", width: '30px' }}\n // src={currentMainMenu === m.title ? `/images/${m.title.toLocaleLowerCase()}-active.svg` : `/images/${m.title.toLocaleLowerCase()}.svg`}\n // src={`/images/menu/${m.title}.svg`}\n src={m.icon.startsWith(\"/\") ? m.icon : `${env(\"API_URL\")}/${m.icon}`}\n // src={`/images/menu/app-builder.svg`}\n alt=\"Solid\"\n />\n </a>\n </div>\n ))}\n </>\n </div>\n </div>\n <UserProfileMenu></UserProfileMenu>\n </div>\n {currentMenu && (\n <div className={visibleNavbar ? \"show navBarTwo\" : \"hide navBarTwo\"}>\n <div className=\"flex relative justify-content-between align-items-center pt-4 px-3 pb-3 mb-3\">\n <div className=\"absolute bottom-0\" style={{ width: 50, height: 0.8, background: '#d8e2ea' }}></div>\n {!isSearchShow && <div className=\"text-base font-semibold\">{currentMainMenu && currentMainMenu}</div>}\n {isSearchShow === false && <Button outlined icon=\"pi pi-search\" severity=\"secondary\" aria-label=\"Search\" size=\"small\" style={{ maxWidth: 32, maxHeight: 32, border: '1px solid #d1d5db' }}\n onClick={() => setSearchShow(true)}\n />\n }\n {isSearchShow &&\n <div className=\"w-full\" style={{ position: 'relative' }} ref={searchRef}>\n <IconField iconPosition=\"left\">\n <InputIcon className=\"pi pi-search text-sm\"> </InputIcon>\n <InputText placeholder=\"Search\" className=\"small-input text-sm w-full pr-6\" />\n </IconField>\n <div className=\"absolute max-h-1rem\" style={{ top: 5, right: 5 }}>\n <img\n // className=\"absolute right-0 top-0 max-h-1rem\"\n style={{ cursor: \"pointer\", maxHeight: '1.3rem' }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div>\n </div>\n }\n {/* <div className=\"input-icon inputDiv navtwo-searchbox\">\n <i className=\"pi pi-search \" style={{ color: '#8D9199' }}></i>\n <input\n type=\"text\"\n placeholder=\"Jump to.\"\n name=\"lastName\"\n id=\"lastName\"\n onChange={(e) => setSearchTerm(e.target.value)}\n value={searchTerm}\n className=\"\"\n />\n <img\n style={{ cursor: \"pointer\" }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div> */}\n </div>\n {/* <div className=\"flex flex-column md:flex-row navtwo-header justify-content-between\">\n <div className=\"text-sm font-semibold\">{currentMainMenu && currentMainMenu}</div> */}\n {/* <a\n className={\n visibleNavbar\n ? \"navtwo-toggle active-menu-image\"\n : \"navtwo-toggle\"\n }\n onClick={handleToggle}\n >\n <img\n style={{ cursor: \"pointer\" }}\n src={`/images/menu-toggle.png`}\n alt=\"Solid\"\n />\n </a> */}\n {/* </div>\n <div className=\"p-inputgroup\"> */}\n {/* <div className=\"p-inputgroup navtwo-searchbox\">\n \n <span className=\"p-inputgroup-addon\">\n <i className=\"pi pi-search \"></i>\n </span>\n <InputText\n placeholder=\"Search\"\n onChange={e => setSearchTerm(e.target.value)} \n />\n <span className=\"p-inputgroup-addon\">⌘+k</span>\n </div> */}\n {/* <div className=\"input-icon inputDiv navtwo-searchbox\">\n <i className=\"pi pi-search \" style={{ color: '#8D9199' }}></i>\n <input\n type=\"text\"\n placeholder=\"Jump to.\"\n name=\"lastName\"\n id=\"lastName\"\n onChange={(e) => setSearchTerm(e.target.value)}\n value={searchTerm}\n className=\"\"\n />\n <img\n style={{ cursor: \"pointer\" }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div> */}\n\n {/* <Button icon=\"pi pi-search\" className=\"p-button-outlined\" onClick={handleSearch} /> */}\n {/* </div> */}\n\n <div\n className={\n visibleNavbar ? \"navTwoMenuLayout px-2 show\" : \"navTwoMenuLayout hide\"\n }\n >\n <NavbarTwoMenu menuItems={currentMenu}></NavbarTwoMenu>\n </div>\n </div>\n )}\n </div>\n );\n};\n\nexport default NavbarOne;\n"]}
@@ -1,4 +1,3 @@
1
- import { ToastContainer } from "../../helpers/ToastContainer";
2
1
  import { useGetSolidMenuBasedOnRoleQuery } from "../../redux/api/solidMenuApi";
3
2
  import { setIsAuthenticated, setUser } from "../../redux/features/userSlice";
4
3
  import { env } from "../../adapters/env";
@@ -72,7 +71,6 @@ const NavbarOne = () => {
72
71
 
73
72
  return (
74
73
  <div className="flex flex-column md:flex-row justify-content-between navBar">
75
- <ToastContainer />
76
74
 
77
75
  {/* commented this as this is not working properly @Jenendar to figure this out... */}
78
76
  {currentMainMenu && (
@@ -1 +1 @@
1
- {"version":3,"file":"navbar-two-menu.d.ts","sourceRoot":"","sources":["../../../src/components/layout/navbar-two-menu.tsx"],"names":[],"mappings":"AAKA,QAAA,MAAM,aAAa,kBAAmB,GAAG,4CA+DxC,CAAC;AAEF,eAAe,aAAa,CAAC"}
1
+ {"version":3,"file":"navbar-two-menu.d.ts","sourceRoot":"","sources":["../../../src/components/layout/navbar-two-menu.tsx"],"names":[],"mappings":"AAMA,QAAA,MAAM,aAAa,kBAAmB,GAAG,4CAgFxC,CAAC;AAEF,eAAe,aAAa,CAAC"}
@@ -1,45 +1,71 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
1
12
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
13
  import Link from "../common/Link";
3
- import { usePathname } from "../../hooks/usePathname";
4
14
  import { PanelMenu } from "primereact/panelmenu";
5
- import { useState } from "react";
15
+ import { useState, useEffect } from "react";
16
+ import { useSearchParams } from "../../hooks/useSearchParams";
6
17
  var NavbarTwoMenu = function (_a) {
7
18
  var menuItems = _a.menuItems;
8
- var pathname = usePathname();
19
+ var searchParams = useSearchParams();
9
20
  var _b = useState({}), expandedKeys = _b[0], setExpandedKeys = _b[1];
21
+ var activeId = searchParams.get("menuItemId");
22
+ var hasActiveChild = function (items) {
23
+ if (!activeId)
24
+ return false;
25
+ return items === null || items === void 0 ? void 0 : items.some(function (item) { var _a; return (item.id !== null && item.id === activeId) || hasActiveChild((_a = item.items) !== null && _a !== void 0 ? _a : []); });
26
+ };
10
27
  var itemRenderer = function (item, options) {
11
- var _a;
12
- var isSelected = pathname === item.url;
13
- return (_jsx("div", { className: "flex align-items-center cursor-pointer menuHead px-3 ".concat(isSelected ? ' p-highlight' : ''), onClick: options.onClick, children: _jsxs(Link, { href: (item === null || item === void 0 ? void 0 : item.url) ? item === null || item === void 0 ? void 0 : item.url : '#', className: "w-full flex justify-content-between font-normal", children: [_jsxs("div", { className: "flex align-items-center", style: { gap: 10 }, children: [item.icon && (
28
+ var _a, _b;
29
+ var isSelected = activeId !== null && item.id !== null && item.id === activeId;
30
+ var isParentActive = activeId !== null && ((_a = item.items) === null || _a === void 0 ? void 0 : _a.length) > 0 && hasActiveChild(item.items);
31
+ return (_jsx("div", { className: "flex align-items-center cursor-pointer menuHead px-3 ".concat(isSelected || isParentActive ? "p-highlight" : ""), onClick: options.onClick, children: _jsxs(Link, { href: (item === null || item === void 0 ? void 0 : item.url) ? item === null || item === void 0 ? void 0 : item.url : "#", className: "w-full flex justify-content-between font-normal", children: [_jsxs("div", { className: "flex align-items-center", style: { gap: 10 }, children: [item.icon && (
14
32
  // material-symbols-${item.iconVariant ?? 'outlined'}
15
- _jsx("span", { className: "material-symbols-outlined", style: { fontSize: 18 }, children: item.icon })), _jsx("span", { children: item.label })] }), (item === null || item === void 0 ? void 0 : item.items) && ((_a = item === null || item === void 0 ? void 0 : item.items) === null || _a === void 0 ? void 0 : _a.length) > 0 &&
16
- _jsx("span", { className: "sidebar-chevrons ".concat(expandedKeys[item.key] === true ? "pi pi-angle-up" : "pi pi-angle-down") })] }) }, item === null || item === void 0 ? void 0 : item.key));
33
+ _jsx("span", { className: "material-symbols-outlined", style: { fontSize: 18 }, children: item.icon })), _jsx("span", { children: item.label })] }), ((_b = item === null || item === void 0 ? void 0 : item.items) === null || _b === void 0 ? void 0 : _b.length) > 0 &&
34
+ _jsx("span", { className: "sidebar-chevrons ".concat(expandedKeys[item.key] ? "pi pi-angle-up" : "pi pi-angle-down") })] }) }, item === null || item === void 0 ? void 0 : item.key));
17
35
  };
18
36
  var createMenuItems = function (menuItems) {
19
37
  return menuItems.map(function (mi) {
20
- var _a;
21
- return ({
38
+ var _a, _b, _c;
39
+ var menuItemId = new URLSearchParams((_a = mi.path) === null || _a === void 0 ? void 0 : _a.split("?")[1]).get("menuItemId");
40
+ return {
22
41
  key: mi.key,
42
+ id: menuItemId,
23
43
  label: mi.title,
24
- icon: (_a = mi.icon) !== null && _a !== void 0 ? _a : "",
44
+ icon: (_b = mi.icon) !== null && _b !== void 0 ? _b : "",
25
45
  // iconVariant: mi.iconVariant,
26
46
  template: itemRenderer,
27
- url: mi.path ? mi.path : null,
28
- items: mi.children ? createMenuItems(mi.children) : null, // Recursively add children
29
- });
47
+ url: (_c = mi.path) !== null && _c !== void 0 ? _c : null,
48
+ items: mi.children ? createMenuItems(mi.children) : null,
49
+ };
30
50
  });
31
51
  };
32
52
  var items = createMenuItems(menuItems);
33
- var onExpandedKeysChange = function (keys) {
34
- setExpandedKeys(keys);
35
- };
36
- var expandNode = function (node) {
37
- if (node.items && node.items.length) {
38
- expandedKeys[node.key] = true;
39
- node.items.forEach(expandNode);
40
- }
41
- };
42
- return (_jsx("div", { className: "solid-panel-menu", children: _jsx(PanelMenu, { model: items, expandedKeys: expandedKeys, onExpandedKeysChange: onExpandedKeysChange, className: "w-full", multiple: true }) }));
53
+ // Auto-expand parents with active child when activeId changes
54
+ useEffect(function () {
55
+ var newExpandedKeys = {};
56
+ var expandIfActive = function (items) {
57
+ items === null || items === void 0 ? void 0 : items.forEach(function (item) {
58
+ var _a;
59
+ if (((_a = item.items) === null || _a === void 0 ? void 0 : _a.length) && hasActiveChild(item.items)) {
60
+ newExpandedKeys[item.key] = true;
61
+ expandIfActive(item.items);
62
+ }
63
+ });
64
+ };
65
+ expandIfActive(createMenuItems(menuItems));
66
+ setExpandedKeys(function (prev) { return (__assign(__assign({}, prev), newExpandedKeys)); });
67
+ }, [activeId]);
68
+ return (_jsx("div", { className: "solid-panel-menu", children: _jsx(PanelMenu, { model: items, expandedKeys: expandedKeys, onExpandedKeysChange: setExpandedKeys, className: "w-full", multiple: true }) }));
43
69
  };
44
70
  export default NavbarTwoMenu;
45
71
  //# sourceMappingURL=navbar-two-menu.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"navbar-two-menu.js","sourceRoot":"","sources":["../../../src/components/layout/navbar-two-menu.tsx"],"names":[],"mappings":"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","sourcesContent":["import Link from \"../common/Link\";\nimport { usePathname } from \"../../hooks/usePathname\";\nimport { PanelMenu } from \"primereact/panelmenu\";\nimport { useState } from \"react\";\n\nconst NavbarTwoMenu = ({ menuItems }: any) => {\n const pathname = usePathname();\n const [expandedKeys, setExpandedKeys] = useState<any>({});\n const itemRenderer = (item: any, options: any) => {\n const isSelected = pathname === item.url\n return (\n <div key={item?.key} className={`flex align-items-center cursor-pointer menuHead px-3 ${isSelected ? ' p-highlight' : ''}`} onClick={options.onClick}>\n <Link href={item?.url ? item?.url : '#'} className=\"w-full flex justify-content-between font-normal\">\n <div className=\"flex align-items-center\" style={{ gap: 10 }}>\n {item.icon && (\n // material-symbols-${item.iconVariant ?? 'outlined'}\n <span className={`material-symbols-outlined`} style={{ fontSize: 18 }}>\n {item.icon}\n </span>\n )}\n <span>\n {item.label}\n </span>\n </div>\n {item?.items && item?.items?.length > 0 &&\n <span className={`sidebar-chevrons ${expandedKeys[item.key] === true ? \"pi pi-angle-up\" : \"pi pi-angle-down\"}`} />\n }\n </Link>\n </div>\n )\n };\n\n const createMenuItems = (menuItems: any[]): any[] => {\n return menuItems.map((mi) => ({\n key: mi.key,\n label: mi.title,\n icon: mi.icon ?? \"\",\n // iconVariant: mi.iconVariant,\n template: itemRenderer,\n url: mi.path ? mi.path : null,\n items: mi.children ? createMenuItems(mi.children) : null, // Recursively add children\n }));\n };\n\n const items = createMenuItems(menuItems);\n\n const onExpandedKeysChange = (keys: any) => {\n setExpandedKeys(keys);\n };\n\n const expandNode = (node: any) => {\n if (node.items && node.items.length) {\n expandedKeys[node.key] = true;\n node.items.forEach(expandNode);\n }\n };\n\n return (\n <div className=\"solid-panel-menu\">\n <PanelMenu\n model={items}\n expandedKeys={expandedKeys}\n onExpandedKeysChange={onExpandedKeysChange}\n className=\"w-full\"\n multiple\n />\n </div>\n );\n};\n\nexport default NavbarTwoMenu;\n"]}
1
+ {"version":3,"file":"navbar-two-menu.js","sourceRoot":"","sources":["../../../src/components/layout/navbar-two-menu.tsx"],"names":[],"mappings":"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","sourcesContent":["import Link from \"../common/Link\";\nimport { usePathname } from \"../../hooks/usePathname\";\nimport { PanelMenu } from \"primereact/panelmenu\";\nimport { useState, useEffect } from \"react\";\nimport { useSearchParams } from \"../../hooks/useSearchParams\";\n\nconst NavbarTwoMenu = ({ menuItems }: any) => {\n const searchParams = useSearchParams();\n const [expandedKeys, setExpandedKeys] = useState<any>({});\n\n const activeId = searchParams.get(\"menuItemId\");\n const hasActiveChild = (items: any[]): boolean => {\n if (!activeId) return false;\n return items?.some((item) =>\n (item.id !== null && item.id === activeId) || hasActiveChild(item.items ?? [])\n );\n };\n const itemRenderer = (item: any, options: any) => {\n const isSelected = activeId !== null && item.id !== null && item.id === activeId;\n const isParentActive = activeId !== null && item.items?.length > 0 && hasActiveChild(item.items);\n return (\n <div key={item?.key} className={`flex align-items-center cursor-pointer menuHead px-3 ${isSelected || isParentActive ? \"p-highlight\" : \"\"}`} onClick={options.onClick} >\n <Link href={item?.url ? item?.url : \"#\"} className=\"w-full flex justify-content-between font-normal\">\n <div className=\"flex align-items-center\" style={{ gap: 10 }}>\n {item.icon && (\n // material-symbols-${item.iconVariant ?? 'outlined'}\n <span className=\"material-symbols-outlined\" style={{ fontSize: 18 }}>\n {item.icon}\n </span>\n )}\n <span>\n {item.label}\n </span>\n </div>\n {item?.items?.length > 0 &&\n <span className={`sidebar-chevrons ${expandedKeys[item.key] ? \"pi pi-angle-up\" : \"pi pi-angle-down\"}`} />\n }\n </Link>\n </div>\n )\n };\n\n const createMenuItems = (menuItems: any[]): any[] =>\n menuItems.map((mi) => {\n const menuItemId = new URLSearchParams(mi.path?.split(\"?\")[1]).get(\"menuItemId\");\n return {\n key: mi.key,\n id: menuItemId, // ← extracted from path\n label: mi.title,\n icon: mi.icon ?? \"\",\n // iconVariant: mi.iconVariant,\n template: itemRenderer,\n url: mi.path ?? null,\n items: mi.children ? createMenuItems(mi.children) : null,\n };\n })\n\n\n const items = createMenuItems(menuItems);\n\n // Auto-expand parents with active child when activeId changes\n useEffect(() => {\n const newExpandedKeys: any = {};\n const expandIfActive = (items: any[]) => {\n items?.forEach((item) => {\n if (item.items?.length && hasActiveChild(item.items)) {\n newExpandedKeys[item.key] = true;\n expandIfActive(item.items);\n }\n });\n };\n expandIfActive(createMenuItems(menuItems));\n setExpandedKeys((prev: any) => ({ ...prev, ...newExpandedKeys }));\n }, [activeId]);\n\n return (\n <div className=\"solid-panel-menu\">\n <PanelMenu\n model={items}\n expandedKeys={expandedKeys}\n onExpandedKeysChange={setExpandedKeys}\n className=\"w-full\"\n multiple\n />\n </div>\n );\n};\n\nexport default NavbarTwoMenu;\n"]}