epmet pc工作端
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

606 lines
16 KiB

4 years ago
import Vue from "vue";
import Router from "vue-router";
import http from "@/utils/request";
import { isURL } from "@/utils/validate";
import store from "@/js/store";
4 years ago
4 years ago
Vue.use(Router);
4 years ago
// 页面路由(独立页面)
4 years ago
export const pageRoutes = [
{
path: "/404",
component: () => import("@/views/pages/404"),
name: "404",
4 years ago
meta: {
4 years ago
title: "404未找到",
4 years ago
},
beforeEnter(to, from, next) {
// 拦截处理特殊业务场景
// 如果, 重定向路由包含__双下划线, 为临时添加路由
if (/__.*/.test(to.redirectedFrom)) {
4 years ago
return next(to.redirectedFrom.replace(/__.*/, ""));
4 years ago
}
4 years ago
next();
},
4 years ago
},
{
4 years ago
path: "/login",
component: () => import("@/views/pages/login"),
name: "login",
4 years ago
meta: {
4 years ago
title: "登录",
},
4 years ago
},
{
4 years ago
path: "/",
name: "index",
4 years ago
component: () => import("@/views/pages/index"),
4 years ago
},
{
4 years ago
path: "/indexWork",
name: "indexWork",
4 years ago
redirect: {
name: "index",
4 years ago
},
},
{
path: "/caiji/:id",
props: true,
name: "caiji",
component: () => import("@/views/pages/caiji"),
meta: {
title: "居民信息填报",
},
},
{
path: "/caijisuccess",
props: true,
name: "caijisuccess",
component: () => import("@/views/pages/caijisuccess"),
meta: {
title: "居民信息填报",
},
},
4 years ago
];
4 years ago
// 模块路由(基于主入口布局页面)
export const moduleRoutes = {
4 years ago
path: "/main",
component: () => import("@/views/main"),
name: "main",
4 years ago
redirect: {
path: "/main/shequ-index",
4 years ago
},
meta: {
4 years ago
title: "主入口布局",
4 years ago
},
4 years ago
children: [
{
path: "/home",
component: () => import("@/views/modules/home"),
name: "home",
4 years ago
meta: {
4 years ago
title: "主页",
isTab: true,
},
},
4 years ago
{
path: "unopen",
component: () => import("@/views/modules/unopen"),
name: "unopen",
meta: {
title: "未开放功能",
isTab: true,
},
},
4 years ago
],
};
4 years ago
// 模块路由(基于主入口布局页面) 可视化数据
export const moduleShujuRoutes = {
4 years ago
path: "/main-shuju",
component: () => import("@/views/main-shuju/main"),
name: "main-shuju",
4 years ago
redirect: {
4 years ago
path: "/main-shuju/visual-basicinfo-basicInfoMain",
4 years ago
},
meta: {
4 years ago
title: "主入口布局",
4 years ago
},
4 years ago
children: [
{
path: "/home2",
component: () => import("@/views/modules/home"),
name: "home2",
4 years ago
meta: {
4 years ago
title: "主页2",
isTab: false,
4 years ago
},
},
4 years ago
{
4 years ago
path: "/main-shuju/visual-basicinfo-people/:uid",
props: true,
4 years ago
component: () => import("@/views/modules/visual/basicinfo/people"),
name: "visual-basicinfo-people",
meta: {
title: "个人详情",
isTab: false,
4 years ago
},
},
{
path: "/main-shuju/visual-basicinfo-people-list",
props: true,
component: () => import("@/views/modules/visual/basicinfo/peopleList"),
name: "visual-basicinfo-people-list",
meta: {
title: "人员列表",
isTab: false,
4 years ago
},
},
4 years ago
],
};
4 years ago
export function addDynamicRoute(routeParams, router) {
// 组装路由名称, 并判断是否已添加, 如是: 则直接跳转
4 years ago
var routeName = routeParams.routeName;
var dynamicRoute = window.SITE_CONFIG["dynamicRoutes"].filter(
4 years ago
(item) => item.name === routeName
4 years ago
)[0];
4 years ago
if (dynamicRoute) {
return router.push({
name: routeName,
4 years ago
params: routeParams.params,
});
4 years ago
}
// 否则: 添加并全局变量保存, 再跳转
dynamicRoute = {
path: routeName,
component: () => import(`@/views/modules/${routeParams.path}`),
name: routeName,
meta: {
4 years ago
...window.SITE_CONFIG["contentTabDefault"],
4 years ago
menuId: routeParams.menuId,
4 years ago
title: `${routeParams.title}`,
},
};
router.addRoutes([
{
...moduleRoutes,
name: `main-dynamic__${dynamicRoute.name}`,
children: [dynamicRoute],
},
]);
window.SITE_CONFIG["dynamicRoutes"].push(dynamicRoute);
4 years ago
router.push({
name: dynamicRoute.name,
4 years ago
params: routeParams.params,
});
4 years ago
}
const router = new Router({
4 years ago
mode: "hash",
4 years ago
scrollBehavior: () => ({
4 years ago
y: 0,
4 years ago
}),
4 years ago
routes: pageRoutes.concat(moduleRoutes, moduleShujuRoutes),
});
4 years ago
router.beforeEach((to, from, next) => {
// 添加动态(菜单)路由
// 已添加或者当前路由为页面路由, 可直接访问
4 years ago
if (to.name === "caiji") {
return next();
}
4 years ago
if (
4 years ago
window.SITE_CONFIG["dynamicMenuRoutesHasAdded"] ||
4 years ago
fnCurrentRouteIsPageRoute(to, pageRoutes)
) {
4 years ago
return next();
4 years ago
}
4 years ago
const customerId = localStorage.getItem("customerId");
console.log("customerId:", customerId);
4 years ago
// http
// .get("/gov/access/menu/nav")
// .then(({ data: res }) => {
// if (res.code !== 0) {
// // Vue.prototype.$message.error(res.msg)
// return next({
// name: "login",
// });
// }
4 years ago
// next({
// ...to,
// replace: true,
// });
// })
// .catch(() => {
// next({
// name: "login",
// });
// });
window.SITE_CONFIG["menuShujuList"] = [
// {
// url: "/visual/plugin/power/organization",
// name: "动力主轴",
// id: "5feawfwaefwa577",
// },
{
id: "22213213",
name: "基础信息",
// url: "visual/basicinfo/basicInfoMain",
children: [
4 years ago
{
url: "/visual/basicinfo/basicInfoMain",
name: "人房信息统计",
id: "5feawfwaefwa5",
4 years ago
},
{
url: "/visual/basicinfo/personCategory/index",
name: "人员类别分析",
id: "5fwaefwaefawef5",
4 years ago
},
4 years ago
{
url: "/visual/basicinfo/houseStatic/houseStatic",
name: "人房概览统计",
id: "5fwaefwaefawef6",
},
],
},
{
icon: "icon-setting",
id: "2",
name: "人员图谱",
url: "visual/basicinfo/peopleSearch",
},
{
icon: "icon-setting",
id: "3",
name: "人员预警",
url: "visual/warning/index",
},
4 years ago
{
icon: "icon-setting",
id: "2221321001",
name: "社区党建",
// url: "visual/basicinfo/basicInfoMain",
children: [
{
url: "/visual/communityParty/party",
name: "党员信息统计",
id: "5feawfwaefwa578",
},
{
url: "/visual/communityParty/community",
name: "联建单位分析",
4 years ago
id: "5fwaefwaefawef588",
},
{
url: "/visual/communityParty/elegant",
name: "党员风采榜",
id: "5fwaefwaefawef589",
},
],
},
{
icon: "icon-setting",
id: "2221321123",
name: "社区服务",
// url: "visual/basicinfo/basicInfoMain",
children: [
{
url: "/visual/measure/service",
name: "需求服务分析",
id: "5feawfwaefwa57",
},
{
url: "/visual/measure/volunteer",
name: "志愿服务分析",
id: "5fwaefwaefawef58",
},
],
},
{
icon: "icon-setting",
id: "6",
name: "社区治理",
children: [
{
url: "visual/communityGovern/shijianchuli/shijianchulifenxi",
name: "事件处理分析",
id: "shijianchulifenxi",
},
3 years ago
// {
// url: "visual/communityGovern/processAnalyze",
// name: "事件处置分析",
// id: "processAnalyze",
// },
4 years ago
{
url: "/visual/communityGovern/shijianfenlei/shijianfenleifenxi",
4 years ago
name: "事件分类分析",
id: "shijianfenleifenxi",
4 years ago
},
{
url: "/visual/communityGovern/duoyuanfuwu/duoyuanfuwufenxi",
name: "多元服务分析",
id: "duoyuanfuwufenxi",
},
// {
// url: "/visual/communityGovern/typeAnalyze",
// name: "事件分类分析",
// id: "typeAnalyze",
// },
3 years ago
// {
// url: "/visual/communityGovern/resibuzz",
// name: "居民热议分析",
// id: "resibuzz",
// },
// {
// url: "/visual/communityGovern/distributionAnalyze",
// name: "事件分布分析",
// id: "distributionAnalyze",
// },
],
},
{
icon: "icon-setting",
id: "2221321fefefaewfa123",
name: "初心互助",
url: "visual/heart/index",
children: [],
},
4 years ago
{
icon: "icon-setting",
id: "2221321fefefaewfa122223",
name: "疫情防控",
url: "",
children: [],
},
{
icon: "icon-setting",
id: "44rq22222q2222",
4 years ago
name: "智慧安防",
// url: "visual/basicinfo/basicInfoMain",
children: [
{
url: "https://test-rxs-job.elinkservice.cn/haiqin-ai/aisecurity.html#/monitor-panel",
// url: "/visual/ai/index",
name: "视频监控",
id: "5feawfwa111111efwa57",
},
/*{
url: "/visual/ai/renliu",
name: "人流数据",
id: "5fwaefwae222112fawef58",
},
{
url: "/visual/ai/cheliu",
name: "车流数据",
id: "erawerwecsxefwaw",
},
{
url: "/visual/ai/shebei",
name: "设备数据",
id: "zfzffewaf",
},
{
url: "/visual/ai/gongdan",
name: "工单数据",
id: "fewafwafewaefddd",
},*/
{
// url: "/visual/ai/yujing",
url: "https://test-rxs-job.elinkservice.cn/haiqin-ai/aisecurity.html#/data-analysis",
name: "预警分析",
id: "545345fdsfs",
},
],
},
];
fnAddDynamicMenuRoutes2(window.SITE_CONFIG["menuShujuList"]);
4 years ago
4 years ago
http
.get("/gov/access/menu/nav")
.then(({ data: res }) => {
4 years ago
if (res.code == 10005 || res.code == 10006 || res.code == 10007) {
// 10005 token为空 10006登陆超时 10007别处登录
console.log("登录失效");
Vue.prototype.$message.error(res.msg);
return next({
name: "login",
});
4 years ago
}
window.SITE_CONFIG["menuList"] = res.data;
fnAddDynamicMenuRoutes(window.SITE_CONFIG["menuList"]);
// next({ ...to, replace: true })
next({
...to,
replace: true,
});
})
.catch(() => {
4 years ago
// next({
// name: "login",
// });
4 years ago
});
});
4 years ago
/**
* 判断当前路由是否为页面路由
* @param {*} route 当前路由
* @param {*} pageRoutes 页面路由
*/
function fnCurrentRouteIsPageRoute(route, pageRoutes = []) {
4 years ago
var temp = [];
4 years ago
for (var i = 0; i < pageRoutes.length; i++) {
if (route.path === pageRoutes[i].path) {
4 years ago
return true;
4 years ago
}
if (pageRoutes[i].children && pageRoutes[i].children.length >= 1) {
4 years ago
temp = temp.concat(pageRoutes[i].children);
4 years ago
}
}
4 years ago
return temp.length >= 1 ? fnCurrentRouteIsPageRoute(route, temp) : false;
4 years ago
}
/**
* 添加动态(菜单)路由
* @param {*} menuList 菜单列表
* @param {*} routes 递归创建的动态(菜单)路由
*/
function fnAddDynamicMenuRoutes(menuList = [], routes = []) {
4 years ago
var temp = [];
4 years ago
for (var i = 0; i < menuList.length; i++) {
if (menuList[i].children && menuList[i].children.length >= 1) {
4 years ago
temp = temp.concat(menuList[i].children);
// continue;
4 years ago
}
// 组装路由
var route = {
4 years ago
path: "",
4 years ago
component: null,
4 years ago
name: "",
4 years ago
meta: {
4 years ago
...window.SITE_CONFIG["contentTabDefault"],
4 years ago
menuId: menuList[i].id,
4 years ago
title: menuList[i].name,
},
};
4 years ago
// eslint-disable-next-line
4 years ago
let URL = (menuList[i].url || "").replace(/{{([^}}]+)?}}/g, (s1, s2) =>
4 years ago
eval(s2)
4 years ago
); // URL支持{{ window.xxx }}占位符变量
4 years ago
if (isURL(URL)) {
if (menuList[i].children && menuList[i].children.length >= 1) {
let item = menuList[i].children.find(
(subMenu) => subMenu.url == menuList[i].url
);
if (item) {
route["path"] = route["name"] = `i-${menuList[i].id}`;
route["redirect"] = `i-${item.id}`;
} else {
route["path"] = route["name"] = `i-${menuList[i].id}`;
route["meta"]["iframeURL"] = URL;
}
} else {
route["path"] = route["name"] = `i-${menuList[i].id}`;
route["meta"]["iframeURL"] = URL;
}
4 years ago
} else {
4 years ago
URL = URL.replace(/^\//, "").replace(/_/g, "-");
4 years ago
if (URL.startsWith("unopen")) {
route["path"] = route["name"] = URL.replace(/\//g, "-");
route["component"] = () => import(`@/views/modules/unopen`);
} else if (menuList[i].children && menuList[i].children.length >= 1) {
4 years ago
route["path"] = route["name"] = URL;
route["redirect"] = URL.replace(/\//g, "-");
} else {
route["path"] = route["name"] = URL.replace(/\//g, "-");
route["component"] = () => import(`@/views/modules/${URL}`);
}
4 years ago
}
4 years ago
routes.push(route);
4 years ago
}
if (temp.length >= 1) {
4 years ago
return fnAddDynamicMenuRoutes(temp, routes);
4 years ago
}
4 years ago
// routers.reverse();
4 years ago
// 添加路由
4 years ago
router.addRoutes([
{
4 years ago
...moduleRoutes,
4 years ago
name: "main-dynamic-menu",
children: routes,
4 years ago
},
{
4 years ago
path: "*",
// redirect: {
// name: "404",
// },
4 years ago
},
]);
window.SITE_CONFIG["dynamicMenuRoutes"] = routes;
window.SITE_CONFIG["dynamicMenuRoutesHasAdded"] = true;
4 years ago
}
4 years ago
function fnAddDynamicMenuRoutes2(menuList = [], routes = []) {
4 years ago
var temp = [];
4 years ago
for (var i = 0; i < menuList.length; i++) {
if (menuList[i].children && menuList[i].children.length >= 1) {
4 years ago
temp = temp.concat(menuList[i].children);
continue;
4 years ago
}
// 组装路由
var route = {
4 years ago
path: "",
4 years ago
component: null,
4 years ago
name: "",
4 years ago
meta: {
4 years ago
// ...window.SITE_CONFIG["contentTabDefault"],
4 years ago
menuId: menuList[i].id,
4 years ago
title: menuList[i].name,
},
};
4 years ago
// eslint-disable-next-line
4 years ago
let URL = (menuList[i].url || "").replace(/{{([^}}]+)?}}/g, (s1, s2) =>
4 years ago
eval(s2)
4 years ago
); // URL支持{{ window.xxx }}占位符变量
4 years ago
if (isURL(URL)) {
4 years ago
if (menuList[i].children && menuList[i].children.length >= 1) {
let item = menuList[i].children.find(
(subMenu) => subMenu.url == menuList[i].url
);
if (item) {
route["path"] = route["name"] = `i-${menuList[i].id}`;
route["redirect"] = `i-${item.id}`;
} else {
route["path"] = route["name"] = `i-${menuList[i].id}`;
route["meta"]["iframeURL"] = URL;
}
} else {
route["path"] = route["name"] = `i-${menuList[i].id}`;
route["meta"]["iframeURL"] = URL;
}
4 years ago
} else {
4 years ago
URL = URL.replace(/^\//, "").replace(/_/g, "-");
4 years ago
if (URL.startsWith("unopen")) {
route["path"] = route["name"] = URL.replace(/\//g, "-");
route["component"] = () => import(`@/views/modules/unopen`);
} else if (menuList[i].children && menuList[i].children.length >= 1) {
route["path"] = route["name"] = URL;
route["redirect"] = URL.replace(/\//g, "-");
} else {
route["path"] = route["name"] = URL.replace(/\//g, "-");
route["component"] = () => import(`@/views/modules/${URL}`);
}
4 years ago
}
4 years ago
routes.push(route);
4 years ago
}
if (temp.length >= 1) {
4 years ago
return fnAddDynamicMenuRoutes2(temp, routes);
4 years ago
}
// 添加路由
4 years ago
router.addRoutes([
{
4 years ago
...moduleShujuRoutes,
4 years ago
name: "main-dynamic-menu-shuju",
children: routes,
4 years ago
},
{
4 years ago
path: "*",
// redirect: {
// name: "404",
// },
4 years ago
},
]);
window.SITE_CONFIG["dynamicMenuRoutesShuju"] = routes;
window.SITE_CONFIG["dynamicMenuRoutesShujuHasAdded"] = true;
4 years ago
}
4 years ago
export default router;