2020-11-21 22:47:10 +08:00
|
|
|
import { useTimeoutFn } from '/@/hooks/core/useTimeout';
|
2020-10-12 00:18:32 +08:00
|
|
|
import { PageEnum } from '/@/enums/pageEnum';
|
2020-09-28 20:19:10 +08:00
|
|
|
import { TabItem, tabStore } from '/@/store/modules/tab';
|
|
|
|
import { appStore } from '/@/store/modules/app';
|
2020-10-12 00:18:32 +08:00
|
|
|
import router from '/@/router';
|
2020-10-13 01:39:56 +08:00
|
|
|
import { ref } from 'vue';
|
2020-10-14 21:08:07 +08:00
|
|
|
import { pathToRegexp } from 'path-to-regexp';
|
2020-10-13 01:39:56 +08:00
|
|
|
|
|
|
|
const activeKeyRef = ref<string>('');
|
2020-10-12 00:18:32 +08:00
|
|
|
|
2020-09-28 20:19:10 +08:00
|
|
|
type Fn = () => void;
|
|
|
|
type RouteFn = (tabItem: TabItem) => void;
|
|
|
|
|
|
|
|
interface TabFn {
|
|
|
|
refreshPageFn: RouteFn;
|
|
|
|
closeAllFn: Fn;
|
|
|
|
closeLeftFn: RouteFn;
|
|
|
|
closeRightFn: RouteFn;
|
|
|
|
closeOtherFn: RouteFn;
|
|
|
|
closeCurrentFn: RouteFn;
|
|
|
|
}
|
|
|
|
|
|
|
|
let refreshPage: RouteFn;
|
|
|
|
let closeAll: Fn;
|
|
|
|
let closeLeft: RouteFn;
|
|
|
|
let closeRight: RouteFn;
|
|
|
|
let closeOther: RouteFn;
|
|
|
|
let closeCurrent: RouteFn;
|
|
|
|
|
|
|
|
export let isInitUseTab = false;
|
|
|
|
export function useTabs() {
|
|
|
|
function initTabFn({
|
|
|
|
refreshPageFn,
|
|
|
|
closeAllFn,
|
|
|
|
closeLeftFn,
|
|
|
|
closeRightFn,
|
|
|
|
closeOtherFn,
|
|
|
|
closeCurrentFn,
|
|
|
|
}: TabFn) {
|
|
|
|
if (isInitUseTab) return;
|
|
|
|
refreshPageFn && (refreshPage = refreshPageFn);
|
|
|
|
closeAllFn && (closeAll = closeAllFn);
|
|
|
|
closeLeftFn && (closeLeft = closeLeftFn);
|
|
|
|
closeRightFn && (closeRight = closeRightFn);
|
|
|
|
closeOtherFn && (closeOther = closeOtherFn);
|
|
|
|
closeCurrentFn && (closeCurrent = closeCurrentFn);
|
|
|
|
isInitUseTab = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function resetCache() {
|
|
|
|
const def = undefined as any;
|
|
|
|
refreshPage = def;
|
|
|
|
closeAll = def;
|
|
|
|
closeLeft = def;
|
|
|
|
closeRight = def;
|
|
|
|
closeOther = def;
|
|
|
|
closeCurrent = def;
|
|
|
|
}
|
|
|
|
|
|
|
|
function canIUseFn(): boolean {
|
|
|
|
const { getProjectConfig } = appStore;
|
|
|
|
const { multiTabsSetting: { show } = {} } = getProjectConfig;
|
|
|
|
if (!show) {
|
|
|
|
throw new Error('当前未开启多标签页,请在设置中打开!');
|
|
|
|
}
|
|
|
|
return !!show;
|
|
|
|
}
|
2020-10-13 22:22:04 +08:00
|
|
|
function getTo(path: string): any {
|
|
|
|
const routes = router.getRoutes();
|
|
|
|
const fn = (p: string): any => {
|
2020-10-14 21:08:07 +08:00
|
|
|
const to = routes.find((item) => {
|
|
|
|
if (item.path === '/:path(.*)*') return;
|
|
|
|
const regexp = pathToRegexp(item.path);
|
|
|
|
return regexp.test(p);
|
|
|
|
});
|
2020-10-13 22:22:04 +08:00
|
|
|
if (!to) return '';
|
|
|
|
if (!to.redirect) return to;
|
|
|
|
if (to.redirect) {
|
|
|
|
return getTo(to.redirect as string);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
return fn(path);
|
|
|
|
}
|
2020-09-28 20:19:10 +08:00
|
|
|
return {
|
|
|
|
initTabFn,
|
|
|
|
refreshPage: () => canIUseFn() && refreshPage(tabStore.getCurrentTab),
|
|
|
|
closeAll: () => canIUseFn() && closeAll(),
|
|
|
|
closeLeft: () => canIUseFn() && closeLeft(tabStore.getCurrentTab),
|
|
|
|
closeRight: () => canIUseFn() && closeRight(tabStore.getCurrentTab),
|
|
|
|
closeOther: () => canIUseFn() && closeOther(tabStore.getCurrentTab),
|
|
|
|
closeCurrent: () => canIUseFn() && closeCurrent(tabStore.getCurrentTab),
|
|
|
|
resetCache: () => canIUseFn() && resetCache(),
|
2020-10-22 00:14:11 +08:00
|
|
|
addTab: (
|
|
|
|
path: PageEnum | string,
|
|
|
|
goTo = false,
|
|
|
|
opt?: { replace?: boolean; query?: any; params?: any }
|
|
|
|
) => {
|
2020-10-13 22:22:04 +08:00
|
|
|
const to = getTo(path);
|
2020-10-14 21:08:07 +08:00
|
|
|
|
2020-10-13 22:22:04 +08:00
|
|
|
if (!to) return;
|
2020-11-12 22:40:16 +08:00
|
|
|
useTimeoutFn(() => {
|
2020-10-14 21:08:07 +08:00
|
|
|
tabStore.addTabByPathAction();
|
2020-10-12 00:18:32 +08:00
|
|
|
}, 0);
|
2020-10-22 00:14:11 +08:00
|
|
|
const { replace, query = {}, params = {} } = opt || {};
|
2020-10-14 21:08:07 +08:00
|
|
|
activeKeyRef.value = path;
|
2020-10-22 00:14:11 +08:00
|
|
|
const data = {
|
|
|
|
path,
|
|
|
|
query,
|
|
|
|
params,
|
|
|
|
};
|
|
|
|
goTo && replace ? router.replace(data) : router.push(data);
|
2020-10-12 00:18:32 +08:00
|
|
|
},
|
2020-10-13 01:39:56 +08:00
|
|
|
activeKeyRef,
|
2020-09-28 20:19:10 +08:00
|
|
|
};
|
|
|
|
}
|