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.
704 lines
20 KiB
704 lines
20 KiB
5 months ago
|
<template>
|
||
|
<!-- 个人资料 -->
|
||
|
<view>
|
||
|
<!-- #ifdef MP -->
|
||
|
<!-- <NavBar showBack bagColor="#f5f5f5" titleText="个人资料"></NavBar> -->
|
||
|
<view class="topdaohang" @click="goarrow">
|
||
|
<text class="iconfont icon-ic_leftarrow"></text>
|
||
|
<text >个人资料</text>
|
||
|
</view>
|
||
|
<!-- #endif -->
|
||
|
<form @submit="formSubmit">
|
||
|
<view class='personal-data' :style="colorStyle">
|
||
|
<view class='list rd-24rpx mx-20'>
|
||
|
<view class='item acea-row row-between-wrapper'>
|
||
|
<view>头像</view>
|
||
|
<view class="avatar-box" v-if="!mp_is_new" @click.stop='uploadpic'>
|
||
|
<image :src="userInfo.avatar"></image>
|
||
|
</view>
|
||
|
<button v-else class="avatar-box" open-type="chooseAvatar" @chooseavatar="onChooseAvatar">
|
||
|
<image :src="userInfo.avatar"></image>
|
||
|
</button>
|
||
|
</view>
|
||
|
<view class='item acea-row row-between-wrapper'>
|
||
|
<view>昵称</view>
|
||
|
<view class='input'><input type='nickname' name='nickname' :value='userInfo.nickname' maxlength="16"></input>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class='item acea-row row-between-wrapper'>
|
||
|
<view>手机号码</view>
|
||
|
<navigator url="/pages/users/user_phone/index" hover-class="none" class="input"
|
||
|
v-if="!userInfo.phone">
|
||
|
点击绑定手机号<text class="iconfont icon-ic_rightarrow"></text>
|
||
|
</navigator>
|
||
|
<view @click="isCancellation = true" class="input"
|
||
|
v-else>
|
||
|
{{userInfo.phone}}<text class="iconfont icon-ic_rightarrow"></text>
|
||
|
</view>
|
||
|
<view class='input acea-row row-between-wrapper' v-else>
|
||
|
<input type='text' disabled='true' name='phone' :value='userInfo.phone' class='id'></input>
|
||
|
<text class='iconfont icon-ic_rightarrow'></text>
|
||
|
</view>
|
||
|
</view>
|
||
|
<!-- <view class='item acea-row row-between-wrapper'>
|
||
|
<view>ID号</view>
|
||
|
<view class='input acea-row row-between-wrapper'>
|
||
|
<input type='text' :value='userInfo.uid' disabled='true' class='id'></input>
|
||
|
<text class='iconfont icon-ic_lock ml-12'></text>
|
||
|
</view>
|
||
|
</view> -->
|
||
|
<!-- #ifdef H5 -->
|
||
|
<view class="item acea-row row-between-wrapper" v-if="userInfo.phone && !this.$wechat.isWeixin()">
|
||
|
<view>密码</view>
|
||
|
<navigator url="/pages/users/user_pwd_edit/index" hover-class="none" class="input grab">
|
||
|
点击修改密码
|
||
|
<text class="iconfont icon-ic_rightarrow"></text>
|
||
|
</navigator>
|
||
|
</view>
|
||
|
<!-- #endif -->
|
||
|
|
||
|
<!-- #ifdef APP-PLUS -->
|
||
|
<view class="item acea-row row-between-wrapper" v-if="userInfo.phone">
|
||
|
<view>密码</view>
|
||
|
<navigator url="/pages/users/user_pwd_edit/index" hover-class="none" class="grab">
|
||
|
点击修改密码
|
||
|
<text class="iconfont icon-ic_rightarrow"></text>
|
||
|
</navigator>
|
||
|
</view>
|
||
|
<!-- #endif -->
|
||
|
<!-- <view class="item acea-row row-between-wrapper">
|
||
|
<view>账号注销</view>
|
||
|
<navigator url="/pages/users/user_cancellation/index" hover-class="none" class="input grab">
|
||
|
注销后无法恢复
|
||
|
<text class="iconfont icon-ic_rightarrow"></text>
|
||
|
</navigator>
|
||
|
</view> -->
|
||
|
<view class='item acea-row row-between-wrapper' v-for="(item,index) in userInfo.register_extend_info" :key="index">
|
||
|
<view class="acea-row row-middle">{{item.info}}<text v-if="item.required==1" class="asterisk iconfont icon-xinghao"></text></view>
|
||
|
<!-- text -->
|
||
|
<view class='input' v-if="item.format == 'text'">
|
||
|
<input type='text' v-model="item.value" :placeholder="item.tip" placeholder-class="placeholder"></input>
|
||
|
</view>
|
||
|
<!-- number -->
|
||
|
<view class='input' v-if="item.format == 'num'">
|
||
|
<input type='number' v-model="item.value" :placeholder="item.tip" placeholder-class="placeholder"></input>
|
||
|
</view>
|
||
|
<!-- email -->
|
||
|
<view class='input' v-if="item.format == 'mail'">
|
||
|
<input type='text' v-model="item.value" :placeholder="item.tip" placeholder-class="placeholder"></input>
|
||
|
</view>
|
||
|
<!-- data -->
|
||
|
<view class="input acea-row row-middle row-right" v-if="item.format=='date'">
|
||
|
<picker mode="date" :value="item.value" @change="bindDateChange($event,index)">
|
||
|
<view class="acea-row row-right dater">
|
||
|
<view class="grab" v-if="!item.value || item.value == ''">{{item.tip}}</view>
|
||
|
<view v-else>{{item.value}}</view>
|
||
|
</view>
|
||
|
</picker>
|
||
|
<text class='iconfont icon-xiangyou'></text>
|
||
|
</view>
|
||
|
<!-- id -->
|
||
|
<view class='input' v-if="item.format == 'id'">
|
||
|
<input type='idcard' v-model="item.value" :placeholder="item.tip" placeholder-class="placeholder"></input>
|
||
|
</view>
|
||
|
<!-- phone -->
|
||
|
<view class='input' v-if="item.format == 'phone'">
|
||
|
<input type='tel' v-model="item.value" :placeholder="item.tip" placeholder-class="placeholder"></input>
|
||
|
</view>
|
||
|
<!-- radio -->
|
||
|
<view class="input" v-if="item.format=='radio'">
|
||
|
<radio-group @change="radioChange($event,index)">
|
||
|
<label class="label" v-for="(j ,jindex) in item.singlearr" :key="jindex">
|
||
|
<!-- <radio :value="j" :checked="item.value == j" /> -->
|
||
|
<!-- #ifndef MP -->
|
||
|
<radio :value="jindex.toString()" :checked='item.value == jindex'/>
|
||
|
<!-- #endif -->
|
||
|
<!-- #ifdef MP -->
|
||
|
<radio :value="jindex" :checked='item.value == jindex'/>
|
||
|
<!-- #endif -->
|
||
|
{{j}}
|
||
|
</label>
|
||
|
</radio-group>
|
||
|
</view>
|
||
|
<!-- address -->
|
||
|
<view class="input acea-row row-middle row-right" @click="addressList" v-if="item.format=='address'">
|
||
|
<!-- <picker mode="multiSelector" @change="bindRegionChange($event,index)"
|
||
|
@columnchange="bindMultiPickerColumnChange" :value="valueRegion"
|
||
|
:range="multiArray">
|
||
|
<view class='acea-row'>
|
||
|
<view class="picker" :class="region[0] == '省'?'grab':''">{{region[0]}},{{region[1]}},{{region[2]}}</view>
|
||
|
</view>
|
||
|
</picker>
|
||
|
<text class='iconfont icon-xiangyou'></text> -->
|
||
|
<input type='text' v-model="item.value" :placeholder="item.tip" placeholder-class="placeholder"></input>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<button class='modifyBnt' formType="submit">保存修改</button>
|
||
|
|
||
|
</view>
|
||
|
</form>
|
||
|
<canvas canvas-id="canvas" v-if="canvasStatus"
|
||
|
:style="{width: canvasWidth + 'px', height: canvasHeight + 'px',position: 'absolute',left:'-100000px',top:'-100000px'}"></canvas>
|
||
|
<!-- #ifdef MP -->
|
||
|
<authorize v-if="isShowAuth" @authColse="authColse" @onLoadFun="onLoadFun"></authorize>
|
||
|
<!-- #endif -->
|
||
|
<tui-modal :show="isCancellation" maskClosable custom @cancel="isCancellation = false">
|
||
|
<view class="tui-modal-custom">
|
||
|
<view class="fs-32 fw-500 lh-44rpx text-center">更换已绑定的手机号?</view>
|
||
|
<view class="fs-30 text--w111-666 lh-42rpx text-center mt-22">当前绑定的手机号码为 {{userInfo.phone}}</view>
|
||
|
<view class="flex-y-center">
|
||
|
<view class="w-full h-72 rd-36rpx flex-center border b-solid b--w111-ccc text-primary-con fs-26 text--w111-fff mt-32 mr-16" @tap="bindPhone">更换</view>
|
||
|
<view class="w-full h-72 rd-36rpx flex-center bg-red fs-26 text--w111-fff mt-32 ml-16" @tap="isCancellation = false">取消</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</tui-modal>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
import {
|
||
|
getUserInfo,
|
||
|
userEdit,
|
||
|
getLogout
|
||
|
} from '@/api/user.js';
|
||
|
import tuiModal from '@/components/tui-modal/index.vue';
|
||
|
import {
|
||
|
switchH5Login,
|
||
|
getCity
|
||
|
} from '@/api/api.js';
|
||
|
import {
|
||
|
toLogin
|
||
|
} from '@/libs/login.js';
|
||
|
import {
|
||
|
mapGetters
|
||
|
} from "vuex";
|
||
|
import dayjs from "@/plugin/dayjs/dayjs.min.js";
|
||
|
import colors from '@/mixins/color.js';
|
||
|
import NavBar from '@/components/NavBar.vue';
|
||
|
export default {
|
||
|
components: {tuiModal,NavBar},
|
||
|
mixins: [colors],
|
||
|
data() {
|
||
|
return {
|
||
|
isCancellation: false,
|
||
|
userInfo: {},
|
||
|
loginType: 'h5', //app.globalData.loginType
|
||
|
userIndex: 0,
|
||
|
switchUserInfo: [],
|
||
|
isAuto: false, //没有授权的不会自动授权
|
||
|
isShowAuth: false, //是否隐藏授权
|
||
|
canvasWidth: "",
|
||
|
canvasHeight: "",
|
||
|
canvasStatus: false,
|
||
|
district: [],
|
||
|
multiArray: [],
|
||
|
multiIndex: [0, 0, 0],
|
||
|
valueRegion: [0, 0, 0],
|
||
|
region: ['省', '市', '区'],
|
||
|
mp_is_new: this.$Cache.get('MP_VERSION_ISNEW') || false
|
||
|
};
|
||
|
},
|
||
|
computed: mapGetters(['isLogin']),
|
||
|
watch: {
|
||
|
isLogin: {
|
||
|
handler: function(newV, oldV) {
|
||
|
if (newV) {
|
||
|
// #ifndef MP
|
||
|
this.getUserInfo();
|
||
|
// #endif
|
||
|
}
|
||
|
},
|
||
|
deep: true
|
||
|
}
|
||
|
},
|
||
|
onLoad() {
|
||
|
if (this.isLogin) {
|
||
|
this.getUserInfo();
|
||
|
} else {
|
||
|
this.getIsLogin();
|
||
|
}
|
||
|
},
|
||
|
onShow() {
|
||
|
uni.removeStorageSync('form_type_cart');
|
||
|
},
|
||
|
methods: {
|
||
|
goarrow(){
|
||
|
uni.navigateBack()
|
||
|
},
|
||
|
getIsLogin(){
|
||
|
toLogin()
|
||
|
},
|
||
|
// 省市区地址处理逻辑;
|
||
|
addressList(){
|
||
|
this.getCityList();
|
||
|
},
|
||
|
// 获取地址数据
|
||
|
getCityList() {
|
||
|
let that = this;
|
||
|
getCity().then(res => {
|
||
|
this.district = res.data
|
||
|
that.initialize();
|
||
|
})
|
||
|
},
|
||
|
// 处理地址数据
|
||
|
initialize: function() {
|
||
|
let that = this,
|
||
|
province = [],
|
||
|
city = [],
|
||
|
area = [];
|
||
|
if (that.district.length) {
|
||
|
let cityChildren = that.district[0].c || [];
|
||
|
let areaChildren = cityChildren.length ? (cityChildren[0].c || []) : [];
|
||
|
that.district.forEach(function(item) {
|
||
|
province.push(item.n);
|
||
|
});
|
||
|
cityChildren.forEach(function(item) {
|
||
|
city.push(item.n);
|
||
|
});
|
||
|
areaChildren.forEach(function(item) {
|
||
|
area.push(item.n);
|
||
|
});
|
||
|
this.multiArray = [province, city, area]
|
||
|
}
|
||
|
},
|
||
|
bindRegionChange(e,index) {
|
||
|
let multiIndex = this.multiIndex,
|
||
|
province = this.district[multiIndex[0]] || {
|
||
|
c: []
|
||
|
},
|
||
|
city = province.c[multiIndex[1]] || {
|
||
|
v: 0
|
||
|
},
|
||
|
multiArray = this.multiArray,
|
||
|
value = e.detail.value;
|
||
|
|
||
|
this.region = [multiArray[0][value[0]], multiArray[1][value[1]], multiArray[2][value[2]]]
|
||
|
this.userInfo.register_extend_info[index].value = city.v;
|
||
|
this.userInfo.register_extend_info[index].province = this.region[0];
|
||
|
this.userInfo.register_extend_info[index].city = this.region[1];
|
||
|
this.userInfo.register_extend_info[index].district = this.region[2];
|
||
|
this.valueRegion = [0, 0, 0]
|
||
|
this.initialize();
|
||
|
},
|
||
|
bindMultiPickerColumnChange(e) {
|
||
|
let that = this,
|
||
|
column = e.detail.column,
|
||
|
value = e.detail.value,
|
||
|
currentCity = this.district[value] || {
|
||
|
c: []
|
||
|
},
|
||
|
multiArray = that.multiArray,
|
||
|
multiIndex = that.multiIndex;
|
||
|
multiIndex[column] = value;
|
||
|
switch (column) {
|
||
|
case 0:
|
||
|
let areaList = currentCity.c[0] || {
|
||
|
c: []
|
||
|
};
|
||
|
multiArray[1] = currentCity.c.map((item) => {
|
||
|
return item.n;
|
||
|
});
|
||
|
multiArray[2] = areaList.c.map((item) => {
|
||
|
return item.n;
|
||
|
});
|
||
|
break;
|
||
|
case 1:
|
||
|
let cityList = that.district[multiIndex[0]].c[multiIndex[1]].c || [];
|
||
|
multiArray[2] = cityList.map((item) => {
|
||
|
return item.n;
|
||
|
});
|
||
|
break;
|
||
|
case 2:
|
||
|
break;
|
||
|
}
|
||
|
// #ifdef MP || APP-PLUS
|
||
|
this.$set(this.multiArray, 0, multiArray[0]);
|
||
|
this.$set(this.multiArray, 1, multiArray[1]);
|
||
|
this.$set(this.multiArray, 2, multiArray[2]);
|
||
|
// #endif
|
||
|
// #ifdef H5
|
||
|
this.multiArray = multiArray;
|
||
|
// #endif
|
||
|
this.multiIndex = multiIndex
|
||
|
},
|
||
|
radioChange(e, index){
|
||
|
this.userInfo.register_extend_info[index].value = e.detail.value
|
||
|
},
|
||
|
bindDateChange: function(e, index) {
|
||
|
this.userInfo.register_extend_info[index].value = e.target.value
|
||
|
},
|
||
|
/**
|
||
|
* 授权回调
|
||
|
*/
|
||
|
onLoadFun: function() {
|
||
|
this.getUserInfo();
|
||
|
this.isShowAuth = false;
|
||
|
},
|
||
|
// 授权关闭
|
||
|
authColse: function(e) {
|
||
|
this.isShowAuth = e
|
||
|
},
|
||
|
/**
|
||
|
* 小程序设置
|
||
|
*/
|
||
|
Setting: function() {
|
||
|
uni.openSetting({
|
||
|
success: function(res) {}
|
||
|
});
|
||
|
},
|
||
|
switchAccounts: function(index) {
|
||
|
let userInfo = this.switchUserInfo[index],
|
||
|
that = this;
|
||
|
that.userIndex = index;
|
||
|
if (that.switchUserInfo.length <= 1) return true;
|
||
|
if (userInfo === undefined) return that.$util.Tips({
|
||
|
title: '切换的账号不存在'
|
||
|
});
|
||
|
if (userInfo.user_type === 'h5') {
|
||
|
uni.showLoading({
|
||
|
title: '正在切换中'
|
||
|
});
|
||
|
switchH5Login().then(res => {
|
||
|
uni.hideLoading();
|
||
|
that.$store.commit("LOGIN", {
|
||
|
'token': res.data.token,
|
||
|
'time': this.$Cache.strTotime(res.data.expires_time) - this.$Cache.time()
|
||
|
});
|
||
|
that.getUserInfo();
|
||
|
|
||
|
}).catch(err => {
|
||
|
uni.hideLoading();
|
||
|
return that.$util.Tips({
|
||
|
title: err
|
||
|
});
|
||
|
})
|
||
|
} else {
|
||
|
that.$store.commit("LOGOUT");
|
||
|
uni.showLoading({
|
||
|
title: '正在切换中'
|
||
|
});
|
||
|
this.getIsLogin();
|
||
|
}
|
||
|
},
|
||
|
|
||
|
/**
|
||
|
* 获取用户详情
|
||
|
*/
|
||
|
getUserInfo: function() {
|
||
|
let that = this;
|
||
|
getUserInfo().then(res => {
|
||
|
res.data.register_extend_info.forEach(item=>{
|
||
|
if(item.format == 'radio'){
|
||
|
item.value = '0'
|
||
|
}else{
|
||
|
item.value = ''
|
||
|
if(item.format == 'address'){
|
||
|
item.province = "";
|
||
|
item.city = "";
|
||
|
item.district = "";
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
res.data.register_extend_info.forEach(item=>{
|
||
|
res.data.extend_info.forEach(j=>{
|
||
|
if(item.info === j.info){
|
||
|
item.value = j.value
|
||
|
if(item.format == 'address'){
|
||
|
let region = [j.province, j.city, j.district];
|
||
|
that.$set(that, 'region', region);
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
that.$set(that, 'userInfo', res.data);
|
||
|
let switchUserInfo = res.data.switchUserInfo || [];
|
||
|
for (let i = 0; i < switchUserInfo.length; i++) {
|
||
|
if (switchUserInfo[i].uid == that.userInfo.uid) that.userIndex = i;
|
||
|
// 切割h5用户;user_type状态:h5、routine(小程序)、wechat(公众号);注:只有h5未注册手机号时,h5才可和小程序或是公众号数据想通;
|
||
|
//#ifdef H5
|
||
|
if (
|
||
|
!that.$wechat.isWeixin() &&
|
||
|
switchUserInfo[i].user_type != "h5" &&
|
||
|
switchUserInfo[i].phone === ""
|
||
|
)
|
||
|
switchUserInfo.splice(i, 1);
|
||
|
//#endif
|
||
|
}
|
||
|
that.$set(that, "switchUserInfo", switchUserInfo);
|
||
|
});
|
||
|
},
|
||
|
/**
|
||
|
* 上传文件
|
||
|
*
|
||
|
*/
|
||
|
uploadpic: function() {
|
||
|
let that = this;
|
||
|
this.canvasStatus = true
|
||
|
that.$util.uploadImageChange('upload/image', (res) => {
|
||
|
let userInfo = that.switchUserInfo[that.userIndex];
|
||
|
// if (userInfo !== undefined) {
|
||
|
that.userInfo.avatar = res.data.url;
|
||
|
// }
|
||
|
that.switchUserInfo[that.userIndex] = userInfo;
|
||
|
that.$set(that, 'switchUserInfo', that.switchUserInfo);
|
||
|
this.canvasStatus = false
|
||
|
}, (res) => {
|
||
|
this.canvasStatus = false
|
||
|
}, (res) => {
|
||
|
this.canvasWidth = res.w
|
||
|
this.canvasHeight = res.h
|
||
|
});
|
||
|
},
|
||
|
// 微信头像获取
|
||
|
onChooseAvatar(e) {
|
||
|
const {
|
||
|
avatarUrl
|
||
|
} = e.detail
|
||
|
console.log(avatarUrl)
|
||
|
this.$util.uploadImgs('upload/image', avatarUrl, (res) => {
|
||
|
this.userInfo.avatar = res.data.url
|
||
|
}, (err) => {
|
||
|
console.log(err)
|
||
|
})
|
||
|
},
|
||
|
bindPhone(){
|
||
|
uni.navigateTo({
|
||
|
url:'/pages/users/user_phone/index'
|
||
|
})
|
||
|
},
|
||
|
/**
|
||
|
* 提交修改
|
||
|
*/
|
||
|
formSubmit: function(e) {
|
||
|
let that = this,
|
||
|
value = e.detail.value,
|
||
|
userInfo = that.switchUserInfo[that.userIndex];
|
||
|
if (!value.nickname) return that.$util.Tips({
|
||
|
title: '用户姓名不能为空'
|
||
|
});
|
||
|
value.avatar = this.userInfo.avatar;
|
||
|
for (var i = 0; i < that.userInfo.register_extend_info.length; i++) {
|
||
|
let data = that.userInfo.register_extend_info[i]
|
||
|
if (data.required || data.value) {
|
||
|
if (data.format === 'date' || data.format === 'address') {
|
||
|
if (!data.value) {
|
||
|
return that.$util.Tips({
|
||
|
title: `${data.tip}`
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
if(data.format === 'text'){
|
||
|
if (!data.value.trim()) {
|
||
|
return that.$util.Tips({
|
||
|
title: `${data.tip}`
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
if (data.format === 'num') {
|
||
|
if (data.value <= 0) {
|
||
|
return that.$util.Tips({
|
||
|
title: `${data.tip}`
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
if (data.format === 'mail') {
|
||
|
if (data.required) {
|
||
|
if (!data.value) {
|
||
|
return that.$util.Tips({
|
||
|
title: `${data.tip}`
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
if (data.value) {
|
||
|
if (!/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/.test(data.value)) {
|
||
|
return that.$util.Tips({
|
||
|
title: '请填写正确的邮箱'
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
if (data.format === 'phone') {
|
||
|
if (!/^1(3|4|5|7|8|9|6)\d{9}$/i.test(data.value)) {
|
||
|
return that.$util.Tips({
|
||
|
title: `${data.tip}`
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
if (data.format === 'id') {
|
||
|
if (data.required) {
|
||
|
if (!data.value) {
|
||
|
return that.$util.Tips({
|
||
|
title: `${data.tip}`
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
if (data.value) {
|
||
|
if (!/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$|^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/i.test(data.value)) {
|
||
|
return that.$util.Tips({
|
||
|
title: '请填写正确的身份证号码'
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
value.extend_info = that.userInfo.register_extend_info;
|
||
|
userEdit(value).then(res => {
|
||
|
uni.switchTab({
|
||
|
url:'/pages/user/index'
|
||
|
})
|
||
|
return that.$util.Tips({
|
||
|
title: res.msg,
|
||
|
icon: 'success'
|
||
|
});
|
||
|
}).catch(msg => {
|
||
|
return that.$util.Tips({
|
||
|
title: msg || '保存失败,您并没有修改'
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style scoped lang="scss">
|
||
|
.personal-data{
|
||
|
padding-bottom: 50rpx;
|
||
|
}
|
||
|
.dater{
|
||
|
width: 400rpx;
|
||
|
}
|
||
|
.grab{
|
||
|
color: #999 !important;
|
||
|
}
|
||
|
.asterisk{
|
||
|
color: red;
|
||
|
font-size: 20rpx;
|
||
|
margin-left: 6rpx;
|
||
|
}
|
||
|
.placeholder{
|
||
|
color: #ccc;
|
||
|
}
|
||
|
.cartcolor {
|
||
|
color: var(--view-theme);
|
||
|
border: 1px solid var(--view-theme);
|
||
|
}
|
||
|
|
||
|
.personal-data .wrapper {
|
||
|
margin: 10rpx 0;
|
||
|
background-color: #fff;
|
||
|
padding: 36rpx 30rpx 13rpx 30rpx;
|
||
|
}
|
||
|
|
||
|
.personal-data .wrapper .title {
|
||
|
margin-bottom: 30rpx;
|
||
|
font-size: 30rpx;
|
||
|
color: #282828;
|
||
|
}
|
||
|
|
||
|
|
||
|
.personal-data .list {
|
||
|
margin-top: 60rpx;
|
||
|
background-color: #1C1A1F;
|
||
|
}
|
||
|
|
||
|
.personal-data .list .item {
|
||
|
padding: 32rpx 20rpx 32rpx 24rpx;
|
||
|
font-size: 30rpx;
|
||
|
color: #FFFFFF;
|
||
|
.label{
|
||
|
display: flex;
|
||
|
align-items: center;
|
||
|
margin-left: 50rpx;
|
||
|
line-height: 30rpx;
|
||
|
}
|
||
|
radio-group{
|
||
|
display: flex;
|
||
|
}
|
||
|
/deep/ uni-radio-input{
|
||
|
margin-right: 12rpx;
|
||
|
.uni-radio-input.uni-radio-input-checked:before {
|
||
|
font-size: 26rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
.personal-data .list .item .phone {
|
||
|
width: 160rpx;
|
||
|
height: 56rpx;
|
||
|
font-size: 30rpx;
|
||
|
color: #fff;
|
||
|
line-height: 56rpx;
|
||
|
border-radius: 32rpx
|
||
|
}
|
||
|
|
||
|
.personal-data .list .item .pictrue {
|
||
|
width: 88rpx;
|
||
|
height: 88rpx;
|
||
|
}
|
||
|
|
||
|
.personal-data .list .item .pictrue image {
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
border-radius: 50%;
|
||
|
}
|
||
|
|
||
|
.personal-data .list .item .input {
|
||
|
max-width: 460rpx;
|
||
|
text-align: right;
|
||
|
color: #fff;
|
||
|
input{
|
||
|
text-align: right;
|
||
|
}
|
||
|
/deep/.uni-input-input{
|
||
|
font-size: 30rpx;
|
||
|
}
|
||
|
.picker{
|
||
|
width: 400rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.personal-data .list .item .input .id {
|
||
|
width: 414rpx;
|
||
|
}
|
||
|
|
||
|
.personal-data .list .item .input .iconfont {
|
||
|
font-size: 30rpx;
|
||
|
color: #999;
|
||
|
}
|
||
|
|
||
|
.personal-data .modifyBnt {
|
||
|
font-size: 30rpx;
|
||
|
color: #080313;
|
||
|
width: 710rpx;
|
||
|
height: 98rpx;
|
||
|
border-radius: 24rpx;
|
||
|
text-align: center;
|
||
|
line-height: 90rpx;
|
||
|
margin: 20rpx auto 0 auto;
|
||
|
background-color: #F8BF1F;
|
||
|
}
|
||
|
|
||
|
.personal-data .logOut {
|
||
|
font-size: 30rpx;
|
||
|
text-align: center;
|
||
|
width: 690rpx;
|
||
|
height: 90rpx;
|
||
|
border-radius: 45rpx;
|
||
|
margin: 30rpx auto 0 auto;
|
||
|
}
|
||
|
|
||
|
.avatar-box {
|
||
|
width: 96rpx;
|
||
|
height: 96rpx;
|
||
|
|
||
|
image {
|
||
|
width: 100%;
|
||
|
height: 100%;
|
||
|
border-radius: 50%;
|
||
|
border: 1px solid #eee;
|
||
|
}
|
||
|
}
|
||
|
</style>
|