mirror of
				https://github.com/continew-org/continew-admin-ui.git
				synced 2025-10-26 20:57:14 +08:00 
			
		
		
		
	fix: 修复第三方登录错误
This commit is contained in:
		| @@ -1,4 +1,4 @@ | |||||||
| import { type RouteRecordRaw, createRouter, createWebHashHistory } from 'vue-router' | import { type RouteRecordRaw, createRouter, createWebHistory } from 'vue-router' | ||||||
| import { useRouteStore } from '@/stores' | import { useRouteStore } from '@/stores' | ||||||
|  |  | ||||||
| /** 默认布局 */ | /** 默认布局 */ | ||||||
| @@ -19,6 +19,7 @@ export const constantRoutes: RouteRecordRaw[] = [ | |||||||
|   }, |   }, | ||||||
|   { |   { | ||||||
|     path: '/login', |     path: '/login', | ||||||
|  |     name: 'Login', | ||||||
|     component: () => import('@/views/login/index.vue'), |     component: () => import('@/views/login/index.vue'), | ||||||
|     meta: { hidden: true } |     meta: { hidden: true } | ||||||
|   }, |   }, | ||||||
| @@ -75,7 +76,7 @@ export const constantRoutes: RouteRecordRaw[] = [ | |||||||
| ] | ] | ||||||
|  |  | ||||||
| const router = createRouter({ | const router = createRouter({ | ||||||
|   history: createWebHashHistory(import.meta.env.BASE_URL), |   history: createWebHistory(import.meta.env.BASE_URL), | ||||||
|   routes: constantRoutes, |   routes: constantRoutes, | ||||||
|   scrollBehavior: () => ({ left: 0, top: 0 }) |   scrollBehavior: () => ({ left: 0, top: 0 }) | ||||||
| }) | }) | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| <template> | <template> | ||||||
|   <a-spin :loading="loading" :tip="isLogin() ? '绑定中。。。' : '登录中。。。'"> |   <a-spin :loading="loading" :tip="isLogin() ? '绑定中...' : '登录中...'"> | ||||||
|     <div></div> |     <div></div> | ||||||
|   </a-spin> |   </a-spin> | ||||||
| </template> | </template> | ||||||
| @@ -8,10 +8,12 @@ | |||||||
| import { Message } from '@arco-design/web-vue' | import { Message } from '@arco-design/web-vue' | ||||||
| import { useRoute, useRouter } from 'vue-router' | import { useRoute, useRouter } from 'vue-router' | ||||||
| import { bindSocialAccount } from '@/apis' | import { bindSocialAccount } from '@/apis' | ||||||
|  | import { useUserStore } from '@/stores' | ||||||
| import { isLogin } from '@/utils/auth' | import { isLogin } from '@/utils/auth' | ||||||
|  |  | ||||||
| const route = useRoute() | const route = useRoute() | ||||||
| const router = useRouter() | const router = useRouter() | ||||||
|  | const userStore = useUserStore() | ||||||
| const source = route.query.source as string | const source = route.query.source as string | ||||||
| const loading = ref(false) | const loading = ref(false) | ||||||
|  |  | ||||||
| @@ -50,14 +52,14 @@ const handleBindSocial = () => { | |||||||
|   loading.value = true |   loading.value = true | ||||||
|   const { ...othersQuery } = router.currentRoute.value.query |   const { ...othersQuery } = router.currentRoute.value.query | ||||||
|   bindSocialAccount(source, othersQuery) |   bindSocialAccount(source, othersQuery) | ||||||
|     .then((res) => { |     .then(() => { | ||||||
|       router.push({ |       router.push({ | ||||||
|         path: '/setting/profile', |         path: '/setting/profile', | ||||||
|         query: { |         query: { | ||||||
|           ...othersQuery |           ...othersQuery | ||||||
|         } |         } | ||||||
|       }) |       }) | ||||||
|       proxy.$message.success(res.msg) |       Message.success('绑定成功') | ||||||
|     }) |     }) | ||||||
|     .catch(() => { |     .catch(() => { | ||||||
|       router.push({ |       router.push({ | ||||||
| @@ -80,6 +82,10 @@ if (isLogin()) { | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style scoped lang="less"> | <style scoped lang="less"> | ||||||
|  | :deep(.arco-spin-mask) { | ||||||
|  |   background-color: transparent; | ||||||
|  | } | ||||||
|  |  | ||||||
| div { | div { | ||||||
|   width: 150px; |   width: 150px; | ||||||
|   height: 150px; |   height: 150px; | ||||||
|   | |||||||
| @@ -44,33 +44,38 @@ | |||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script setup lang="ts"> | <script setup lang="ts"> | ||||||
|  | import { Message } from '@arco-design/web-vue' | ||||||
| import type { ModeItem } from '../type' | import type { ModeItem } from '../type' | ||||||
| import VerifyModel from '../components/VerifyModel.vue' | import VerifyModel from '../components/VerifyModel.vue' | ||||||
| import { listUserSocial, socialAuth, unbindSocialAccount } from '@/apis' | import { listUserSocial, socialAuth, unbindSocialAccount } from '@/apis' | ||||||
| import { useUserStore } from '@/stores' |  | ||||||
|  |  | ||||||
| const userStore = useUserStore() |  | ||||||
|  |  | ||||||
| const socialList = ref<any>([]) | const socialList = ref<any>([]) | ||||||
| const modeList = ref<ModeItem[]>([]) | const modeList = ref<ModeItem[]>([]) | ||||||
| modeList.value = [ |  | ||||||
|  | // 初始化数据 | ||||||
|  | const initData = () => { | ||||||
|  |   listUserSocial().then((res) => { | ||||||
|  |     socialList.value = res.data.map((el) => el.source) | ||||||
|  |     modeList.value = [ | ||||||
|       { |       { | ||||||
|         title: '绑定 Gitee', |         title: '绑定 Gitee', | ||||||
|         icon: 'gitee', |         icon: 'gitee', | ||||||
|     subtitle: `${socialList.value.includes('gitee') ? '' : '绑定后,'}可通过 Gitee 进行登录`, |         subtitle: `${socialList.value.includes('GITEE') ? '' : '绑定后,'}可通过 Gitee 进行登录`, | ||||||
|         jumpMode: 'link', |         jumpMode: 'link', | ||||||
|         type: 'gitee', |         type: 'gitee', | ||||||
|     status: socialList.value.includes('gitee') |         status: socialList.value.includes('GITEE') | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         title: '绑定 GitHub', |         title: '绑定 GitHub', | ||||||
|         icon: 'github', |         icon: 'github', | ||||||
|     subtitle: `${socialList.value.includes('gitee') ? '' : '绑定后,'}可通过 GitHub 进行登录`, |         subtitle: `${socialList.value.includes('GITHUB') ? '' : '绑定后,'}可通过 GitHub 进行登录`, | ||||||
|         type: 'github', |         type: 'github', | ||||||
|         jumpMode: 'link', |         jumpMode: 'link', | ||||||
|     status: socialList.value.includes('github') |         status: socialList.value.includes('GITHUB') | ||||||
|       } |       } | ||||||
| ] |     ] | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  |  | ||||||
| // 绑定 | // 绑定 | ||||||
| const onBinding = (type: string, status: boolean) => { | const onBinding = (type: string, status: boolean) => { | ||||||
| @@ -79,10 +84,9 @@ const onBinding = (type: string, status: boolean) => { | |||||||
|       window.open(res.data.authorizeUrl, '_self') |       window.open(res.data.authorizeUrl, '_self') | ||||||
|     }) |     }) | ||||||
|   } else { |   } else { | ||||||
|     unbindSocialAccount(type).then((res) => { |     unbindSocialAccount(type).then(() => { | ||||||
|       if (res.code === 200) { |       initData() | ||||||
|         userStore.getInfo() |       Message.success('解绑成功') | ||||||
|       } |  | ||||||
|     }) |     }) | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -93,13 +97,6 @@ const onUpdate = (type: string) => { | |||||||
|   verifyModelRef.value?.open(type) |   verifyModelRef.value?.open(type) | ||||||
| } | } | ||||||
|  |  | ||||||
| // 初始化数据 |  | ||||||
| const initData = () => { |  | ||||||
|   listUserSocial().then((res) => { |  | ||||||
|     socialList.value = res.data.map((el) => el.source) |  | ||||||
|   }) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| onMounted(() => { | onMounted(() => { | ||||||
|   initData() |   initData() | ||||||
| }) | }) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user