vue-vben-admin/src/store/modules/permission.ts

128 lines
3.9 KiB
TypeScript
Raw Normal View History

2020-09-28 20:19:10 +08:00
import type { AppRouteRecordRaw, Menu } from '/@/router/types';
import store from '/@/store/index';
import { hotModuleUnregisterModule } from '/@/utils/helper/vuexHelper';
import { VuexModule, Mutation, Module, getModule, Action } from 'vuex-module-decorators';
import { PermissionModeEnum } from '/@/enums/appEnum';
import { appStore } from '/@/store/modules/app';
import { userStore } from '/@/store/modules/user';
2020-11-12 22:20:15 +08:00
import { asyncRoutes } from '/@/router/routes';
2020-09-28 20:19:10 +08:00
import { filter } from '/@/utils/helper/treeHelper';
import { toRaw } from 'vue';
import { getMenuListById } from '/@/api/sys/menu';
2020-12-03 21:49:32 +08:00
import { transformObjToRoute } from '/@/router/helper/routeHelper';
import { transformRouteToMenu } from '/@/router/helper/menuHelper';
2020-09-28 20:19:10 +08:00
import { useMessage } from '/@/hooks/web/useMessage';
2020-11-26 21:10:21 +08:00
import { useI18n } from '/@/hooks/web/useI18n';
import { ERROR_LOG_ROUTE, PAGE_NOT_FOUND_ROUTE } from '/@/router/constant';
2020-11-26 21:10:21 +08:00
2020-09-28 20:19:10 +08:00
const { createMessage } = useMessage();
2021-02-28 12:25:57 +08:00
const NAME = 'app-permission';
2020-09-28 20:19:10 +08:00
hotModuleUnregisterModule(NAME);
@Module({ dynamic: true, namespaced: true, store, name: NAME })
class Permission extends VuexModule {
2020-10-30 21:32:05 +08:00
// Permission code list
2020-09-28 20:19:10 +08:00
private permCodeListState: string[] = [];
// Whether the route has been dynamically added
private isDynamicAddedRouteState = false;
2020-10-30 21:32:05 +08:00
// To trigger a menu update
2020-09-28 20:19:10 +08:00
private lastBuildMenuTimeState = 0;
2020-10-30 21:32:05 +08:00
// Backstage menu list
2020-09-28 20:19:10 +08:00
private backMenuListState: Menu[] = [];
get getPermCodeListState() {
return this.permCodeListState;
}
get getBackMenuListState() {
return this.backMenuListState;
}
get getLastBuildMenuTimeState() {
return this.lastBuildMenuTimeState;
}
get getIsDynamicAddedRouteState() {
return this.isDynamicAddedRouteState;
}
@Mutation
commitPermCodeListState(codeList: string[]): void {
this.permCodeListState = codeList;
}
@Mutation
commitBackMenuListState(list: Menu[]): void {
this.backMenuListState = list;
}
@Mutation
commitLastBuildMenuTimeState(): void {
this.lastBuildMenuTimeState = new Date().getTime();
}
@Mutation
commitDynamicAddedRouteState(added: boolean): void {
this.isDynamicAddedRouteState = added;
}
@Mutation
commitResetState(): void {
this.isDynamicAddedRouteState = false;
this.permCodeListState = [];
this.backMenuListState = [];
this.lastBuildMenuTimeState = 0;
}
@Action
async buildRoutesAction(id?: number | string): Promise<AppRouteRecordRaw[]> {
2020-12-03 21:49:32 +08:00
const { t } = useI18n();
2020-09-28 20:19:10 +08:00
let routes: AppRouteRecordRaw[] = [];
const roleList = toRaw(userStore.getRoleListState);
const { permissionMode = PermissionModeEnum.ROLE } = appStore.getProjectConfig;
2020-09-28 20:19:10 +08:00
// role permissions
if (permissionMode === PermissionModeEnum.ROLE) {
routes = filter(asyncRoutes, (route) => {
2020-12-03 21:49:32 +08:00
const { meta } = route as AppRouteRecordRaw;
const { roles } = meta || {};
2020-09-28 20:19:10 +08:00
if (!roles) return true;
return roleList.some((role) => roles.includes(role));
});
// If you are sure that you do not need to do background dynamic permissions, please comment the entire judgment below
2020-09-28 20:19:10 +08:00
} else if (permissionMode === PermissionModeEnum.BACK) {
createMessage.loading({
2020-12-01 23:51:39 +08:00
content: t('sys.app.menuLoading'),
2020-09-28 20:19:10 +08:00
duration: 1,
});
// Here to get the background routing menu logic to modify by yourself
2020-09-28 20:19:10 +08:00
const paramId = id || userStore.getUserInfoState.userId;
if (!paramId) {
throw new Error('paramId is undefined!');
}
2020-12-23 21:16:27 +08:00
let routeList = (await getMenuListById({ id: paramId })) as AppRouteRecordRaw[];
// Dynamically introduce components
2020-09-28 20:19:10 +08:00
routeList = transformObjToRoute(routeList);
// Background routing to menu structure
2020-09-28 20:19:10 +08:00
const backMenuList = transformRouteToMenu(routeList);
2020-12-03 21:49:32 +08:00
2020-09-28 20:19:10 +08:00
this.commitBackMenuListState(backMenuList);
2020-12-03 21:49:32 +08:00
2020-12-23 21:16:27 +08:00
routes = [PAGE_NOT_FOUND_ROUTE, ...routeList];
2020-09-28 20:19:10 +08:00
}
routes.push(ERROR_LOG_ROUTE);
2020-09-28 20:19:10 +08:00
return routes;
}
}
export const permissionStore = getModule<Permission>(Permission);