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

45 lines
1.2 KiB
TypeScript
Raw Normal View History

2020-09-28 20:19:10 +08:00
import { appStore } from '/@/store/modules/app';
import type { RouteLocationRaw } from 'vue-router';
import { useRouter } from 'vue-router';
import { PageEnum } from '/@/enums/pageEnum';
import { isString } from '/@/utils/is';
import { unref } from 'vue';
export type RouteLocationRawEx = Omit<RouteLocationRaw, 'path'> & { path: PageEnum };
function handleError(e: Error) {
console.error(e);
// 101是为了 大于 打开时候设置的100延时防止闪动
2020-09-28 20:19:10 +08:00
setTimeout(() => {
appStore.commitPageLoadingState(false);
}, 101);
}
// page switch
export function useGo() {
const { push, replace } = useRouter();
2020-10-18 21:55:21 +08:00
function go(opt: PageEnum | RouteLocationRawEx | string = PageEnum.BASE_HOME, isReplace = false) {
2020-09-28 20:19:10 +08:00
if (isString(opt)) {
isReplace ? replace(opt).catch(handleError) : push(opt).catch(handleError);
} else {
const o = opt as RouteLocationRaw;
isReplace ? replace(o).catch(handleError) : push(o).catch(handleError);
}
}
return go;
}
/**
* @description: redo current page
*/
export const useRedo = () => {
const { push, currentRoute } = useRouter();
function redo() {
push({
path: '/redirect' + unref(currentRoute).fullPath,
});
}
return redo;
};