1
0

permission.ts 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. import { REDIRECT_ROUTE } from '/@/router/constant';
  2. import type { AppRouteRecordRaw, Menu } from '/@/router/types';
  3. import store from '/@/store/index';
  4. import { hotModuleUnregisterModule } from '/@/utils/helper/vuexHelper';
  5. import { VuexModule, Mutation, Module, getModule, Action } from 'vuex-module-decorators';
  6. import { PermissionModeEnum } from '/@/enums/appEnum';
  7. import { appStore } from '/@/store/modules/app';
  8. import { userStore } from '/@/store/modules/user';
  9. import { asyncRoutes } from '/@/router/routes/index';
  10. import { filter } from '/@/utils/helper/treeHelper';
  11. import { toRaw } from 'vue';
  12. import { getMenuListById } from '/@/api/sys/menu';
  13. import { genRouteModule, transformObjToRoute } from '/@/utils/helper/routeHelper';
  14. import { transformRouteToMenu } from '/@/utils/helper/menuHelper';
  15. import { useMessage } from '/@/hooks/web/useMessage';
  16. import { warn } from 'vue';
  17. const { createMessage } = useMessage();
  18. const NAME = 'permission';
  19. hotModuleUnregisterModule(NAME);
  20. @Module({ dynamic: true, namespaced: true, store, name: NAME })
  21. class Permission extends VuexModule {
  22. // private routesState: AppRouteRecordRaw[] = [];
  23. // 权限编码列表
  24. private permCodeListState: string[] = [];
  25. // Whether the route has been dynamically added
  26. private isDynamicAddedRouteState = false;
  27. private lastBuildMenuTimeState = 0;
  28. private backMenuListState: Menu[] = [];
  29. get getPermCodeListState() {
  30. return this.permCodeListState;
  31. }
  32. get getBackMenuListState() {
  33. return this.backMenuListState;
  34. }
  35. get getLastBuildMenuTimeState() {
  36. return this.lastBuildMenuTimeState;
  37. }
  38. // get getRoutesState() {
  39. // return this.routesState;
  40. // }
  41. get getIsDynamicAddedRouteState() {
  42. return this.isDynamicAddedRouteState;
  43. }
  44. @Mutation
  45. commitPermCodeListState(codeList: string[]): void {
  46. this.permCodeListState = codeList;
  47. }
  48. @Mutation
  49. commitBackMenuListState(list: Menu[]): void {
  50. this.backMenuListState = list;
  51. }
  52. @Mutation
  53. commitLastBuildMenuTimeState(): void {
  54. this.lastBuildMenuTimeState = new Date().getTime();
  55. }
  56. // @Mutation
  57. // commitRoutesState(routes: AppRouteRecordRaw[]): void {
  58. // this.routesState = routes;
  59. // }
  60. @Mutation
  61. commitDynamicAddedRouteState(added: boolean): void {
  62. this.isDynamicAddedRouteState = added;
  63. }
  64. @Mutation
  65. commitResetState(): void {
  66. this.isDynamicAddedRouteState = false;
  67. this.permCodeListState = [];
  68. this.backMenuListState = [];
  69. this.lastBuildMenuTimeState = 0;
  70. }
  71. @Action
  72. async buildRoutesAction(id?: number | string): Promise<AppRouteRecordRaw[]> {
  73. let routes: AppRouteRecordRaw[] = [];
  74. const roleList = toRaw(userStore.getRoleListState);
  75. const { permissionMode } = appStore.getProjectConfig;
  76. // role permissions
  77. if (permissionMode === PermissionModeEnum.ROLE) {
  78. routes = filter(asyncRoutes, (route) => {
  79. const { meta } = route;
  80. const { roles } = meta!;
  81. if (!roles) return true;
  82. return roleList.some((role) => roles.includes(role));
  83. });
  84. // this.commitRoutesState(routes);
  85. // Background permissions
  86. warn(
  87. `当前权限模式为:${PermissionModeEnum.ROLE},请将src/store/modules/permission.ts内的后台菜单获取函数注释,如果已注释可以忽略此信息!`
  88. );
  89. // 如果确定不需要做后台动态权限,请将下面整个判断注释
  90. } else if (permissionMode === PermissionModeEnum.BACK) {
  91. const messageKey = 'loadMenu';
  92. createMessage.loading({
  93. content: '菜单加载中...',
  94. key: messageKey,
  95. duration: 1,
  96. });
  97. // 这里获取后台路由菜单逻辑自行修改
  98. const paramId = id || userStore.getUserInfoState.userId;
  99. if (!paramId) {
  100. throw new Error('paramId is undefined!');
  101. }
  102. let routeList: any[] = await getMenuListById({ id: paramId });
  103. // 动态引入组件
  104. routeList = transformObjToRoute(routeList);
  105. // 后台路由转菜单结构
  106. const backMenuList = transformRouteToMenu(routeList);
  107. this.commitBackMenuListState(backMenuList);
  108. // 生成路由
  109. routes = genRouteModule(routeList) as AppRouteRecordRaw[];
  110. routes.push(REDIRECT_ROUTE);
  111. }
  112. return routes;
  113. }
  114. }
  115. export { Permission };
  116. export const permissionStore = getModule<Permission>(Permission);