Merge branch 'demo' into dev

# Conflicts:
#	src/pages/user/components/UserCard.tsx
This commit is contained in:
2025-09-10 10:10:04 +08:00
16 changed files with 965 additions and 247 deletions

View File

@@ -65,11 +65,23 @@ export function parseInviteParams(options: any): InviteParams | null {
}
}
// 从 query 参数中解析邀请信息(兼容旧版本
if (options.referrer) {
return {
inviter: options.referrer,
source: 'link'
// 从 query 参数中解析邀请信息(处理首页分享链接
if (options.query) {
const query = options.query
if (query.inviter) {
return {
inviter: query.inviter,
source: query.source || 'share',
t: query.t
}
}
// 兼容旧版本
if (query.referrer) {
return {
inviter: query.referrer,
source: 'link'
}
}
}
@@ -163,13 +175,21 @@ export async function handleInviteRelation(userId: number): Promise<boolean> {
return true // 返回true表示关系已存在
}
// 设置API调用超时
const timeoutPromise = new Promise((_, reject) =>
setTimeout(() => reject(new Error('API调用超时')), 5000)
);
// 使用新的绑定推荐关系接口
await bindRefereeRelation({
const apiPromise = bindRefereeRelation({
dealerId: inviterId,
userId: userId,
source: inviteParams.source || 'qrcode',
scene: inviteParams.source === 'qrcode' ? `uid_${inviterId}` : `inviter=${inviterId}&source=${inviteParams.source}&t=${inviteParams.t}`
})
});
// 等待API调用完成或超时
await Promise.race([apiPromise, timeoutPromise]);
// 标记邀请关系已处理设置过期时间为7天
Taro.setStorageSync(relationKey, {
@@ -185,6 +205,16 @@ export async function handleInviteRelation(userId: number): Promise<boolean> {
return true
} catch (error) {
console.error('建立邀请关系失败:', error)
// 如果是网络错误或超时,不清除邀请参数,允许稍后重试
const errorMessage = error instanceof Error ? error.message : String(error)
if (errorMessage.includes('超时') || errorMessage.includes('网络')) {
console.log('网络问题,保留邀请参数供稍后重试')
return false
}
// 其他错误(如业务逻辑错误),清除邀请参数
clearInviteParams()
return false
}
}
@@ -329,9 +359,30 @@ export async function checkAndHandleInviteRelation(): Promise<boolean> {
}
console.log('使用用户ID处理邀请关系:', finalUserId)
return await handleInviteRelation(parseInt(finalUserId))
// 设置整体超时保护
const timeoutPromise = new Promise<boolean>((_, reject) =>
setTimeout(() => reject(new Error('邀请关系处理整体超时')), 6000)
);
const handlePromise = handleInviteRelation(parseInt(finalUserId));
return await Promise.race([handlePromise, timeoutPromise]);
} catch (error) {
console.error('检查邀请关系失败:', error)
// 记录失败次数,避免无限重试
const failKey = 'invite_handle_fail_count'
const failCount = Taro.getStorageSync(failKey) || 0
if (failCount >= 3) {
console.log('邀请关系处理失败次数过多,清除邀请参数')
clearInviteParams()
Taro.removeStorageSync(failKey)
} else {
Taro.setStorageSync(failKey, failCount + 1)
}
return false
}
}