diff --git a/src/router/guard/route.ts b/src/router/guard/route.ts index 68f360471..a6b7b9d7e 100644 --- a/src/router/guard/route.ts +++ b/src/router/guard/route.ts @@ -36,54 +36,34 @@ export function createRouteGuard(router: Router) { const routeRoles = to.meta.roles || []; const hasRole = authStore.userInfo.roles.some(role => routeRoles.includes(role)); - const hasAuth = authStore.isStaticSuper || !routeRoles.length || hasRole; - const routeSwitches: CommonType.StrategicPattern[] = [ - // if it is login route when logged in, then switch to the root page - { - condition: isLogin && to.name === loginRoute, - callback: () => { - next({ name: rootRoute }); - } - }, - // if it is constant route, then it is allowed to access directly - { - condition: !needLogin, - callback: () => { - handleRouteSwitch(to, from, next); - } - }, - // if the route need login but the user is not logged in, then switch to the login page - { - condition: !isLogin && needLogin, - callback: () => { - next({ name: loginRoute, query: { redirect: to.fullPath } }); - } - }, - // if the user is logged in and has authorization, then it is allowed to access - { - condition: isLogin && needLogin && hasAuth, - callback: () => { - handleRouteSwitch(to, from, next); - } - }, - // if the user is logged in but does not have authorization, then switch to the 403 page - { - condition: isLogin && needLogin && !hasAuth, - callback: () => { - next({ name: noAuthorizationRoute }); - } - } - ]; - - routeSwitches.some(({ condition, callback }) => { - if (condition) { - callback(); - } - - return condition; - }); + // if it is login route when logged in, then switch to the root page + if (to.name === loginRoute && isLogin) { + next({ name: rootRoute }); + return; + } + + // if the route does not need login, then it is allowed to access directly + if (!needLogin) { + handleRouteSwitch(to, from, next); + return; + } + + // the route need login but the user is not logged in, then switch to the login page + if (!isLogin) { + next({ name: loginRoute, query: { redirect: to.fullPath } }); + return; + } + + // if the user is logged in but does not have authorization, then switch to the 403 page + if (!hasAuth) { + next({ name: noAuthorizationRoute }); + return; + } + + // switch route normally + handleRouteSwitch(to, from, next); }); } @@ -93,7 +73,6 @@ export function createRouteGuard(router: Router) { * @param to to route */ async function initRoute(to: RouteLocationNormalized): Promise { - const authStore = useAuthStore(); const routeStore = useRouteStore(); const notFoundRoute: RouteKey = 'not-found'; @@ -105,50 +84,28 @@ async function initRoute(to: RouteLocationNormalized): Promise { return getSelectedMenuKeyPathByKey(selectedKey, menus.value); } + async function onRouteSwitchWhenLoggedIn() { + authStore.initUserInfo(); + } + + async function onRouteSwitchWhenNotLoggedIn() { + // some global init logic if it does not need to be logged in + } + return { resetStore, routeHome, @@ -326,6 +334,8 @@ export const useRouteStore = defineStore(SetupStoreId.Route, () => { isInitAuthRoute, setIsInitAuthRoute, getIsAuthRouteExist, - getSelectedMenuKeyPath + getSelectedMenuKeyPath, + onRouteSwitchWhenLoggedIn, + onRouteSwitchWhenNotLoggedIn }; });