@solidxai/core-ui 0.1.5-beta.10 → 0.1.5-beta.12
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/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/SolidOTPVerify.d.ts +3 -0
- package/dist/components/auth/SolidOTPVerify.d.ts.map +1 -0
- package/dist/components/auth/SolidOTPVerify.js +67 -0
- package/dist/components/auth/SolidOTPVerify.js.map +1 -0
- package/dist/components/auth/SolidOTPVerify.tsx +133 -0
- 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/AuthBanner.js.map +1 -1
- 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/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/LoadDynamicJsxComponent.d.ts +2 -0
- package/dist/components/core/common/LoadDynamicJsxComponent.d.ts.map +1 -0
- package/dist/components/core/common/LoadDynamicJsxComponent.js +50 -0
- package/dist/components/core/common/LoadDynamicJsxComponent.js.map +1 -0
- package/dist/components/core/common/LoadDynamicJsxComponent.tsx +70 -0
- 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/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/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/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/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/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/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/nextAuth/authProviders.d.ts +4 -0
- package/dist/nextAuth/authProviders.d.ts.map +1 -0
- package/dist/nextAuth/authProviders.js +198 -0
- package/dist/nextAuth/authProviders.js.map +1 -0
- package/dist/nextAuth/authProviders.tsx +232 -0
- package/dist/nextAuth/handleLogout.d.ts +2 -0
- package/dist/nextAuth/handleLogout.d.ts.map +1 -0
- package/dist/nextAuth/handleLogout.js +36 -0
- package/dist/nextAuth/handleLogout.js.map +1 -0
- package/dist/nextAuth/handleLogout.tsx +39 -0
- package/dist/nextAuth/refreshAccessToken.d.ts +2 -0
- package/dist/nextAuth/refreshAccessToken.d.ts.map +1 -0
- package/dist/nextAuth/refreshAccessToken.js +24 -0
- package/dist/nextAuth/refreshAccessToken.js.map +1 -0
- package/dist/nextAuth/refreshAccessToken.tsx +28 -0
- package/dist/redux/features/settingsSlice.d.ts +20 -0
- package/dist/redux/features/settingsSlice.d.ts.map +1 -0
- package/dist/redux/features/settingsSlice.js +39 -0
- package/dist/redux/features/settingsSlice.js.map +1 -0
- package/dist/redux/features/settingsSlice.ts +60 -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/package.json +1 -1
- package/dist/components/auth/AuthTabs.d.ts +0 -14
- package/dist/components/auth/AuthTabs.d.ts.map +0 -1
- package/dist/components/auth/AuthTabs.js +0 -19
- package/dist/components/auth/AuthTabs.js.map +0 -1
- package/dist/components/auth/AuthTabs.tsx +0 -38
- package/dist/components/common/SolidErrorStatePage.d.ts +0 -12
- package/dist/components/common/SolidErrorStatePage.d.ts.map +0 -1
- package/dist/components/common/SolidErrorStatePage.js +0 -16
- package/dist/components/common/SolidErrorStatePage.js.map +0 -1
- package/dist/components/common/SolidErrorStatePage.tsx +0 -55
- package/dist/components/core/list/PLAN.md +0 -92
- package/dist/components/core/list/SolidDataTable.d.ts +0 -58
- package/dist/components/core/list/SolidDataTable.d.ts.map +0 -1
- package/dist/components/core/list/SolidDataTable.js +0 -141
- package/dist/components/core/list/SolidDataTable.js.map +0 -1
- package/dist/components/core/list/SolidDataTable.tsx +0 -314
- package/dist/components/core/list/SolidDataTablePagination.d.ts +0 -15
- package/dist/components/core/list/SolidDataTablePagination.d.ts.map +0 -1
- package/dist/components/core/list/SolidDataTablePagination.js +0 -22
- package/dist/components/core/list/SolidDataTablePagination.js.map +0 -1
- package/dist/components/core/list/SolidDataTablePagination.tsx +0 -71
- package/dist/components/layout/AdminTopHeader.d.ts +0 -2
- package/dist/components/layout/AdminTopHeader.d.ts.map +0 -1
- package/dist/components/layout/AdminTopHeader.js +0 -68
- package/dist/components/layout/AdminTopHeader.js.map +0 -1
- package/dist/components/layout/AdminTopHeader.tsx +0 -135
- package/dist/components/shad-cn-ui/SolidAutocomplete.d.ts +0 -24
- package/dist/components/shad-cn-ui/SolidAutocomplete.d.ts.map +0 -1
- package/dist/components/shad-cn-ui/SolidAutocomplete.js +0 -224
- package/dist/components/shad-cn-ui/SolidAutocomplete.js.map +0 -1
- package/dist/components/shad-cn-ui/SolidAutocomplete.tsx +0 -339
- package/dist/components/shad-cn-ui/SolidButton.d.ts +0 -14
- package/dist/components/shad-cn-ui/SolidButton.d.ts.map +0 -1
- package/dist/components/shad-cn-ui/SolidButton.js +0 -36
- package/dist/components/shad-cn-ui/SolidButton.js.map +0 -1
- package/dist/components/shad-cn-ui/SolidButton.tsx +0 -54
- package/dist/components/shad-cn-ui/SolidInput.d.ts +0 -5
- package/dist/components/shad-cn-ui/SolidInput.d.ts.map +0 -1
- package/dist/components/shad-cn-ui/SolidInput.js +0 -35
- package/dist/components/shad-cn-ui/SolidInput.js.map +0 -1
- package/dist/components/shad-cn-ui/SolidInput.tsx +0 -12
- package/dist/components/shad-cn-ui/SolidNumberInput.d.ts +0 -10
- package/dist/components/shad-cn-ui/SolidNumberInput.d.ts.map +0 -1
- package/dist/components/shad-cn-ui/SolidNumberInput.js +0 -33
- package/dist/components/shad-cn-ui/SolidNumberInput.js.map +0 -1
- package/dist/components/shad-cn-ui/SolidNumberInput.tsx +0 -24
- package/dist/components/shad-cn-ui/SolidSelect.d.ts +0 -16
- package/dist/components/shad-cn-ui/SolidSelect.d.ts.map +0 -1
- package/dist/components/shad-cn-ui/SolidSelect.js +0 -26
- package/dist/components/shad-cn-ui/SolidSelect.js.map +0 -1
- package/dist/components/shad-cn-ui/SolidSelect.tsx +0 -65
- package/dist/components/shad-cn-ui/SolidTabs.d.ts +0 -18
- package/dist/components/shad-cn-ui/SolidTabs.d.ts.map +0 -1
- package/dist/components/shad-cn-ui/SolidTabs.js +0 -22
- package/dist/components/shad-cn-ui/SolidTabs.js.map +0 -1
- package/dist/components/shad-cn-ui/SolidTabs.tsx +0 -73
- package/dist/components/shad-cn-ui/index.d.ts +0 -7
- package/dist/components/shad-cn-ui/index.d.ts.map +0 -1
- package/dist/components/shad-cn-ui/index.js +0 -7
- package/dist/components/shad-cn-ui/index.js.map +0 -1
- package/dist/components/shad-cn-ui/index.ts +0 -6
- package/dist/components/solid-ui/SolidButton.d.ts +0 -14
- package/dist/components/solid-ui/SolidButton.d.ts.map +0 -1
- package/dist/components/solid-ui/SolidButton.js +0 -36
- package/dist/components/solid-ui/SolidButton.js.map +0 -1
- package/dist/components/solid-ui/SolidButton.tsx +0 -54
- package/dist/components/solid-ui/SolidTabs.d.ts +0 -18
- package/dist/components/solid-ui/SolidTabs.d.ts.map +0 -1
- package/dist/components/solid-ui/SolidTabs.js +0 -22
- package/dist/components/solid-ui/SolidTabs.js.map +0 -1
- package/dist/components/solid-ui/SolidTabs.tsx +0 -73
- package/dist/components/solid-ui/index.d.ts +0 -3
- package/dist/components/solid-ui/index.d.ts.map +0 -1
- package/dist/components/solid-ui/index.js +0 -3
- package/dist/components/solid-ui/index.js.map +0 -1
- package/dist/components/solid-ui/index.ts +0 -2
- package/dist/resources/images/errors/error-astronaut-404.png +0 -0
- package/dist/resources/shadcn-base.css +0 -3200
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"UserListView.js","sourceRoot":"","sources":["../../../../src/components/core/users/UserListView.tsx"],"names":[],"mappings":"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","sourcesContent":["\nimport { useDeleteMultipleUsersMutation, useLazyGetusersQuery } from '../../../redux/api/userApi';\nimport Link from \"../../common/Link\";\nimport { FilterMatchMode } from \"primereact/api\";\nimport { Button } from \"primereact/button\";\nimport { Column } from \"primereact/column\";\nimport {\n DataTable,\n DataTableFilterMeta,\n DataTableStateEvent,\n} from \"primereact/datatable\";\nimport { useEffect, useRef, useState } from \"react\";\n\nimport { CreateButton } from \"../../../components/common/CreateButton\";\nimport { FetchBaseQueryError } from \"@reduxjs/toolkit/query\";\nimport { Dialog } from \"primereact/dialog\";\nimport { Toast } from \"primereact/toast\";\nimport qs from \"qs\";\nimport { ERROR_MESSAGES } from '../../../constants/error-messages';\n\ninterface Users {\n id: string;\n fullName: string;\n username: string;\n email: string;\n mobile: string;\n // roles: string[];\n}\n\ninterface ErrorResponseData {\n message: string;\n statusCode: number;\n error: string;\n}\n\nexport const UserListView = () => {\n const toast = useRef<Toast>(null);\n const [users, setUsers] = useState<Users[]>([]);\n const [filters, setFilters] = useState<DataTableFilterMeta>({\n fullName: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n username: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n email: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n mobile: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n // \"roles.name\": { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n });\n const [first, setFirst] = useState(0);\n const [rows, setRows] = useState(25);\n const [totalRecords, setTotalRecords] = useState(0);\n const [sortField, setSortField] = useState(\"\");\n const [sortOrder, setSortOrder] = useState(0);\n const [selectedUsers, setSelectedUsers] = useState<Users[]>([]);\n const [loading, setLoading] = useState<boolean>(true);\n const [isDialogVisible, setDialogVisible] = useState(false);\n const [triggerGetUser, { data: user, isLoading, error, isError }] = useLazyGetusersQuery();\n\n const [\n deleteManyUser,\n {\n isLoading: isUserDeleted,\n isSuccess: isDeleteUserSuceess,\n isError: isUserDeleteError,\n error: UserDeleteError,\n data: DeletedUser,\n },\n ] = useDeleteMultipleUsersMutation();\n\n\n useEffect(() => {\n if (user) {\n setUsers(user?.data.records);\n setTotalRecords(user?.data.meta?.totalRecords);\n setLoading(false);\n }\n }, [user]);\n\n // const initFilters = () => {\n // setFilters(defaultFilters);\n // setGlobalFilterValue('');\n // };\n\n // const clearFilter = () => {\n // initFilters();\n // };\n\n useEffect(() => {\n const queryData = {\n offset: 0,\n limit: 25,\n populate: ['roles']\n };\n const queryString = qs.stringify(queryData, {\n encodeValuesOnly: true\n });\n triggerGetUser(queryString);\n setSelectedUsers([]);\n }, [isDeleteUserSuceess]);\n\n useEffect(() => {\n if (isError || isUserDeleteError) {\n setLoading(false);\n let errorMessage = ERROR_MESSAGES.ERROR_OCCURED;\n\n const errorToast = isError ? error : UserDeleteError;\n\n if (isFetchBaseQueryErrorWithErrorResponse(errorToast)) {\n errorMessage = `${errorToast.data.message}`;\n } else {\n errorMessage = ERROR_MESSAGES.SOMETHING_WRONG;\n }\n\n toast.current?.show({\n severity: 'error',\n summary: ERROR_MESSAGES.ERROR,\n detail: errorMessage,\n life: 3000,\n //@ts-ignore\n content: (props) => (\n <div\n className=\"flex flex-column align-items-left\"\n style={{ flex: \"1\" }}\n >\n <div className=\"flex align-items-center gap-2\" >\n <span className=\"font-bold text-900\">{errorMessage}</span>\n </div>\n </div>\n ),\n });\n }\n }, [isError, isUserDeleteError]);\n\n function isFetchBaseQueryErrorWithErrorResponse(error: any): error is FetchBaseQueryError & { data: ErrorResponseData } {\n return error && typeof error === 'object' && 'data' in error && 'message' in error.data;\n }\n\n const onPageChange = (event: any) => {\n setFirst(event.first);\n setRows(event.rows);\n setQueryString(event.first, event.rows, sortField, sortOrder, filters);\n };\n\n const onSort = (event: DataTableStateEvent) => {\n const { sortField, sortOrder } = event;\n const validSortOrder = sortOrder === 1 || sortOrder === -1 ? sortOrder : 0;\n setSortField(sortField);\n setSortOrder(validSortOrder);\n setFirst(0);\n setQueryString(\n 0,\n rows,\n sortField,\n sortOrder === 1 || sortOrder === -1 ? sortOrder : 0,\n filters\n );\n };\n\n const onSelectionChange = (event: any) => {\n const value = event.value;\n setSelectedUsers(value);\n };\n\n // Filter fuctions\n const setQueryString = async (\n offset?: number,\n row?: number,\n field?: string,\n order?: number,\n filterQuery?: any\n ) => {\n\n const formattedFilters: any = {};\n\n Object.keys(filterQuery).forEach((field) => {\n const filterValue = filterQuery[field].value;\n const matchMode = filterQuery[field].matchMode;\n\n if (filterValue !== null && filterValue !== undefined) {\n let operator = matchMode;\n switch (matchMode) {\n case FilterMatchMode.CONTAINS:\n operator = \"$containsi\";\n break;\n case FilterMatchMode.STARTS_WITH:\n operator = \"$startsWithi\";\n break;\n case FilterMatchMode.EQUALS:\n operator = \"$eqi\";\n break;\n case FilterMatchMode.NOT_CONTAINS:\n operator = \"$notContainsi\";\n break;\n case FilterMatchMode.NOT_EQUALS:\n operator = \"$nei\";\n break;\n case FilterMatchMode.ENDS_WITH:\n operator = \"$endsWithi\";\n break;\n default:\n operator = matchMode;\n }\n\n if (field.includes(\".\")) {\n const fieldParts = field.split(\".\");\n if (!formattedFilters[fieldParts[0]]) {\n formattedFilters[fieldParts[0]] = {};\n }\n formattedFilters[fieldParts[0]][fieldParts[1]] = { [operator]: filterValue };\n } else {\n formattedFilters[field] = { [operator]: filterValue };\n }\n }\n });\n\n const queryData: any = {\n offset: offset ?? first,\n limit: row ?? rows,\n populate: ['roles'],\n filters: formattedFilters,\n };\n\n if (field) {\n queryData.sort = [\n `${field}:${order == 0 ? null : order == 1 ? \"asc\" : \"desc\"}`,\n ];\n }\n\n const queryString = qs.stringify(queryData, {\n encodeValuesOnly: true,\n });\n\n triggerGetUser(queryString);\n };\n\n const onFilter = (e: any) => {\n setFilters(e.filters);\n setQueryString(\n 0,\n rows,\n sortField,\n sortOrder === 1 || sortOrder === -1 ? sortOrder : 0,\n e.filters\n );\n };\n\n const detailsBodyTemplate = (product: Users) => {\n return (\n <Link\n href={`${product.id}`}\n rel=\"noopener noreferrer\"\n className=\"text-sm font-bold p-0\"\n style={{ color: \"#12415D\" }}\n >\n <i className=\"pi pi-pencil\" style={{ fontSize: \"1rem\" }}></i>\n </Link>\n );\n };\n\n const deleteBulk = () => {\n let deleteList: any = [];\n selectedUsers.forEach((element: Users) => {\n deleteList.push(element.id);\n });\n deleteManyUser(deleteList);\n setDialogVisible(false);\n };\n\n const onDeleteClose = () => {\n setDialogVisible(false);\n setSelectedUsers([]);\n }\n\n return (\n <div className=\"\">\n <Toast ref={toast} />\n <div className=\"flex gap-3 mb-4\">\n <CreateButton />\n {selectedUsers.length > 0 && <Button\n type=\"button\"\n label=\"Delete\"\n size=\"small\"\n onClick={() => setDialogVisible(true)}\n className=\"small-button\"\n severity=\"danger\"\n />}\n </div>\n <style>{`\n .p-datatable .p-datatable-loading-overlay {\n background-color: rgba(0, 0, 0, 0.0);\n }\n `}</style>\n <DataTable\n value={users}\n lazy\n tableStyle={{ minWidth: \"60rem\", margin: \"auto\" }}\n size=\"small\"\n paginator\n rows={rows}\n rowsPerPageOptions={[10, 25, 50]}\n dataKey=\"id\"\n filters={filters}\n emptyMessage=\"No users found\"\n onFilter={onFilter}\n filterDisplay=\"row\"\n totalRecords={totalRecords}\n first={first}\n onPage={onPageChange}\n onSort={(e: DataTableStateEvent) => onSort(e)}\n sortField={sortField}\n sortOrder={sortOrder === 1 || sortOrder === -1 ? sortOrder : 0}\n loading={loading || isLoading}\n loadingIcon=\"pi pi-spinner\"\n selection={selectedUsers}\n onSelectionChange={onSelectionChange}\n selectionMode=\"multiple\"\n removableSort\n >\n <Column selectionMode=\"multiple\" headerStyle={{ width: \"3em\" }} />\n <Column field=\"id\" header=\"ID\" className=\"text-sm\" sortable headerClassName=\"table-header-fs\"></Column>\n <Column\n field=\"fullName\"\n header=\"Full Name\"\n className=\"text-sm\"\n sortable\n filter\n filterPlaceholder=\"Search user by full name\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column>\n <Column\n field=\"username\"\n header=\"Username\"\n className=\"text-sm\"\n sortable\n filter\n filterPlaceholder=\"Search user by username\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column>\n <Column\n field=\"email\"\n header=\"Email\"\n className=\"text-sm\"\n sortable\n filter\n filterPlaceholder=\"Search user by email\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column>\n {/* <Column\n field=\"roles.name\"\n header=\"Roles\"\n className=\"text-sm\"\n filter\n filterPlaceholder=\"Search category by parent category\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column> */}\n <Column body={detailsBodyTemplate}></Column>\n </DataTable>\n <Dialog\n visible={isDialogVisible}\n header=\"Confirm Delete\"\n modal\n className=\"solid-confirm-dialog\"\n footer={() => (\n <div className=\"flex justify-content-center\">\n <Button label=\"Yes\" icon=\"pi pi-check\" className='small-button' severity=\"danger\" autoFocus onClick={deleteBulk} />\n <Button label=\"No\" icon=\"pi pi-times\" className='small-button' onClick={onDeleteClose} />\n </div>\n )}\n onHide={() => setDialogVisible(false)}\n >\n <p>Are you sure you want to delete the selected Users?</p>\n </Dialog>\n </div>\n );\n};\n"]}
|
|
1
|
+
{"version":3,"file":"UserListView.js","sourceRoot":"","sources":["../../../../src/components/core/users/UserListView.tsx"],"names":[],"mappings":"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","sourcesContent":["\nimport { useDeleteMultipleUsersMutation, useLazyGetusersQuery } from '../../../redux/api/userApi';\nimport Link from \"../../common/Link\";\nimport { FilterMatchMode } from \"primereact/api\";\nimport { Button } from \"primereact/button\";\nimport { Column } from \"primereact/column\";\nimport {\n DataTable,\n DataTableFilterMeta,\n DataTableStateEvent,\n} from \"primereact/datatable\";\nimport { useEffect, useState } from \"react\";\nimport { useDispatch } from \"react-redux\";\n\nimport { CreateButton } from \"../../../components/common/CreateButton\";\nimport { FetchBaseQueryError } from \"@reduxjs/toolkit/query\";\nimport { Dialog } from \"primereact/dialog\";\nimport qs from \"qs\";\nimport { ERROR_MESSAGES } from '../../../constants/error-messages';\nimport { showToast } from '../../../redux/features/toastSlice';\n\ninterface Users {\n id: string;\n fullName: string;\n username: string;\n email: string;\n mobile: string;\n // roles: string[];\n}\n\ninterface ErrorResponseData {\n message: string;\n statusCode: number;\n error: string;\n}\n\nexport const UserListView = () => {\n const dispatch = useDispatch();\n const [users, setUsers] = useState<Users[]>([]);\n const [filters, setFilters] = useState<DataTableFilterMeta>({\n fullName: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n username: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n email: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n mobile: { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n // \"roles.name\": { value: null, matchMode: FilterMatchMode.STARTS_WITH },\n });\n const [first, setFirst] = useState(0);\n const [rows, setRows] = useState(25);\n const [totalRecords, setTotalRecords] = useState(0);\n const [sortField, setSortField] = useState(\"\");\n const [sortOrder, setSortOrder] = useState(0);\n const [selectedUsers, setSelectedUsers] = useState<Users[]>([]);\n const [loading, setLoading] = useState<boolean>(true);\n const [isDialogVisible, setDialogVisible] = useState(false);\n const [triggerGetUser, { data: user, isLoading, error, isError }] = useLazyGetusersQuery();\n\n const [\n deleteManyUser,\n {\n isLoading: isUserDeleted,\n isSuccess: isDeleteUserSuceess,\n isError: isUserDeleteError,\n error: UserDeleteError,\n data: DeletedUser,\n },\n ] = useDeleteMultipleUsersMutation();\n\n\n useEffect(() => {\n if (user) {\n setUsers(user?.data.records);\n setTotalRecords(user?.data.meta?.totalRecords);\n setLoading(false);\n }\n }, [user]);\n\n // const initFilters = () => {\n // setFilters(defaultFilters);\n // setGlobalFilterValue('');\n // };\n\n // const clearFilter = () => {\n // initFilters();\n // };\n\n useEffect(() => {\n const queryData = {\n offset: 0,\n limit: 25,\n populate: ['roles']\n };\n const queryString = qs.stringify(queryData, {\n encodeValuesOnly: true\n });\n triggerGetUser(queryString);\n setSelectedUsers([]);\n }, [isDeleteUserSuceess]);\n\n useEffect(() => {\n if (isError || isUserDeleteError) {\n setLoading(false);\n let errorMessage = ERROR_MESSAGES.ERROR_OCCURED;\n\n const errorToast = isError ? error : UserDeleteError;\n\n if (isFetchBaseQueryErrorWithErrorResponse(errorToast)) {\n errorMessage = `${errorToast.data.message}`;\n } else {\n errorMessage = ERROR_MESSAGES.SOMETHING_WRONG;\n }\n\n dispatch(showToast({ severity: 'error', summary: ERROR_MESSAGES.ERROR, detail: errorMessage, life: 3000 }));\n }\n }, [isError, isUserDeleteError]);\n\n function isFetchBaseQueryErrorWithErrorResponse(error: any): error is FetchBaseQueryError & { data: ErrorResponseData } {\n return error && typeof error === 'object' && 'data' in error && 'message' in error.data;\n }\n\n const onPageChange = (event: any) => {\n setFirst(event.first);\n setRows(event.rows);\n setQueryString(event.first, event.rows, sortField, sortOrder, filters);\n };\n\n const onSort = (event: DataTableStateEvent) => {\n const { sortField, sortOrder } = event;\n const validSortOrder = sortOrder === 1 || sortOrder === -1 ? sortOrder : 0;\n setSortField(sortField);\n setSortOrder(validSortOrder);\n setFirst(0);\n setQueryString(\n 0,\n rows,\n sortField,\n sortOrder === 1 || sortOrder === -1 ? sortOrder : 0,\n filters\n );\n };\n\n const onSelectionChange = (event: any) => {\n const value = event.value;\n setSelectedUsers(value);\n };\n\n // Filter fuctions\n const setQueryString = async (\n offset?: number,\n row?: number,\n field?: string,\n order?: number,\n filterQuery?: any\n ) => {\n\n const formattedFilters: any = {};\n\n Object.keys(filterQuery).forEach((field) => {\n const filterValue = filterQuery[field].value;\n const matchMode = filterQuery[field].matchMode;\n\n if (filterValue !== null && filterValue !== undefined) {\n let operator = matchMode;\n switch (matchMode) {\n case FilterMatchMode.CONTAINS:\n operator = \"$containsi\";\n break;\n case FilterMatchMode.STARTS_WITH:\n operator = \"$startsWithi\";\n break;\n case FilterMatchMode.EQUALS:\n operator = \"$eqi\";\n break;\n case FilterMatchMode.NOT_CONTAINS:\n operator = \"$notContainsi\";\n break;\n case FilterMatchMode.NOT_EQUALS:\n operator = \"$nei\";\n break;\n case FilterMatchMode.ENDS_WITH:\n operator = \"$endsWithi\";\n break;\n default:\n operator = matchMode;\n }\n\n if (field.includes(\".\")) {\n const fieldParts = field.split(\".\");\n if (!formattedFilters[fieldParts[0]]) {\n formattedFilters[fieldParts[0]] = {};\n }\n formattedFilters[fieldParts[0]][fieldParts[1]] = { [operator]: filterValue };\n } else {\n formattedFilters[field] = { [operator]: filterValue };\n }\n }\n });\n\n const queryData: any = {\n offset: offset ?? first,\n limit: row ?? rows,\n populate: ['roles'],\n filters: formattedFilters,\n };\n\n if (field) {\n queryData.sort = [\n `${field}:${order == 0 ? null : order == 1 ? \"asc\" : \"desc\"}`,\n ];\n }\n\n const queryString = qs.stringify(queryData, {\n encodeValuesOnly: true,\n });\n\n triggerGetUser(queryString);\n };\n\n const onFilter = (e: any) => {\n setFilters(e.filters);\n setQueryString(\n 0,\n rows,\n sortField,\n sortOrder === 1 || sortOrder === -1 ? sortOrder : 0,\n e.filters\n );\n };\n\n const detailsBodyTemplate = (product: Users) => {\n return (\n <Link\n href={`${product.id}`}\n rel=\"noopener noreferrer\"\n className=\"text-sm font-bold p-0\"\n style={{ color: \"#12415D\" }}\n >\n <i className=\"pi pi-pencil\" style={{ fontSize: \"1rem\" }}></i>\n </Link>\n );\n };\n\n const deleteBulk = () => {\n let deleteList: any = [];\n selectedUsers.forEach((element: Users) => {\n deleteList.push(element.id);\n });\n deleteManyUser(deleteList);\n setDialogVisible(false);\n };\n\n const onDeleteClose = () => {\n setDialogVisible(false);\n setSelectedUsers([]);\n }\n\n return (\n <div className=\"\">\n <div className=\"flex gap-3 mb-4\">\n <CreateButton />\n {selectedUsers.length > 0 && <Button\n type=\"button\"\n label=\"Delete\"\n size=\"small\"\n onClick={() => setDialogVisible(true)}\n className=\"small-button\"\n severity=\"danger\"\n />}\n </div>\n <style>{`\n .p-datatable .p-datatable-loading-overlay {\n background-color: rgba(0, 0, 0, 0.0);\n }\n `}</style>\n <DataTable\n value={users}\n lazy\n tableStyle={{ minWidth: \"60rem\", margin: \"auto\" }}\n size=\"small\"\n paginator\n rows={rows}\n rowsPerPageOptions={[10, 25, 50]}\n dataKey=\"id\"\n filters={filters}\n emptyMessage=\"No users found\"\n onFilter={onFilter}\n filterDisplay=\"row\"\n totalRecords={totalRecords}\n first={first}\n onPage={onPageChange}\n onSort={(e: DataTableStateEvent) => onSort(e)}\n sortField={sortField}\n sortOrder={sortOrder === 1 || sortOrder === -1 ? sortOrder : 0}\n loading={loading || isLoading}\n loadingIcon=\"pi pi-spinner\"\n selection={selectedUsers}\n onSelectionChange={onSelectionChange}\n selectionMode=\"multiple\"\n removableSort\n >\n <Column selectionMode=\"multiple\" headerStyle={{ width: \"3em\" }} />\n <Column field=\"id\" header=\"ID\" className=\"text-sm\" sortable headerClassName=\"table-header-fs\"></Column>\n <Column\n field=\"fullName\"\n header=\"Full Name\"\n className=\"text-sm\"\n sortable\n filter\n filterPlaceholder=\"Search user by full name\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column>\n <Column\n field=\"username\"\n header=\"Username\"\n className=\"text-sm\"\n sortable\n filter\n filterPlaceholder=\"Search user by username\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column>\n <Column\n field=\"email\"\n header=\"Email\"\n className=\"text-sm\"\n sortable\n filter\n filterPlaceholder=\"Search user by email\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column>\n {/* <Column\n field=\"roles.name\"\n header=\"Roles\"\n className=\"text-sm\"\n filter\n filterPlaceholder=\"Search category by parent category\"\n style={{ minWidth: \"12rem\" }}\n headerClassName=\"table-header-fs\"\n ></Column> */}\n <Column body={detailsBodyTemplate}></Column>\n </DataTable>\n <Dialog\n visible={isDialogVisible}\n header=\"Confirm Delete\"\n modal\n className=\"solid-confirm-dialog\"\n footer={() => (\n <div className=\"flex justify-content-center\">\n <Button label=\"Yes\" icon=\"pi pi-check\" className='small-button' severity=\"danger\" autoFocus onClick={deleteBulk} />\n <Button label=\"No\" icon=\"pi pi-times\" className='small-button' onClick={onDeleteClose} />\n </div>\n )}\n onHide={() => setDialogVisible(false)}\n >\n <p>Are you sure you want to delete the selected Users?</p>\n </Dialog>\n </div>\n );\n};\n"]}
|
|
@@ -9,14 +9,15 @@ import {
|
|
|
9
9
|
DataTableFilterMeta,
|
|
10
10
|
DataTableStateEvent,
|
|
11
11
|
} from "primereact/datatable";
|
|
12
|
-
import { useEffect,
|
|
12
|
+
import { useEffect, useState } from "react";
|
|
13
|
+
import { useDispatch } from "react-redux";
|
|
13
14
|
|
|
14
15
|
import { CreateButton } from "../../../components/common/CreateButton";
|
|
15
16
|
import { FetchBaseQueryError } from "@reduxjs/toolkit/query";
|
|
16
17
|
import { Dialog } from "primereact/dialog";
|
|
17
|
-
import { Toast } from "primereact/toast";
|
|
18
18
|
import qs from "qs";
|
|
19
19
|
import { ERROR_MESSAGES } from '../../../constants/error-messages';
|
|
20
|
+
import { showToast } from '../../../redux/features/toastSlice';
|
|
20
21
|
|
|
21
22
|
interface Users {
|
|
22
23
|
id: string;
|
|
@@ -34,7 +35,7 @@ interface ErrorResponseData {
|
|
|
34
35
|
}
|
|
35
36
|
|
|
36
37
|
export const UserListView = () => {
|
|
37
|
-
const
|
|
38
|
+
const dispatch = useDispatch();
|
|
38
39
|
const [users, setUsers] = useState<Users[]>([]);
|
|
39
40
|
const [filters, setFilters] = useState<DataTableFilterMeta>({
|
|
40
41
|
fullName: { value: null, matchMode: FilterMatchMode.STARTS_WITH },
|
|
@@ -108,23 +109,7 @@ export const UserListView = () => {
|
|
|
108
109
|
errorMessage = ERROR_MESSAGES.SOMETHING_WRONG;
|
|
109
110
|
}
|
|
110
111
|
|
|
111
|
-
|
|
112
|
-
severity: 'error',
|
|
113
|
-
summary: ERROR_MESSAGES.ERROR,
|
|
114
|
-
detail: errorMessage,
|
|
115
|
-
life: 3000,
|
|
116
|
-
//@ts-ignore
|
|
117
|
-
content: (props) => (
|
|
118
|
-
<div
|
|
119
|
-
className="flex flex-column align-items-left"
|
|
120
|
-
style={{ flex: "1" }}
|
|
121
|
-
>
|
|
122
|
-
<div className="flex align-items-center gap-2" >
|
|
123
|
-
<span className="font-bold text-900">{errorMessage}</span>
|
|
124
|
-
</div>
|
|
125
|
-
</div>
|
|
126
|
-
),
|
|
127
|
-
});
|
|
112
|
+
dispatch(showToast({ severity: 'error', summary: ERROR_MESSAGES.ERROR, detail: errorMessage, life: 3000 }));
|
|
128
113
|
}
|
|
129
114
|
}, [isError, isUserDeleteError]);
|
|
130
115
|
|
|
@@ -270,7 +255,6 @@ export const UserListView = () => {
|
|
|
270
255
|
|
|
271
256
|
return (
|
|
272
257
|
<div className="">
|
|
273
|
-
<Toast ref={toast} />
|
|
274
258
|
<div className="flex gap-3 mb-4">
|
|
275
259
|
<CreateButton />
|
|
276
260
|
{selectedUsers.length > 0 && <Button
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AdminLayout.d.ts","sourceRoot":"","sources":["../../../src/components/layout/AdminLayout.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AdminLayout.d.ts","sourceRoot":"","sources":["../../../src/components/layout/AdminLayout.tsx"],"names":[],"mappings":"AAYA,eAAO,MAAM,WAAW;cAA8B,MAAM,SAAS;6CA4CpE,CAAA"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { handleError } from "../../helpers/ToastContainer";
|
|
3
2
|
import { signOut } from "../../adapters/auth/index";
|
|
4
3
|
import { useSession } from "../../hooks/useSession";
|
|
5
4
|
import { useRouter } from "../../hooks/useRouter";
|
|
6
5
|
import { useEffect, useState } from "react";
|
|
6
|
+
import { useDispatch } from 'react-redux';
|
|
7
|
+
import { showToast } from '../../redux/features/toastSlice';
|
|
7
8
|
import { Layout } from "./Layout";
|
|
8
9
|
import { Dialog } from "primereact/dialog";
|
|
9
10
|
import { Divider } from "primereact/divider";
|
|
@@ -12,6 +13,7 @@ import { ERROR_MESSAGES } from "../../constants/error-messages";
|
|
|
12
13
|
export var AdminLayout = function (_a) {
|
|
13
14
|
var children = _a.children;
|
|
14
15
|
// const theme = useSelector((state: any) => state.theme.mode);
|
|
16
|
+
var dispatch = useDispatch();
|
|
15
17
|
var _b = useSession(), session = _b.data, status = _b.status;
|
|
16
18
|
var _c = useState(false), isForcePasswordChange = _c[0], setIsForcePasswordChange = _c[1];
|
|
17
19
|
useEffect(function () {
|
|
@@ -29,7 +31,7 @@ export var AdminLayout = function (_a) {
|
|
|
29
31
|
if (status === "loading")
|
|
30
32
|
return;
|
|
31
33
|
if (!session || (session === null || session === void 0 ? void 0 : session.error) === "RefreshAccessTokenError") {
|
|
32
|
-
|
|
34
|
+
dispatch(showToast({ severity: 'error', summary: 'Error', detail: ERROR_MESSAGES.SESSION_EXPIRED }));
|
|
33
35
|
signOut({ callbackUrl: "/auth/login" });
|
|
34
36
|
}
|
|
35
37
|
}, [session, status]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AdminLayout.js","sourceRoot":"","sources":["../../../src/components/layout/AdminLayout.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"AdminLayout.js","sourceRoot":"","sources":["../../../src/components/layout/AdminLayout.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,wBAAwB,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAEhE,MAAM,CAAC,IAAM,WAAW,GAAG,UAAC,EAA2C;QAAzC,QAAQ,cAAA;IAClC,+DAA+D;IAC/D,IAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IACzB,IAAA,KAA4B,UAAU,EAAE,EAAhC,OAAO,UAAA,EAAE,MAAM,YAAiB,CAAC;IACzC,IAAA,KAAoD,QAAQ,CAAC,KAAK,CAAC,EAAlE,qBAAqB,QAAA,EAAE,wBAAwB,QAAmB,CAAA;IACzE,SAAS,CAAC;;QACN,IAAI,CAAA,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,0CAAE,mBAAmB,MAAK,IAAI,EAAE;YAC7C,wBAAwB,CAAC,IAAI,CAAC,CAAA;SACjC;aAAM;YACH,wBAAwB,CAAC,KAAK,CAAC,CAAA;SAClC;IACL,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAA;IACb,kCAAkC;IAClC,IAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAC3B,SAAS,CAAC;QACN,IAAI,MAAM,KAAK,SAAS;YAAE,OAAO;QACjC,IAAI,CAAC,OAAO,IAAI,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,MAAK,yBAAyB,EAAE;YAC1D,QAAQ,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,cAAc,CAAC,eAAe,EAAE,CAAC,CAAC,CAAA;YACpG,OAAO,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC,CAAC;SAC3C;IAEL,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;IAErB,OAAO,CACH,MAAC,MAAM,eAQF,QAAQ,EAIR,qBAAqB;gBAClB,MAAC,MAAM,IAAC,MAAM,EAAC,yBAAyB,EAAC,SAAS,EAAC,qBAAqB,EAAC,OAAO,EAAE,qBAAqB,EAAE,QAAQ,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,cAAM,OAAA,wBAAwB,CAAC,KAAK,CAAC,EAA/B,CAA+B,aAC/M,KAAC,OAAO,IAAC,SAAS,EAAC,MAAM,GAAG,EAC5B,KAAC,wBAAwB,KAAG,IACvB,IAER,CACZ,CAAA;AACL,CAAC,CAAA","sourcesContent":["import { signOut } from \"../../adapters/auth/index\";\nimport { useSession } from \"../../hooks/useSession\";\nimport { useRouter } from \"../../hooks/useRouter\";\nimport { useEffect, useState } from \"react\";\nimport { useDispatch } from 'react-redux';\nimport { showToast } from '../../redux/features/toastSlice';\nimport { Layout } from \"./Layout\";\nimport { Dialog } from \"primereact/dialog\";\nimport { Divider } from \"primereact/divider\";\nimport SolidChangeForcePassword from \"../auth/SolidChangeForcePassword\";\nimport { ERROR_MESSAGES } from \"../../constants/error-messages\";\n\nexport const AdminLayout = ({ children }: { children: React.ReactNode }) => {\n // const theme = useSelector((state: any) => state.theme.mode);\n const dispatch = useDispatch();\n const { data: session, status } = useSession();\n const [isForcePasswordChange, setIsForcePasswordChange] = useState(false)\n useEffect(() => {\n if (session?.user?.forcePasswordChange === true) {\n setIsForcePasswordChange(true)\n } else {\n setIsForcePasswordChange(false)\n }\n }, [session])\n // const pathname = usePathname();\n const router = useRouter();\n useEffect(() => {\n if (status === \"loading\") return;\n if (!session || session?.error === \"RefreshAccessTokenError\") {\n dispatch(showToast({ severity: 'error', summary: 'Error', detail: ERROR_MESSAGES.SESSION_EXPIRED }))\n signOut({ callbackUrl: \"/auth/login\" });\n }\n\n }, [session, status])\n\n return (\n <Layout>\n {/* <div className={`${getEnv(\"NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER\") == \"true\" && 'header-margin-top'}`} style={{ minHeight: `${getEnv(\"NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER\") == \"true\" ? 'calc(100vh - 70px)' : 'calc(100vh)'}` }}> */}\n\n {/* <div className=\"min-h-full max-h-full flex flex-column relative flex-auto overflow-x-auto\"> */}\n {/* <DashboardHeader /> */}\n {/* <SolidListingHeader></SolidListingHeader> */}\n {/* {pathname.includes('all') && <ListingHeader />} */}\n {/* <div className=\"flex flex-column flex-auto\" style={{ backgroundColor: '#f6f6f9', padding: '1.5rem 1.5rem 1.5rem', }}> */}\n {children}\n {/* </div> */}\n {/* </div> */}\n {/* </div> */}\n {isForcePasswordChange &&\n <Dialog header=\"Change Default Password\" className=\"solid-change-dialog\" visible={isForcePasswordChange} closable={false} draggable={false} style={{ width: '25vw' }} onHide={() => setIsForcePasswordChange(false)}>\n <Divider className=\"mt-0\" />\n <SolidChangeForcePassword />\n </Dialog>\n }\n </Layout>\n )\n}\n"]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { handleError } from "../../helpers/ToastContainer";
|
|
2
1
|
import { signOut } from "../../adapters/auth/index";
|
|
3
2
|
import { useSession } from "../../hooks/useSession";
|
|
4
3
|
import { useRouter } from "../../hooks/useRouter";
|
|
5
4
|
import { useEffect, useState } from "react";
|
|
5
|
+
import { useDispatch } from 'react-redux';
|
|
6
|
+
import { showToast } from '../../redux/features/toastSlice';
|
|
6
7
|
import { Layout } from "./Layout";
|
|
7
8
|
import { Dialog } from "primereact/dialog";
|
|
8
9
|
import { Divider } from "primereact/divider";
|
|
@@ -11,6 +12,7 @@ import { ERROR_MESSAGES } from "../../constants/error-messages";
|
|
|
11
12
|
|
|
12
13
|
export const AdminLayout = ({ children }: { children: React.ReactNode }) => {
|
|
13
14
|
// const theme = useSelector((state: any) => state.theme.mode);
|
|
15
|
+
const dispatch = useDispatch();
|
|
14
16
|
const { data: session, status } = useSession();
|
|
15
17
|
const [isForcePasswordChange, setIsForcePasswordChange] = useState(false)
|
|
16
18
|
useEffect(() => {
|
|
@@ -25,7 +27,7 @@ export const AdminLayout = ({ children }: { children: React.ReactNode }) => {
|
|
|
25
27
|
useEffect(() => {
|
|
26
28
|
if (status === "loading") return;
|
|
27
29
|
if (!session || session?.error === "RefreshAccessTokenError") {
|
|
28
|
-
|
|
30
|
+
dispatch(showToast({ severity: 'error', summary: 'Error', detail: ERROR_MESSAGES.SESSION_EXPIRED }))
|
|
29
31
|
signOut({ callbackUrl: "/auth/login" });
|
|
30
32
|
}
|
|
31
33
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AppSidebar.d.ts","sourceRoot":"","sources":["../../../src/components/layout/AppSidebar.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"AppSidebar.d.ts","sourceRoot":"","sources":["../../../src/components/layout/AppSidebar.tsx"],"names":[],"mappings":"AAcA,QAAA,MAAM,UAAU,+CAqMf,CAAC;AAEF,eAAe,UAAU,CAAC"}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import { ToastContainer } from "../../helpers/ToastContainer";
|
|
3
2
|
import { useGetSolidMenuBasedOnRoleQuery } from "../../redux/api/solidMenuApi";
|
|
4
3
|
import { showNavbar, toggleNavbar, hideNavbar } from "../../redux/features/navbarSlice";
|
|
5
4
|
import { setIsAuthenticated, setUser } from "../../redux/features/userSlice";
|
|
@@ -97,7 +96,7 @@ var AppSidebar = function () {
|
|
|
97
96
|
],
|
|
98
97
|
icon: env("NEXT_PUBLIC_SETTINGS_ICON") ? env("NEXT_PUBLIC_SETTINGS_ICON") : SettingImage
|
|
99
98
|
};
|
|
100
|
-
return (_jsxs(_Fragment, { children: [
|
|
99
|
+
return (_jsxs(_Fragment, { children: [visibleNavbar && (_jsx("div", { className: "sidebar-backdrop", onClick: handleToggle })), (visibleNavbar || currentMainMenu) && (_jsx("div", { className: "sidebar-toggle-button ".concat(!visibleNavbar || !currentMainMenu ? "s-collapsed hidden md:flex" : ""), onClick: handleToggle, children: _jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", children: [_jsx("rect", { x: "0.3", y: "0.3", width: "23.4", height: "23.4", rx: "2.1", fill: "white" }), _jsx("rect", { x: "0.3", y: "0.3", width: "23.4", height: "23.4", rx: "2.1", stroke: "#D8E2EA", strokeWidth: "0.6" }), _jsx("path", { d: "M5.09735 16V14.6667H13.5929V16H5.09735ZM5.09735 12.6667V11.3333H11.6324V12.6667H5.09735ZM5.09735 9.33333V8H13.5929V9.33333H5.09735Z", fill: "#8D9199" }), _jsx("path", { d: "M16.2621 12L18.9026 14.3L18.099 15L14.6549 12L18.099 9L18.9026 9.7L16.2621 12Z", fill: "#8D9199" })] }) })), _jsxs("div", { className: "sidebar-left ".concat(visibleNavbar ? "open" : ""), children: [_jsx("div", { className: "navbar-menu", children: (menu === null || menu === void 0 ? void 0 : menu.data.length) > 0 && (menu === null || menu === void 0 ? void 0 : menu.data.map(function (m) {
|
|
101
100
|
var iconSrc = typeof m.icon === "string"
|
|
102
101
|
? m.icon
|
|
103
102
|
: m.icon && typeof m.icon.src === "string"
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AppSidebar.js","sourceRoot":"","sources":["../../../src/components/layout/AppSidebar.tsx"],"names":[],"mappings":"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","sourcesContent":["import { ToastContainer } from \"../../helpers/ToastContainer\";\nimport { useGetSolidMenuBasedOnRoleQuery } from \"../../redux/api/solidMenuApi\";\nimport { showNavbar, toggleNavbar, hideNavbar } from \"../../redux/features/navbarSlice\";\nimport { setIsAuthenticated, setUser } from \"../../redux/features/userSlice\";\nimport { useSession } from \"../../hooks/useSession\";\nimport { useEffect, useRef, useState } from \"react\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport NavbarTwoMenu from \"./navbar-two-menu\";\nimport UserProfileMenu from \"./user-profile-menu\";\nimport Image from \"../common/Image\";\nimport SettingImage from '../../resources/images/Navigation/SolidSettinsIcon.svg'\nimport { Avatar } from \"primereact/avatar\";\nimport { usePathname } from \"../../hooks/usePathname\";\nimport { env } from \"../../adapters/env\";\n\nconst AppSidebar = () => {\n const dispatch = useDispatch();\n const pathname = usePathname();\n // const [show, setShow] = useState(false);\n const visibleNavbar = useSelector(\n (state: any) => state.navbarState.visibleNavbar\n );\n const { data: menu } = useGetSolidMenuBasedOnRoleQuery(\"\");\n\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 = () => dispatch(toggleNavbar());\n const handleMenu = (m: any) => {\n // setShow(true);\n dispatch(showNavbar());\n setCurrentMainMenu(m.title);\n setCurrentMenu(m.children);\n };\n\n useEffect(() => {\n // Check if screen is small at the time of route change\n if (window.innerWidth <= 1199) {\n dispatch(hideNavbar());\n }\n }, [pathname, dispatch]);\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 const additionalMenu = {\n title: \"General Settings\",\n key: \"general-settings\",\n children: [\n {\n title: \"Settings\",\n path: \"\",\n key: \"settings-menu-item\",\n children: [\n {\n title: \"App Settings\",\n path: \"/admin/settings/app-settings\",\n key: \"app-setting\"\n },\n {\n title: \"Authentication Settings\",\n path: \"/admin/settings/authentication-settings\",\n key: \"auth-setting\"\n },\n {\n title: \"Misc\",\n path: \"/admin/settings/misc-settings\",\n key: \"misc-setting\"\n }\n ]\n }\n ],\n icon: env(\"NEXT_PUBLIC_SETTINGS_ICON\") ? env(\"NEXT_PUBLIC_SETTINGS_ICON\") : SettingImage\n };\n\n\n\n return (\n <>\n <ToastContainer />\n {visibleNavbar && (\n <div\n className=\"sidebar-backdrop\"\n onClick={handleToggle}\n />\n )}\n {/* commented this as this is not working properly @Jenendar to figure this out... */}\n {(visibleNavbar || currentMainMenu) && (\n <div\n className={`sidebar-toggle-button ${!visibleNavbar || !currentMainMenu ? \"s-collapsed hidden md:flex\" : \"\"}`}\n onClick={handleToggle}\n // severity=\"secondary\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <rect x=\"0.3\" y=\"0.3\" width=\"23.4\" height=\"23.4\" rx=\"2.1\" fill=\"white\" />\n <rect x=\"0.3\" y=\"0.3\" width=\"23.4\" height=\"23.4\" rx=\"2.1\" stroke=\"#D8E2EA\" strokeWidth=\"0.6\" />\n <path d=\"M5.09735 16V14.6667H13.5929V16H5.09735ZM5.09735 12.6667V11.3333H11.6324V12.6667H5.09735ZM5.09735 9.33333V8H13.5929V9.33333H5.09735Z\" fill=\"#8D9199\" />\n <path d=\"M16.2621 12L18.9026 14.3L18.099 15L14.6549 12L18.099 9L18.9026 9.7L16.2621 12Z\" fill=\"#8D9199\" />\n </svg>\n </div>\n )}\n\n <div className={`sidebar-left ${visibleNavbar ? \"open\" : \"\"}`}>\n <div className=\"navbar-menu\">\n {menu?.data.length > 0 && menu?.data.map((m: any) => {\n const iconSrc =\n typeof m.icon === \"string\"\n ? m.icon\n : m.icon && typeof m.icon.src === \"string\"\n ? m.icon.src\n : null;\n return (\n <a\n key={m.title}\n className={`flex align-items-center menu-item ${currentMainMenu === m.title ? \"active-menu-image\" : \"\"}`}\n onClick={() => handleMenu(m)}\n style={{ cursor: 'pointer' }}\n >\n {m.icon ?\n <Image\n src={iconSrc.startsWith(\"/\") ? iconSrc : `${env(\"API_URL\")}/${iconSrc}`}\n alt={m.title}\n height={30}\n width={30}\n className=\"relative\"\n unoptimized\n />\n :\n <div>\n <Avatar label={m.title.charAt(0)} shape=\"circle\" style={{ backgroundColor: 'var(--primary-color)', fontWeight: 500 }} />\n </div>\n }\n </a>\n )\n })}\n </div>\n\n <UserProfileMenu></UserProfileMenu>\n </div>\n {currentMenu && (\n <div className={`sidebar-right ${visibleNavbar ? \"open\" : \"\"}`}>\n\n <div className=\"flex relative justify-content-between align-items-center py-3 xl:py-4 px-3\">\n <div className=\"text-base sidebar-title font-semibold\">{currentMainMenu && currentMainMenu}</div>\n {/* <button\n className=\"sidebar-toggle-button\"\n onClick={handleToggle}\n >\n <img\n style={{ cursor: \"pointer\" }}\n src={`/images/menu-toggle.png`}\n alt=\"Solid\"\n />\n </button> */}\n </div>\n {/* <div className=\"w-full px-3 mb-3\" 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: 20 }}>\n <img\n style={{ cursor: \"pointer\", maxHeight: '1.3rem' }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div>\n </div> */}\n <div className=\"px-3 solid-sidebar-menuitems-wrapper\">\n <NavbarTwoMenu menuItems={currentMenu}></NavbarTwoMenu>\n </div>\n </div>\n )}\n </>\n );\n};\n\nexport default AppSidebar;\n"]}
|
|
1
|
+
{"version":3,"file":"AppSidebar.js","sourceRoot":"","sources":["../../../src/components/layout/AppSidebar.tsx"],"names":[],"mappings":"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","sourcesContent":["import { useGetSolidMenuBasedOnRoleQuery } from \"../../redux/api/solidMenuApi\";\nimport { showNavbar, toggleNavbar, hideNavbar } from \"../../redux/features/navbarSlice\";\nimport { setIsAuthenticated, setUser } from \"../../redux/features/userSlice\";\nimport { useSession } from \"../../hooks/useSession\";\nimport { useEffect, useRef, useState } from \"react\";\nimport { useDispatch, useSelector } from \"react-redux\";\nimport NavbarTwoMenu from \"./navbar-two-menu\";\nimport UserProfileMenu from \"./user-profile-menu\";\nimport Image from \"../common/Image\";\nimport SettingImage from '../../resources/images/Navigation/SolidSettinsIcon.svg'\nimport { Avatar } from \"primereact/avatar\";\nimport { usePathname } from \"../../hooks/usePathname\";\nimport { env } from \"../../adapters/env\";\n\nconst AppSidebar = () => {\n const dispatch = useDispatch();\n const pathname = usePathname();\n // const [show, setShow] = useState(false);\n const visibleNavbar = useSelector(\n (state: any) => state.navbarState.visibleNavbar\n );\n const { data: menu } = useGetSolidMenuBasedOnRoleQuery(\"\");\n\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 = () => dispatch(toggleNavbar());\n const handleMenu = (m: any) => {\n // setShow(true);\n dispatch(showNavbar());\n setCurrentMainMenu(m.title);\n setCurrentMenu(m.children);\n };\n\n useEffect(() => {\n // Check if screen is small at the time of route change\n if (window.innerWidth <= 1199) {\n dispatch(hideNavbar());\n }\n }, [pathname, dispatch]);\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 const additionalMenu = {\n title: \"General Settings\",\n key: \"general-settings\",\n children: [\n {\n title: \"Settings\",\n path: \"\",\n key: \"settings-menu-item\",\n children: [\n {\n title: \"App Settings\",\n path: \"/admin/settings/app-settings\",\n key: \"app-setting\"\n },\n {\n title: \"Authentication Settings\",\n path: \"/admin/settings/authentication-settings\",\n key: \"auth-setting\"\n },\n {\n title: \"Misc\",\n path: \"/admin/settings/misc-settings\",\n key: \"misc-setting\"\n }\n ]\n }\n ],\n icon: env(\"NEXT_PUBLIC_SETTINGS_ICON\") ? env(\"NEXT_PUBLIC_SETTINGS_ICON\") : SettingImage\n };\n\n\n\n return (\n <>\n {visibleNavbar && (\n <div\n className=\"sidebar-backdrop\"\n onClick={handleToggle}\n />\n )}\n {/* commented this as this is not working properly @Jenendar to figure this out... */}\n {(visibleNavbar || currentMainMenu) && (\n <div\n className={`sidebar-toggle-button ${!visibleNavbar || !currentMainMenu ? \"s-collapsed hidden md:flex\" : \"\"}`}\n onClick={handleToggle}\n // severity=\"secondary\"\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\">\n <rect x=\"0.3\" y=\"0.3\" width=\"23.4\" height=\"23.4\" rx=\"2.1\" fill=\"white\" />\n <rect x=\"0.3\" y=\"0.3\" width=\"23.4\" height=\"23.4\" rx=\"2.1\" stroke=\"#D8E2EA\" strokeWidth=\"0.6\" />\n <path d=\"M5.09735 16V14.6667H13.5929V16H5.09735ZM5.09735 12.6667V11.3333H11.6324V12.6667H5.09735ZM5.09735 9.33333V8H13.5929V9.33333H5.09735Z\" fill=\"#8D9199\" />\n <path d=\"M16.2621 12L18.9026 14.3L18.099 15L14.6549 12L18.099 9L18.9026 9.7L16.2621 12Z\" fill=\"#8D9199\" />\n </svg>\n </div>\n )}\n\n <div className={`sidebar-left ${visibleNavbar ? \"open\" : \"\"}`}>\n <div className=\"navbar-menu\">\n {menu?.data.length > 0 && menu?.data.map((m: any) => {\n const iconSrc =\n typeof m.icon === \"string\"\n ? m.icon\n : m.icon && typeof m.icon.src === \"string\"\n ? m.icon.src\n : null;\n return (\n <a\n key={m.title}\n className={`flex align-items-center menu-item ${currentMainMenu === m.title ? \"active-menu-image\" : \"\"}`}\n onClick={() => handleMenu(m)}\n style={{ cursor: 'pointer' }}\n >\n {m.icon ?\n <Image\n src={iconSrc.startsWith(\"/\") ? iconSrc : `${env(\"API_URL\")}/${iconSrc}`}\n alt={m.title}\n height={30}\n width={30}\n className=\"relative\"\n unoptimized\n />\n :\n <div>\n <Avatar label={m.title.charAt(0)} shape=\"circle\" style={{ backgroundColor: 'var(--primary-color)', fontWeight: 500 }} />\n </div>\n }\n </a>\n )\n })}\n </div>\n\n <UserProfileMenu></UserProfileMenu>\n </div>\n {currentMenu && (\n <div className={`sidebar-right ${visibleNavbar ? \"open\" : \"\"}`}>\n\n <div className=\"flex relative justify-content-between align-items-center py-3 xl:py-4 px-3\">\n <div className=\"text-base sidebar-title font-semibold\">{currentMainMenu && currentMainMenu}</div>\n {/* <button\n className=\"sidebar-toggle-button\"\n onClick={handleToggle}\n >\n <img\n style={{ cursor: \"pointer\" }}\n src={`/images/menu-toggle.png`}\n alt=\"Solid\"\n />\n </button> */}\n </div>\n {/* <div className=\"w-full px-3 mb-3\" 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: 20 }}>\n <img\n style={{ cursor: \"pointer\", maxHeight: '1.3rem' }}\n src=\"/images/icons/jump-to-icon.png\"\n alt=\"Solid\"\n />\n </div>\n </div> */}\n <div className=\"px-3 solid-sidebar-menuitems-wrapper\">\n <NavbarTwoMenu menuItems={currentMenu}></NavbarTwoMenu>\n </div>\n </div>\n )}\n </>\n );\n};\n\nexport default AppSidebar;\n"]}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { ToastContainer } from "../../helpers/ToastContainer";
|
|
2
1
|
import { useGetSolidMenuBasedOnRoleQuery } from "../../redux/api/solidMenuApi";
|
|
3
2
|
import { showNavbar, toggleNavbar, hideNavbar } from "../../redux/features/navbarSlice";
|
|
4
3
|
import { setIsAuthenticated, setUser } from "../../redux/features/userSlice";
|
|
@@ -115,7 +114,6 @@ const AppSidebar = () => {
|
|
|
115
114
|
|
|
116
115
|
return (
|
|
117
116
|
<>
|
|
118
|
-
<ToastContainer />
|
|
119
117
|
{visibleNavbar && (
|
|
120
118
|
<div
|
|
121
119
|
className="sidebar-backdrop"
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Layout.d.ts","sourceRoot":"","sources":["../../../src/components/layout/Layout.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAe,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"Layout.d.ts","sourceRoot":"","sources":["../../../src/components/layout/Layout.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAe,MAAM,aAAa,CAAC;AAkB/D,eAAO,MAAM,MAAM,iBAAkB,mBAAmB,4CA2LvD,CAAC"}
|
|
@@ -57,6 +57,7 @@ import AppConfig from './AppConfig';
|
|
|
57
57
|
import { LayoutContext } from './context/layoutcontext';
|
|
58
58
|
import AppSidebar from './AppSidebar';
|
|
59
59
|
import SolidPopupContainer from '../common/SolidPopupContainer';
|
|
60
|
+
import { GlobalToast } from '../common/GlobalToast';
|
|
60
61
|
import { useSession } from "../../hooks/useSession";
|
|
61
62
|
import { getExtensionFunction } from '../../helpers/registry';
|
|
62
63
|
import { env } from "../../adapters/env";
|
|
@@ -207,6 +208,6 @@ export var Layout = function (_a) {
|
|
|
207
208
|
// dispatch(showNavbar()); // open both
|
|
208
209
|
// }
|
|
209
210
|
// };
|
|
210
|
-
return (_jsx(React.Fragment, { children: _jsxs("div", { className: containerClass, children: [_jsx(AppSidebar, {}), _jsx(SolidPopupContainer, {}), _jsx("div", { className: "main-content ".concat(visibleNavbar ? "shifted" : ""), children: children }), _jsx(AppConfig, {}), _jsx("div", { className: "layout-mask" })] }) }));
|
|
211
|
+
return (_jsx(React.Fragment, { children: _jsxs("div", { className: containerClass, children: [_jsx(AppSidebar, {}), _jsx(SolidPopupContainer, {}), _jsx(GlobalToast, {}), _jsx("div", { className: "main-content ".concat(visibleNavbar ? "shifted" : ""), children: children }), _jsx(AppConfig, {}), _jsx("div", { className: "layout-mask" })] }) }));
|
|
211
212
|
};
|
|
212
213
|
//# sourceMappingURL=Layout.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Layout.js","sourceRoot":"","sources":["../../../src/components/layout/Layout.tsx"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable react-hooks/exhaustive-deps */\nimport { ChildContainerProps, LayoutState } from '../../types';\nimport { usePathname } from \"../../hooks/usePathname\";\nimport { useSearchParams } from \"../../hooks/useSearchParams\";\nimport { PrimeReactContext } from 'primereact/api';\nimport { useEventListener, useUnmountEffect } from 'primereact/hooks';\nimport { classNames } from 'primereact/utils';\nimport React, { useContext, useEffect, useRef } from 'react';\nimport { useSelector } from 'react-redux';\nimport AppConfig from './AppConfig';\nimport { LayoutContext } from './context/layoutcontext';\nimport AppSidebar from './AppSidebar';\nimport SolidPopupContainer from '../common/SolidPopupContainer';\nimport { useSession } from \"../../hooks/useSession\";\nimport { getExtensionFunction } from '../../helpers/registry';\nimport { SolidOnApplicationMountEvent } from '../../types/solid-core';\nimport { env } from \"../../adapters/env\";\n\nexport const Layout = ({ children }: ChildContainerProps) => {\n const { layoutConfig, layoutState, setLayoutState } = useContext(LayoutContext);\n const { setRipple } = useContext(PrimeReactContext);\n // const topbarRef = useRef<AppTopbarRef>(null);\n const sidebarRef = useRef<HTMLDivElement>(null);\n const [bindMenuOutsideClickListener, unbindMenuOutsideClickListener] = useEventListener({\n type: 'click',\n listener: (event) => {\n const isOutsideClicked = !(\n sidebarRef.current?.isSameNode(event.target as Node) ||\n sidebarRef.current?.contains(event.target as Node)\n // topbarRef.current?.menubutton?.isSameNode(event.target as Node) ||\n // topbarRef.current?.menubutton?.contains(event.target as Node)\n );\n\n if (isOutsideClicked) {\n hideMenu();\n }\n }\n });\n\n const pathname = usePathname();\n const searchParams = useSearchParams();\n useEffect(() => {\n hideMenu();\n hideProfileMenu();\n }, [pathname, searchParams]);\n\n // const [bindProfileMenuOutsideClickListener, unbindProfileMenuOutsideClickListener] = useEventListener({\n // type: 'click',\n // listener: (event) => {\n // const isOutsideClicked = !(\n // topbarRef.current?.topbarmenu?.isSameNode(event.target as Node) ||\n // topbarRef.current?.topbarmenu?.contains(event.target as Node) ||\n // topbarRef.current?.topbarmenubutton?.isSameNode(event.target as Node) ||\n // topbarRef.current?.topbarmenubutton?.contains(event.target as Node)\n // );\n\n // if (isOutsideClicked) {\n // hideProfileMenu();\n // }\n // }\n // });\n\n const hideMenu = () => {\n setLayoutState((prevLayoutState: LayoutState) => ({\n ...prevLayoutState,\n overlayMenuActive: false,\n staticMenuMobileActive: false,\n menuHoverActive: false\n }));\n unbindMenuOutsideClickListener();\n unblockBodyScroll();\n };\n\n const hideProfileMenu = () => {\n setLayoutState((prevLayoutState: LayoutState) => ({\n ...prevLayoutState,\n profileSidebarVisible: false\n }));\n // unbindProfileMenuOutsideClickListener();\n };\n\n const blockBodyScroll = (): void => {\n if (document.body.classList) {\n document.body.classList.add('blocked-scroll');\n } else {\n document.body.className += ' blocked-scroll';\n }\n };\n\n const unblockBodyScroll = (): void => {\n if (document.body.classList) {\n document.body.classList.remove('blocked-scroll');\n } else {\n document.body.className = document.body.className.replace(new RegExp('(^|\\\\b)' + 'blocked-scroll'.split(' ').join('|') + '(\\\\b|$)', 'gi'), ' ');\n }\n };\n\n useEffect(() => {\n if (layoutState.overlayMenuActive || layoutState.staticMenuMobileActive) {\n bindMenuOutsideClickListener();\n }\n\n layoutState.staticMenuMobileActive && blockBodyScroll();\n }, [layoutState.overlayMenuActive, layoutState.staticMenuMobileActive]);\n\n // useEffect(() => {\n // if (layoutState.profileSidebarVisible) {\n // bindProfileMenuOutsideClickListener();\n // }\n // }, [layoutState.profileSidebarVisible]);\n\n useUnmountEffect(() => {\n unbindMenuOutsideClickListener();\n // unbindProfileMenuOutsideClickListener();\n });\n\n const containerClass = classNames('layout-wrapper', {\n 'layout-overlay-active': layoutState.overlayMenuActive,\n 'layout-mobile-active': layoutState.staticMenuMobileActive,\n 'p-input-filled': layoutConfig.inputStyle === 'filled',\n });\n const { visibleNavbar } = useSelector((state: any) => state.navbarState); // Get the visibility state of sidebar-two\n\n\n const session = useSession();\n const user = session?.data?.user;\n\n const hasRunRef = useRef(false);\n\n useEffect(() => {\n if (hasRunRef.current) return;\n if (!session || !user) return;\n\n const navEntry = performance.getEntriesByType(\"navigation\")[0] as PerformanceNavigationTiming;\n const isReload = navEntry?.type === \"reload\";\n\n // Detect first mount (after login redirect)\n const isFirstMount = !sessionStorage.getItem(\"app-mounted\");\n\n // Allow execution only for:\n // 1. First mount\n // 2. Reload\n if (isFirstMount || isReload) {\n sessionStorage.setItem(\"app-mounted\", \"true\");\n } else {\n return;\n }\n\n hasRunRef.current = true;\n\n const handleDynamicFunction = async () => {\n const dynamicHeader = env(\"SOLIDX_ON_APPLICATION_MOUNT_HANDLER\");\n\n const event: SolidOnApplicationMountEvent = {\n type: \"onApplicationMount\",\n user,\n session: session.data\n };\n\n if (dynamicHeader) {\n const DynamicFunctionComponent = getExtensionFunction(dynamicHeader);\n if (DynamicFunctionComponent) {\n await DynamicFunctionComponent(event);\n }\n }\n };\n\n handleDynamicFunction();\n }, [session, session?.data, user]);\n\n // const dispatch = useDispatch()\n // const { data: solidSettingsDataInitialData } = useGetSolidSettingsQuery(\"\")\n // useEffect(() => {\n // if (solidSettingsDataInitialData) {\n // dispatch(setSolidSettings(solidSettingsDataInitialData?.data));\n // }\n // }, [solidSettingsDataInitialData]);\n\n // const toggleBothSidebars = () => {\n // if (visibleNavbar) {\n // dispatch(toggleNavbar()); // close both\n // } else {\n // dispatch(showNavbar()); // open both\n // }\n // };\n\n return (\n <React.Fragment>\n <div className={containerClass}>\n {/* {getEnv(\"NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER\") == \"true\" && <CustomHeader />} */}\n <AppSidebar />\n {/* <div className=\"apps-icon block md:hidden\" onClick={toggleBothSidebars}>\n <i className=\"pi pi-th-large\"></i>\n </div> */}\n <SolidPopupContainer></SolidPopupContainer>\n <div className={`main-content ${visibleNavbar ? \"shifted\" : \"\"}`}>\n {children}\n {/* {getEnv(\"NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER\") == \"true\" && <CustomFooter />} */}\n </div>\n <AppConfig />\n <div className=\"layout-mask\"></div>\n </div>\n </React.Fragment>\n );\n};\n"]}
|
|
1
|
+
{"version":3,"file":"Layout.js","sourceRoot":"","sources":["../../../src/components/layout/Layout.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,OAAO,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,UAAU,MAAM,cAAc,CAAC;AACtC,OAAO,mBAAmB,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAEzC,MAAM,CAAC,IAAM,MAAM,GAAG,UAAC,EAAiC;;QAA/B,QAAQ,cAAA;IACvB,IAAA,KAAgD,UAAU,CAAC,aAAa,CAAC,EAAvE,YAAY,kBAAA,EAAE,WAAW,iBAAA,EAAE,cAAc,oBAA8B,CAAC;IACxE,IAAA,SAAS,GAAK,UAAU,CAAC,iBAAiB,CAAC,UAAlC,CAAmC;IACpD,gDAAgD;IAChD,IAAM,UAAU,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAC1C,IAAA,KAAiE,gBAAgB,CAAC;QACpF,IAAI,EAAE,OAAO;QACb,QAAQ,EAAE,UAAC,KAAK;;YACZ,IAAM,gBAAgB,GAAG,CAAC,CACtB,CAAA,MAAA,UAAU,CAAC,OAAO,0CAAE,UAAU,CAAC,KAAK,CAAC,MAAc,CAAC;iBACpD,MAAA,UAAU,CAAC,OAAO,0CAAE,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,CAAA;YAClD,qEAAqE;YACrE,gEAAgE;aACnE,CAAC;YAEF,IAAI,gBAAgB,EAAE;gBAClB,QAAQ,EAAE,CAAC;aACd;QACL,CAAC;KACJ,CAAC,EAdK,4BAA4B,QAAA,EAAE,8BAA8B,QAcjE,CAAC;IAEH,IAAM,QAAQ,GAAG,WAAW,EAAE,CAAC;IAC/B,IAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IACvC,SAAS,CAAC;QACN,QAAQ,EAAE,CAAC;QACX,eAAe,EAAE,CAAC;IACtB,CAAC,EAAE,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC;IAE7B,0GAA0G;IAC1G,qBAAqB;IACrB,6BAA6B;IAC7B,sCAAsC;IACtC,iFAAiF;IACjF,+EAA+E;IAC/E,uFAAuF;IACvF,kFAAkF;IAClF,aAAa;IAEb,kCAAkC;IAClC,iCAAiC;IACjC,YAAY;IACZ,QAAQ;IACR,MAAM;IAEN,IAAM,QAAQ,GAAG;QACb,cAAc,CAAC,UAAC,eAA4B,IAAK,OAAA,uBAC1C,eAAe,KAClB,iBAAiB,EAAE,KAAK,EACxB,sBAAsB,EAAE,KAAK,EAC7B,eAAe,EAAE,KAAK,IACxB,EAL+C,CAK/C,CAAC,CAAC;QACJ,8BAA8B,EAAE,CAAC;QACjC,iBAAiB,EAAE,CAAC;IACxB,CAAC,CAAC;IAEF,IAAM,eAAe,GAAG;QACpB,cAAc,CAAC,UAAC,eAA4B,IAAK,OAAA,uBAC1C,eAAe,KAClB,qBAAqB,EAAE,KAAK,IAC9B,EAH+C,CAG/C,CAAC,CAAC;QACJ,2CAA2C;IAC/C,CAAC,CAAC;IAEF,IAAM,eAAe,GAAG;QACpB,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE;YACzB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;SACjD;aAAM;YACH,QAAQ,CAAC,IAAI,CAAC,SAAS,IAAI,iBAAiB,CAAC;SAChD;IACL,CAAC,CAAC;IAEF,IAAM,iBAAiB,GAAG;QACtB,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE;YACzB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;SACpD;aAAM;YACH,QAAQ,CAAC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,SAAS,GAAG,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;SACnJ;IACL,CAAC,CAAC;IAEF,SAAS,CAAC;QACN,IAAI,WAAW,CAAC,iBAAiB,IAAI,WAAW,CAAC,sBAAsB,EAAE;YACrE,4BAA4B,EAAE,CAAC;SAClC;QAED,WAAW,CAAC,sBAAsB,IAAI,eAAe,EAAE,CAAC;IAC5D,CAAC,EAAE,CAAC,WAAW,CAAC,iBAAiB,EAAE,WAAW,CAAC,sBAAsB,CAAC,CAAC,CAAC;IAExE,oBAAoB;IACpB,+CAA+C;IAC/C,iDAAiD;IACjD,QAAQ;IACR,2CAA2C;IAE3C,gBAAgB,CAAC;QACb,8BAA8B,EAAE,CAAC;QACjC,2CAA2C;IAC/C,CAAC,CAAC,CAAC;IAEH,IAAM,cAAc,GAAG,UAAU,CAAC,gBAAgB,EAAE;QAChD,uBAAuB,EAAE,WAAW,CAAC,iBAAiB;QACtD,sBAAsB,EAAE,WAAW,CAAC,sBAAsB;QAC1D,gBAAgB,EAAE,YAAY,CAAC,UAAU,KAAK,QAAQ;KACzD,CAAC,CAAC;IACK,IAAA,aAAa,GAAK,WAAW,CAAC,UAAC,KAAU,IAAK,OAAA,KAAK,CAAC,WAAW,EAAjB,CAAiB,CAAC,cAAnD,CAAoD,CAAC,0CAA0C;IAGpH,IAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,IAAM,IAAI,GAAG,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,0CAAE,IAAI,CAAC;IAEjC,IAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEhC,SAAS,CAAC;QACN,IAAI,SAAS,CAAC,OAAO;YAAE,OAAO;QAC9B,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI;YAAE,OAAO;QAE9B,IAAM,QAAQ,GAAG,WAAW,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAgC,CAAC;QAC9F,IAAM,QAAQ,GAAG,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,MAAK,QAAQ,CAAC;QAE7C,4CAA4C;QAC5C,IAAM,YAAY,GAAG,CAAC,cAAc,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAE5D,4BAA4B;QAC5B,kBAAkB;QAClB,aAAa;QACb,IAAI,YAAY,IAAI,QAAQ,EAAE;YAC1B,cAAc,CAAC,OAAO,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;SACjD;aAAM;YACH,OAAO;SACV;QAED,SAAS,CAAC,OAAO,GAAG,IAAI,CAAC;QAEzB,IAAM,qBAAqB,GAAG;;;;;wBACpB,aAAa,GAAG,GAAG,CAAC,qCAAqC,CAAC,CAAC;wBAE3D,KAAK,GAAiC;4BACxC,IAAI,EAAE,oBAAoB;4BAC1B,IAAI,MAAA;4BACJ,OAAO,EAAE,OAAO,CAAC,IAAI;yBACxB,CAAC;6BAEE,aAAa,EAAb,wBAAa;wBACP,wBAAwB,GAAG,oBAAoB,CAAC,aAAa,CAAC,CAAC;6BACjE,wBAAwB,EAAxB,wBAAwB;wBACxB,qBAAM,wBAAwB,CAAC,KAAK,CAAC,EAAA;;wBAArC,SAAqC,CAAC;;;;;aAGjD,CAAC;QAEF,qBAAqB,EAAE,CAAC;IAC5B,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;IAEnC,iCAAiC;IACjC,8EAA8E;IAC9E,oBAAoB;IACpB,0CAA0C;IAC1C,0EAA0E;IAC1E,QAAQ;IACR,sCAAsC;IAEtC,qCAAqC;IACrC,2BAA2B;IAC3B,oDAAoD;IACpD,eAAe;IACf,mDAAmD;IACnD,QAAQ;IACR,KAAK;IAEL,OAAO,CACH,KAAC,KAAK,CAAC,QAAQ,cACX,eAAK,SAAS,EAAE,cAAc,aAE1B,KAAC,UAAU,KAAG,EAId,KAAC,mBAAmB,KAAuB,EAC3C,KAAC,WAAW,KAAG,EACf,cAAK,SAAS,EAAE,uBAAgB,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAE,YAC3D,QAAQ,GAEP,EACN,KAAC,SAAS,KAAG,EACb,cAAK,SAAS,EAAC,aAAa,GAAO,IACjC,GACO,CACpB,CAAC;AACN,CAAC,CAAC","sourcesContent":["/* eslint-disable react-hooks/exhaustive-deps */\nimport { ChildContainerProps, LayoutState } from '../../types';\nimport { usePathname } from \"../../hooks/usePathname\";\nimport { useSearchParams } from \"../../hooks/useSearchParams\";\nimport { PrimeReactContext } from 'primereact/api';\nimport { useEventListener, useUnmountEffect } from 'primereact/hooks';\nimport { classNames } from 'primereact/utils';\nimport React, { useContext, useEffect, useRef } from 'react';\nimport { useSelector } from 'react-redux';\nimport AppConfig from './AppConfig';\nimport { LayoutContext } from './context/layoutcontext';\nimport AppSidebar from './AppSidebar';\nimport SolidPopupContainer from '../common/SolidPopupContainer';\nimport { GlobalToast } from '../common/GlobalToast';\nimport { useSession } from \"../../hooks/useSession\";\nimport { getExtensionFunction } from '../../helpers/registry';\nimport { SolidOnApplicationMountEvent } from '../../types/solid-core';\nimport { env } from \"../../adapters/env\";\n\nexport const Layout = ({ children }: ChildContainerProps) => {\n const { layoutConfig, layoutState, setLayoutState } = useContext(LayoutContext);\n const { setRipple } = useContext(PrimeReactContext);\n // const topbarRef = useRef<AppTopbarRef>(null);\n const sidebarRef = useRef<HTMLDivElement>(null);\n const [bindMenuOutsideClickListener, unbindMenuOutsideClickListener] = useEventListener({\n type: 'click',\n listener: (event) => {\n const isOutsideClicked = !(\n sidebarRef.current?.isSameNode(event.target as Node) ||\n sidebarRef.current?.contains(event.target as Node)\n // topbarRef.current?.menubutton?.isSameNode(event.target as Node) ||\n // topbarRef.current?.menubutton?.contains(event.target as Node)\n );\n\n if (isOutsideClicked) {\n hideMenu();\n }\n }\n });\n\n const pathname = usePathname();\n const searchParams = useSearchParams();\n useEffect(() => {\n hideMenu();\n hideProfileMenu();\n }, [pathname, searchParams]);\n\n // const [bindProfileMenuOutsideClickListener, unbindProfileMenuOutsideClickListener] = useEventListener({\n // type: 'click',\n // listener: (event) => {\n // const isOutsideClicked = !(\n // topbarRef.current?.topbarmenu?.isSameNode(event.target as Node) ||\n // topbarRef.current?.topbarmenu?.contains(event.target as Node) ||\n // topbarRef.current?.topbarmenubutton?.isSameNode(event.target as Node) ||\n // topbarRef.current?.topbarmenubutton?.contains(event.target as Node)\n // );\n\n // if (isOutsideClicked) {\n // hideProfileMenu();\n // }\n // }\n // });\n\n const hideMenu = () => {\n setLayoutState((prevLayoutState: LayoutState) => ({\n ...prevLayoutState,\n overlayMenuActive: false,\n staticMenuMobileActive: false,\n menuHoverActive: false\n }));\n unbindMenuOutsideClickListener();\n unblockBodyScroll();\n };\n\n const hideProfileMenu = () => {\n setLayoutState((prevLayoutState: LayoutState) => ({\n ...prevLayoutState,\n profileSidebarVisible: false\n }));\n // unbindProfileMenuOutsideClickListener();\n };\n\n const blockBodyScroll = (): void => {\n if (document.body.classList) {\n document.body.classList.add('blocked-scroll');\n } else {\n document.body.className += ' blocked-scroll';\n }\n };\n\n const unblockBodyScroll = (): void => {\n if (document.body.classList) {\n document.body.classList.remove('blocked-scroll');\n } else {\n document.body.className = document.body.className.replace(new RegExp('(^|\\\\b)' + 'blocked-scroll'.split(' ').join('|') + '(\\\\b|$)', 'gi'), ' ');\n }\n };\n\n useEffect(() => {\n if (layoutState.overlayMenuActive || layoutState.staticMenuMobileActive) {\n bindMenuOutsideClickListener();\n }\n\n layoutState.staticMenuMobileActive && blockBodyScroll();\n }, [layoutState.overlayMenuActive, layoutState.staticMenuMobileActive]);\n\n // useEffect(() => {\n // if (layoutState.profileSidebarVisible) {\n // bindProfileMenuOutsideClickListener();\n // }\n // }, [layoutState.profileSidebarVisible]);\n\n useUnmountEffect(() => {\n unbindMenuOutsideClickListener();\n // unbindProfileMenuOutsideClickListener();\n });\n\n const containerClass = classNames('layout-wrapper', {\n 'layout-overlay-active': layoutState.overlayMenuActive,\n 'layout-mobile-active': layoutState.staticMenuMobileActive,\n 'p-input-filled': layoutConfig.inputStyle === 'filled',\n });\n const { visibleNavbar } = useSelector((state: any) => state.navbarState); // Get the visibility state of sidebar-two\n\n\n const session = useSession();\n const user = session?.data?.user;\n\n const hasRunRef = useRef(false);\n\n useEffect(() => {\n if (hasRunRef.current) return;\n if (!session || !user) return;\n\n const navEntry = performance.getEntriesByType(\"navigation\")[0] as PerformanceNavigationTiming;\n const isReload = navEntry?.type === \"reload\";\n\n // Detect first mount (after login redirect)\n const isFirstMount = !sessionStorage.getItem(\"app-mounted\");\n\n // Allow execution only for:\n // 1. First mount\n // 2. Reload\n if (isFirstMount || isReload) {\n sessionStorage.setItem(\"app-mounted\", \"true\");\n } else {\n return;\n }\n\n hasRunRef.current = true;\n\n const handleDynamicFunction = async () => {\n const dynamicHeader = env(\"SOLIDX_ON_APPLICATION_MOUNT_HANDLER\");\n\n const event: SolidOnApplicationMountEvent = {\n type: \"onApplicationMount\",\n user,\n session: session.data\n };\n\n if (dynamicHeader) {\n const DynamicFunctionComponent = getExtensionFunction(dynamicHeader);\n if (DynamicFunctionComponent) {\n await DynamicFunctionComponent(event);\n }\n }\n };\n\n handleDynamicFunction();\n }, [session, session?.data, user]);\n\n // const dispatch = useDispatch()\n // const { data: solidSettingsDataInitialData } = useGetSolidSettingsQuery(\"\")\n // useEffect(() => {\n // if (solidSettingsDataInitialData) {\n // dispatch(setSolidSettings(solidSettingsDataInitialData?.data));\n // }\n // }, [solidSettingsDataInitialData]);\n\n // const toggleBothSidebars = () => {\n // if (visibleNavbar) {\n // dispatch(toggleNavbar()); // close both\n // } else {\n // dispatch(showNavbar()); // open both\n // }\n // };\n\n return (\n <React.Fragment>\n <div className={containerClass}>\n {/* {getEnv(\"NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER\") == \"true\" && <CustomHeader />} */}\n <AppSidebar />\n {/* <div className=\"apps-icon block md:hidden\" onClick={toggleBothSidebars}>\n <i className=\"pi pi-th-large\"></i>\n </div> */}\n <SolidPopupContainer></SolidPopupContainer>\n <GlobalToast />\n <div className={`main-content ${visibleNavbar ? \"shifted\" : \"\"}`}>\n {children}\n {/* {getEnv(\"NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER\") == \"true\" && <CustomFooter />} */}\n </div>\n <AppConfig />\n <div className=\"layout-mask\"></div>\n </div>\n </React.Fragment>\n );\n};\n"]}
|
|
@@ -11,6 +11,7 @@ import AppConfig from './AppConfig';
|
|
|
11
11
|
import { LayoutContext } from './context/layoutcontext';
|
|
12
12
|
import AppSidebar from './AppSidebar';
|
|
13
13
|
import SolidPopupContainer from '../common/SolidPopupContainer';
|
|
14
|
+
import { GlobalToast } from '../common/GlobalToast';
|
|
14
15
|
import { useSession } from "../../hooks/useSession";
|
|
15
16
|
import { getExtensionFunction } from '../../helpers/registry';
|
|
16
17
|
import { SolidOnApplicationMountEvent } from '../../types/solid-core';
|
|
@@ -193,6 +194,7 @@ export const Layout = ({ children }: ChildContainerProps) => {
|
|
|
193
194
|
<i className="pi pi-th-large"></i>
|
|
194
195
|
</div> */}
|
|
195
196
|
<SolidPopupContainer></SolidPopupContainer>
|
|
197
|
+
<GlobalToast />
|
|
196
198
|
<div className={`main-content ${visibleNavbar ? "shifted" : ""}`}>
|
|
197
199
|
{children}
|
|
198
200
|
{/* {getEnv("NEXT_PUBLIC_ENABLE_CUSTOM_HEADER_FOOTER") == "true" && <CustomFooter />} */}
|
|
@@ -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`}
|