|
|
|
import Vue from "vue";
|
|
|
|
import Router from "vue-router";
|
|
|
|
import routes from "./routes";
|
|
|
|
import Setting from "@/setting";
|
|
|
|
import { get } from "@/plugins/requests/index.js";
|
|
|
|
import api from "@/api";
|
|
|
|
import util from "@/libs/util";
|
|
|
|
import BasicLayout from "@/layouts/home";
|
|
|
|
Vue.use(Router);
|
|
|
|
const createRouter = () => new Router({
|
|
|
|
mode: Setting.routerMode,
|
|
|
|
base: process.env.BASE_URL,
|
|
|
|
scrollBehavior: () => ({ y: 0 }),
|
|
|
|
routes
|
|
|
|
});
|
|
|
|
|
|
|
|
export function resetRouter() {
|
|
|
|
const newRouter = createRouter();
|
|
|
|
router.matcher = newRouter.matcher;
|
|
|
|
}
|
|
|
|
|
|
|
|
let router = createRouter();
|
|
|
|
|
|
|
|
|
|
|
|
export default router;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 错误页面
|
|
|
|
*/
|
|
|
|
const errorPage = [
|
|
|
|
{
|
|
|
|
path: "/403",
|
|
|
|
name: "403",
|
|
|
|
meta: {
|
|
|
|
title: "403"
|
|
|
|
},
|
|
|
|
component: () => import("@/pages/exception/error/403")
|
|
|
|
},
|
|
|
|
{
|
|
|
|
path: "*",
|
|
|
|
name: "404",
|
|
|
|
meta: {
|
|
|
|
title: "404"
|
|
|
|
},
|
|
|
|
component: () => import("@/pages/exception/error/404")
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
// 处理路由权限的方法
|
|
|
|
function getPermission() {
|
|
|
|
sessionStorage.setItem("handelPermission", true);// 记录已处理权限
|
|
|
|
get(`${api.getUserRolesPermissionMenu}?platformId=${Setting.platformId}`).then(res => {
|
|
|
|
// 取得路由的值,使用addRouter添加进路由里
|
|
|
|
// 该项目的路由实际上做了两层处理,一层指向了默认的路由,对应模块,用于基础布局的nav,下面一层才是实际上的路由跳转,
|
|
|
|
// 所以需要默认进行赋值,实际操作时根据path去禁用掉对应的nav即可。
|
|
|
|
const arr = ['achievement','assessment','course',"evaluation",'information','match','project','setting','student', 'station','system'];
|
|
|
|
let permissionRouters = []; // 最后处理好的路由数组
|
|
|
|
|
|
|
|
let data = res.permissionMenu[0].children;
|
|
|
|
if (data.length > 0) {
|
|
|
|
data.forEach(e => {
|
|
|
|
// 第一级路由,需要根据匹配到的path,塞进对应的路由children里
|
|
|
|
let str = e.path.split("/")[1];
|
|
|
|
let index = arr.indexOf(str);
|
|
|
|
if (index !== -1) {
|
|
|
|
let obj = {
|
|
|
|
path: e.path,
|
|
|
|
name: arr[index] + "-list",
|
|
|
|
component: () => import(`@/pages${e.path}`),
|
|
|
|
meta: { title: e.name, btn: [] },
|
|
|
|
children: []
|
|
|
|
};
|
|
|
|
let meta = [];
|
|
|
|
let children = [];
|
|
|
|
// 第二级是按钮级数据,一级归属当前页的同级页面,实际上一共就一级路由
|
|
|
|
if (e.children && e.children.length > 0) {
|
|
|
|
e.children.forEach(i => {
|
|
|
|
// 避免重复生成路由
|
|
|
|
if (i.path && permissionRouters[index] && !permissionRouters[index].children.some(e => i.path === e.path)) {
|
|
|
|
let obj = {
|
|
|
|
path: i.path,
|
|
|
|
name: arr[index] + "-" + i.path.split("/").pop(),
|
|
|
|
component: () => import(`@/pages${i.path}`),
|
|
|
|
meta: { title: i.name, btn: [] },
|
|
|
|
children: []
|
|
|
|
};
|
|
|
|
// 没找到第一级就生成一个
|
|
|
|
if (!permissionRouters.some(e => e.path === `/${str}`)) {
|
|
|
|
let one = {
|
|
|
|
path: "/" + arr[index],
|
|
|
|
name: arr[index],
|
|
|
|
redirect: {
|
|
|
|
name: `${arr[index]}-list`
|
|
|
|
},
|
|
|
|
component: BasicLayout,
|
|
|
|
children: []// 传来的路由实际上传入对应的children中
|
|
|
|
};
|
|
|
|
one.children.push(obj);
|
|
|
|
permissionRouters.push(one);
|
|
|
|
} else {
|
|
|
|
// 找到第一级,判断没有重复地址直接塞进去
|
|
|
|
let nowIndex = permissionRouters.findIndex(e => {
|
|
|
|
return e.path === `/${str}`;
|
|
|
|
});
|
|
|
|
if (nowIndex != -1 && permissionRouters[nowIndex] && !permissionRouters[nowIndex].children.some(e => e.path === obj.path)) {
|
|
|
|
permissionRouters[nowIndex].children.push(obj);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// permissionRouters.push(obj) // path是页面,要塞入上一级同级里,需要单独push进去生成路由
|
|
|
|
meta.push(i.name);
|
|
|
|
} else {
|
|
|
|
meta.push(i.name);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (i.children && i.children.length) {
|
|
|
|
i.children.forEach(j => {
|
|
|
|
if (j.path && permissionRouters[index] && !permissionRouters[index].children.some(e => j.path === e.path)) {
|
|
|
|
// console.log(j.path,'当前三级路由的路径')
|
|
|
|
let obj = {
|
|
|
|
path: j.path,
|
|
|
|
name: arr[index] + "-" + j.path.split("/").pop(),
|
|
|
|
component: () => import(`@/pages${j.path}`),
|
|
|
|
meta: { title: j.name, btn: [] },
|
|
|
|
children: []
|
|
|
|
};
|
|
|
|
// 没找到第一级就生成一个
|
|
|
|
if (!permissionRouters.some(e => e.path === `/${str}`)) {
|
|
|
|
let one = {
|
|
|
|
path: "/" + arr[index],
|
|
|
|
name: arr[index],
|
|
|
|
redirect: {
|
|
|
|
name: `${arr[index]}-list`
|
|
|
|
},
|
|
|
|
component: BasicLayout,
|
|
|
|
children: []// 传来的路由实际上传入对应的children中
|
|
|
|
};
|
|
|
|
one.children.push(obj);
|
|
|
|
permissionRouters.push(one);
|
|
|
|
} else {
|
|
|
|
// 找到第一级,判断没有重复地址直接塞进去
|
|
|
|
let nowIndex = permissionRouters.findIndex(e => {
|
|
|
|
return e.path === `/${str}`;
|
|
|
|
});
|
|
|
|
if (nowIndex != -1 && permissionRouters[nowIndex] && !permissionRouters[nowIndex].children.some(e => e.path === obj.path)) {
|
|
|
|
permissionRouters[nowIndex].children.push(obj);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// permissionRouters.push(obj) // path是页面,要塞入上一级同级里,需要单独push进去生成路由
|
|
|
|
meta.push(i.name+"-"+j.name);
|
|
|
|
} else {
|
|
|
|
meta.push(i.name+"-"+j.name);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (j.children && j.children.length) {
|
|
|
|
j.children.forEach(k => {
|
|
|
|
if (k.path && permissionRouters[index] && !permissionRouters[index].children.some(e => k.path === e.path)) {
|
|
|
|
// console.log(j.path,'当前四级路由的路径')
|
|
|
|
let obj = {
|
|
|
|
path: k.path,
|
|
|
|
name: arr[index] + "-" + k.path.split("/").pop(),
|
|
|
|
component: () => import(`@/pages${k.path}`),
|
|
|
|
meta: { title: k.name, btn: [] },
|
|
|
|
children: []
|
|
|
|
};
|
|
|
|
// 没找到第一级就生成一个
|
|
|
|
if (!permissionRouters.some(e => e.path === `/${str}`)) {
|
|
|
|
let one = {
|
|
|
|
path: "/" + arr[index],
|
|
|
|
name: arr[index],
|
|
|
|
redirect: {
|
|
|
|
name: `${arr[index]}-list`
|
|
|
|
},
|
|
|
|
component: BasicLayout,
|
|
|
|
children: []// 传来的路由实际上传入对应的children中
|
|
|
|
};
|
|
|
|
one.children.push(obj);
|
|
|
|
permissionRouters.push(one);
|
|
|
|
} else {
|
|
|
|
// 找到第一级,判断没有重复地址直接塞进去
|
|
|
|
let nowIndex = permissionRouters.findIndex(e => {
|
|
|
|
return e.path === `/${str}`;
|
|
|
|
});
|
|
|
|
if (nowIndex != -1 && permissionRouters[nowIndex] && !permissionRouters[nowIndex].children.some(e => e.path === obj.path)) {
|
|
|
|
permissionRouters[nowIndex].children.push(obj);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// permissionRouters.push(obj) // path是页面,要塞入上一级同级里,需要单独push进去生成路由
|
|
|
|
meta.push(j.name+"-"+k.name);
|
|
|
|
} else {
|
|
|
|
meta.push(j.name+"-"+k.name);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
obj.meta.btn = meta;
|
|
|
|
obj.children = children;
|
|
|
|
// 处理好的路由,需要进行一次匹配,arr中必然存在对应的路由,所以在此处才生成第一级路由,免得额外判断是否有children
|
|
|
|
if (permissionRouters.length === 0 || !permissionRouters.some(e => e.path === `/${str}`)) {
|
|
|
|
// 生成第一级
|
|
|
|
let one = {
|
|
|
|
path: "/" + arr[index],
|
|
|
|
name: arr[index],
|
|
|
|
redirect: {
|
|
|
|
name: `${arr[index]}-list`
|
|
|
|
},
|
|
|
|
component: BasicLayout,
|
|
|
|
children: []// 传来的路由实际上传入对应的children中
|
|
|
|
};
|
|
|
|
one.children.push(obj);
|
|
|
|
permissionRouters.push(one);
|
|
|
|
// console.log(one,'当前的第一级别',obj,'第二级别')
|
|
|
|
} else {
|
|
|
|
// 找到第一级直接塞进去
|
|
|
|
let nowIndex = permissionRouters.findIndex(e => {
|
|
|
|
return e.path === `/${str}`;
|
|
|
|
});
|
|
|
|
if (nowIndex != -1) {
|
|
|
|
permissionRouters[nowIndex].children.push(obj);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
console.log(permissionRouters, "处理好的");
|
|
|
|
const station = permissionRouters.findIndex(e => e.name === 'station')
|
|
|
|
if (station !== -1) {
|
|
|
|
permissionRouters[station].children.push({
|
|
|
|
name: `stationPreview`,
|
|
|
|
path: `/station/preview`,
|
|
|
|
component: () => import("@/pages/station/preview"),
|
|
|
|
meta: { title: "实验台" }
|
|
|
|
})
|
|
|
|
}
|
|
|
|
const assessment = permissionRouters.findIndex(e => e.name === 'assessment')
|
|
|
|
if (assessment !== -1) {
|
|
|
|
permissionRouters[assessment].children.push({
|
|
|
|
name: `assessment-add`,
|
|
|
|
path: `/assessment/add`,
|
|
|
|
component: () => import("@/pages/assessment/add"),
|
|
|
|
meta: { title: "创建考核" }
|
|
|
|
})
|
|
|
|
}
|
|
|
|
const notice = permissionRouters.findIndex(e => e.name === 'match')
|
|
|
|
if (notice !== -1) {
|
|
|
|
const match = [
|
|
|
|
{
|
|
|
|
name: `noticeDetail`,
|
|
|
|
path: `/match/noticeDetail`,
|
|
|
|
component: () => import("@/pages/match/manage/noticeDetail"),
|
|
|
|
meta: { title: "通知公告" }
|
|
|
|
}
|
|
|
|
]
|
|
|
|
permissionRouters[notice].children.push(...match)
|
|
|
|
}
|
|
|
|
// 把处理完成的路由,add到router里
|
|
|
|
// 记录一下路由的名称,用于nav
|
|
|
|
let nav = data.map(e => e.path);
|
|
|
|
router.app.$options.store.commit("routers", nav);
|
|
|
|
let redirect = [{
|
|
|
|
path: "/index",
|
|
|
|
redirect: station !== -1 ? '/station' : permissionRouters[0].path
|
|
|
|
}];
|
|
|
|
router.addRoutes(redirect);
|
|
|
|
router.addRoutes(permissionRouters);
|
|
|
|
router.addRoutes(errorPage);
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
// 权限
|
|
|
|
router.beforeEach(function(to, from, next) {
|
|
|
|
// console.log(router.app.$options.store.commit('routers'),'router.app.$options.store')
|
|
|
|
document.title = Setting.titleSuffix;
|
|
|
|
if (to.path == "/login") {
|
|
|
|
localStorage.removeItem(Setting.tokenKey);
|
|
|
|
sessionStorage.removeItem("handelPermission");
|
|
|
|
}
|
|
|
|
// console.log(util.local.get(Setting.tokenKey),'token')
|
|
|
|
// console.log(sessionStorage.getItem('handelPermission'),'保存的是否处理')
|
|
|
|
if (util.local.get(Setting.tokenKey)) {
|
|
|
|
if (!sessionStorage.getItem("handelPermission")) {// 是否已处理权限
|
|
|
|
getPermission();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (to.path !== "/login" && to.path !== '/redirect') {
|
|
|
|
next({
|
|
|
|
path: "/login",
|
|
|
|
query: { redirect: to.path }
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// 根据路由元信息设置文档标题
|
|
|
|
// window.document.title = to.meta.title ? to.meta.title : "";
|
|
|
|
window.document.title = "教师管理端"
|
|
|
|
next();
|
|
|
|
|
|
|
|
});
|