征信小程序
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

331 lines
7.9 KiB

<template>
<view class="site">
<view class="site-bd">
<form @submit="sureSubmit">
<view class="item">
<view class="a">用户头像</view>
<view class="b">
<!-- #ifdef H5 -->
<view class="pic" @click="uploadImg()">
<image v-if="userInfo.avatar" class="img" :src="baseUrl + userInfo.avatar"></image>
<image v-else class="img" src="https://www.lijkj.cn/static/default.png"></image>
</view>
<text @click="uploadImg()">编辑</text>
<!-- #endif -->
<!-- #ifdef MP-WEIXIN -->
<view class="pic">
<image v-if="userInfo.avatar" class="img" :src="baseUrl + userInfo.avatar"></image>
<image v-else class="img" src="https://www.lijkj.cn/static/default.png"></image>
<button open-type="chooseAvatar" @chooseavatar="chooseavatar"></button>
</view>
<text>编辑</text>
<!-- #endif -->
</view>
</view>
<view class="item">
<view class="a">用户昵称</view>
<view class="b">
<input :value="userInfo.nickname" name='nickname' type="nickname" placeholder="请输入用户名" />
<button class="btn" v-if="isShow1 == true" formType="submit">完成</button>
<text @click="openPage(2)" v-else>编辑</text>
</view>
</view>
<!-- <view class="item">
<view class="a">密码</view>
<view class="b" @click="openPage(3)">
<text>设置</text>
</view>
</view> -->
<view class="item">
<view class="a">实名认证</view>
<view class="b" @click="openPage(4)">
<text>{{userInfos.is_shiming == 0?'审核中':userInfos.is_shiming == 1?'已通过':userInfos.is_shiming == -1?'已驳回':'去认证'}}</text>
</view>
</view>
<!--#ifdef MP-WEIXIN-->
<view class="item">
<view class="a">手机号</view>
<view class="b" @click="openPage(5)">
<input disabled :value="userInfo.mobile" type="number"/>
<text>编辑</text>
</view>
</view>
<!--#endif-->
<view class="item" v-if="systembasicInfoopen.wechat">
<view class="a">微信号</view>
<view class="b">
<input :disabled="isShow2 == false" v-model="userInfo.wechat_num" type="text" placeholder="请输入微信号" />
<text v-if="isShow2 == false" @click="openPage(1)">编辑</text>
<text v-else @click="openPage(7)">完成</text>
</view>
</view>
</form>
</view>
</view>
</template>
<script>
export default {
data() {
return {
systembasicInfoopen: {},
userInfo: {},
isShow1: false,
isShow2: false,
baseUrl: "",
userInfos: {}
};
},
onShow() {
this.systembasicInfoopen = uni.getStorageSync("systembasicInfoopen")
this.getUserInfo();
this.baseUrl=this.$baseUrl
this.getUsershenhe();
},
methods: {
//查询当前实名认证情况
async getUsershenhe() {
const { code, data, msg } = await this.$api.getUsershenhe({token: uni.getStorageSync("token")});
if(code == 1){
this.userInfos = data
}
},
openPage(index){
if(index == 1){
this.isShow2 = !this.isShow2
}else if(index == 2){
this.isShow1 = !this.isShow1
}else if(index == 3){
uni.navigateTo({
url: "/pages/user/password"
})
}else if(index == 4){
uni.navigateTo({
url: "/pages/user/verification"
})
}else if(index == 5){
uni.navigateTo({
url: "/pages/user/phone"
})
}else if(index == 6){
uni.navigateTo({
url: "/pages/user/verification"
})
}else if(index == 7){
if(!this.userInfo.wechat_num){
uni.showToast({
icon: "none",
title: "请输入微信号"
})
return ;
}
this.toSubmit();
}
},
sureSubmit(e) {
this.userInfo.nickname = e.detail.value.nickname
if(!this.userInfo.nickname){
uni.showToast({
icon: "none",
title: "请输入用户昵称"
})
return ;
}
this.toSubmit();
},
async toSubmit() {
const { code, data, msg} = await this.$api.editMember({
avatar: this.userInfo.avatar?this.userInfo.avatar:'',
nickname: this.userInfo.nickname?this.userInfo.nickname:"",
wechat_num: this.userInfo.wechat_num?this.userInfo.wechat_num:"",
token: uni.getStorageSync("token")
})
if(code == 1){
uni.showToast({
title: "修改成功"
})
this.getUserInfo();
}else{
uni.showToast({
icon: "none",
title: msg
})
}
},
//获取用户信息
async getUserInfo() {
const { code, data , msg } = await this.$api.getMemberInfo({token: uni.getStorageSync("token")});
if(code == 1){
uni.setStorageSync('userInfo', data.user);
this.userInfo = data.user;
this.isShow1 = false;
this.isShow2 = false;
}else{
uni.showToast({
title: msg,
icon: "none",
})
}
},
uploadImg() {
const that = this
uni.chooseImage({
count: 1,
sizeType: ["original","complete"], //可以指定是原图还是压缩图,默认二者都有
sourceType: ["album", "camera"],
success: (res) => {
uni.uploadFile({
name: 'file',
url: this.$baseUrl+'/api/Common/upload',
filePath: res.tempFilePaths[0],
formData: {
token: uni.getStorageSync('token')
},
success: (upRes) => {
const {code, data, msg } = JSON.parse(upRes.data);
if(code == 1){
that.userInfo.avatar = data.url
that.toSubmit();
}else{
uni.showToast({
icon: "error",
title: "上传失败"
})
}
},
fail: (err) => {
console.log("toUpload err",err)
console.log(err)
}
});
},
fail(err){
console.log("fail",err)
}
});
},
chooseavatar(e){
let tempFiles = e.detail.avatarUrl;
const that = this;
uni.uploadFile({
name: 'file',
url: this.$baseUrl+'/api/Common/upload',
filePath: tempFiles,
formData: {
token: uni.getStorageSync('token')
},
success: (upRes) => {
const {code, data, msg } = JSON.parse(upRes.data);
if(code == 1){
that.userInfo.avatar = data.url
that.toSubmit();
}else{
uni.showToast({
icon: "error",
title: "上传失败"
})
}
},
fail: (err) => {
console.log("toUpload err",err)
console.log(err)
}
});
},
}
}
</script>
<style lang="scss" scoped>
.site{
padding: 25rpx;
overflow: hidden;
&-bd{
width: 700rpx;
background: #FFFFFF;
box-shadow: 0px 3rpx 10rpx 0px rgba(9,44,39,0.05);
border-radius: 20rpx;
margin: 0 auto;
padding: 0 30rpx;
box-sizing: border-box;
position: relative;
.item{
display: flex;
align-items: center;
justify-content: space-between;
border-top: 1px solid #EAEAEA;
padding: 35rpx 0;
overflow: hidden;
position: relative;
&:first-child{
border-color: #FFFFFF;
}
.a{
width: 160rpx;
display: flex;
align-items: center;
font-weight: 500;
font-size: 30rpx;
color: #222222;
}
.b{
flex: 1;
display: flex;
align-items: center;
justify-content: flex-end;
font-weight: 500;
font-size: 24rpx;
color: #999999;
input{
flex: 1;
font-weight: 500;
font-size: 24rpx;
color: #999999;
}
text{
font-weight: 500;
font-size: 28rpx;
color: #00C6A9;
margin-left: 15rpx;
}
button{
font-weight: 500;
font-size: 28rpx;
color: #00C6A9;
background-color: transparent;
display: inline-block;
line-height: 30rpx;
padding: 0;
margin: 0;
&::after{
border-color: transparent;
}
}
.pic{
width: 60rpx;
height: 60rpx;
position: relative;
overflow: hidden;
button{
width: 100%;
height: 100%;
position: absolute;
left: 0;
top: 0;
z-index: 2;
opacity: 0;
}
}
image{
width: 60rpx;
height: 60rpx;
border-radius: 50%;
}
}
}
}
}
</style>