NurseStationApp/pages/modify/modify.vue

336 lines
9.6 KiB
Vue
Raw Normal View History

2022-10-28 13:31:36 +08:00
<template>
<view class="app">
2022-11-03 17:26:15 +08:00
<view class="userinfo">
<view class="item" style="height: 200rpx; " @tap='uploadImag'>
<span style='height:200rpx;line-height: 200rpx;'>头像:</span>
2022-11-11 14:19:07 +08:00
<image class="picture" :src="img" mode=""></image>
2022-10-28 13:31:36 +08:00
<image class="pictureA" src="../../static/jiantou.png" mode=""></image>
</view>
2022-11-03 17:26:15 +08:00
<view class="item">
<span>姓名:</span>
2022-12-01 17:03:02 +08:00
<u-input :clearable='false' v-model="appPersonallist.patientName" placeholder="请输入" type="text"
maxlength='5' />
2022-11-03 17:26:15 +08:00
</view>
2022-11-14 12:31:02 +08:00
<!-- <view class="item">
2022-11-03 17:26:15 +08:00
<span>电话:</span>
2022-11-11 17:23:23 +08:00
<u-input :clearable='false' v-model="appPersonallist.phone" placeholder="请输入" maxlength='11' type="text" />
2022-11-14 12:31:02 +08:00
</view> -->
2022-11-03 17:26:15 +08:00
<view class="item">
<span>身份证号:</span>
2022-12-01 17:03:02 +08:00
<u-input :clearable='false' v-model="appPersonallist.cardNo" placeholder="请输入" type="text"
maxlength='18' />
2022-11-03 17:26:15 +08:00
</view>
2023-01-10 10:35:17 +08:00
<view class="item" @tap='showPicker'>
2022-11-03 17:26:15 +08:00
<span>所属区域:</span>
2022-11-14 11:24:55 +08:00
<view class="address">{{address}}</view>
2022-10-28 13:31:36 +08:00
</view>
2022-11-03 17:26:15 +08:00
<view class="item">
<span>详细地址:</span>
2022-11-11 17:23:23 +08:00
<u-input :clearable='false' v-model="appPersonallist.address" type="text" placeholder='小区、单元、门牌号' />
2022-11-03 17:26:15 +08:00
</view>
2022-12-01 17:03:02 +08:00
<view class="item" @tap='getAddress'>
2022-11-03 17:26:15 +08:00
<span>所在位置:</span>
2022-12-01 17:03:02 +08:00
<view class="address" style="overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">
2023-01-10 10:35:17 +08:00
{{chooseLocation}}
</view>
2022-11-03 17:26:15 +08:00
</view>
<view class="disease" style="border: none;" @tap="godisease">
<view style="display: block;line-height: 120rpx;">疾病类型:</view>
<image class="pictureA" src="../../static/jiantou.png" mode=""></image>
<view class="" style="padding-right: 10rpx" v-for="(item,index) in patientDiseaseInfoList">
{{item.diseaseName}}
</view>
2022-10-28 13:31:36 +08:00
</view>
</view>
2022-12-01 17:03:02 +08:00
<view class="radio-content">
<view class="radio-right" @tap="changeRadio">
<view class="radio" :class="radio == 2 ? 'radio-default':''">
<view :class="radio == 2 ? 'radio-active':''"></view>
</view>
</view>
<view class="agreement">我已阅读并同意<text @tap='maskshow=true'
style="color: #000000;border-bottom: 1rpx solid #000000;">用户协议</text>
</view>
</view>
2023-01-10 10:35:17 +08:00
<!-- <u-select v-model="areashow" mode="mutil-column-auto" label-name='areaName' value-name='areaCode'
:list="arealist" @confirm="areaconfirm"></u-select> -->
2022-11-03 17:26:15 +08:00
<view class="finish" @tap="informationinfo()">完成
</view>
<u-toast ref="uToast" />
2022-12-01 17:03:02 +08:00
<!-- //用户协议 -->
<u-mask :show="maskshow" class='mask' @click='maskshow=false'>
<view class="Agreement">
<view class="title">
用户协议与隐私政策
</view>
<scroll-view scroll-y="true" class="scroll-Y" style="">
<contenttext></contenttext>
</scroll-view>
<view class="cancel" @tap='maskshow=false'>
取消
</view>
<view class="determine" @tap='tapradio'>
确定并同意
</view>
</view>
</u-mask>
2023-01-10 10:35:17 +08:00
<view class="">
<m-city style='z-index: 10076;' :provinceData="list" headTitle="地区选择" ref="cityPicker"
@funcValue="getpickerParentValue" pickerSize="4">
</m-city>
</view>
2022-10-28 13:31:36 +08:00
</view>
</template>
<script>
2022-11-01 14:54:09 +08:00
import {
2022-11-03 17:26:15 +08:00
getRegionAndStreetInfo
} from '@/api/information/index.js'
import {
information
} from '@/api/information/index.js'
2022-12-01 17:03:02 +08:00
import contenttext from '../information/text.vue'
2022-11-01 14:54:09 +08:00
import baseurl from '@/api/baseurl.js'
2023-01-10 10:35:17 +08:00
import gkcity from "../m-city/m-city.vue";
import {
getSubordinateRegions,
} from '@/api/modifyAddress/modifyAddress.js';
import {
appPersonal,
} from '@/api/user/user.js';
2022-10-28 13:31:36 +08:00
export default {
2022-12-01 17:03:02 +08:00
components: {
2023-01-10 10:35:17 +08:00
contenttext,
"m-city": gkcity
2022-12-01 17:03:02 +08:00
},
2022-10-28 13:31:36 +08:00
data() {
return {
2022-12-01 17:03:02 +08:00
radio: 1,
timer: null,
2022-11-03 17:26:15 +08:00
baseurl: '',
address: '',
2023-01-10 10:35:17 +08:00
list: [{
id: "",
localName: "请选择",
children: [],
}, ],
maskshow: false, //用户协议
2022-11-03 17:26:15 +08:00
chooseLocation: '',
2022-11-09 16:38:05 +08:00
img: null,
2022-11-11 14:19:07 +08:00
image: null,
2022-11-01 14:54:09 +08:00
appPersonallist: {
2022-11-03 17:26:15 +08:00
patientName: "",
cardNo: "",
phone: "",
address: "",
areaCode: "",
homeLongitude: "",
homeLatitude: "",
nurseTypeIdList: [],
diseaseInfoList: [],
2022-11-01 14:54:09 +08:00
headPictureUrl: '',
2022-11-14 11:24:55 +08:00
locationName: '',
2022-11-01 14:54:09 +08:00
},
patientDiseaseInfoList: [], //获取个人信息
2023-01-10 10:35:17 +08:00
addresslength: null,
2022-10-28 13:31:36 +08:00
}
},
2022-11-01 14:54:09 +08:00
onLoad(options) {
2023-01-10 10:35:17 +08:00
var that = this
2022-11-03 17:26:15 +08:00
this.areaInfo();
this.baseurl = baseurl
2023-01-10 10:35:17 +08:00
const value = uni.getStorageSync('patientId');
if (value) {
appPersonal(value).then(Response => {
if (Response.code == 200) {
that.appPersonallist = Response.data
that.appPersonallist.homeLatitude = Number(that.appPersonallist.homeLatitude)
that.appPersonallist.homeLongitude = Number(that.appPersonallist.homeLongitude)
that.img = baseurl + that.appPersonallist.headPictureUrl
if (that.appPersonallist.streetName) {
that.address = that.appPersonallist.provinceName + '-' + that.appPersonallist
.cityName + '-' + that.appPersonallist.regionName + '-' + that.appPersonallist
.streetName
} else {
that.address = that.appPersonallist.provinceName + '-' + that.appPersonallist
.cityName + '-' + that.appPersonallist.regionName
}
that.patientDiseaseInfoList = that.appPersonallist.patientDiseaseInfoList
that.patientDiseaseInfoList.forEach(e => {
e.id = e.diseaseId
})
if (that.appPersonallist.locationName) {
that.chooseLocation = that.appPersonallist.locationName
}
} else if (Response.code == 9999) {} else {}
})
} else {}
2022-11-01 14:54:09 +08:00
},
2022-10-28 13:31:36 +08:00
methods: {
2023-01-10 10:35:17 +08:00
// 三级地址联动回调
getpickerParentValue(e) {
this.addresslength = e
if (e.length == 4) {
this.address = e[0].localName + '-' + e[1].localName + '-' + e[2].localName + '-' + e[3]
.localName
this.appPersonallist.areaCode = e[3].id
} else if (e.length == 3) {
this.address = e[0].localName + '-' + e[1].localName + '-' + e[2].localName
this.appPersonallist.areaCode = e[2].id
} else if (e.length == 2) {
this.address = e[0].localName + '-' + e[1].localName
this.appPersonallist.areaCode = e[1].id
} else if (e.length == 1) {
this.address = e[0].localName
this.appPersonallist.areaCode = e[0].id
}
},
// 显示三级地址联动
showPicker() {
this.$refs.cityPicker.show();
},
2022-11-03 17:26:15 +08:00
//上传图片+提交信息
informationinfo() {
//上传图片
var that = this
2022-12-01 17:03:02 +08:00
var that = this
if (that.radio == 1) {
that.$refs.uToast.show({
title: '请审核并同意用户协议',
type: 'error'
2022-11-09 16:38:05 +08:00
})
} else {
2022-12-01 17:03:02 +08:00
if (this.image) {
uni.uploadFile({
url: baseurl + '/nurseApplet/uploadFile/uploadHeadPictureUrl',
filePath: that.appPersonallist.headPictureUrl,
name: 'file',
formData: {
'patientId': that.appPersonallist.patientId
},
timeout: 5000,
success(res) {
that.appPersonallist.headPictureUrl = JSON.parse(res.data).imgUrl
that.appPersonallist.diseaseInfoList = that.patientDiseaseInfoList
information(that.appPersonallist).then(res => {
if (res.code == 200) {
that.$refs.uToast.show({
title: '修改信息成功',
type: 'success',
duration: '1500'
})
if (that.timer) {
clearTimeout(that.timer)
}
that.timer = setTimeout(e => {
uni.navigateBack({
delta: 1
})
}, 1500)
} else if (res.code == 500) {
that.$refs.uToast.show({
title: res.msg,
type: 'error',
url: ''
})
}
})
2022-11-11 17:23:23 +08:00
}
2022-12-01 17:03:02 +08:00
})
} else {
that.appPersonallist.diseaseInfoList = that.patientDiseaseInfoList
information(that.appPersonallist).then(res => {
if (res.code == 200) {
that.$refs.uToast.show({
title: '修改信息成功',
type: 'success',
duration: '1500'
2022-11-11 14:19:07 +08:00
})
2022-12-01 17:03:02 +08:00
if (that.timer) {
clearTimeout(that.timer)
}
that.timer = setTimeout(e => {
uni.navigateBack({
delta: 1
})
}, 1500)
} else if (res.code == 500) {
that.$refs.uToast.show({
title: res.msg,
type: 'error',
url: ''
})
}
})
}
2022-11-09 16:38:05 +08:00
}
2022-11-03 17:26:15 +08:00
},
//上传头像
uploadImag() {
var that = this;
uni.chooseImage({
count: 1,
sourceType: ['album'],
success(res) {
that.appPersonallist.headPictureUrl = res.tempFilePaths[0]
2022-11-09 16:38:05 +08:00
that.img = res.tempFilePaths[0]
2022-11-11 14:19:07 +08:00
that.image = res.tempFilePaths[0]
2022-11-03 17:26:15 +08:00
}
})
},
2022-12-01 17:03:02 +08:00
tapradio() {
this.radio = 2;
this.maskshow = false;
},
changeRadio() {
if (this.radio == 1) {
this.radio = 2;
} else {
this.radio = 1;
}
},
2022-11-03 17:26:15 +08:00
//获取所在位置
getAddress() {
var that = this;
uni.chooseLocation({
success: function(res) {
2022-11-14 11:24:55 +08:00
that.appPersonallist.locationName = res.address
2022-11-11 14:19:07 +08:00
that.chooseLocation = res.name
that.appPersonallist.homeLongitude = res.longitude;
that.appPersonallist.homeLatitude = res.latitude;
2022-11-03 17:26:15 +08:00
}
});
},
//区街道选择
areaconfirm(e) {
this.appPersonallist.areaCode = e[e.length - 1].value
this.address = e[0].label + '-' + e[1].label
},
//区街道
areaInfo() {
2023-01-10 10:35:17 +08:00
getSubordinateRegions().then(res => {
this.list = res.data;
2022-11-03 17:26:15 +08:00
})
},
//跳转疾病选择
2022-11-01 14:54:09 +08:00
godisease() {
uni.navigateTo({
url: `/pages/disease/disease?diseaseInfoList=${JSON.stringify(this.patientDiseaseInfoList)}`,
})
},
},
//带参返回
onShow() {
let that = this
uni.$on('disease', function(data) {
that.patientDiseaseInfoList = JSON.parse(data.disease)
})
2022-10-28 13:31:36 +08:00
}
}
</script>
<style lang="scss">
2022-11-03 17:26:15 +08:00
@import "./modify.scss"
2022-10-28 13:31:36 +08:00
</style>