|
|
@ -1,43 +1,13 @@
|
|
|
|
import { asyncRoutes, constantRoutes } from '@/router'
|
|
|
|
import router, { constantRoutes } from '@/router'
|
|
|
|
|
|
|
|
import { user_power } from '@/api/user/user'
|
|
|
|
/**
|
|
|
|
import { getALLRouter } from '@/utils'
|
|
|
|
* Use meta.role to determine if the current userinfo 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 = {
|
|
|
|
const state = {
|
|
|
|
routes: [],
|
|
|
|
routes: [],
|
|
|
|
addRoutes: [],
|
|
|
|
addRoutes: [],
|
|
|
|
roleData: {}
|
|
|
|
// 存储home页区块路由,下拉选项路由
|
|
|
|
|
|
|
|
roleData: {},
|
|
|
|
|
|
|
|
opts: []
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const mutations = {
|
|
|
|
const mutations = {
|
|
|
@ -47,20 +17,25 @@ const mutations = {
|
|
|
|
},
|
|
|
|
},
|
|
|
|
SET_ROLE_DATA: (state, data) => {
|
|
|
|
SET_ROLE_DATA: (state, data) => {
|
|
|
|
state.roleData = data
|
|
|
|
state.roleData = data
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
SET_OPTS: (state, opt) => {
|
|
|
|
|
|
|
|
state.opts = opt
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const actions = {
|
|
|
|
const actions = {
|
|
|
|
generateRoutes({ commit }, roles) {
|
|
|
|
generateRoutes({ commit }) {
|
|
|
|
return new Promise(resolve => {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
let accessedRoutes
|
|
|
|
user_power().then(res => {
|
|
|
|
if (roles.includes('admin')) {
|
|
|
|
const { asyncRoutes, option } = getALLRouter(res.data)
|
|
|
|
accessedRoutes = asyncRoutes || []
|
|
|
|
commit('SET_OPTS', option)
|
|
|
|
} else {
|
|
|
|
commit('SET_ROLE_DATA', res.data)
|
|
|
|
accessedRoutes = filterAsyncRoutes(asyncRoutes, roles)
|
|
|
|
commit('SET_ROUTES', asyncRoutes)
|
|
|
|
}
|
|
|
|
router.addRoutes(asyncRoutes)
|
|
|
|
commit('SET_ROUTES', accessedRoutes)
|
|
|
|
resolve()
|
|
|
|
resolve(accessedRoutes)
|
|
|
|
}).catch(error => {
|
|
|
|
|
|
|
|
reject(error)
|
|
|
|
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|