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.

400 lines
8.9 KiB

<template>
<view class="visitor-form-page">
<view class="block">
<input-box class="inputcom-wrapper" v-model="name" holder="必填项" label="姓名"
4 months ago
@blurEvent="nameBlurEvent" required inputstyle="border-radius:0;width:100%;"></input-box>
<FormItem label="性别" type="picker" :display-value="genders[sex] || ''" placeholder="必选" required
@click="showGenderPicker" />
<FormItem label="出生年份" type="picker" :display-value="year ? `${year}` : ''" placeholder="必选"
required @click="showYearPicker" />
4 months ago
<FormItem label="手机号" type="input" v-model="phone" rule="phone" placeholder="方便预约后联系,非必填"/>
</view>
2 years ago
<view class="submit-wrapper btPadding" v-if="!vid">
<view :class="'btn btn3 PfScMedium submit' + (canSubmit ? ' primary' : ' noclick')"
:hover-class="(canSubmit ? 'hover' : '')" @click="submit" v-if="!vid && (doctorInfo.aid || !canSubmit)">
确认新增
</view>
<button :class="'btn btn3 PfScMedium submit' + (canSubmit ? ' primary' : ' noclick')" open-type="getPhoneNumber" @getphonenumber="getPhoneNumber" v-if="!doctorInfo.aid && canSubmit && !vid">确认新增</button>
<view :class="'btn btn3 PfScMedium submit' + (canSubmit ? ' primary' : ' noclick')"
:hover-class="(canSubmit ? 'hover' : '')" @click="submit" v-if="vid">
确认修改
</view>
</view>
<view class="fixedBot btPadding" v-if="vid">
<view class="submit">
<view class="btn cancel btn1" @click="reback">取消</view>
<view class="btn primary btn1" hover-class="hover" @click="submit">确认</view>
</view>
</view>
4 months ago
<CustomeDatePicker ref="customeDatePicker" @getDateString="handleYearChange" />
<SexPop ref="genderPopup" v-model="sex" @confirm="handleConfirm" />
<uni-popup ref="nameWrap" :safe-area="false" v-if="!vid">
<view class="popup-container">
<view class="header">
<view class="title PfScMedium">需要填写真实姓名来确保您账号的唯一性</view>
</view>
<view class="label">真实姓名</view>
<input type="text" class="realName" v-model="realName" placeholder-class="placeholder-style" placeholder="请填写">
<view class="confirm-button-wrapper btPadding">
<view class="confirm-button PfScMedium" @click="handleConfirmPhone">
完成
</view>
</view>
</view>
</uni-popup>
</view>
</template>
2 years ago
<script>
import InputBox from '@/components/inputBox.vue';
import FormItem from '@/components/FormItem.vue';
4 months ago
import CustomeDatePicker from '@/components/customeDatePicker.vue';
import SexPop from '@/components/SexPop.vue';
export default {
data() {
return {
canSubmit: false,
cssUrl: this.cssUrl,
year: '',
name: '',
sex:'',
nameRule: false,
idcard: '',
idcardExtRule: false,
phone: '',
phoneRule: false,
type: 1,
adding: false,
vid: false,
visitor_info: {},
genders: {
0:'男',
1:'女'
},
doctorInfo:false,
realName:'',
}
},
components: {
InputBox,
FormItem,
SexPop,
4 months ago
CustomeDatePicker
},
onLoad(option) {
if (option.type) this.type = option.type
if (option.vid) {
this.vid = option.vid
uni.setNavigationBarTitle({
title: '修改预约人'
});
} else {
uni.setNavigationBarTitle({
title: '新增预约人'
});
}
},
onShow() {
if (this.vid) {
this.getVisitorInfo()
}else{
this.getDoctorInfo()
}
},
methods: {
handleConfirmPhone(){
if(!this.realName.trim()){
uni.showModal({
title:'提示',
content: '姓名不可为空',
})
return
}
this.$http.req('/api/user/set_realname', { realname:this.realName}, 'POST').then(data => {
if (data == -1) return
this.$refs.nameWrap.close()
});
},
getPhoneNumber(e) {
if (e.detail.errMsg === 'getPhoneNumber:ok') {
this.$http.req('api/user/bind_phone', {phonecode:e.detail.code}, 'POST').then(data=>{
if(data == -1) return
this.getDoctorInfo()
});
} else {
}
},
async getDoctorInfo() {
this.$http.req('api/user/index_info', {}, 'GET').then(data=>{
if(data == -1) return
this.doctorInfo = data;
if(!data.realname && data.aid) {
this.$nextTick(() => {
this.$refs.nameWrap.open('bottom')
})
}
});
},
handleConfirm(sex){
this.sex = sex;
this.checkSubmit()
2 years ago
},
handleYearChange(year) {
4 months ago
this.year = year.split('/')[0];
this.checkSubmit()
},
showYearPicker() {
4 months ago
this.$refs.customeDatePicker.open('bottom')
2 years ago
},
showGenderPicker() {
this.$refs.genderPopup.show();
},
add() {
if (this.adding) return
this.adding = true
var param = new Object()
param.name = this.name
param.sex = this.sex
param.birth_year = this.year
param.phone = this.phone
// param.idcard = this.idcard
var that = this
var addtimer = setTimeout(function () {
that.adding = false
}, 5000);
6 months ago
var req = 'api/user/add_visitor'
var method = 'POST'
if (this.vid) {
param.id = this.vid
param.get_idcard = 1
req = 'api/user/update_visitor'
}
6 months ago
this.$http.req(req, param, method).then(data => {
if (data == -1) return
clearTimeout(addtimer)
this.adding = false
if (this.vid) {
uni.removeStorageSync('visitor_info_' + this.vid)
}
uni.navigateBack()
});
},
getVisitorInfo() {
var param = new Object()
param.vid = this.vid
this.$http.req('api/user/get_modify_visitor', param, 'POST').then(data => {
if (data == -1) return
this.name = data.name
this.year = data.birth_year
this.sex = data.sex
// this.idcard = data.idcard
this.phone = data.phone
this.nameRule = true
// this.idcardExtRule = true
this.phoneRule = false
2 years ago
this.checkSubmit()
});
},
nameBlurEvent(value, res) {
this.name = value
this.nameRule = res
this.checkSubmit()
},
checkSubmit() {
this.canSubmit = false
5 months ago
if (!this.name || (this.sex !=0 && this.sex!=1) || !this.year) return
this.canSubmit = true
},
reback() {
if (this.vid) {
uni.removeStorageSync('visitor_info_' + this.vid)
}
this.$func.toPage('/pages/visitors_new/visitors_new')
},
submit() {
this.checkSubmit()
if (!this.canSubmit) return
this.add()
}
}
}
</script>
<style lang="scss" scoped>
.getphone-box{
position: fixed;
left: 0;
top: 0;
width: 100vw;
height: 100vh;
z-index: 8999999999;
opacity: 0;
}
.popup-container {
position: relative;
max-height: calc(100vh - 200rpx);
overflow-y: scroll;
background: #ffffff;
border-radius: 40rpx 40rpx 0px 0px;
padding: 42rpx 48rpx 16rpx;
.header {
position: relative;
text-align: left;
.title {
font-size: 30rpx;
font-weight: 500;
line-height: 42rpx;
letter-spacing: normal;
color: #000000;
}
}
.label {
margin-top: 54rpx;
font-family: PingFang SC;
font-size: 34rpx;
font-weight: 500;
line-height: 47.6rpx;
letter-spacing: normal;
color: #000000;
}
.realName {
color: #000000;
font-size: 34rpx;
line-height: 40rpx;
height: 40rpx;
font-family: PingFang SC;
font-weight: normal;
letter-spacing: normal;
padding: 22rpx 0;
border-bottom: 2rpx solid rgba(0, 0, 0, 0.1);
margin-bottom: 160rpx;
margin-top: 22rpx;
&::placeholder {
opacity: 0.3;
}
}
.placeholder-style {
opacity: 0.3;
}
.confirm-button-wrapper {
display: flex;
align-items: center;
justify-content: center;
.confirm-button {
justify-content: center;
display: flex;
align-items: center;
font-weight: 600;
font-size: 34rpx;
color: #ffffff;
text-align: center;
width: 368rpx;
height: 80rpx;
border-radius: 8rpx;
background: #07C160;
}
}
.date {
margin: 12rpx 36rpx 42rpx;
text-align: center;
color: #000000;
font-size: 26rpx;
font-family: PingFang SC;
}
}
.visitor-form-page {
4 months ago
background: #F8F8F8;
height: 100vh;
overflow-y: scroll;
.block {
4 months ago
background: #FFFFFF;
box-shadow: 0rpx 2rpx 24rpx 0rpx rgba(0, 0, 0, 0.03);
border-radius: 8rpx;
width: 714rpx;
margin: 20rpx auto 0rpx;
overflow: hidden;
4 months ago
padding: 0 24rpx;
box-sizing: border-box;
&:nth-child(3) {
border: none !important;
}
.title {
font-size: 32rpx;
color: #000000;
width: 666rpx;
height: 50rpx;
line-height: 50rpx;
letter-spacing: 2rpx;
margin: 36rpx 0 36rpx 24rpx;
}
}
.submit-wrapper {
overflow: hidden;
position: fixed;
top: 88vh;
height: 92rpx;
left: 50%;
transform: translateX(-50%);
}
.submit {
margin: 0 auto;
4 months ago
font-size: 32rpx;
}
.fixedBot {
position: fixed;
bottom: 0;
left: 0;
width: 100%;
height: 124rpx;
background: #FFFFFF;
box-shadow: 0rpx -2rpx 6rpx 0rpx rgba(181, 181, 181, 0.13);
backdrop-filter: blur(20rpx);
display: flex;
.submit {
width: 100%;
display: flex;
justify-content: center;
align-items: center;
column-gap: 50rpx;
}
}
}
</style>