|
@@ -1,10 +1,10 @@
|
|
/**
|
|
/**
|
|
- * @copyright chuzhixin 1204505056@qq.com
|
|
|
|
|
|
+ * @author chuzhixin 1204505056@qq.com
|
|
* @description 路由拦截状态管理,目前两种模式:all模式与intelligence模式,其中partialRoutes是菜单暂未使用
|
|
* @description 路由拦截状态管理,目前两种模式:all模式与intelligence模式,其中partialRoutes是菜单暂未使用
|
|
*/
|
|
*/
|
|
import { asyncRoutes, constantRoutes } from "@/router";
|
|
import { asyncRoutes, constantRoutes } from "@/router";
|
|
import { getRouterList } from "@/api/router";
|
|
import { getRouterList } from "@/api/router";
|
|
-import { filterAllRoutes, filterAsyncRoutes } from "@/utils/handleRoutes";
|
|
|
|
|
|
+import { convertRouter, filterRoutes } from "@/utils/routes";
|
|
|
|
|
|
const state = { routes: [], partialRoutes: [] };
|
|
const state = { routes: [], partialRoutes: [] };
|
|
const getters = {
|
|
const getters = {
|
|
@@ -13,38 +13,46 @@ const getters = {
|
|
};
|
|
};
|
|
const mutations = {
|
|
const mutations = {
|
|
setRoutes(state, routes) {
|
|
setRoutes(state, routes) {
|
|
- state.routes = constantRoutes.concat(routes);
|
|
|
|
- },
|
|
|
|
- setAllRoutes(state, routes) {
|
|
|
|
- state.routes = constantRoutes.concat(routes);
|
|
|
|
|
|
+ state.routes = routes;
|
|
},
|
|
},
|
|
setPartialRoutes(state, routes) {
|
|
setPartialRoutes(state, routes) {
|
|
- state.partialRoutes = constantRoutes.concat(routes);
|
|
|
|
|
|
+ state.partialRoutes = routes;
|
|
},
|
|
},
|
|
};
|
|
};
|
|
const actions = {
|
|
const actions = {
|
|
- async setRoutes({ commit }, permissions) {
|
|
|
|
- //防止污染路由
|
|
|
|
- const baseRoutes = [...asyncRoutes];
|
|
|
|
- let accessedRoutes = [];
|
|
|
|
- if (permissions.includes("admin")) {
|
|
|
|
- accessedRoutes = baseRoutes;
|
|
|
|
- } else {
|
|
|
|
- accessedRoutes = await filterAsyncRoutes(baseRoutes, permissions);
|
|
|
|
- }
|
|
|
|
- commit("setRoutes", accessedRoutes);
|
|
|
|
- return accessedRoutes;
|
|
|
|
|
|
+ /**
|
|
|
|
+ * @author chuzhixin 1204505056@qq.com
|
|
|
|
+ * @description intelligence模式设置路由
|
|
|
|
+ * @param {*} { commit }
|
|
|
|
+ * @returns
|
|
|
|
+ */
|
|
|
|
+ async setRoutes({ commit }) {
|
|
|
|
+ const finallyRoutes = filterRoutes([...constantRoutes, ...asyncRoutes]);
|
|
|
|
+ commit("setRoutes", finallyRoutes);
|
|
|
|
+ return [...asyncRoutes];
|
|
},
|
|
},
|
|
|
|
+ /**
|
|
|
|
+ * @author chuzhixin 1204505056@qq.com
|
|
|
|
+ * @description all模式设置路由
|
|
|
|
+ * @param {*} { commit }
|
|
|
|
+ * @returns
|
|
|
|
+ */
|
|
async setAllRoutes({ commit }) {
|
|
async setAllRoutes({ commit }) {
|
|
let { data } = await getRouterList();
|
|
let { data } = await getRouterList();
|
|
- data.push({ path: "*", redirect: "/404", hidden: true });
|
|
|
|
- let accessRoutes = filterAllRoutes(data);
|
|
|
|
- commit("setAllRoutes", accessRoutes);
|
|
|
|
- return accessRoutes;
|
|
|
|
|
|
+ if (data[data.length - 1].path !== "*")
|
|
|
|
+ data.push({ path: "*", redirect: "/404", hidden: true });
|
|
|
|
+ const finallyRoutes = filterRoutes(convertRouter(data));
|
|
|
|
+ commit("setRoutes", finallyRoutes);
|
|
|
|
+ return finallyRoutes;
|
|
},
|
|
},
|
|
- setPartialRoutes({ commit }, accessRoutes) {
|
|
|
|
- commit("setPartialRoutes", accessRoutes);
|
|
|
|
- return accessRoutes;
|
|
|
|
|
|
+ /**
|
|
|
|
+ * @author chuzhixin 1204505056@qq.com
|
|
|
|
+ * @description 画廊布局、综合布局设置路由
|
|
|
|
+ * @param {*} { commit }
|
|
|
|
+ * @param accessedRoutes 画廊布局、综合布局设置路由
|
|
|
|
+ */
|
|
|
|
+ setPartialRoutes({ commit }, accessedRoutes) {
|
|
|
|
+ commit("setPartialRoutes", accessedRoutes);
|
|
},
|
|
},
|
|
};
|
|
};
|
|
export default { state, getters, mutations, actions };
|
|
export default { state, getters, mutations, actions };
|