536 lines
17 KiB
Vue
536 lines
17 KiB
Vue
<template>
|
||
<view :data-theme="theme">
|
||
<form @submit="formSubmit" report-submit='true'>
|
||
<view class='personal-data borderPad'>
|
||
<view class='list borRadius14'>
|
||
<view class="item acea-row row-between-wrapper">
|
||
<view>头像</view>
|
||
<!-- #ifndef MP -->
|
||
<view class="pictrue" @click.stop='uploadpic'>
|
||
<image :src='avatarUrl'></image>
|
||
<image :src='editPng' class="alter"></image>
|
||
</view>
|
||
<!-- #endif -->
|
||
<!-- #ifdef MP -->
|
||
<view class="pictrue">
|
||
<button class="avatar-wrapper" open-type="chooseAvatar" @chooseavatar="onChooseAvatar">
|
||
<image class="avatar" :src="avatarUrl"></image>
|
||
</button>
|
||
<image :src='editPng' class="alter"></image>
|
||
</view>
|
||
<!-- #endif -->
|
||
</view>
|
||
<view class='item acea-row row-between-wrapper'>
|
||
<view>昵称</view>
|
||
<view class='input fontColor'>
|
||
<!-- #ifndef MP -->
|
||
<input type='text' name='nickname' :value='nickname' maxlength="10"></input>
|
||
<!-- #endif -->
|
||
<!-- #ifdef MP -->
|
||
<input type="nickname" name='nickname' :value='nickname' class="weui-input"
|
||
placeholder="请输入昵称" maxlength="10"/>
|
||
<!-- #endif -->
|
||
</view>
|
||
</view>
|
||
<view class='item acea-row row-between-wrapper'>
|
||
<view>性别</view>
|
||
<view class='input'>
|
||
<picker @change="bindSexChange" :value="sexindex" :range="sexList" range-key="name">
|
||
<view class="uni-input">{{sexList[sexindex].name}}</view>
|
||
</picker>
|
||
</view>
|
||
</view>
|
||
<view class='item acea-row row-between-wrapper'>
|
||
<view>出生日期</view>
|
||
<view class='input'>
|
||
<picker mode="date" :value="date" :start="startDate" :end="endDate"
|
||
@change="bindDateChange">
|
||
<view class="uni-input">{{date}}</view>
|
||
</picker>
|
||
</view>
|
||
</view>
|
||
<view class='item acea-row row-between-wrapper'>
|
||
<view>地区</view>
|
||
<view class='input'>
|
||
<picker mode="multiSelector" :value="cityIndex" :range="cityData" @change="bindCityChange"
|
||
@columnchange="selMonitor">
|
||
<view class="uni-input">{{addressNode.province&&addressNode.city ? addressNode.province + ' , ' + addressNode.city : '-'}}
|
||
</view>
|
||
</picker>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<button class='modifyBnt bg_color' formType="submit">保存修改</button>
|
||
</view>
|
||
</form>
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
// +----------------------------------------------------------------------
|
||
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
||
// +----------------------------------------------------------------------
|
||
// | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
|
||
// +----------------------------------------------------------------------
|
||
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
||
// +----------------------------------------------------------------------
|
||
// | Author: CRMEB Team <admin@crmeb.com>
|
||
// +----------------------------------------------------------------------
|
||
import {
|
||
userEdit
|
||
} from '@/api/user.js';
|
||
import {
|
||
getCity
|
||
} from '@/api/api.js';
|
||
import {
|
||
toLogin
|
||
} from '@/libs/login.js';
|
||
import {
|
||
mapGetters
|
||
} from "vuex";
|
||
import {
|
||
Debounce
|
||
} from '@/utils/validate.js'
|
||
import city from "../static/js/city.js";
|
||
let app = getApp();
|
||
const CACHE_ADDRESS = {};
|
||
export default {
|
||
data() {
|
||
return {
|
||
memberInfo: {
|
||
avatar: '',
|
||
},
|
||
userIndex: 0,
|
||
wechat: false,
|
||
theme: app.globalData.theme,
|
||
editPng: '../../../static/images/alert1.png',
|
||
sexList: [{
|
||
val: 0,
|
||
name: '未知'
|
||
},
|
||
{
|
||
val: 1,
|
||
name: '男'
|
||
},
|
||
{
|
||
val: 2,
|
||
name: '女'
|
||
}
|
||
],
|
||
sexindex: 0,
|
||
date: '',
|
||
sex: 0,
|
||
cityData: city,
|
||
cityIndex: 0,
|
||
addressNode: {
|
||
province: "请选择城市",
|
||
city: ""
|
||
},
|
||
provinceList: [],
|
||
cityAllList: [],
|
||
avatarUrl: "",
|
||
nickname: '',
|
||
userInfo: null
|
||
};
|
||
},
|
||
computed: {
|
||
...mapGetters(['isLogin']),
|
||
startDate() {
|
||
return this.getDate('start');
|
||
},
|
||
endDate() {
|
||
return this.getDate('end');
|
||
}
|
||
|
||
},
|
||
onLoad() {
|
||
//this.loadAddress(1, 1);
|
||
if (!this.isLogin) {
|
||
toLogin();
|
||
} else {
|
||
this.getUserInfo();
|
||
}
|
||
this.getAddressData();
|
||
// #ifdef H5
|
||
let ua = navigator.userAgent.toLowerCase();
|
||
if (ua.match(/MicroMessenger/i) == "micromessenger") {
|
||
this.$set(this, 'wechat', false);
|
||
} else {
|
||
this.$set(this, 'wechat', true);
|
||
}
|
||
// #endif
|
||
switch (this.theme) {
|
||
case 'theme2':
|
||
this.editPng = '../static/images/alert2.png'
|
||
break;
|
||
case 'theme3':
|
||
this.editPng = '../static/images/alert3.png'
|
||
break;
|
||
case 'theme4':
|
||
this.editPng = '../static/images/alert4.png'
|
||
break;
|
||
case 'theme5':
|
||
this.editPng = '../static/images/alert5.png'
|
||
break;
|
||
default:
|
||
this.editPng = '../static/images/alert1.png'
|
||
break;
|
||
}
|
||
},
|
||
methods: {
|
||
getUserInfo(data) {
|
||
this.$store.dispatch('USERINFO').then(res => {
|
||
this.userInfo = res
|
||
let currentDate = this.getDate({
|
||
format: true
|
||
})
|
||
this.avatarUrl = this.userInfo.avatar ? this.userInfo.avatar : '../static/images/f.png';
|
||
this.nickname = this.userInfo.nickname ? this.userInfo.nickname : '-';
|
||
this.date = this.userInfo.birthday || currentDate;
|
||
this.sexindex = this.userInfo.sex;
|
||
this.sex = this.sexList[this.sexindex].val;
|
||
this.addressNode = {
|
||
province: this.userInfo.province,
|
||
city: this.userInfo.city
|
||
}
|
||
});
|
||
},
|
||
/**
|
||
* 小程序端上传头像
|
||
*
|
||
*/
|
||
onChooseAvatar(e) {
|
||
const {
|
||
avatarUrl
|
||
} = e.detail
|
||
uni.showLoading({
|
||
title: '加载中...'
|
||
});
|
||
this.$util.uploadImgs( avatarUrl, {
|
||
url: 'upload/image',
|
||
name: 'multipart',
|
||
model: "maintain",
|
||
pid: 0
|
||
},(res) => {
|
||
this.avatarUrl = res.data.url;
|
||
uni.hideLoading();
|
||
}, (err) => {
|
||
uni.hideLoading();
|
||
})
|
||
},
|
||
/**
|
||
* 监听省市区滚动
|
||
*
|
||
*/
|
||
selMonitor(e) {
|
||
const that = this
|
||
let column = e.detail.column
|
||
if (column == 0) {
|
||
let index = e.detail.value
|
||
let length = that.cityData[1].length
|
||
// 改变市
|
||
that.cityData[1].splice(0, length, ...that.cityAllList[index])
|
||
}
|
||
},
|
||
/**
|
||
* 将省市区的数据转换为picker可用的多维数组
|
||
*
|
||
*/
|
||
getAddressData() {
|
||
// 所有城市列表,二维数组
|
||
let cityAllList = [];
|
||
// 省列表
|
||
let provinceList = [];
|
||
// cityData为省市区的json数据
|
||
for (let key in this.cityData) {
|
||
let newDataList = [];
|
||
if (this.cityData[key].child) {
|
||
for (let key2 in this.cityData[key].child) {
|
||
newDataList.push(this.cityData[key].child[key2].city);
|
||
}
|
||
}
|
||
provinceList.push(this.cityData[key].province);
|
||
cityAllList.push(newDataList);
|
||
}
|
||
this.provinceList = provinceList;
|
||
this.cityAllList = cityAllList;
|
||
this.cityData = [provinceList, cityAllList[0]];
|
||
},
|
||
bindCityColumnChange(e) {
|
||
let column = e.detail.column
|
||
if (column == 0) {
|
||
let index = e.detail.value
|
||
this.cityData[1] = this.cityAllList[index]
|
||
}
|
||
},
|
||
bindCityChange(e) {
|
||
let val = e.target.value
|
||
this.addressNode = {
|
||
province: this.cityData[0][val[0]],
|
||
city: this.cityData[1][val[1]]
|
||
}
|
||
},
|
||
bindSexChange(e) {
|
||
this.sexindex = e.detail.value;
|
||
this.sex = this.sexList[this.sexindex].val;
|
||
},
|
||
bindDateChange: function(e) {
|
||
this.date = e.detail.value
|
||
},
|
||
getDate(type) {
|
||
const date = new Date();
|
||
let year = date.getFullYear();
|
||
let month = date.getMonth() + 1;
|
||
let day = date.getDate();
|
||
|
||
if (type === 'start') {
|
||
year = year - 60;
|
||
} else if (type === 'end') {
|
||
year = year + 2;
|
||
}
|
||
month = month > 9 ? month : '0' + month;
|
||
day = day > 9 ? day : '0' + day;
|
||
return `${year}-${month}-${day}`;
|
||
},
|
||
/**
|
||
* 上传文件
|
||
*
|
||
*/
|
||
uploadpic: function() {
|
||
let that = this;
|
||
that.$util.uploadImageOne({
|
||
url: 'upload/image',
|
||
name: 'multipart',
|
||
model: "maintain",
|
||
pid: 0,
|
||
count: 1
|
||
}, function(res) {
|
||
that.avatarUrl = res;
|
||
});
|
||
},
|
||
|
||
/**
|
||
* 提交修改
|
||
*/
|
||
formSubmit: Debounce(function(e) {
|
||
let that = this,
|
||
value = e.detail.value
|
||
if (!value.nickname) return that.$util.Tips({
|
||
title: '用户姓名不能为空'
|
||
});
|
||
value.avatar = that.avatarUrl ? that.avatarUrl : that.userInfo.avatar;
|
||
uni.showLoading({
|
||
title: '加载中...'
|
||
});
|
||
|
||
userEdit({
|
||
avatar: value.avatar,
|
||
birthday: that.date,
|
||
city: this.addressNode.city,
|
||
province: this.addressNode.province,
|
||
nickname: value.nickname,
|
||
sex: that.sex
|
||
}).then(res => {
|
||
uni.hideLoading();
|
||
that.$util.Tips({
|
||
title: '保存成功',
|
||
icon: 'success'
|
||
});
|
||
setTimeout(function() {
|
||
uni.reLaunch({
|
||
url: '/pages/user/index',
|
||
})
|
||
}, 2000);
|
||
|
||
}).catch(msg => {
|
||
uni.hideLoading();
|
||
return that.$util.Tips({
|
||
title: msg || '保存失败,您并没有修改'
|
||
});
|
||
});
|
||
})
|
||
}
|
||
}
|
||
</script>
|
||
|
||
<style scoped lang="scss">
|
||
.fontColor {
|
||
color: #868686;
|
||
}
|
||
|
||
.personal-data .wrapper {
|
||
margin: 10rpx 0;
|
||
background-color: #fff;
|
||
padding: 36rpx 30rpx 13rpx 30rpx;
|
||
}
|
||
|
||
.personal-data .wrapper .title {
|
||
margin-bottom: 30rpx;
|
||
font-size: 32rpx;
|
||
color: #282828;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item {
|
||
width: 690rpx;
|
||
height: 160rpx;
|
||
background-color: #f8f8f8;
|
||
border-radius: 20rpx;
|
||
margin-bottom: 22rpx;
|
||
padding: 0 30rpx;
|
||
position: relative;
|
||
border: 2rpx solid #f8f8f8;
|
||
box-sizing: border-box;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item.on {
|
||
border-color: $theme-color;
|
||
border-radius: 20rpx;
|
||
background-image: url("");
|
||
background-size: 100% 100%;
|
||
background-color: #fff9f9;
|
||
background-repeat: no-repeat;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .picTxt {
|
||
width: 445rpx;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .picTxt .pictrue {
|
||
width: 96rpx;
|
||
height: 96rpx;
|
||
position: relative;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .picTxt .pictrue image,
|
||
.pictrue button {
|
||
width: 100%;
|
||
height: 100%;
|
||
border-radius: 50%;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .picTxt .pictrue .alter {
|
||
width: 30rpx;
|
||
height: 30rpx;
|
||
border-radius: 50%;
|
||
position: absolute;
|
||
bottom: 0;
|
||
right: 0;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .picTxt .text {
|
||
width: 325rpx;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .picTxt .text .name {
|
||
width: 100%;
|
||
font-size: 30rpx;
|
||
color: #282828;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .picTxt .text .phone {
|
||
font-size: 24rpx;
|
||
color: #999;
|
||
margin-top: 10rpx;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .bnt {
|
||
font-size: 24rpx;
|
||
background-color: #fff;
|
||
border-radius: 27rpx;
|
||
width: 140rpx;
|
||
height: 54rpx;
|
||
border: 2rpx solid $theme-color;
|
||
}
|
||
|
||
.personal-data .wrapper .wrapList .item .currentBnt {
|
||
position: absolute;
|
||
right: 0;
|
||
top: 0;
|
||
font-size: 26rpx;
|
||
background-color: rgba(233, 51, 35, 0.1);
|
||
width: 140rpx;
|
||
height: 48rpx;
|
||
border-radius: 0 20rpx 0 20rpx;
|
||
}
|
||
|
||
.personal-data .list {
|
||
margin-top: 30rpx;
|
||
background-color: #fff;
|
||
}
|
||
|
||
.personal-data .list .item {
|
||
border-bottom: 1rpx solid #f2f2f2;
|
||
padding: 24rpx;
|
||
font-size: 32rpx;
|
||
color: #333333;
|
||
}
|
||
|
||
.personal-data .list .item .phone {
|
||
width: 160rpx;
|
||
height: 56rpx;
|
||
font-size: 24rpx;
|
||
color: #fff;
|
||
line-height: 56rpx;
|
||
border-radius: 32rpx
|
||
}
|
||
|
||
.personal-data .list .item .pictrue {
|
||
width: 80rpx;
|
||
height: 80rpx;
|
||
position: relative;
|
||
}
|
||
|
||
.personal-data .list .item .pictrue image {
|
||
width: 100%;
|
||
height: 100%;
|
||
border-radius: 50%;
|
||
}
|
||
|
||
.personal-data .list .item .pictrue .alter {
|
||
width: 30rpx;
|
||
height: 30rpx;
|
||
border-radius: 50%;
|
||
position: absolute;
|
||
bottom: 0;
|
||
right: 0;
|
||
}
|
||
|
||
.personal-data .list .item .input {
|
||
width: 415rpx;
|
||
text-align: right;
|
||
color: #666666;
|
||
}
|
||
|
||
.personal-data .list .item .input .id {
|
||
width: 365rpx;
|
||
}
|
||
|
||
.personal-data .list .item .input .iconfont {
|
||
font-size: 35rpx;
|
||
}
|
||
|
||
.personal-data .modifyBnt {
|
||
font-size: 32rpx;
|
||
color: #fff;
|
||
width: 690rpx;
|
||
height: 90rpx;
|
||
border-radius: 50rpx;
|
||
text-align: center;
|
||
line-height: 90rpx;
|
||
margin: 76rpx auto 0 auto;
|
||
}
|
||
|
||
.bg_color {
|
||
@include main_bg_color(theme);
|
||
}
|
||
|
||
.personal-data .logOut {
|
||
font-size: 32rpx;
|
||
text-align: center;
|
||
width: 690rpx;
|
||
height: 90rpx;
|
||
border-radius: 45rpx;
|
||
margin: 30rpx auto 0 auto;
|
||
}
|
||
</style>
|