41 lines
1.5 KiB
TypeScript
41 lines
1.5 KiB
TypeScript
import type { Router } from 'vue-router';
|
|
|
|
import { Modal, notification } from 'ant-design-vue';
|
|
import { AxiosCanceler } from '/@/utils/http/axios/axiosCancel';
|
|
import { createPageTitleGuard } from './pageTitleGuard';
|
|
import { createProgressGuard } from './progressGuard';
|
|
import { createPermissionGuard } from './permissionGuard';
|
|
import { createPageLoadingGuard } from './pageLoadingGuard';
|
|
import { useSetting } from '/@/hooks/core/useSetting';
|
|
import { getIsOpenTab, setCurrentTo } from '/@/utils/helper/routeHelper';
|
|
|
|
const { projectSetting } = useSetting();
|
|
export function createGuard(router: Router) {
|
|
const { openNProgress, closeMessageOnSwitch, removeAllHttpPending } = projectSetting;
|
|
let axiosCanceler: AxiosCanceler | null;
|
|
if (removeAllHttpPending) {
|
|
axiosCanceler = new AxiosCanceler();
|
|
}
|
|
router.beforeEach(async (to) => {
|
|
const isOpen = getIsOpenTab(to.fullPath);
|
|
to.meta.inTab = isOpen;
|
|
try {
|
|
if (closeMessageOnSwitch) {
|
|
Modal.destroyAll();
|
|
notification.destroy();
|
|
}
|
|
// TODO Some special interfaces require long connections
|
|
// Switching the route will delete the previous request
|
|
removeAllHttpPending && axiosCanceler!.removeAllPending();
|
|
} catch (error) {
|
|
console.warn('basic guard error:' + error);
|
|
}
|
|
setCurrentTo(to);
|
|
return true;
|
|
});
|
|
openNProgress && createProgressGuard(router);
|
|
createPermissionGuard(router);
|
|
createPageTitleGuard(router);
|
|
createPageLoadingGuard(router);
|
|
}
|