vue-vben-admin/src/hooks/web/useTabs.ts

73 lines
1.9 KiB
TypeScript
Raw Normal View History

2020-09-28 20:19:10 +08:00
import { TabItem, tabStore } from '/@/store/modules/tab';
import { appStore } from '/@/store/modules/app';
2020-09-28 20:19:10 +08:00
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;
2020-11-25 22:28:58 +08:00
2020-09-28 20:19:10 +08:00
export function useTabs() {
function initTabFn({
refreshPageFn,
closeAllFn,
closeLeftFn,
closeRightFn,
closeOtherFn,
closeCurrentFn,
}: TabFn) {
if (isInitUseTab) return;
2020-11-25 22:28:58 +08:00
2020-09-28 20:19:10 +08:00
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 {
2020-11-25 22:28:58 +08:00
const { multiTabsSetting: { show } = {} } = appStore.getProjectConfig;
2020-09-28 20:19:10 +08:00
if (!show) {
throw new Error('当前未开启多标签页,请在设置中打开!');
}
return !!show;
}
2020-11-25 22:28:58 +08:00
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(),
};
}