| | |
| | | import type { AppRouteRecordRaw, Menu } from '/@/router/types'; |
| | | import store from '/@/store/index'; |
| | | import { hotModuleUnregisterModule } from '/@/utils/helper/vuexHelper'; |
| | | |
| | | import store from '/@/store'; |
| | | import { toRaw } from 'vue'; |
| | | import { VuexModule, Mutation, Module, getModule, Action } from 'vuex-module-decorators'; |
| | | |
| | | import { hotModuleUnregisterModule } from '/@/utils/helper/vuexHelper'; |
| | | |
| | | import { PermissionModeEnum } from '/@/enums/appEnum'; |
| | | |
| | | import { appStore } from '/@/store/modules/app'; |
| | | import { userStore } from '/@/store/modules/user'; |
| | | import projectSetting from '/@/settings/projectSetting'; |
| | | |
| | | import { asyncRoutes } from '/@/router/routes'; |
| | | import { filter } from '/@/utils/helper/treeHelper'; |
| | | import { toRaw } from 'vue'; |
| | | import { getMenuListById } from '/@/api/sys/menu'; |
| | | import { getPermCodeByUserId } from '/@/api/sys/user'; |
| | | |
| | | import { ERROR_LOG_ROUTE, PAGE_NOT_FOUND_ROUTE } from '/@/router/routes/basic'; |
| | | import { transformObjToRoute, flatMultiLevelRoutes } from '/@/router/helper/routeHelper'; |
| | | import { transformRouteToMenu } from '/@/router/helper/menuHelper'; |
| | | |
| | | import { filter } from '/@/utils/helper/treeHelper'; |
| | | |
| | | import { getMenuListById } from '/@/api/sys/menu'; |
| | | import { getPermCodeByUserId } from '/@/api/sys/user'; |
| | | |
| | | import { useMessage } from '/@/hooks/web/useMessage'; |
| | | import { useI18n } from '/@/hooks/web/useI18n'; |
| | | import { ERROR_LOG_ROUTE, PAGE_NOT_FOUND_ROUTE } from '/@/router/routes/basic'; |
| | | |
| | | const { createMessage } = useMessage(); |
| | | const NAME = 'app-permission'; |
| | | hotModuleUnregisterModule(NAME); |
| | | @Module({ dynamic: true, namespaced: true, store, name: NAME }) |
| | |
| | | const { t } = useI18n(); |
| | | let routes: AppRouteRecordRaw[] = []; |
| | | const roleList = toRaw(userStore.getRoleListState); |
| | | |
| | | const { permissionMode = PermissionModeEnum.ROLE } = appStore.getProjectConfig; |
| | | |
| | | const { permissionMode = projectSetting.permissionMode } = appStore.getProjectConfig; |
| | | // role permissions |
| | | if (permissionMode === PermissionModeEnum.ROLE) { |
| | | const routeFilter = (route) => { |
| | | const { meta } = route as AppRouteRecordRaw; |
| | | const routeFilter = (route: AppRouteRecordRaw) => { |
| | | const { meta } = route; |
| | | const { roles } = meta || {}; |
| | | if (!roles) return true; |
| | | return roleList.some((role) => roles.includes(role)); |
| | |
| | | routes = flatMultiLevelRoutes(routes); |
| | | // If you are sure that you do not need to do background dynamic permissions, please comment the entire judgment below |
| | | } else if (permissionMode === PermissionModeEnum.BACK) { |
| | | const { createMessage } = useMessage(); |
| | | |
| | | createMessage.loading({ |
| | | content: t('sys.app.menuLoading'), |
| | | duration: 1, |