132 lines
4.1 KiB
TypeScript
Raw Normal View History

2023-10-10 09:31:35 +08:00
import { createRouter, createWebHashHistory } from "vue-router";
2023-12-05 14:11:47 +08:00
import { Global3DStore } from "@/stores";
2023-10-10 09:31:35 +08:00
import { AuthStore } from "@/stores/modules/auth";
import { LOGIN_URL, ROUTER_WHITE_LIST } from "@/config/config";
import { initDynamicRouter } from "@/routers/modules/dynamicRouter";
import { staticRouter, errorRouter } from "@/routers/modules/staticRouter";
import NProgress from "@/config/nprogress";
import { HOME_URL } from "@/enums/Home";
2023-12-06 11:12:07 +08:00
import { loginOutsideApi } from "@/api/modules/login";
2023-11-22 17:09:22 +08:00
import { TabsStore } from "@/stores/modules/tabs";
import { KeepAliveStore } from "@/stores/modules/keepAlive";
2023-10-10 09:31:35 +08:00
// import path from "path";
/**
* @description 📚
* @param path ==>
* @param name ==>
* @param redirect ==>
* @param component ==>
* @param meta ==>
* @param meta.icon ==>
* @param meta.title ==>
* @param meta.activeMenu ==>
* @param meta.isLink ==>
* @param meta.isHide ==>
* @param meta.isFull ==> ()
* @param meta.isAffix ==> tabs nav
* @param meta.isKeepAlive ==>
* */
const router = createRouter({
history: createWebHashHistory(),
routes: [...staticRouter, ...errorRouter],
strict: false,
scrollBehavior: () => ({ left: 0, top: 0 })
});
/**
* @description beforeEach
* */
router.beforeEach(async (to, from, next) => {
2023-12-05 14:11:47 +08:00
const globalStore = Global3DStore();
2023-10-10 09:31:35 +08:00
// 1.NProgress 开始
NProgress.start();
// 2.动态设置标题
const title = import.meta.env.VITE_GLOB_APP_TITLE;
// document.title = to.meta.title ? `${to.meta.title} - ${title}` : title;
document.title = to.meta.title ? `${to.meta.title} ` : title;
2023-11-22 17:09:22 +08:00
// 附加.判断是否特殊进入,是的话则默认登录
2023-12-06 11:12:07 +08:00
if (to.query.projectId) {
await defaultLogin(to.query.projectId);
2023-11-22 17:09:22 +08:00
}
2023-10-10 09:31:35 +08:00
// 3.判断是访问登陆页,有 Token 就在当前页面,没有 Token 重置路由并放行到登陆页
if (to.path === LOGIN_URL) {
if (globalStore.token) return next(from.fullPath);
resetRouter();
return next();
}
// 4.判断访问页面是否在路由白名单地址中,如果存在直接放行
if (ROUTER_WHITE_LIST.includes(to.path)) return next();
// 5.判断是否有 Token没有重定向到 login
if (!globalStore.token) return next({ path: LOGIN_URL, replace: true });
// 6.如果没有菜单列表,就重新请求菜单列表并添加动态路由
const authStore = AuthStore();
authStore.setRouteName(to.name as string);
if (!authStore.authMenuListGet.length) {
await initDynamicRouter();
if (globalStore.accountType && globalStore.accountType !== 1 && to.fullPath === HOME_URL[0]) {
next(HOME_URL[globalStore.accountType - 1]);
}
return next({ ...to, replace: true });
}
// 7.正常访问页面
next();
});
2023-11-22 17:09:22 +08:00
/**
* @description
* */
2023-12-06 11:12:07 +08:00
export const defaultLogin = async (id: any) => {
const { result } = await loginOutsideApi({ projectId: id });
2023-12-05 14:11:47 +08:00
const globalStore = Global3DStore();
2023-11-22 17:09:22 +08:00
const tabsStore = TabsStore();
const keepAlive = KeepAliveStore();
console.log(result);
globalStore.setUserInfo(result);
globalStore.setToken(result.token);
globalStore.setAccount(result.account);
globalStore.setAccountType(result.accountType);
globalStore.setProjectDateAuth(result.projectDateAuth);
globalStore.setIsManager(result.isManager); //我已知晓
// 2.添加动态路由
// await initDynamicRouter();
// router.push(arr[result.accountType - 1]);
// 3.清空 tabs、keepAlive 保留的数据
tabsStore.closeMultipleTab();
keepAlive.setKeepAliveName();
};
2023-10-10 09:31:35 +08:00
/**
* @description
* */
export const resetRouter = () => {
const authStore = AuthStore();
authStore.flatMenuListGet.forEach(route => {
const { name } = route;
if (name && router.hasRoute(name)) router.removeRoute(name);
});
};
/**
* @description
* */
router.afterEach(() => {
NProgress.done();
});
/**
* @description
* */
router.onError(error => {
NProgress.done();
console.warn("路由错误", error.message);
});
export default router;