ruoyi-plus-soybean/src/views/_builtin/social-callback/index.vue

115 lines
2.9 KiB
Vue
Raw Normal View History

2025-04-24 17:36:38 +08:00
<script setup lang="ts">
import { onMounted, ref } from 'vue';
2025-04-24 17:36:38 +08:00
import { useRoute } from 'vue-router';
import { useLoading } from '@sa/hooks';
import { fetchSocialLoginCallback } from '@/service/api';
import { useAuthStore } from '@/store/modules/auth';
import { useRouterPush } from '@/hooks/common/router';
const route = useRoute();
const authStore = useAuthStore();
const { routerPushByKey } = useRouterPush();
const { loading, startLoading, endLoading } = useLoading(true);
2025-04-24 17:36:38 +08:00
/**
* 接收Route传递的参数
*
* @param {Object} route.query.
*/
const code = route.query.code as string;
const state = route.query.state as string;
const source = route.query.source as string;
const stateJson = state ? JSON.parse(atob(state)) : {};
const tenantId = (stateJson.tenantId as string) ?? '000000';
const domain = (stateJson.domain as string) ?? window.location.host;
const msg = ref('正在登录,请稍后......');
2025-04-24 17:36:38 +08:00
const processResponse = async () => {
window.$message?.success('登录成功');
msg.value = '登录成功2s 后即将跳转至首页';
setTimeout(() => {
msg.value = '登录成功1s 后即将跳转至首页';
}, 1000);
2025-04-24 17:36:38 +08:00
setTimeout(() => {
routerPushByKey(import.meta.env.VITE_ROUTE_HOME || 'home');
}, 1000);
2025-04-24 17:36:38 +08:00
};
const handleError = () => {
msg.value = '登录失败2s 后即将跳转至登录页';
setTimeout(() => {
msg.value = '登录失败1s 后即将跳转至登录页';
}, 1000);
2025-04-24 17:36:38 +08:00
setTimeout(() => {
routerPushByKey('login');
}, 1000);
2025-04-24 17:36:38 +08:00
};
const callbackByCode = async (data: Api.Auth.SocialLoginForm) => {
const { error } = await fetchSocialLoginCallback({
...data,
clientId: import.meta.env.VITE_APP_CLIENT_ID,
grantType: 'social'
});
if (error) {
handleError();
return;
}
await processResponse();
endLoading();
};
const loginByCode = async (data: Api.Auth.SocialLoginForm) => {
try {
await authStore.login(data);
await processResponse();
} catch {
handleError();
}
endLoading();
};
const init = async () => {
startLoading();
// 如果域名不相等 则重定向处理
const host = window.location.host;
if (domain !== host) {
const urlFull = new URL(window.location.href);
urlFull.host = domain;
window.location.href = urlFull.toString();
return;
}
const data: Api.Auth.SocialLoginForm = {
socialCode: code,
socialState: state,
tenantId,
source,
grantType: 'social'
};
if (!authStore.isLogin) {
await loginByCode(data);
} else {
await callbackByCode(data);
}
};
onMounted(async () => {
await init();
});
</script>
<template>
<div class="fixed-center flex-col bg-layout">
<div class="my-36px h-120px w-120px">
<div class="relative h-full" :class="{ 'animate-spin': loading }">
<img src="@/assets/imgs/logo.png" width="120" />
</div>
</div>
<h2 class="text-28px text-primary font-500">{{ msg }}</h2>
</div>
2025-04-24 17:36:38 +08:00
</template>
<style scoped></style>