Skip to content

Commit

Permalink
feat(projects): 添加路由跳转浏览器新标签
Browse files Browse the repository at this point in the history
  • Loading branch information
Soybean committed Nov 30, 2021
1 parent 2ad1ad3 commit 987cef3
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 19 deletions.
48 changes: 31 additions & 17 deletions src/composables/common/router.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { unref } from 'vue';
import { useRouter, useRoute } from 'vue-router';
import type { RouteLocationRaw } from 'vue-router';
import { router as globalRouter, routeName } from '@/router';
import { router as globalRouter, routeName, ROUTE_HOME } from '@/router';
import type { LoginModuleType } from '@/interface';

/**
Expand All @@ -12,55 +12,69 @@ export function useRouterPush(inSetup: boolean = true) {
const router = inSetup ? useRouter() : globalRouter;
const route = inSetup ? useRoute() : unref(globalRouter.currentRoute);

/** 跳转首页 */
function toHome() {
router.push('/');
/**
* 路由跳转
* @param to - 路由
* @param newTab - 在新的浏览器标签打开
*/
function routerPush(to: RouteLocationRaw, newTab = false) {
if (newTab) {
const routerData = router.resolve(to);
window.open(routerData.href, '_blank');
return;
}
router.push(to);
}

/**
* 跳转首页
* @param newTab - 在新的浏览器标签打开
*/
function toHome(newTab = false) {
routerPush(ROUTE_HOME.path, newTab);
}

/**
* 重定向地址
* - current: 取当前的path作为重定向地址
*/
type LoginRedirect = 'current' | string;

/**
* 跳转登录页面(通过vue路由)
* @param module - 展示的登录模块
* @param redirect - 重定向地址(登录成功后跳转的地址)
* @param newTab - 在新的浏览器标签打开
*/
function toLogin(module: LoginModuleType = 'pwd-login', redirect: LoginRedirect = 'current') {
function toLogin(module: LoginModuleType = 'code-login', redirect: LoginRedirect = 'current', newTab = false) {
const routeLocation: RouteLocationRaw = {
name: routeName('login'),
params: { module }
};
if (redirect) {
let url = redirect;
if (redirect === 'current') {
url = router.currentRoute.value.fullPath;
url = route.fullPath;
}
Object.assign(routeLocation, { query: { redirect: url } });
}
router.push(routeLocation);
routerPush(routeLocation, newTab);
}

/**
* 登陆页跳转登陆页(登录模块切换)
* @param module - 展示的登录模块
* @param query - 查询参数
* @param newTab - 在新的浏览器标签打开
*/
function toCurrentLogin(module: LoginModuleType) {
function toCurrentLogin(module: LoginModuleType, newTab = false) {
const { query } = route;
router.push({ name: routeName('login'), params: { module }, query: { ...query } });
}

/** 登录后跳转重定向的地址 */
function toLoginRedirectUrl(path: string) {
router.push(path);
routerPush({ name: routeName('login'), params: { module }, query: { ...query } }, newTab);
}

return {
routerPush,
toHome,
toLogin,
toCurrentLogin,
toLoginRedirectUrl
toCurrentLogin
};
}
4 changes: 2 additions & 2 deletions src/views/system/login/components/PwdLogin/index.vue
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ import { OtherLogin } from './components';
const notification = useNotification();
const auth = useAuthStore();
const { toHome, toCurrentLogin, toLoginRedirectUrl } = useRouterPush();
const { routerPush, toHome, toCurrentLogin } = useRouterPush();
const { loginRedirectUrl } = useRouteQuery();
const { loading, startLoading, endLoading } = useLoading();
Expand Down Expand Up @@ -77,7 +77,7 @@ function handleSubmit(e: MouseEvent) {
endLoading();
setToken('temp-token');
if (loginRedirectUrl.value) {
toLoginRedirectUrl(loginRedirectUrl.value);
routerPush(loginRedirectUrl.value);
} else {
toHome();
}
Expand Down

1 comment on commit 987cef3

@vercel
Copy link

@vercel vercel bot commented on 987cef3 Nov 30, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.