From c7ab8c4fca1c690f3e5536dff520eaa9c4010fd1 Mon Sep 17 00:00:00 2001
From: zhengyiming <540361168@qq.com>
Date: 星期一, 24 三月 2025 19:52:35 +0800
Subject: [PATCH] fix: 三期bug

---
 packages/components/src/views/PhoneBillRecharge/PhoneBillRechargeStep2.vue       |    2 +-
 apps/taro/src/hooks/user.ts                                                      |   22 ++++++++++++++++++----
 packages/components/src/views/GasBillRecharge/GasBillRechargeStep3.vue           |    2 +-
 packages/components/src/views/SelectPayTypeView/SelectPayTypeView.vue            |    2 +-
 packages/components/src/hooks/selectPayType.ts                                   |    5 +++--
 packages/components/src/views/electricBillRecharge/ElectricBillRechargeStep2.vue |    2 +-
 6 files changed, 25 insertions(+), 10 deletions(-)

diff --git a/apps/taro/src/hooks/user.ts b/apps/taro/src/hooks/user.ts
index dfabcc6..b6523b1 100644
--- a/apps/taro/src/hooks/user.ts
+++ b/apps/taro/src/hooks/user.ts
@@ -6,7 +6,11 @@
 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,
+} from '@life-payment/core-vue';
 import { isInWeChat } from '@/utils/env';
 
 export function useUser() {
@@ -101,6 +105,8 @@
   });
 }
 
+let wxIndentityPromise: Promise<WxMiniAppIndentityInfo>;
+
 export function useLifePayWxIndentity() {
   const { blLifeRecharge } = useLifeRechargeContext();
   const userStore = useUserStore();
@@ -110,9 +116,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);
       }
diff --git a/packages/components/src/hooks/selectPayType.ts b/packages/components/src/hooks/selectPayType.ts
index ad03530..5a729ab 100644
--- a/packages/components/src/hooks/selectPayType.ts
+++ b/packages/components/src/hooks/selectPayType.ts
@@ -12,7 +12,7 @@
   isInWeChat?: MaybeRef<boolean>;
   isH5?: MaybeRef<boolean>;
   appId?: MaybeRef<string>;
-  getOpenId?: () => Promise<string>;
+  getOpenId?: MaybeRef<() => Promise<string>>;
 };
 
 export function useSelectPayType(options: UseSelectPayTypeOptions = {}) {
@@ -98,7 +98,8 @@
 
   async function getPayOrderForJsAPI(orderNo: string) {
     try {
-      const openId = await getOpenId();
+      const _getOpenId = unref(getOpenId);
+      const openId = await _getOpenId();
       let params: GetPayOrderForJsAPIInput = {
         orderNo: orderNo,
         lifePayType: blLifeRecharge.constants.LifePayTypeEnum.WxPay,
diff --git a/packages/components/src/views/GasBillRecharge/GasBillRechargeStep3.vue b/packages/components/src/views/GasBillRecharge/GasBillRechargeStep3.vue
index 4a4c43f..6525540 100644
--- a/packages/components/src/views/GasBillRecharge/GasBillRechargeStep3.vue
+++ b/packages/components/src/views/GasBillRecharge/GasBillRechargeStep3.vue
@@ -220,7 +220,7 @@
 }
 
 const { state, invokeAliPay, invokeWeixinPay } = useSelectPayType({
-  getOpenId: props.getOpenId,
+  getOpenId: toRef(props, 'getOpenId'),
   isInWeChat: toRef(props, 'isInWeChat'),
   isH5: toRef(props, 'isH5'),
   appId: toRef(props, 'appId'),
diff --git a/packages/components/src/views/PhoneBillRecharge/PhoneBillRechargeStep2.vue b/packages/components/src/views/PhoneBillRecharge/PhoneBillRechargeStep2.vue
index 89f670a..433e3ab 100644
--- a/packages/components/src/views/PhoneBillRecharge/PhoneBillRechargeStep2.vue
+++ b/packages/components/src/views/PhoneBillRecharge/PhoneBillRechargeStep2.vue
@@ -216,7 +216,7 @@
 }
 
 const { state, invokeAliPay, invokeWeixinPay } = useSelectPayType({
-  getOpenId: props.getOpenId,
+  getOpenId: toRef(props, 'getOpenId'),
   isInWeChat: toRef(props, 'isInWeChat'),
   isH5: toRef(props, 'isH5'),
   appId: toRef(props, 'appId'),
diff --git a/packages/components/src/views/SelectPayTypeView/SelectPayTypeView.vue b/packages/components/src/views/SelectPayTypeView/SelectPayTypeView.vue
index 57cc4e3..2b50807 100644
--- a/packages/components/src/views/SelectPayTypeView/SelectPayTypeView.vue
+++ b/packages/components/src/views/SelectPayTypeView/SelectPayTypeView.vue
@@ -51,7 +51,7 @@
 }>();
 
 const { state, invokeAliPay, invokeWeixinPay } = useSelectPayType({
-  getOpenId: props.getOpenId,
+  getOpenId: toRef(props, 'getOpenId'),
   isInWeChat: toRef(props, 'isInWeChat'),
   isH5: toRef(props, 'isH5'),
   appId: toRef(props, 'appId'),
diff --git a/packages/components/src/views/electricBillRecharge/ElectricBillRechargeStep2.vue b/packages/components/src/views/electricBillRecharge/ElectricBillRechargeStep2.vue
index b2cf93b..ce6c1ee 100644
--- a/packages/components/src/views/electricBillRecharge/ElectricBillRechargeStep2.vue
+++ b/packages/components/src/views/electricBillRecharge/ElectricBillRechargeStep2.vue
@@ -231,7 +231,7 @@
   isInWeChat: toRef(props, 'isInWeChat'),
   isH5: toRef(props, 'isH5'),
   appId: toRef(props, 'appId'),
-  getOpenId: props.getOpenId,
+  getOpenId: toRef(props, 'getOpenId'),
 });
 
 const currentOrderNo = ref('');

--
Gitblit v1.9.1