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

54 lines
1.5 KiB
TypeScript
Raw Normal View History

2021-04-10 19:25:49 +08:00
import type { RouteLocationRaw, Router } from 'vue-router';
2020-09-28 20:19:10 +08:00
import { PageEnum } from '/@/enums/pageEnum';
import { unref } from 'vue';
2021-04-10 19:25:49 +08:00
import { useRouter } from 'vue-router';
import { REDIRECT_NAME } from '/@/router/constant';
2020-12-03 21:49:32 +08:00
export type PathAsPageEnum<T> = T extends { path: string } ? T & { path: PageEnum } : T;
export type RouteLocationRawEx = PathAsPageEnum<RouteLocationRaw>;
2020-09-28 20:19:10 +08:00
function handleError(e: Error) {
console.error(e);
}
/**
* page switch
*/
2021-04-10 19:25:49 +08:00
export function useGo(_router?: Router) {
const { push, replace } = _router || useRouter();
function go(opt: RouteLocationRawEx = PageEnum.BASE_HOME, isReplace = false) {
2021-04-10 19:25:49 +08:00
if (!opt) {
return;
}
isReplace ? replace(opt).catch(handleError) : push(opt).catch(handleError);
2020-09-28 20:19:10 +08:00
}
return go;
}
/**
* @description: redo current page
*/
2021-04-10 19:25:49 +08:00
export const useRedo = (_router?: Router) => {
const { push, currentRoute } = _router || useRouter();
const { query, params = {}, name, fullPath } = unref(currentRoute.value);
2020-12-15 00:13:23 +08:00
function redo(): Promise<boolean> {
return new Promise((resolve) => {
if (name === REDIRECT_NAME) {
resolve(false);
return;
}
if (name && Object.keys(params).length > 0) {
params['_redirect_type'] = 'name';
params['path'] = String(name);
} else {
params['_redirect_type'] = 'path';
params['path'] = fullPath;
}
push({ name: REDIRECT_NAME, params, query }).then(() => resolve(true));
2020-09-28 20:19:10 +08:00
});
}
return redo;
};