411 lines
8.5 KiB
Vue
411 lines
8.5 KiB
Vue
<template>
|
||
<view class="container">
|
||
<view class="top_">
|
||
<view style="width: 100px; height: 100px; border-radius: 50%; overflow: hidden;">
|
||
<u-upload :fileList="fileList1" @afterRead="afterRead" @delete="deletePic" name="1" multiple
|
||
:maxCount="1" width="100" height="100">
|
||
<view class="user_t">
|
||
<image :src="baseUrl + userInfo.avatar" mode="" v-if="userInfo.avatar"></image>
|
||
<image src="http://47.94.122.58:83/userPhoto.png" mode="" v-else></image>
|
||
</view>
|
||
</u-upload>
|
||
</view>
|
||
</view>
|
||
<view class="box_">
|
||
<view class="d_lang">
|
||
<view class="left_">Name</view>
|
||
<view class="right_" @click="inputShow('name')">
|
||
<text style="margin-right: 5px;">{{userInfo.userName || 'name'}}</text>
|
||
<u-icon name="arrow-right" size="16"></u-icon>
|
||
</view>
|
||
</view>
|
||
<view class="d_lang">
|
||
<view class="left_">phonenumber</view>
|
||
<view class="right_" @click="inputShow('phonenumber')">
|
||
<text style="margin-right: 5px;">{{userInfo.phonenumber || 'phonenumber'}}</text>
|
||
<u-icon name="arrow-right" size="16"></u-icon>
|
||
</view>
|
||
</view>
|
||
<view class="d_lang">
|
||
<view class="left_">Gender</view>
|
||
<view class="right_" @click="sexShow()">
|
||
<text style="margin-right: 5px;" v-if="userInfo.sex == 1">women</text>
|
||
<text style="margin-right: 5px;" v-else>men</text>
|
||
<u-icon name="arrow-right" size="16"></u-icon>
|
||
</view>
|
||
</view>
|
||
<view class="d_lang">
|
||
<view class="left_">Birthday </view>
|
||
<view class="right_" @click="dateShow()">
|
||
<text style="margin-right: 5px;">{{value1 | formatDate}}</text>
|
||
<u-icon name="arrow-right" size="16"></u-icon>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<!-- 日期 -->
|
||
<u-datetime-picker :show="timeShow" v-model="value1" mode="date" @confirm="confirmTime"></u-datetime-picker>
|
||
<!-- 选择器 -->
|
||
<u-picker :show="pickerShow" :columns="columns" @confirm="confirm" @cancel="cancel"></u-picker>
|
||
<!-- 输入框 -->
|
||
<u-popup :show="show" mode="center" :round="10" @close="close" @open="open">
|
||
<view class="p_box">
|
||
<view style="margin: 30px auto;">
|
||
<u--input placeholder="Enter " border="surround" v-model="value" @change="change"></u--input>
|
||
</view>
|
||
|
||
<view class="P_">
|
||
<view class="an_niu" @click="save()">confirm</view>
|
||
<view class="an_niux" @click="lost()">cancel</view>
|
||
</view>
|
||
|
||
</view>
|
||
</u-popup>
|
||
|
||
</view>
|
||
</template>
|
||
|
||
<script>
|
||
import request from '../../utils/request'
|
||
import config from '@/config'
|
||
export default {
|
||
data() {
|
||
return {
|
||
baseUrl: config.imagesUrl,
|
||
userInfo: {},
|
||
type: "name",
|
||
columns: [
|
||
['men', 'women']
|
||
],
|
||
fileList1: [],
|
||
timeShow: false,
|
||
pickerShow: false,
|
||
show: false,
|
||
status: 'loading',
|
||
value: '',
|
||
value1: Number(new Date()),
|
||
}
|
||
},
|
||
onLoad() {
|
||
this.userInfo = uni.getStorageSync('user_info')
|
||
console.log(this.userInfo);
|
||
},
|
||
|
||
methods: {
|
||
save() {
|
||
if (this.type == "name") {
|
||
this.userInfo.userName = this.value
|
||
} else {
|
||
this.userInfo.phonenumber = this.value
|
||
}
|
||
this.show = false
|
||
|
||
this.systemUser()
|
||
},
|
||
lost() {
|
||
this.value = ''
|
||
this.show = false
|
||
},
|
||
async systemUser() {
|
||
uni.showLoading({
|
||
title: 'Loading...'
|
||
});
|
||
let res = await request({
|
||
url: 'system/user/editByUser',
|
||
method: 'put',
|
||
data: this.userInfo
|
||
})
|
||
if(res.code == 200){
|
||
uni.hideLoading();
|
||
this.getBaseInfo()
|
||
}
|
||
|
||
|
||
},
|
||
async getBaseInfo() {
|
||
let res = await request({
|
||
url: 'system/user/getUserBaseInfo',
|
||
method: 'get',
|
||
})
|
||
if (res.code == 200) {
|
||
uni.setStorageSync('user_info', res.data);
|
||
}
|
||
|
||
},
|
||
confirmTime(e) {
|
||
console.log(e);
|
||
this.value1 = e.value
|
||
this.timeShow = false
|
||
this.systemUser()
|
||
},
|
||
cancel() {
|
||
this.pickerShow = false
|
||
},
|
||
confirm(e) {
|
||
console.log(e);
|
||
if (e.value[0] == 'men') {
|
||
this.userInfo.sex = 0
|
||
} else {
|
||
this.userInfo.sex = 1
|
||
}
|
||
this.systemUser()
|
||
this.pickerShow = false
|
||
},
|
||
dateShow() {
|
||
this.timeShow = true
|
||
},
|
||
sexShow() {
|
||
this.pickerShow = true
|
||
},
|
||
inputShow(name) {
|
||
this.value = ''
|
||
this.show = true
|
||
this.type = name
|
||
},
|
||
open() {
|
||
// console.log('open');
|
||
},
|
||
close() {
|
||
this.show = false
|
||
// console.log('close');
|
||
},
|
||
change(e) {
|
||
console.log('change', e);
|
||
},
|
||
goback() {
|
||
uni.navigateBack()
|
||
},
|
||
// 删除图片
|
||
deletePic(event) {
|
||
this[`fileList${event.name}`].splice(event.index, 1)
|
||
},
|
||
// 新增图片
|
||
async afterRead(event) {
|
||
// 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式
|
||
let lists = [].concat(event.file)
|
||
let fileListLen = this[`fileList${event.name}`].length
|
||
lists.map((item) => {
|
||
this[`fileList${event.name}`].push({
|
||
...item,
|
||
status: 'uploading',
|
||
message: '上传中'
|
||
})
|
||
})
|
||
for (let i = 0; i < lists.length; i++) {
|
||
const result = await this.uploadFilePromise(lists[i].url)
|
||
let item = this[`fileList${event.name}`][fileListLen]
|
||
this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {
|
||
status: 'success',
|
||
message: '',
|
||
url: result
|
||
}))
|
||
fileListLen++
|
||
}
|
||
},
|
||
uploadFilePromise(url) {
|
||
return new Promise((resolve, reject) => {
|
||
let a = uni.uploadFile({
|
||
url: config.baseUrl + 'common/upload',
|
||
filePath: url,
|
||
name: 'file',
|
||
formData: {
|
||
user: 'test'
|
||
},
|
||
success: (res) => {
|
||
if (!res.data) {
|
||
uni.showToast({
|
||
title: "Upload failed",
|
||
icon: "none"
|
||
})
|
||
return;
|
||
}
|
||
let data = JSON.parse(res.data)
|
||
setTimeout(() => {
|
||
resolve(data.fileName)
|
||
this.userInfo.avatar = data.fileName
|
||
this.systemUser()
|
||
}, 100)
|
||
}
|
||
});
|
||
})
|
||
},
|
||
},
|
||
filters: {
|
||
//过滤器 用于格式化时间
|
||
formatDate(value) {
|
||
let date = new Date(value);
|
||
//时间戳为10位需*1000,时间戳为13位的话不需乘1000
|
||
let y = date.getFullYear();
|
||
let MM = date.getMonth() + 1;
|
||
MM = MM < 10 ? ('0' + MM) : MM; //月补0
|
||
let d = date.getDate();
|
||
d = d < 10 ? ('0' + d) : d; //天补0
|
||
let h = date.getHours();
|
||
h = h < 10 ? ('0' + h) : h; //小时补0
|
||
let m = date.getMinutes();
|
||
m = m < 10 ? ('0' + m) : m; //分钟补0
|
||
let s = date.getSeconds();
|
||
s = s < 10 ? ('0' + s) : s; //秒补0
|
||
return y + '-' + MM + '-' + d; //年月日
|
||
|
||
|
||
}
|
||
},
|
||
|
||
}
|
||
</script>
|
||
|
||
<style scoped lang="scss">
|
||
.container {
|
||
height: 100vh;
|
||
background: #f8f8f8;
|
||
}
|
||
|
||
.top_ {
|
||
width: 100%;
|
||
height: 170px;
|
||
box-sizing: border-box;
|
||
padding-top: 20px;
|
||
display: flex;
|
||
justify-content: center;
|
||
|
||
background-color: #106f3d;
|
||
|
||
}
|
||
|
||
.ds_ {
|
||
width: 85%;
|
||
margin: 15px auto;
|
||
display: flex;
|
||
align-items: center;
|
||
color: #fff;
|
||
|
||
}
|
||
|
||
.user_t {
|
||
width: 100px;
|
||
height: 100px;
|
||
background: #F2F2F2;
|
||
|
||
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
|
||
image {
|
||
width: 100%;
|
||
height: 100%;
|
||
}
|
||
}
|
||
|
||
.user_title {
|
||
font-weight: bold;
|
||
font-size: 20px;
|
||
color: #FFFFFF;
|
||
margin-bottom: 10px;
|
||
}
|
||
|
||
.user_emil {
|
||
font-weight: 500;
|
||
font-size: 16px;
|
||
}
|
||
|
||
.box_ {
|
||
width: 90%;
|
||
background: #FFFFFF;
|
||
box-sizing: border-box;
|
||
|
||
box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.05);
|
||
|
||
margin: 15px auto;
|
||
}
|
||
|
||
.d_lang {
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
border-bottom: 1px solid #F2F2F2;
|
||
box-sizing: border-box;
|
||
padding: 10px 15px;
|
||
}
|
||
|
||
.f_ {
|
||
width: 25%;
|
||
font-weight: 500;
|
||
font-size: 12px;
|
||
color: #333333;
|
||
text-align: center;
|
||
}
|
||
|
||
.icon_ {
|
||
width: 22px;
|
||
height: 22px;
|
||
margin: 0 auto;
|
||
margin-bottom: 5px;
|
||
|
||
image {
|
||
width: 100%;
|
||
height: 100%;
|
||
|
||
}
|
||
}
|
||
|
||
.left_ {
|
||
font-weight: 500;
|
||
font-size: 16px;
|
||
color: #000000;
|
||
}
|
||
|
||
.right_ {
|
||
display: flex;
|
||
align-items: center;
|
||
font-weight: 500;
|
||
font-size: 16px;
|
||
color: #333333;
|
||
}
|
||
|
||
.p_box {
|
||
width: 300px;
|
||
|
||
border-radius: 10px;
|
||
background: #FFFFFF;
|
||
box-sizing: border-box;
|
||
padding: 15px;
|
||
text-align: center;
|
||
|
||
}
|
||
|
||
.an_niu {
|
||
width: 45%;
|
||
border-radius: 6px;
|
||
background: #106f3d;
|
||
color: #fff;
|
||
box-sizing: border-box;
|
||
padding: 10px;
|
||
display: flex;
|
||
align-items: center;
|
||
border: 1px solid #106f3d;
|
||
justify-content: center;
|
||
}
|
||
|
||
.an_niux {
|
||
width: 45%;
|
||
border-radius: 6px;
|
||
|
||
color: #106f3d;
|
||
box-sizing: border-box;
|
||
padding: 10px;
|
||
display: flex;
|
||
align-items: center;
|
||
border: 1px solid #106f3d;
|
||
justify-content: center;
|
||
}
|
||
|
||
.P_ {
|
||
width: 100%;
|
||
display: flex;
|
||
align-items: center;
|
||
|
||
justify-content: space-between;
|
||
margin-top: 15px;
|
||
}
|
||
</style> |