From 381c97332e567a1b95a9a5220275461d0ae3f74e Mon Sep 17 00:00:00 2001 From: zhengyiming <540361168@qq.com> Date: 星期五, 28 三月 2025 17:30:37 +0800 Subject: [PATCH] fix: 四期需求 --- apps/taro/src/hooks/user.ts | 55 ++++++++++++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 50 insertions(+), 5 deletions(-) diff --git a/apps/taro/src/hooks/user.ts b/apps/taro/src/hooks/user.ts index dfabcc6..981d80e 100644 --- a/apps/taro/src/hooks/user.ts +++ b/apps/taro/src/hooks/user.ts @@ -6,8 +6,36 @@ import { useRefeshDidShow } from './infiniteLoading'; import { LoginFormTabs } from '@/subpackages/login/constants'; import { useLoginedJump } from './login'; -import { useLifeRechargeContext, APIgetLifePayWxIndentityParams } from '@life-payment/core-vue'; +import { + useLifeRechargeContext, + APIgetLifePayWxIndentityParams, + WxMiniAppIndentityInfo, + LifePayPhoneMesssageCodeLoginOutput, +} from '@life-payment/core-vue'; import { isInWeChat } from '@/utils/env'; + +export function useVirtualUserInfo() { + const { blLifeRecharge } = useLifeRechargeContext(); + + const { data: virtualUserInfo } = useQuery({ + queryKey: ['blLifeRecharge/lifePayUserMesssageByIduser', blLifeRecharge.accountModel.userId], + queryFn: async () => { + return await blLifeRecharge.services.lifePayUserMesssageByIduser( + { + id: blLifeRecharge.accountModel.userId, + }, + { + showLoading: false, + } + ); + }, + placeholderData: () => ({} as LifePayPhoneMesssageCodeLoginOutput), + enabled: computed(() => !!blLifeRecharge.accountModel.userId), + staleTime: Infinity, + }); + + return { virtualUserInfo }; +} export function useUser() { const userStore = useUserStore(); @@ -26,6 +54,11 @@ return userStore.getCurrentUserInfo(); } + const { blLifeRecharge } = useLifeRechargeContext(); + // const { virtualUserInfo } = useVirtualUserInfo(); + + const isChannelAccount = computed(() => blLifeRecharge.accountModel.isBackClientUser); + return { user: userInfo, userDetail: userDetail, @@ -35,6 +68,8 @@ virtualPhoneNumber, wxCode, wxOpenId, + isChannelAccount, + // virtualUserInfo, }; } @@ -95,11 +130,13 @@ } if (!!code && !wxCode.value) { userStore.setWxCode(router.params.code ?? ''); - // getLifePayWxIndentity(code); + getLifePayWxIndentity(code); } } catch (error) {} }); } + +let wxIndentityPromise: Promise<WxMiniAppIndentityInfo>; export function useLifePayWxIndentity() { const { blLifeRecharge } = useLifeRechargeContext(); @@ -110,9 +147,17 @@ let params: APIgetLifePayWxIndentityParams = { code: code, }; - let res = await blLifeRecharge.services.getLifePayWxIndentity(params, { - showLoading: false, - }); + if (!wxIndentityPromise) { + wxIndentityPromise = blLifeRecharge.services + .getLifePayWxIndentity(params, { + showLoading: false, + }) + .finally(() => { + wxIndentityPromise = undefined; + }); + } + + let res = await wxIndentityPromise; if (res.openId) { userStore.setWxOpenId(res.openId); } -- Gitblit v1.9.1