2024-06-05 19:14:51 +08:00
|
|
|
|
<template>
|
|
|
|
|
<view class="container">
|
|
|
|
|
<!-- <image @click="navBack" src="../../static/images/index/close.png" style="width: 32upx;height: 32upx;margin-left: 46upx;"></image> -->
|
|
|
|
|
<!-- 小程序状态下登录 -->
|
|
|
|
|
<!-- #ifdef MP-WEIXIN -->
|
|
|
|
|
<view class="mp_wxBox">
|
|
|
|
|
<view>
|
|
|
|
|
<view class="headers">
|
|
|
|
|
<image src="../../static/logo.png" style="border-radius: 50%;"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="content">
|
|
|
|
|
<view>申请获取以下权限</view>
|
|
|
|
|
<text>获得你的公开信息(昵称,头像、地区等)</text>
|
|
|
|
|
</view>
|
2024-06-26 16:58:53 +08:00
|
|
|
|
<button v-show="weixinPhone" style="background: linear-gradient(90deg, #019C88, #28BA92, #35C495);color: #FFFFFF;" class="bottom"
|
2024-06-05 19:14:51 +08:00
|
|
|
|
open-type="getPhoneNumber" @getphonenumber="getPhoneNumber">
|
|
|
|
|
授权手机号
|
|
|
|
|
</button>
|
2024-06-26 16:58:53 +08:00
|
|
|
|
<button v-show="!weixinPhone" style="background: linear-gradient(90deg, #019C88, #28BA92, #35C495);color: #FFFFFF;" class='bottom'
|
2024-06-05 19:14:51 +08:00
|
|
|
|
bindtap="getUserProfile" @tap="wxGetUserInfo">
|
|
|
|
|
授权登录
|
|
|
|
|
</button>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="login-view-group">
|
|
|
|
|
<view class="footer">
|
|
|
|
|
<image v-if="showAgree" @tap="isShowAgree"
|
|
|
|
|
src="https://wap.quanmindaojia.com/file/uploadPath/2023/02/15/ee4b62258955340385364b67c57c65e0.png"
|
|
|
|
|
style="width: 30upx;height: 30upx;"></image>
|
|
|
|
|
<image v-else @tap="isShowAgree"
|
|
|
|
|
src="https://wap.quanmindaojia.com/file/uploadPath/2023/01/18/02d699f656ea68f69a67ff906c8f1af6.png"
|
|
|
|
|
style="width: 30upx;height: 30upx;"></image>
|
|
|
|
|
<text style="margin-left: 10upx;margin-right: 0;" @tap="isShowAgree">同意</text>
|
|
|
|
|
<!-- 协议地址 -->
|
|
|
|
|
<navigator url="/my/setting/mimi" open-type="navigate">《隐私政策》</navigator>
|
|
|
|
|
和
|
|
|
|
|
<navigator url="/my/setting/xieyi" open-type="navigate">《用户协议》</navigator>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<!-- #endif -->
|
|
|
|
|
<!-- #ifndef MP-WEIXIN -->
|
|
|
|
|
<view style="text-align: center;">
|
2025-02-28 16:01:27 +08:00
|
|
|
|
<view style="font-size: 40upx;margin-top: 32upx;color: #333333;margin-top: 100rpx;">欢迎登录盛安小象</view>
|
2024-06-05 19:14:51 +08:00
|
|
|
|
<image style="width: 300upx;height: 300upx;margin-top: 200upx;margin-bottom:100rpx;border-radius:20upx"
|
|
|
|
|
src="../../static/logo.png"></image>
|
|
|
|
|
<button v-if="weixinLogin" class="confirm-btn" @click="weixinLo">微信登录</button>
|
|
|
|
|
<button v-if="weixinLogin" class='confirm-btn-weixin' @click="register">手机号登录</button>
|
2024-06-26 16:58:53 +08:00
|
|
|
|
<button v-if="!weixinLogin" class='confirm-btn' style="background: linear-gradient(90deg, #019C88, #28BA92, #35C495);" @click="register">手机号登录</button>
|
2024-06-05 19:14:51 +08:00
|
|
|
|
|
|
|
|
|
<view style="text-align: center;margin: 30rpx 0rpx;align-items: center;">
|
|
|
|
|
<view class="footer">
|
|
|
|
|
<image v-if="showAgree" @tap="isShowAgree"
|
|
|
|
|
src="../../static/images/gouxuan.png"
|
|
|
|
|
style="width: 30upx;height: 30upx;"></image>
|
|
|
|
|
<image v-else @tap="isShowAgree"
|
2025-02-28 16:01:27 +08:00
|
|
|
|
src="../../static/images/weigouxuan.svg"
|
2024-06-05 19:14:51 +08:00
|
|
|
|
style="width: 30upx;height: 30upx;"></image>
|
|
|
|
|
<text style="margin-left: 10upx;margin-right: 0;" @tap="isShowAgree">同意</text>
|
|
|
|
|
<!-- 协议地址 -->
|
|
|
|
|
<navigator url="/my/setting/mimi" open-type="navigate">《隐私政策》</navigator>
|
|
|
|
|
和
|
|
|
|
|
<navigator url="/my/setting/xieyi" open-type="navigate">《用户协议》</navigator>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<!-- #endif -->
|
|
|
|
|
|
|
|
|
|
</view>
|
|
|
|
|
</template>
|
|
|
|
|
<script>
|
|
|
|
|
export default {
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
showAgree: false,
|
|
|
|
|
mobile: '',
|
|
|
|
|
code: '',
|
|
|
|
|
weixinLogin: false,
|
|
|
|
|
sending: false,
|
|
|
|
|
sendTime: '获取验证码',
|
|
|
|
|
count: 60,
|
|
|
|
|
weixinPhone: false,
|
|
|
|
|
sendDataList: {},
|
|
|
|
|
sessionkey: '',
|
|
|
|
|
phoneNum: false
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
onLoad(e) {
|
|
|
|
|
if (e.inviterCode) {
|
|
|
|
|
this.$queue.setData('inviterCode', e.inviterCode);
|
|
|
|
|
}
|
|
|
|
|
//微信登录开启
|
|
|
|
|
this.$Request.getT('/app/common/type/53').then(res => {
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
if (res.data && res.data.value && res.data.value == '是') {
|
|
|
|
|
// this.weixinLogin = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
this.$Request.getT('/app/common/type/188').then(res => {
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
if (res.data && res.data.value && res.data.value == '是') {
|
|
|
|
|
this.phoneNum = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
isShowAgree() {
|
|
|
|
|
//是否选择协议
|
|
|
|
|
this.showAgree = !this.showAgree;
|
|
|
|
|
},
|
|
|
|
|
wxGetUserInfo(e) {
|
|
|
|
|
if (this.showAgree == false) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
icon: 'none',
|
|
|
|
|
position: 'bottom',
|
|
|
|
|
title: '请先同意《隐私政策》和《用户协议》'
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
wx.getUserProfile({
|
|
|
|
|
desc: '业务需要',
|
|
|
|
|
success: infoRes => {
|
|
|
|
|
console.log("infoRes.encryptedData__________:" + JSON.stringify(infoRes.userInfo))
|
|
|
|
|
let nickName = infoRes.userInfo.nickName; //昵称
|
|
|
|
|
let avatarUrl = infoRes.userInfo.avatarUrl; //头像
|
|
|
|
|
let sex = infoRes.userInfo.gender; //头像
|
|
|
|
|
try {
|
|
|
|
|
this.$queue.showLoading('正在登录中...');
|
|
|
|
|
this.login(nickName, avatarUrl, sex);
|
|
|
|
|
} catch (e) {}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
//登录
|
|
|
|
|
login(nickName, avatarUrl, sex) {
|
|
|
|
|
if (this.showAgree == false) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
icon: 'none',
|
|
|
|
|
position: 'bottom',
|
|
|
|
|
title: '请先同意《隐私政策》和《用户协议》'
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
let that = this;
|
|
|
|
|
// 1.wx获取登录用户code
|
|
|
|
|
uni.login({
|
|
|
|
|
provider: 'weixin',
|
|
|
|
|
success: function(loginRes) {
|
|
|
|
|
console.log(loginRes, '************')
|
|
|
|
|
let data = {
|
|
|
|
|
code: loginRes.code,
|
|
|
|
|
type: 2
|
|
|
|
|
}
|
|
|
|
|
that.$Request.get('/app/Login/wxLogin', data).then(res => {
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
uni.hideLoading()
|
|
|
|
|
uni.setStorageSync('openId', res.data.open_id)
|
|
|
|
|
uni.setStorageSync('unionId', res.data.unionId)
|
|
|
|
|
that.sessionkey = res.data.session_key;
|
|
|
|
|
|
|
|
|
|
let inviterCode = '';
|
|
|
|
|
if (uni.getStorageSync('inviterCode')) {
|
|
|
|
|
inviterCode = uni.getStorageSync('inviterCode')
|
|
|
|
|
}
|
|
|
|
|
let sendData = {
|
|
|
|
|
openId: uni.getStorageSync('openId'),
|
|
|
|
|
unionId: uni.getStorageSync('unionId'),
|
|
|
|
|
userName: nickName,
|
|
|
|
|
avatar: avatarUrl,
|
|
|
|
|
sex: sex, //性别
|
|
|
|
|
inviterCode: inviterCode //别人登录进来携带你的邀请码
|
|
|
|
|
};
|
|
|
|
|
that.sendDataList = sendData;
|
|
|
|
|
that.flag = res.data.flag;
|
|
|
|
|
// 第一次登录获取手机号
|
|
|
|
|
console.log(that.phoneNum)
|
|
|
|
|
if (that.flag == '1' && that.phoneNum) {
|
|
|
|
|
that.weixinPhone = true;
|
|
|
|
|
} else {
|
|
|
|
|
that.getWeixinInfo(sendData);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
icon: 'none',
|
|
|
|
|
title: res.msg,
|
|
|
|
|
duration: 2000
|
|
|
|
|
});
|
|
|
|
|
console.log(res, '失败')
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
//小程序微信登录后获取手机号
|
|
|
|
|
getPhoneNumber: function(e) {
|
|
|
|
|
if (e.detail.errMsg == 'getPhoneNumber:fail user deny') {
|
|
|
|
|
console.log('用户拒绝提供手机号');
|
|
|
|
|
} else {
|
|
|
|
|
console.log('用户同意提供手机号');
|
|
|
|
|
console.log(e)
|
|
|
|
|
this.setPhoneByInsert(e.detail.encryptedData, e.detail.iv);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//小程序微信登录后获取手机号
|
|
|
|
|
setPhoneByInsert(decryptData, iv) {
|
|
|
|
|
let data = {
|
|
|
|
|
decryptData: decryptData,
|
|
|
|
|
key: this.sessionkey,
|
|
|
|
|
iv: iv
|
|
|
|
|
};
|
|
|
|
|
if (this.showAgree == false) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
icon: 'none',
|
|
|
|
|
position: 'bottom',
|
|
|
|
|
title: '请先同意《隐私政策》和《用户协议》'
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
this.$Request.postJson('/app/Login/selectPhone', data).then(res => {
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
this.phone = res.data.phoneNumber;
|
|
|
|
|
this.getWeixinInfo(this.sendDataList);
|
|
|
|
|
} else {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
title: res.msg,
|
|
|
|
|
icon: 'none',
|
|
|
|
|
duration: 2000
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
//获取个人信息
|
|
|
|
|
getWeixinInfo(sendData) {
|
|
|
|
|
let that = this;
|
|
|
|
|
uni.showLoading({
|
|
|
|
|
title: '登录中...'
|
|
|
|
|
});
|
|
|
|
|
let postData = {
|
|
|
|
|
openId: sendData.openId, //小程序openId
|
|
|
|
|
unionId: sendData.unionId, //unionId
|
|
|
|
|
userName: sendData.userName, //微信名称
|
|
|
|
|
avatar: sendData.avatar, //头像
|
|
|
|
|
sex: sendData.sex, //性别
|
|
|
|
|
phone: that.phone,
|
|
|
|
|
inviterCode: sendData.inviterCode,
|
|
|
|
|
type: 2
|
|
|
|
|
};
|
|
|
|
|
that.$Request.postJson('/app/Login/insertWxUser', postData).then(res => {
|
|
|
|
|
uni.hideLoading();
|
|
|
|
|
if (res.code == 0) {
|
|
|
|
|
uni.setStorageSync('token', res.token)
|
|
|
|
|
uni.setStorageSync('userName', res.user.userName)
|
|
|
|
|
uni.setStorageSync('avatar', res.user.avatar)
|
|
|
|
|
uni.setStorageSync('phone', res.user.phone)
|
|
|
|
|
uni.setStorageSync('invitationCode', res.user.invitationCode)
|
|
|
|
|
uni.setStorageSync('sex', res.user.sex)
|
|
|
|
|
uni.setStorageSync('userId', res.user.userId)
|
|
|
|
|
uni.setStorageSync('openId', res.user.openId)
|
|
|
|
|
|
|
|
|
|
this.$Request.get("/app/UserVip/isUserVip").then(res => {
|
|
|
|
|
if (res.code == 0 && res.data && res.data.isVip == 2) {
|
|
|
|
|
uni.setStorageSync('isVIP', true)
|
|
|
|
|
} else {
|
|
|
|
|
uni.setStorageSync('isVIP', false)
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
uni.navigateBack();
|
|
|
|
|
} else {
|
|
|
|
|
uni.showModal({
|
|
|
|
|
showCancel: false,
|
|
|
|
|
title: '登录失败',
|
|
|
|
|
content: res.msg,
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
weixinLo() {
|
|
|
|
|
if (this.showAgree == false) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
icon: 'none',
|
|
|
|
|
position: 'bottom',
|
|
|
|
|
title: '请先同意《隐私政策》和《用户协议》'
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
let that = this;
|
|
|
|
|
uni.login({
|
|
|
|
|
provider: 'weixin',
|
|
|
|
|
success: function(loginRes) {
|
|
|
|
|
that.$queue.showLoading('正在登录中...');
|
|
|
|
|
console.error(loginRes.authResult);
|
|
|
|
|
that.$queue.setData('weixinToken', loginRes.authResult.access_token);
|
|
|
|
|
that.$queue.setData('unionid', loginRes.authResult.unionid);
|
|
|
|
|
that.$queue.setData('weixinOpenid', loginRes.authResult.openid);
|
|
|
|
|
that.$Request.postJson('/app/login/loginApp', {
|
|
|
|
|
token: loginRes.authResult.access_token,
|
|
|
|
|
unionid: loginRes.authResult.unionid,
|
|
|
|
|
openid: loginRes.authResult.openid
|
|
|
|
|
}).then(res => {
|
|
|
|
|
console.log(JSON.stringify(res))
|
|
|
|
|
if (res.code === 0) {
|
|
|
|
|
if (uni.getSystemInfoSync().platform == "android") {
|
|
|
|
|
let clientid = plus.push.getClientInfo().clientid;
|
|
|
|
|
that.$Request.postT('/app/login/updateClientId?clientId=' +
|
|
|
|
|
clientid + '&userId=' + res.userId).then(res => {
|
|
|
|
|
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
that.$queue.setData("token", res.uuid);
|
|
|
|
|
that.$queue.setData("userId", res.userId);
|
|
|
|
|
that.getUserInfo(res.userId, res.token);
|
|
|
|
|
} else {
|
|
|
|
|
uni.hideLoading();
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages/public/wxmobile'
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
forget() {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages/public/pwd'
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
register() {
|
|
|
|
|
if (this.showAgree == false) {
|
|
|
|
|
uni.showToast({
|
|
|
|
|
icon: 'none',
|
|
|
|
|
position: 'bottom',
|
|
|
|
|
title: '请先同意《隐私政策》和《用户协议》'
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url: '/pages/public/loginphone'
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
inputChange(e) {
|
|
|
|
|
const key = e.currentTarget.dataset.key;
|
|
|
|
|
this[key] = e.detail.value;
|
|
|
|
|
},
|
|
|
|
|
navBack() {
|
|
|
|
|
uni.navigateBack();
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
getUserInfo(userId, token) {
|
|
|
|
|
this.$Request.postJson('/app/selectUserById?userId=' + userId).then(res => {
|
|
|
|
|
if (res.code === 0) {
|
|
|
|
|
this.$queue.setData('token', res.data.uuid);
|
|
|
|
|
this.$queue.setData('image_url', res.data.imageUrl ? res.data.imageUrl :
|
|
|
|
|
'/static/img/common/logo.jpg');
|
|
|
|
|
this.$queue.setData('inviterCode', res.data.inviterCode);
|
|
|
|
|
this.$queue.setData('invitationCode', res.data.invitationCode);
|
|
|
|
|
this.$queue.setData('grade', res.data.grade);
|
|
|
|
|
this.$queue.setData('mobile', res.data.mobile);
|
|
|
|
|
this.$queue.setData('isInvitation', res.data.isInvitation);
|
|
|
|
|
this.$queue.setData('nickName', res.data.nickName ? res.data.nickName : res.data.phone);
|
|
|
|
|
this.$queue.setData('gender', parseInt(res.data.gender));
|
|
|
|
|
uni.switchTab({
|
|
|
|
|
url: '/pages/index/index'
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
uni.showModal({
|
|
|
|
|
showCancel: false,
|
|
|
|
|
title: '登录失败',
|
|
|
|
|
content: res.msg
|
|
|
|
|
});
|
|
|
|
|
this.$queue.logout();
|
|
|
|
|
}
|
|
|
|
|
uni.hideLoading();
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss">
|
|
|
|
|
page {
|
|
|
|
|
height: 100%;
|
|
|
|
|
background: #FFFFFF !important;
|
|
|
|
|
}
|
|
|
|
|
.login-view-group{
|
|
|
|
|
display: flex;
|
|
|
|
|
flex-direction: column;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
}
|
|
|
|
|
.container {
|
|
|
|
|
top: 0;
|
|
|
|
|
padding-top: 50px;
|
|
|
|
|
position: relative;
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
background: #FFFFFF !important;
|
|
|
|
|
color: #FFF;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
.confirm-btn-weixin {
|
|
|
|
|
width: 200px;
|
|
|
|
|
height: 42px;
|
|
|
|
|
line-height: 42px;
|
|
|
|
|
border-radius: 30px;
|
|
|
|
|
margin-top: 40upx;
|
|
|
|
|
// background: -moz-linear-gradient(left, #f15b6c, #e10a07 100%);
|
|
|
|
|
// background: -webkit-gradient(linear, left top, left right, color-stop(0, #f15b6c), color-stop(100%, #e10a07));
|
|
|
|
|
// background: -webkit-linear-gradient(left, #f15b6c 0, #e10a07 100%);
|
|
|
|
|
// background: -o-linear-gradient(left, #f15b6c 0, #e10a07 100%);
|
|
|
|
|
// background: -ms-linear-gradient(left, #f15b6c 0, #e10a07 100%);
|
|
|
|
|
// background: linear-gradient(to left, #f15b6c 0, #e10a07 100%);
|
2024-06-26 16:58:53 +08:00
|
|
|
|
background: linear-gradient(90deg, #019C88, #28BA92, #35C495);
|
2024-06-05 19:14:51 +08:00
|
|
|
|
color: #fff;
|
|
|
|
|
font-size: 32upx;
|
|
|
|
|
|
|
|
|
|
&:after {
|
|
|
|
|
border-radius: 60px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.confirm-btn {
|
|
|
|
|
width: 200px;
|
|
|
|
|
height: 42px;
|
|
|
|
|
line-height: 42px;
|
|
|
|
|
border-radius: 30px;
|
|
|
|
|
margin-top: 300upx;
|
|
|
|
|
// background: -moz-linear-gradient(left, #f15b6c, #e10a07 100%);
|
|
|
|
|
// background: -webkit-gradient(linear, left top, left right, color-stop(0, #f15b6c), color-stop(100%, #e10a07));
|
|
|
|
|
// background: -webkit-linear-gradient(left, #f15b6c 0, #e10a07 100%);
|
|
|
|
|
// background: -o-linear-gradient(left, #f15b6c 0, #e10a07 100%);
|
|
|
|
|
// background: -ms-linear-gradient(left, #f15b6c 0, #e10a07 100%);
|
|
|
|
|
// background: linear-gradient(to left, #f15b6c 0, #e10a07 100%);
|
2024-06-26 16:58:53 +08:00
|
|
|
|
background: linear-gradient(90deg, #019C88, #28BA92, #35C495);
|
2024-06-05 19:14:51 +08:00
|
|
|
|
color: #fff;
|
|
|
|
|
font-size: 32upx;
|
|
|
|
|
|
|
|
|
|
&:after {
|
|
|
|
|
border-radius: 60px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.headers {
|
|
|
|
|
text-align: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.headers>image {
|
|
|
|
|
width: 400upx;
|
|
|
|
|
height: 400upx;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.footer {
|
|
|
|
|
padding-left: 160upx;
|
|
|
|
|
font-size: 24upx;
|
|
|
|
|
color: #666666;
|
|
|
|
|
text-align: center;
|
|
|
|
|
display: flex;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
page {
|
|
|
|
|
background: #fff;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.send-msg {
|
|
|
|
|
border-radius: 30px;
|
|
|
|
|
color: black;
|
|
|
|
|
background: white;
|
|
|
|
|
height: 30px;
|
|
|
|
|
font-size: 14px;
|
|
|
|
|
line-height: 30px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.container {
|
|
|
|
|
top: 0;
|
|
|
|
|
padding-top: 32upx;
|
|
|
|
|
position: relative;
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
background: #ffffff;
|
|
|
|
|
color: #FFF;
|
|
|
|
|
|
|
|
|
|
.mp_wxBox {
|
|
|
|
|
.headers {
|
|
|
|
|
margin: 35% auto 50rpx;
|
|
|
|
|
text-align: center;
|
|
|
|
|
border-radius: 60rpx;
|
|
|
|
|
width: 650rpx;
|
|
|
|
|
height: 300rpx;
|
|
|
|
|
line-height: 450rpx;
|
|
|
|
|
|
|
|
|
|
image {
|
|
|
|
|
width: 300rpx;
|
|
|
|
|
height: 300rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.content {
|
|
|
|
|
text-align: center;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
text {
|
|
|
|
|
display: block;
|
|
|
|
|
color: #9d9d9d;
|
|
|
|
|
margin-top: 40rpx;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bottom {
|
|
|
|
|
line-height: 80upx;
|
|
|
|
|
border-radius: 80upx;
|
|
|
|
|
margin: 70rpx 50rpx 40rpx;
|
|
|
|
|
height: 80upx;
|
|
|
|
|
font-size: 35rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.wrapper {
|
|
|
|
|
position: relative;
|
|
|
|
|
z-index: 90;
|
|
|
|
|
background: #fff;
|
|
|
|
|
padding-bottom: 20px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.input-content {
|
|
|
|
|
padding: 0 20px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.confirm-btn {
|
|
|
|
|
width: 300px;
|
|
|
|
|
height: 42px;
|
|
|
|
|
line-height: 42px;
|
|
|
|
|
border-radius: 30px;
|
|
|
|
|
margin-top: 40px;
|
|
|
|
|
// background: linear-gradient(to left, #005DFF 0, #005DeF 100%);
|
2024-06-26 16:58:53 +08:00
|
|
|
|
background: linear-gradient(90deg, #019C88, #28BA92, #35C495);
|
2024-06-05 19:14:51 +08:00
|
|
|
|
color: #fff;
|
|
|
|
|
// font-size: $font-lg;
|
|
|
|
|
|
|
|
|
|
&:after {
|
|
|
|
|
border-radius: 60px;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</style>
|