| 
									
										
										
										
											2021-12-18 16:48:31 +08:00
										 |  |  | import auth from '@/plugins/auth' | 
					
						
							|  |  |  | import router, { constantRoutes, dynamicRoutes } from '@/router' | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | import { getRouters } from '@/api/menu' | 
					
						
							|  |  |  | import Layout from '@/layout/index' | 
					
						
							| 
									
										
										
										
											2021-11-24 14:47:24 +08:00
										 |  |  | import ParentView from '@/components/ParentView' | 
					
						
							| 
									
										
										
										
											2021-07-11 16:31:10 +08:00
										 |  |  | import InnerLink from '@/layout/components/InnerLink' | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | const permission = { | 
					
						
							|  |  |  |   state: { | 
					
						
							|  |  |  |     routes: [], | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |     addRoutes: [], | 
					
						
							| 
									
										
										
										
											2021-04-12 09:54:08 +08:00
										 |  |  |     defaultRoutes: [], | 
					
						
							|  |  |  |     topbarRouters: [], | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |     sidebarRouters: [] | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  |   mutations: { | 
					
						
							|  |  |  |     SET_ROUTES: (state, routes) => { | 
					
						
							|  |  |  |       state.addRoutes = routes | 
					
						
							|  |  |  |       state.routes = constantRoutes.concat(routes) | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2021-04-12 09:54:08 +08:00
										 |  |  |     SET_DEFAULT_ROUTES: (state, routes) => { | 
					
						
							|  |  |  |       state.defaultRoutes = constantRoutes.concat(routes) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     SET_TOPBAR_ROUTES: (state, routes) => { | 
					
						
							| 
									
										
										
										
											2022-03-06 09:03:44 +08:00
										 |  |  |       state.topbarRouters = routes | 
					
						
							| 
									
										
										
										
											2021-04-12 09:54:08 +08:00
										 |  |  |     }, | 
					
						
							|  |  |  |     SET_SIDEBAR_ROUTERS: (state, routes) => { | 
					
						
							|  |  |  |       state.sidebarRouters = routes | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  |   actions: { | 
					
						
							|  |  |  |     // 生成路由
 | 
					
						
							|  |  |  |     GenerateRoutes({ commit }) { | 
					
						
							|  |  |  |       return new Promise(resolve => { | 
					
						
							|  |  |  |         // 向后端请求路由数据
 | 
					
						
							|  |  |  |         getRouters().then(res => { | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |           const sdata = JSON.parse(JSON.stringify(res.data)) | 
					
						
							|  |  |  |           const rdata = JSON.parse(JSON.stringify(res.data)) | 
					
						
							|  |  |  |           const sidebarRoutes = filterAsyncRouter(sdata) | 
					
						
							| 
									
										
										
										
											2021-02-06 09:29:50 +08:00
										 |  |  |           const rewriteRoutes = filterAsyncRouter(rdata, false, true) | 
					
						
							| 
									
										
										
										
											2021-12-18 16:48:31 +08:00
										 |  |  |           const asyncRoutes = filterDynamicRoutes(dynamicRoutes); | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |           rewriteRoutes.push({ path: '*', redirect: '/404', hidden: true }) | 
					
						
							| 
									
										
										
										
											2021-12-18 16:48:31 +08:00
										 |  |  |           router.addRoutes(asyncRoutes); | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |           commit('SET_ROUTES', rewriteRoutes) | 
					
						
							| 
									
										
										
										
											2021-04-12 09:54:08 +08:00
										 |  |  |           commit('SET_SIDEBAR_ROUTERS', constantRoutes.concat(sidebarRoutes)) | 
					
						
							|  |  |  |           commit('SET_DEFAULT_ROUTES', sidebarRoutes) | 
					
						
							|  |  |  |           commit('SET_TOPBAR_ROUTES', sidebarRoutes) | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |           resolve(rewriteRoutes) | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |         }) | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // 遍历后台传来的路由字符串,转换为组件对象
 | 
					
						
							| 
									
										
										
										
											2021-02-06 09:29:50 +08:00
										 |  |  | function filterAsyncRouter(asyncRouterMap, lastRouter = false, type = false) { | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |   return asyncRouterMap.filter(route => { | 
					
						
							| 
									
										
										
										
											2021-02-06 09:29:50 +08:00
										 |  |  |     if (type && route.children) { | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |       route.children = filterChildren(route.children) | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |     if (route.component) { | 
					
						
							| 
									
										
										
										
											2020-11-28 20:39:03 +08:00
										 |  |  |       // Layout ParentView 组件特殊处理
 | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |       if (route.component === 'Layout') { | 
					
						
							|  |  |  |         route.component = Layout | 
					
						
							| 
									
										
										
										
											2020-11-28 20:39:03 +08:00
										 |  |  |       } else if (route.component === 'ParentView') { | 
					
						
							|  |  |  |         route.component = ParentView | 
					
						
							| 
									
										
										
										
											2021-07-11 16:31:10 +08:00
										 |  |  |       } else if (route.component === 'InnerLink') { | 
					
						
							|  |  |  |         route.component = InnerLink | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |       } else { | 
					
						
							|  |  |  |         route.component = loadView(route.component) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (route.children != null && route.children && route.children.length) { | 
					
						
							| 
									
										
										
										
											2021-02-06 09:29:50 +08:00
										 |  |  |       route.children = filterAsyncRouter(route.children, route, type) | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       delete route['children'] | 
					
						
							|  |  |  |       delete route['redirect'] | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  |     } | 
					
						
							|  |  |  |     return true | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-06 09:29:50 +08:00
										 |  |  | function filterChildren(childrenMap, lastRouter = false) { | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |   var children = [] | 
					
						
							|  |  |  |   childrenMap.forEach((el, index) => { | 
					
						
							|  |  |  |     if (el.children && el.children.length) { | 
					
						
							| 
									
										
										
										
											2021-10-14 16:19:46 +08:00
										 |  |  |       if (el.component === 'ParentView' && !lastRouter) { | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |         el.children.forEach(c => { | 
					
						
							|  |  |  |           c.path = el.path + '/' + c.path | 
					
						
							|  |  |  |           if (c.children && c.children.length) { | 
					
						
							|  |  |  |             children = children.concat(filterChildren(c.children, c)) | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           children.push(c) | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-02-06 09:29:50 +08:00
										 |  |  |     if (lastRouter) { | 
					
						
							|  |  |  |       el.path = lastRouter.path + '/' + el.path | 
					
						
							| 
									
										
										
										
											2023-11-10 15:31:30 +08:00
										 |  |  |       if (el.children && el.children.length) { | 
					
						
							|  |  |  |         children = children.concat(filterChildren(el.children, el)) | 
					
						
							|  |  |  |         return | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2021-02-06 09:29:50 +08:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-12-16 20:57:48 +08:00
										 |  |  |     children = children.concat(el) | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  |   return children | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-18 16:48:31 +08:00
										 |  |  | // 动态路由遍历,验证是否具备权限
 | 
					
						
							|  |  |  | export function filterDynamicRoutes(routes) { | 
					
						
							|  |  |  |   const res = [] | 
					
						
							|  |  |  |   routes.forEach(route => { | 
					
						
							|  |  |  |     if (route.permissions) { | 
					
						
							|  |  |  |       if (auth.hasPermiOr(route.permissions)) { | 
					
						
							|  |  |  |         res.push(route) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else if (route.roles) { | 
					
						
							|  |  |  |       if (auth.hasRoleOr(route.roles)) { | 
					
						
							|  |  |  |         res.push(route) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  |   return res | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 17:57:46 +08:00
										 |  |  | export const loadView = (view) => { | 
					
						
							|  |  |  |   if (process.env.NODE_ENV === 'development') { | 
					
						
							|  |  |  |     return (resolve) => require([`@/views/${view}`], resolve) | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     // 使用 import 实现生产环境的路由懒加载
 | 
					
						
							|  |  |  |     return () => import(`@/views/${view}`) | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-10-08 09:14:38 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default permission |