feat: alipay login
This commit is contained in:
@@ -160,6 +160,11 @@ const getFestivalName = () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const open = async () => {
|
const open = async () => {
|
||||||
|
// #ifdef MP-ALIPAY
|
||||||
|
handleAlipayLogin();
|
||||||
|
return;
|
||||||
|
// #endif
|
||||||
|
|
||||||
// #ifdef MP-WEIXIN
|
// #ifdef MP-WEIXIN
|
||||||
const isAgreed = await privacyRef.value.check();
|
const isAgreed = await privacyRef.value.check();
|
||||||
if (isAgreed) {
|
if (isAgreed) {
|
||||||
@@ -167,11 +172,50 @@ const open = async () => {
|
|||||||
}
|
}
|
||||||
// #endif
|
// #endif
|
||||||
|
|
||||||
// #ifndef MP-WEIXIN
|
// #ifndef MP-WEIXIN || MP-ALIPAY
|
||||||
popupRef.value.open();
|
popupRef.value.open();
|
||||||
// #endif
|
// #endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const handleAlipayLogin = async () => {
|
||||||
|
try {
|
||||||
|
uni.showLoading({ title: "登录中...", mask: true });
|
||||||
|
const code = await alipayLogin();
|
||||||
|
const imageUrl = avatarUrl.value ? await uploadImage(avatarUrl.value) : "";
|
||||||
|
|
||||||
|
const loginRes = await apiLogin({
|
||||||
|
code,
|
||||||
|
nickname: nickname.value || getFestivalName(),
|
||||||
|
avatarUrl: imageUrl,
|
||||||
|
platform: "alipay",
|
||||||
|
shareToken: props.shareToken,
|
||||||
|
});
|
||||||
|
// 保存用户信息到store
|
||||||
|
userStore.setUserInfo({
|
||||||
|
nickName: loginRes?.user?.nickname || nickname.value || getFestivalName(),
|
||||||
|
avatarUrl: loginRes?.user?.avatar || imageUrl,
|
||||||
|
id: loginRes?.user?.id,
|
||||||
|
isVip: loginRes?.isVip || false,
|
||||||
|
vipExpireAt: loginRes?.vipExpireAt || null,
|
||||||
|
});
|
||||||
|
|
||||||
|
userStore.setToken(loginRes.token);
|
||||||
|
|
||||||
|
uni.hideLoading();
|
||||||
|
uni.showToast({ title: "登录成功", icon: "success" });
|
||||||
|
emit("logind");
|
||||||
|
popupRef.value.close();
|
||||||
|
|
||||||
|
// 重置临时变量
|
||||||
|
avatarUrl.value = "";
|
||||||
|
nickname.value = "";
|
||||||
|
} catch (err) {
|
||||||
|
uni.hideLoading();
|
||||||
|
uni.showToast({ title: "登录失败", icon: "none" });
|
||||||
|
console.error(err);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
const onPrivacyAgree = () => {
|
const onPrivacyAgree = () => {
|
||||||
popupRef.value.open();
|
popupRef.value.open();
|
||||||
};
|
};
|
||||||
@@ -235,36 +279,7 @@ const confirmLogin = async () => {
|
|||||||
avatarUrl.value = "";
|
avatarUrl.value = "";
|
||||||
nickname.value = "";
|
nickname.value = "";
|
||||||
} else if (platform === "mp-alipay") {
|
} else if (platform === "mp-alipay") {
|
||||||
const code = await alipayLogin();
|
await handleAlipayLogin();
|
||||||
const imageUrl = avatarUrl.value
|
|
||||||
? await uploadImage(avatarUrl.value)
|
|
||||||
: "";
|
|
||||||
|
|
||||||
const loginRes = await apiLogin({
|
|
||||||
code,
|
|
||||||
nickname: nickname.value || getFestivalName(),
|
|
||||||
avatarUrl: imageUrl,
|
|
||||||
platform: "alipay",
|
|
||||||
shareToken: props.shareToken,
|
|
||||||
});
|
|
||||||
// 保存用户信息到store
|
|
||||||
userStore.setUserInfo({
|
|
||||||
nickName: loginRes?.user?.nickname || nickname.value,
|
|
||||||
avatarUrl: loginRes?.user?.avatar || imageUrl,
|
|
||||||
id: loginRes?.user?.id,
|
|
||||||
isVip: loginRes?.isVip || false,
|
|
||||||
vipExpireAt: loginRes?.vipExpireAt || null,
|
|
||||||
});
|
|
||||||
|
|
||||||
userStore.setToken(loginRes.token);
|
|
||||||
|
|
||||||
uni.showToast({ title: "登录成功", icon: "success" });
|
|
||||||
emit("logind");
|
|
||||||
popupRef.value.close();
|
|
||||||
|
|
||||||
// 重置临时变量
|
|
||||||
avatarUrl.value = "";
|
|
||||||
nickname.value = "";
|
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
uni.showToast({ title: "登录失败", icon: "none" });
|
uni.showToast({ title: "登录失败", icon: "none" });
|
||||||
|
|||||||
@@ -35,8 +35,8 @@ const privacyContractName = ref("《用户隐私保护指引》");
|
|||||||
const emit = defineEmits(["agree"]);
|
const emit = defineEmits(["agree"]);
|
||||||
let resolveCheck = null;
|
let resolveCheck = null;
|
||||||
|
|
||||||
// #ifdef MP-WEIXIN
|
|
||||||
const check = () => {
|
const check = () => {
|
||||||
|
// #ifdef MP-WEIXIN
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
if (uni.getPrivacySetting) {
|
if (uni.getPrivacySetting) {
|
||||||
uni.getPrivacySetting({
|
uni.getPrivacySetting({
|
||||||
@@ -59,8 +59,11 @@ const check = () => {
|
|||||||
resolve(true);
|
resolve(true);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
// #endif
|
||||||
|
// #ifdef MP-ALIPAY
|
||||||
|
return Promise.resolve(true);
|
||||||
|
// #endif
|
||||||
};
|
};
|
||||||
// #endif
|
|
||||||
|
|
||||||
// Only for WeChat Mini Program
|
// Only for WeChat Mini Program
|
||||||
// #ifdef MP-WEIXIN
|
// #ifdef MP-WEIXIN
|
||||||
|
|||||||
Reference in New Issue
Block a user