| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- import { asyncRoutes, resetRouter, constantRoutes } from '@/router'
- import permission from '@/utils/permission'
- /**
- * Use meta.role to determine if the current user has permission
- * @param roles
- * @param route
- */
- function hasPermission(roles, route) {
- if (route.meta && route.meta.roles) {
- return roles.some(role => route.meta.roles.includes(role))
- } else {
- return true
- }
- }
- /**
- * Filter asynchronous routing tables by recursion
- * @param routes asyncRoutes
- * @param roles
- */
- export function filterAsyncRoutes(routes, roles) {
- const res = []
- routes.forEach(route => {
- const tmp = { ...route }
- if (hasPermission(roles, tmp)) {
- if (tmp.children) {
- tmp.children = filterAsyncRoutes(tmp.children, roles)
- }
- res.push(tmp)
- }
- })
- return res
- }
- const state = {
- routes: [],
- addRoutes: []
- }
- const mutations = {
- SET_ROUTES: (state, routes) => {
- resetRouter()
- state.addRoutes = routes
- state.routes = constantRoutes
- filterRoutes(state.routes)
- }
- }
- const actions = {
- generateRoutes({ commit }, roles) {
- return new Promise(resolve => {
- let accessedRoutes
- if (roles.includes('admin')) {
- accessedRoutes = asyncRoutes || []
- } else {
- accessedRoutes = filterAsyncRoutes(asyncRoutes, roles)
- }
- commit('SET_ROUTES', accessedRoutes)
- resolve(accessedRoutes)
- })
- }
- }
- function filterRoutes(routes, parent) {
- //console.log("路由遍历", routes, parent);
- routes.forEach((route) => {
- const authRoute = state.addRoutes.find(authRoute => (authRoute[permission.RESOURCE_KEY] === route.path))
- if (authRoute) {
- if (!route.disabled) {
- route.hidden = false
- if (route.meta) {
- route.meta.onlyView = authRoute.onlyView || false
- } else {
- route.meta = { onlyView: authRoute.onlyView }
- }
- if (parent) {
- parent.hidden = false;
- }
- } else {
- authRoute[permission.RESOURCE_KEY] = "";
- route.hidden = true;
- }
- } else if (route.sharePath) {
- const shareRoute = state.addRoutes.find(_route => _route[permission.RESOURCE_KEY] === route.sharePath);
- if (shareRoute) {
- route.hidden = false
- if (route.meta) {
- route.meta.onlyView = shareRoute.onlyView || false
- } else {
- route.meta = { onlyView: shareRoute.onlyView }
- }
- if (parent) {
- parent.hidden = false;
- }
- state.addRoutes.push({
- resourceName: route.name,
- resourcePath: route.path
- })
- }
- } else {
- route.hidden = true;
- }
- if (route.children) {
- filterRoutes(route.children, route)
- }
- })
- }
- export default {
- namespaced: true,
- state,
- mutations,
- actions
- }
|