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.
		
		
		
		
		
			
		
			
				
					
					
						
							399 lines
						
					
					
						
							8.9 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							399 lines
						
					
					
						
							8.9 KiB
						
					
					
				| <template> | |
| 	<view class="visitor-form-page"> | |
| 		<view class="block"> | |
| 			<input-box class="inputcom-wrapper" v-model="name" holder="必填项" label="姓名" | |
| 				@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" /> | |
| 			<FormItem label="手机号" type="input" v-model="phone" rule="phone" placeholder="方便预约后联系,非必填"/> | |
| 		</view> | |
|  | |
| 		<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> | |
| 		<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> | |
| 
 | |
| <script> | |
| import InputBox from '@/components/inputBox.vue'; | |
| import FormItem from '@/components/FormItem.vue'; | |
| 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, | |
| 		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() | |
| 		}, | |
| 		handleYearChange(year) { | |
| 			this.year = year.split('/')[0]; | |
| 			this.checkSubmit() | |
| 		}, | |
| 		showYearPicker() { | |
| 			this.$refs.customeDatePicker.open('bottom') | |
| 		}, | |
| 		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); | |
| 
 | |
| 			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' | |
| 			} | |
| 
 | |
| 			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 | |
| 				this.checkSubmit() | |
| 			}); | |
| 
 | |
| 		}, | |
| 		nameBlurEvent(value, res) { | |
| 			this.name = value | |
| 			this.nameRule = res | |
| 			this.checkSubmit() | |
| 		}, | |
| 		checkSubmit() { | |
| 			this.canSubmit = false | |
| 			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 { | |
| 	background: #F8F8F8; | |
| 	height: 100vh; | |
| 	overflow-y: scroll; | |
| 
 | |
| 	.block { | |
| 		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; | |
| 		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; | |
| 		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>
 | |
| 
 |