@solidxai/core-ui 0.1.5-beta.9 → 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.
- package/dist/components/auth/AuthTabs.d.ts +14 -0
- package/dist/components/auth/AuthTabs.d.ts.map +1 -0
- package/dist/components/auth/AuthTabs.js +19 -0
- package/dist/components/auth/AuthTabs.js.map +1 -0
- package/dist/components/auth/AuthTabs.tsx +38 -0
- package/dist/components/auth/GoogleAuthChecking.d.ts.map +1 -1
- package/dist/components/auth/GoogleAuthChecking.js +10 -10
- package/dist/components/auth/GoogleAuthChecking.js.map +1 -1
- package/dist/components/auth/GoogleAuthChecking.tsx +8 -9
- package/dist/components/auth/SolidChangeForcePassword.d.ts.map +1 -1
- package/dist/components/auth/SolidChangeForcePassword.js +9 -10
- package/dist/components/auth/SolidChangeForcePassword.js.map +1 -1
- package/dist/components/auth/SolidChangeForcePassword.tsx +6 -9
- package/dist/components/auth/SolidForgotPassword.d.ts.map +1 -1
- package/dist/components/auth/SolidForgotPassword.js +8 -8
- package/dist/components/auth/SolidForgotPassword.js.map +1 -1
- package/dist/components/auth/SolidForgotPassword.tsx +6 -8
- package/dist/components/auth/SolidInitialLoginOtp.d.ts.map +1 -1
- package/dist/components/auth/SolidInitialLoginOtp.js +57 -57
- package/dist/components/auth/SolidInitialLoginOtp.js.map +1 -1
- package/dist/components/auth/SolidInitialLoginOtp.tsx +10 -11
- package/dist/components/auth/SolidInitiateRegisterOtp.d.ts.map +1 -1
- package/dist/components/auth/SolidInitiateRegisterOtp.js +57 -57
- package/dist/components/auth/SolidInitiateRegisterOtp.js.map +1 -1
- package/dist/components/auth/SolidInitiateRegisterOtp.tsx +10 -11
- package/dist/components/auth/SolidLogin.d.ts.map +1 -1
- package/dist/components/auth/SolidLogin.js +12 -12
- package/dist/components/auth/SolidLogin.js.map +1 -1
- package/dist/components/auth/SolidLogin.tsx +11 -16
- package/dist/components/auth/SolidRegister.d.ts.map +1 -1
- package/dist/components/auth/SolidRegister.js +19 -19
- package/dist/components/auth/SolidRegister.js.map +1 -1
- package/dist/components/auth/SolidRegister.tsx +18 -23
- package/dist/components/auth/SolidResetPassword.d.ts.map +1 -1
- package/dist/components/auth/SolidResetPassword.js +15 -15
- package/dist/components/auth/SolidResetPassword.js.map +1 -1
- package/dist/components/auth/SolidResetPassword.tsx +7 -8
- package/dist/components/common/GeneralSettings.d.ts.map +1 -1
- package/dist/components/common/GeneralSettings.js +87 -120
- package/dist/components/common/GeneralSettings.js.map +1 -1
- package/dist/components/common/GeneralSettings.tsx +12 -42
- package/dist/components/common/GlobalToast.d.ts +2 -0
- package/dist/components/common/GlobalToast.d.ts.map +1 -0
- package/dist/components/common/GlobalToast.js +25 -0
- package/dist/components/common/GlobalToast.js.map +1 -0
- package/dist/components/common/GlobalToast.tsx +25 -0
- package/dist/components/common/SolidErrorStatePage.d.ts +12 -0
- package/dist/components/common/SolidErrorStatePage.d.ts.map +1 -0
- package/dist/components/common/SolidErrorStatePage.js +16 -0
- package/dist/components/common/SolidErrorStatePage.js.map +1 -0
- package/dist/components/common/SolidErrorStatePage.tsx +55 -0
- package/dist/components/common/SolidExport.d.ts.map +1 -1
- package/dist/components/common/SolidExport.js +19 -31
- package/dist/components/common/SolidExport.js.map +1 -1
- package/dist/components/common/SolidExport.tsx +7 -19
- package/dist/components/common/SolidFormStepper.d.ts.map +1 -1
- package/dist/components/common/SolidFormStepper.js +41 -41
- package/dist/components/common/SolidFormStepper.js.map +1 -1
- package/dist/components/common/SolidFormStepper.tsx +5 -6
- package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.d.ts.map +1 -1
- package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.js +9 -9
- package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.js.map +1 -1
- package/dist/components/core/common/SolidAccountSettings/SolidChangePassword.tsx +8 -9
- package/dist/components/core/common/SolidAccountSettings/SolidNotifications.d.ts.map +1 -1
- package/dist/components/core/common/SolidAccountSettings/SolidNotifications.js +8 -8
- package/dist/components/core/common/SolidAccountSettings/SolidNotifications.js.map +1 -1
- package/dist/components/core/common/SolidAccountSettings/SolidNotifications.tsx +7 -9
- package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.d.ts.map +1 -1
- package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.js +11 -11
- package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.js.map +1 -1
- package/dist/components/core/common/SolidAccountSettings/SolidPersonalInfo.tsx +10 -11
- package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.d.ts.map +1 -1
- package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.js +9 -9
- package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.js.map +1 -1
- package/dist/components/core/common/SolidGenericImport/SolidImportDropzone.tsx +8 -9
- package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.d.ts.map +1 -1
- package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.js +7 -7
- package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.js.map +1 -1
- package/dist/components/core/common/SolidGenericImport/SolidImportTransaction.tsx +6 -7
- package/dist/components/core/common/SolidGlobalSearchElement.d.ts.map +1 -1
- package/dist/components/core/common/SolidGlobalSearchElement.js +78 -21
- package/dist/components/core/common/SolidGlobalSearchElement.js.map +1 -1
- package/dist/components/core/common/SolidGlobalSearchElement.tsx +65 -10
- package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.d.ts.map +1 -1
- package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.js +6 -8
- package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.js.map +1 -1
- package/dist/components/core/extension/solid-core/modelMetadata/list/DeleteModelRowAction.tsx +5 -9
- package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.d.ts.map +1 -1
- package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.js +9 -11
- package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.js.map +1 -1
- package/dist/components/core/extension/solid-core/modelMetadata/list/GenerateModelCodeRowAction.tsx +5 -10
- package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.d.ts.map +1 -1
- package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.js +5 -6
- package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.js.map +1 -1
- package/dist/components/core/extension/solid-core/moduleMetadata/list/DeleteModuleRowAction.tsx +5 -8
- package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.d.ts.map +1 -1
- package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.js +10 -12
- package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.js.map +1 -1
- package/dist/components/core/extension/solid-core/moduleMetadata/list/GenerateModuleCodeRowAction.tsx +6 -11
- package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.d.ts.map +1 -1
- package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.js +11 -6
- package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.js.map +1 -1
- package/dist/components/core/extension/solid-core/roleMetadata/RolePermissionsManyToManyFieldWidget.tsx +13 -1
- package/dist/components/core/form/SolidFormUserViewLayout.d.ts.map +1 -1
- package/dist/components/core/form/SolidFormUserViewLayout.js +7 -8
- package/dist/components/core/form/SolidFormUserViewLayout.js.map +1 -1
- package/dist/components/core/form/SolidFormUserViewLayout.tsx +5 -7
- package/dist/components/core/form/SolidFormView.d.ts.map +1 -1
- package/dist/components/core/form/SolidFormView.js +12 -21
- package/dist/components/core/form/SolidFormView.js.map +1 -1
- package/dist/components/core/form/SolidFormView.tsx +11 -33
- package/dist/components/core/form/fields/SolidMediaSingleField.d.ts.map +1 -1
- package/dist/components/core/form/fields/SolidMediaSingleField.js +22 -15
- package/dist/components/core/form/fields/SolidMediaSingleField.js.map +1 -1
- package/dist/components/core/form/fields/SolidMediaSingleField.tsx +14 -2
- package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.d.ts.map +1 -1
- package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js +37 -26
- package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.js.map +1 -1
- package/dist/components/core/form/fields/relations/SolidRelationManyToManyField.tsx +38 -5
- package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.d.ts.map +1 -1
- package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js +11 -11
- package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.js.map +1 -1
- package/dist/components/core/form/fields/relations/SolidRelationManyToOneField.tsx +9 -11
- package/dist/components/core/kanban/KanbanUserViewLayout.d.ts.map +1 -1
- package/dist/components/core/kanban/KanbanUserViewLayout.js +7 -8
- package/dist/components/core/kanban/KanbanUserViewLayout.js.map +1 -1
- package/dist/components/core/kanban/KanbanUserViewLayout.tsx +4 -6
- package/dist/components/core/kanban/SolidKanbanView.d.ts.map +1 -1
- package/dist/components/core/kanban/SolidKanbanView.js +5 -7
- package/dist/components/core/kanban/SolidKanbanView.js.map +1 -1
- package/dist/components/core/kanban/SolidKanbanView.tsx +4 -9
- package/dist/components/core/list/PLAN.md +92 -0
- package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.d.ts.map +1 -1
- package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.js +13 -13
- package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.js.map +1 -1
- package/dist/components/core/list/SolidColumnSelector/SolidListColumnSelector.tsx +5 -6
- package/dist/components/core/list/SolidDataTable.d.ts +58 -0
- package/dist/components/core/list/SolidDataTable.d.ts.map +1 -0
- package/dist/components/core/list/SolidDataTable.js +141 -0
- package/dist/components/core/list/SolidDataTable.js.map +1 -0
- package/dist/components/core/list/SolidDataTable.tsx +314 -0
- package/dist/components/core/list/SolidListView.d.ts.map +1 -1
- package/dist/components/core/list/SolidListView.js +20 -67
- package/dist/components/core/list/SolidListView.js.map +1 -1
- package/dist/components/core/list/SolidListView.tsx +9 -76
- package/dist/components/core/model/CreateModel.d.ts.map +1 -1
- package/dist/components/core/model/CreateModel.js +15 -25
- package/dist/components/core/model/CreateModel.js.map +1 -1
- package/dist/components/core/model/CreateModel.tsx +12 -32
- package/dist/components/core/model/FieldMetaData.d.ts.map +1 -1
- package/dist/components/core/model/FieldMetaData.js +6 -17
- package/dist/components/core/model/FieldMetaData.js.map +1 -1
- package/dist/components/core/model/FieldMetaData.tsx +5 -26
- package/dist/components/core/model/ModelMetaData.d.ts.map +1 -1
- package/dist/components/core/model/ModelMetaData.js +48 -55
- package/dist/components/core/model/ModelMetaData.js.map +1 -1
- package/dist/components/core/model/ModelMetaData.tsx +4 -22
- package/dist/components/core/module/CreateModule.d.ts.map +1 -1
- package/dist/components/core/module/CreateModule.js +42 -44
- package/dist/components/core/module/CreateModule.js.map +1 -1
- package/dist/components/core/module/CreateModule.tsx +13 -27
- package/dist/components/core/module/ModuleListViewData.d.ts.map +1 -1
- package/dist/components/core/module/ModuleListViewData.js +11 -7
- package/dist/components/core/module/ModuleListViewData.js.map +1 -1
- package/dist/components/core/module/ModuleListViewData.tsx +10 -8
- package/dist/components/core/solid-ai/SolidAiChat.d.ts +3 -0
- package/dist/components/core/solid-ai/SolidAiChat.d.ts.map +1 -0
- package/dist/components/core/solid-ai/SolidAiChat.js +1043 -0
- package/dist/components/core/solid-ai/SolidAiChat.js.map +1 -0
- package/dist/components/core/solid-ai/SolidAiChat.module.css +1339 -0
- package/dist/components/core/solid-ai/SolidAiChat.tsx +1237 -0
- package/dist/components/core/tree/SolidTreeView.d.ts.map +1 -1
- package/dist/components/core/tree/SolidTreeView.js +32 -69
- package/dist/components/core/tree/SolidTreeView.js.map +1 -1
- package/dist/components/core/tree/SolidTreeView.tsx +8 -47
- package/dist/components/core/users/CreateUser.d.ts.map +1 -1
- package/dist/components/core/users/CreateUser.js +24 -37
- package/dist/components/core/users/CreateUser.js.map +1 -1
- package/dist/components/core/users/CreateUser.tsx +8 -46
- package/dist/components/core/users/UserListView.d.ts.map +1 -1
- package/dist/components/core/users/UserListView.js +9 -16
- package/dist/components/core/users/UserListView.js.map +1 -1
- package/dist/components/core/users/UserListView.tsx +5 -21
- package/dist/components/layout/AdminLayout.d.ts.map +1 -1
- package/dist/components/layout/AdminLayout.js +4 -2
- package/dist/components/layout/AdminLayout.js.map +1 -1
- package/dist/components/layout/AdminLayout.tsx +4 -2
- package/dist/components/layout/AdminTopHeader.d.ts +2 -0
- package/dist/components/layout/AdminTopHeader.d.ts.map +1 -0
- package/dist/components/layout/AdminTopHeader.js +80 -0
- package/dist/components/layout/AdminTopHeader.js.map +1 -0
- package/dist/components/layout/AdminTopHeader.tsx +165 -0
- package/dist/components/layout/AppSidebar.d.ts.map +1 -1
- package/dist/components/layout/AppSidebar.js +1 -2
- package/dist/components/layout/AppSidebar.js.map +1 -1
- package/dist/components/layout/AppSidebar.tsx +0 -2
- package/dist/components/layout/Layout.d.ts.map +1 -1
- package/dist/components/layout/Layout.js +2 -1
- package/dist/components/layout/Layout.js.map +1 -1
- package/dist/components/layout/Layout.tsx +2 -0
- package/dist/components/layout/SolidAiStudioLayout.d.ts +10 -0
- package/dist/components/layout/SolidAiStudioLayout.d.ts.map +1 -0
- package/dist/components/layout/SolidAiStudioLayout.js +159 -0
- package/dist/components/layout/SolidAiStudioLayout.js.map +1 -0
- package/dist/components/layout/SolidAiStudioLayout.tsx +333 -0
- package/dist/components/layout/navbar-one.d.ts.map +1 -1
- package/dist/components/layout/navbar-one.js +1 -2
- package/dist/components/layout/navbar-one.js.map +1 -1
- package/dist/components/layout/navbar-one.tsx +0 -2
- package/dist/components/layout/navbar-two-menu.d.ts.map +1 -1
- package/dist/components/layout/navbar-two-menu.js +50 -24
- package/dist/components/layout/navbar-two-menu.js.map +1 -1
- package/dist/components/layout/navbar-two-menu.tsx +48 -30
- package/dist/components/shad-cn-ui/SolidAutocomplete.d.ts +24 -0
- package/dist/components/shad-cn-ui/SolidAutocomplete.d.ts.map +1 -0
- package/dist/components/shad-cn-ui/SolidAutocomplete.js +224 -0
- package/dist/components/shad-cn-ui/SolidAutocomplete.js.map +1 -0
- package/dist/components/shad-cn-ui/SolidAutocomplete.tsx +339 -0
- package/dist/components/shad-cn-ui/SolidButton.d.ts +14 -0
- package/dist/components/shad-cn-ui/SolidButton.d.ts.map +1 -0
- package/dist/components/shad-cn-ui/SolidButton.js +36 -0
- package/dist/components/shad-cn-ui/SolidButton.js.map +1 -0
- package/dist/components/shad-cn-ui/SolidButton.tsx +54 -0
- package/dist/components/shad-cn-ui/SolidInput.d.ts +5 -0
- package/dist/components/shad-cn-ui/SolidInput.d.ts.map +1 -0
- package/dist/components/shad-cn-ui/SolidInput.js +35 -0
- package/dist/components/shad-cn-ui/SolidInput.js.map +1 -0
- package/dist/components/shad-cn-ui/SolidInput.tsx +12 -0
- package/dist/components/shad-cn-ui/SolidNumberInput.d.ts +10 -0
- package/dist/components/shad-cn-ui/SolidNumberInput.d.ts.map +1 -0
- package/dist/components/shad-cn-ui/SolidNumberInput.js +33 -0
- package/dist/components/shad-cn-ui/SolidNumberInput.js.map +1 -0
- package/dist/components/shad-cn-ui/SolidNumberInput.tsx +24 -0
- package/dist/components/shad-cn-ui/SolidSelect.d.ts +16 -0
- package/dist/components/shad-cn-ui/SolidSelect.d.ts.map +1 -0
- package/dist/components/shad-cn-ui/SolidSelect.js +26 -0
- package/dist/components/shad-cn-ui/SolidSelect.js.map +1 -0
- package/dist/components/shad-cn-ui/SolidSelect.tsx +65 -0
- package/dist/components/shad-cn-ui/SolidTabs.d.ts +18 -0
- package/dist/components/shad-cn-ui/SolidTabs.d.ts.map +1 -0
- package/dist/components/shad-cn-ui/SolidTabs.js +22 -0
- package/dist/components/shad-cn-ui/SolidTabs.js.map +1 -0
- package/dist/components/shad-cn-ui/SolidTabs.tsx +73 -0
- package/dist/components/shad-cn-ui/index.d.ts +7 -0
- package/dist/components/shad-cn-ui/index.d.ts.map +1 -0
- package/dist/components/shad-cn-ui/index.js +7 -0
- package/dist/components/shad-cn-ui/index.js.map +1 -0
- package/dist/components/shad-cn-ui/index.ts +6 -0
- package/dist/helpers/studioSandbox.d.ts +31 -0
- package/dist/helpers/studioSandbox.d.ts.map +1 -0
- package/dist/helpers/studioSandbox.js +104 -0
- package/dist/helpers/studioSandbox.js.map +1 -0
- package/dist/helpers/studioSandbox.ts +117 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/index.ts +4 -0
- package/dist/redux/features/solidStudioSlice.d.ts +9 -0
- package/dist/redux/features/solidStudioSlice.d.ts.map +1 -0
- package/dist/redux/features/solidStudioSlice.js +72 -0
- package/dist/redux/features/solidStudioSlice.js.map +1 -0
- package/dist/redux/features/solidStudioSlice.ts +78 -0
- package/dist/redux/features/toastSlice.d.ts +15 -0
- package/dist/redux/features/toastSlice.d.ts.map +1 -0
- package/dist/redux/features/toastSlice.js +20 -0
- package/dist/redux/features/toastSlice.js.map +1 -0
- package/dist/redux/features/toastSlice.ts +35 -0
- package/dist/redux/store/defaultStoreConfig.d.ts +1 -0
- package/dist/redux/store/defaultStoreConfig.d.ts.map +1 -1
- package/dist/redux/store/defaultStoreConfig.js +2 -1
- package/dist/redux/store/defaultStoreConfig.js.map +1 -1
- package/dist/redux/store/defaultStoreConfig.ts +2 -0
- package/dist/resources/images/errors/error-astronaut-404.png +0 -0
- package/dist/resources/shadcn-base.css +4171 -0
- package/dist/routes/SolidLayoutRegistry.d.ts +51 -0
- package/dist/routes/SolidLayoutRegistry.d.ts.map +1 -0
- package/dist/routes/SolidLayoutRegistry.js +108 -0
- package/dist/routes/SolidLayoutRegistry.js.map +1 -0
- package/dist/routes/SolidLayoutRegistry.tsx +157 -0
- package/dist/routes/guards/AdminGuard.d.ts +2 -0
- package/dist/routes/guards/AdminGuard.d.ts.map +1 -0
- package/dist/routes/guards/AdminGuard.js +16 -0
- package/dist/routes/guards/AdminGuard.js.map +1 -0
- package/dist/routes/guards/AdminGuard.tsx +17 -0
- package/dist/routes/pages/studio/StudioHomePage.d.ts +2 -0
- package/dist/routes/pages/studio/StudioHomePage.d.ts.map +1 -0
- package/dist/routes/pages/studio/StudioHomePage.js +22 -0
- package/dist/routes/pages/studio/StudioHomePage.js.map +1 -0
- package/dist/routes/pages/studio/StudioHomePage.tsx +106 -0
- package/dist/routes/pages/studio/StudioLandingPage.d.ts +2 -0
- package/dist/routes/pages/studio/StudioLandingPage.d.ts.map +1 -0
- package/dist/routes/pages/studio/StudioLandingPage.js +78 -0
- package/dist/routes/pages/studio/StudioLandingPage.js.map +1 -0
- package/dist/routes/pages/studio/StudioLandingPage.tsx +320 -0
- 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":"
|
|
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: [
|
|
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":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,8BAA8B,CAAC;AAC9D,OAAO,EAAE,+BAA+B,EAAE,MAAM,8BAA8B,CAAC;AAC/E,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,MAAM,gCAAgC,CAAC;AAC7E,OAAO,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,aAAa,MAAM,mBAAmB,CAAC;AAC9C,OAAO,eAAe,MAAM,qBAAqB,CAAC;AAElD,IAAM,SAAS,GAAG;IACd,IAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IACzB,IAAA,KAAoC,QAAQ,CAAC,KAAK,CAAC,EAAlD,aAAa,QAAA,EAAE,gBAAgB,QAAmB,CAAC;IAElD,IAAM,IAAI,GAAK,+BAA+B,CAAC,EAAE,CAAC,KAAxC,CAAyC;IAErD,IAAA,KAAgC,QAAQ,EAAE,EAAzC,WAAW,QAAA,EAAE,cAAc,QAAc,CAAC;IAC3C,IAAA,KAAwC,QAAQ,EAAE,EAAjD,eAAe,QAAA,EAAE,kBAAkB,QAAc,CAAC;IACnD,IAAA,KAA8B,QAAQ,CAAC,EAAE,CAAC,EAAzC,UAAU,QAAA,EAAE,aAAa,QAAgB,CAAC;IAEjD,SAAS,CAAC;;QACN,IAAI,IAAI,EAAE;YACN,cAAc,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,KAAI,MAAA,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAC,CAAM,IAAK,OAAA,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,8BAA8B,CAAC,EAA7C,CAA6C,CAAC,CAAC,CAAC,CAAC,0CAAE,QAAQ,CAAA,CAAC,CAAC;YACzI,kBAAkB,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,KAAI,MAAA,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAC,CAAM,IAAK,OAAA,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,8BAA8B,CAAC,EAA7C,CAA6C,CAAC,CAAC,CAAC,CAAC,0CAAE,KAAK,CAAA,CAAC,CAAA;SAC5I;IACL,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAA;IAEF,IAAA,IAAI,GAAK,UAAU,EAAE,KAAjB,CAAkB;IAE9B,6CAA6C;IAC7C,IAAM,YAAY,GAAG,cAAM,OAAA,gBAAgB,CAAC,CAAC,aAAa,CAAC,EAAhC,CAAgC,CAAC;IAC5D,IAAM,UAAU,GAAG,UAAC,CAAM;QACtB,iBAAiB;QACjB,gBAAgB,CAAC,CAAC,aAAa,CAAC,CAAC;QACjC,kBAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC5B,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAC/B,CAAC,CAAC;IAEF,SAAS,CAAC;QACN,IAAI,IAAI,EAAE;YACN,QAAQ,CAAC,OAAO,CAAC,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,IAAI,CAAC,CAAC,CAAC;YAC9B,QAAQ,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC;SACtC;IACL,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAEL,IAAA,KAAgC,QAAQ,CAAC,KAAK,CAAC,EAA9C,YAAY,QAAA,EAAE,aAAa,QAAmB,CAAC;IACtD,IAAM,SAAS,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAE/C,IAAM,kBAAkB,GAAG,UAAC,KAAU;QAClC,IAAI,SAAS,CAAC,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAChE,aAAa,CAAC,KAAK,CAAC,CAAC;SACxB;IACL,CAAC,CAAC;IAEF,SAAS,CAAC;QACN,IAAI,YAAY,EAAE;YACd,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;SAC9D;aAAM;YACH,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;SACjE;QAED,OAAO;YACH,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;QAClE,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAInB,OAAO,CACH,eAAK,SAAS,EAAC,6DAA6D,aACxE,KAAC,cAAc,KAAG,EAGjB,eAAe,IAAI,CAChB,wBACI,YACI,SAAS,EACL,aAAa;wBACT,CAAC,CAAC,iCAAiC;wBACnC,CAAC,CAAC,eAAe,EAEzB,OAAO,EAAE,YAAY,YAErB,cACI,KAAK,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,EAC5B,GAAG,EAAE,yBAAyB,EAC9B,GAAG,EAAC,OAAO,GACb,GACF,GACF,CACT,EACD,eAAK,SAAS,EAAC,WAAW,aACtB,wBACI,cAAK,SAAS,EAAC,aAAa,YACxB,4BACK,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,UAAC,CAAM,IAAK,OAAA,CACvD,cAEI,SAAS,EAAE,oBAAa,eAAe,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,EAAE,CAAE,YAEhF,YAAG,OAAO,EAAE,cAAM,OAAA,UAAU,CAAC,CAAC,CAAC,EAAb,CAAa,YAC3B,cACI,KAAK,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE;4CAC3C,yIAAyI;4CACzI,sCAAsC;4CACtC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAG,GAAG,CAAC,SAAS,CAAC,cAAI,CAAC,CAAC,IAAI,CAAE;4CACpE,uCAAuC;4CACvC,GAAG,EAAC,OAAO,GACb,GACF,IAZC,CAAC,CAAC,KAAK,CAaV,CACT,EAhB0D,CAgB1D,CAAC,GACH,GACD,GACJ,EACN,KAAC,eAAe,KAAmB,IACjC,EACL,WAAW,IAAI,CACZ,eAAK,SAAS,EAAE,aAAa,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,gBAAgB,aAC/D,eAAK,SAAS,EAAC,8EAA8E,aACzF,cAAK,SAAS,EAAC,mBAAmB,EAAC,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,GAAG,EAAE,UAAU,EAAE,SAAS,EAAE,GAAQ,EAClG,CAAC,YAAY,IAAI,cAAK,SAAS,EAAC,yBAAyB,YAAE,eAAe,IAAI,eAAe,GAAO,EACpG,YAAY,KAAK,KAAK,IAAI,KAAC,MAAM,IAAC,QAAQ,QAAC,IAAI,EAAC,cAAc,EAAC,QAAQ,EAAC,WAAW,gBAAY,QAAQ,EAAC,IAAI,EAAC,OAAO,EAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,MAAM,EAAE,mBAAmB,EAAE,EACrL,OAAO,EAAE,cAAM,OAAA,aAAa,CAAC,IAAI,CAAC,EAAnB,CAAmB,GACpC,EAED,YAAY;gCACT,eAAK,SAAS,EAAC,QAAQ,EAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,GAAG,EAAE,SAAS,aACnE,MAAC,SAAS,IAAC,YAAY,EAAC,MAAM,aAC1B,KAAC,SAAS,IAAC,SAAS,EAAC,sBAAsB,kBAAc,EACzD,KAAC,SAAS,IAAC,WAAW,EAAC,QAAQ,EAAC,SAAS,EAAC,iCAAiC,GAAG,IACtE,EACZ,cAAK,SAAS,EAAC,qBAAqB,EAAC,KAAK,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,YAC5D;gDACI,gDAAgD;gDAChD,KAAK,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,EACjD,GAAG,EAAC,gCAAgC,EACpC,GAAG,EAAC,OAAO,GACb,GACA,IACJ,IAmBR,EAmDN,cACI,SAAS,EACL,aAAa,CAAC,CAAC,CAAC,4BAA4B,CAAC,CAAC,CAAC,uBAAuB,YAG1E,KAAC,aAAa,IAAC,SAAS,EAAE,WAAW,GAAkB,GACrD,IACJ,CACT,IACC,CACT,CAAC;AACN,CAAC,CAAC;AAEF,eAAe,SAAS,CAAC","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":"
|
|
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
|
|
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 =
|
|
13
|
-
|
|
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 })] }), (
|
|
16
|
-
_jsx("span", { className: "sidebar-chevrons ".concat(expandedKeys[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
|
-
|
|
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: (
|
|
44
|
+
icon: (_b = mi.icon) !== null && _b !== void 0 ? _b : "",
|
|
25
45
|
// iconVariant: mi.iconVariant,
|
|
26
46
|
template: itemRenderer,
|
|
27
|
-
url: mi.path ?
|
|
28
|
-
items: mi.children ? createMenuItems(mi.children) : null,
|
|
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
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
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":"
|
|
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"]}
|