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.
		
		
		
		
		
			
		
			
				
					
					
						
							398 lines
						
					
					
						
							10 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							398 lines
						
					
					
						
							10 KiB
						
					
					
				| <template> | |
| 	<view class="index-page btPadding" v-if="pageShow"> | |
| 		<view class="header-wrapper flex"> | |
| 			<view class="left"> | |
| 				<view class="flex top PfScMedium"> | |
| 					<view class="ft50 over2">{{doctorInfo.doctor_info.name}}</view> | |
| 					<view v-if="doctor_dept"> | |
| 						<view class="over2">{{doctor_dept}}</view> | |
| 					</view> | |
| 				</view> | |
| 				<view class="bt over2" v-if="doctorInfo.doctor_info.desc"> | |
| 					{{doctorInfo.doctor_info.desc}} | |
| 				</view> | |
| 			</view> | |
| 			<img class="right" :src="doctorInfo.doctor_info.avator" alt="" @click="enlargePicture(doctorInfo.doctor_info.avator)" v-if="doctorInfo.doctor_info.avator"> | |
| 		</view> | |
|  | |
| 		<view class="block desc-wrapper" v-if="doctorInfo.doctor_info.detail"> | |
| 			<view class="title-wrapper flex"> | |
| 				<view class="title"> | |
| 					医生简介 | |
| 				</view> | |
| 				<img :src="cssUrl+'right_bg.png'" alt=""> | |
| 			</view> | |
| 			 | |
| 			<view class="con over2 over4"> | |
| 				{{doctorInfo.doctor_info.detail}} | |
| 			</view> | |
| 		</view> | |
| 		 | |
| 		<view class="block hospital-wrapper" v-if="hospitals"> | |
| 			<view class="item" v-for="(item,key) in hospitals"> | |
| 				<view class="top flex"> | |
| 					<view class="left"> | |
| 						<view class="title flex"> | |
| 							<text class="over2">{{item.h_name}} {{item.depart_name}}</text> | |
| 							<img :src="cssUrl+'index_comback.svg'" v-if="item.h_pos" @click="toLocation(item)"> | |
| 						</view> | |
| 						<view class="date over2" v-if="item.visit_times"> | |
| 							出诊:{{item.visit_times}} | |
| 						</view> | |
| 					</view> | |
| 					<view class="right"> | |
| 						<view class="flex right-wrapper" style="justify-content:flex-end;" v-if="item.h_pos"> | |
| 							<view class="" @click="toLocation(item)"> | |
| 								<img :src="cssUrl+'index_nav.svg'" alt=""> | |
| 								<view>导航</view> | |
| 							</view> | |
| 						</view> | |
| 					</view> | |
| 				</view> | |
| 				 | |
| 				<view class="bot primary btn btn2" hover-class="hover" @click="toVisitors(item)"> | |
| 					预约看诊 | |
| 				</view> | |
| 			</view> | |
| 		</view> | |
| 		 | |
| 		<view class="block visit-wrapper" v-if="recentAppoint"> | |
| 			<view class="header flex"> | |
| 				<view class="title-wrapper flex booklist"> | |
| 					<view class="title"> | |
| 						最近预约 | |
| 					</view> | |
| 					<img :src="cssUrl+'right_bg.png'" alt=""> | |
| 				</view> | |
| 				 | |
| 				<view class="opt flex" @click="toPrebookList"> | |
| 					查看全部<img :src="cssUrl+'index_comback2.svg'" alt=""> | |
| 				</view> | |
| 			</view> | |
| 		</view> | |
| 		<pre-book-list class="preg-books" :dataList="recentAppoint"></pre-book-list> | |
| 
 | |
| 		<tabbar current="1"></tabbar> | |
| 	</view> | |
| </template> | |
| 
 | |
| <script> | |
| 	import tabbar from '@/components/tabbar.vue' | |
| 	import preBookList from '@/components/preBookList.vue' | |
| 
 | |
| 	export default { | |
| 		data() { | |
| 			return { | |
| 				cssUrl:this.cssUrl, | |
| 				code:'', | |
| 				pageShow:false, | |
| 				doctor_id:'', | |
| 				doctorInfo:false, | |
| 				doctor_dept:false, | |
| 				hospitals:false, | |
| 				recentAppoint:[], | |
| 				loginToken:false, | |
| 				state:'', | |
| 			} | |
| 		}, | |
| 		components:{ | |
| 			tabbar, | |
| 			preBookList, | |
| 		}, | |
| 		onLoad(option) { | |
| 			if(option.code && option.state) { | |
| 				this.code = option.code | |
| 				this.state = option.state | |
| 			} | |
| 			// if(option.token) { | |
| 			// 	this.loginToken = option.token | |
| 			// 	uni.setStorageSync('token', this.loginToken) | |
| 			// 	// var rebackPagePath = uni.getStorageSync('rebackPagePath') | |
| 			// 	// if(!rebackPagePath) | |
| 			// } | |
| 		}, | |
| 		async onShow() { | |
| 			this.doctor_id = getApp().globalData.doctorId | |
| 			if(!this.doctor_id) return | |
| 
 | |
| 			var title = '预约就诊' | |
| 			if(this.code) title = '登录' | |
| 			uni.setNavigationBarTitle({ | |
| 				title:title | |
| 			}) | |
| 
 | |
| 			var token = uni.getStorageSync('token') | |
| 			if(this.code && this.state && !token) { | |
| 				var rebackPagePath = uni.getStorageSync('rebackPagePath') | |
| 				this.login() | |
| 				return | |
| 			} | |
| 			await this.getDoctorInfo() | |
| 		}, | |
| 		methods: { | |
| 			toLocation(hospital){ | |
| 				var that = this | |
| 				uni.showActionSheet({ | |
| 					itemList: ['腾讯地图', '百度地图', '高德地图'], | |
| 					success: function (res) { | |
| 						var  lngLat = hospital.h_pos.toString().split(',') | |
| 						var lng = lngLat[0].toString() | |
| 						, lat = lngLat[1].toString() | |
| 
 | |
| 						var baiduLngLat = that.qqMapTransBMap(lng, lat) | |
| 						var mapList = [ | |
| 							'http://apis.map.qq.com/uri/v1/marker?marker=coord:'+ lat+','+lng+';addr:'+hospital.h_name, | |
| 							'http://api.map.baidu.com/marker?location='+baiduLngLat.lat+','+baiduLngLat.lng+'&title='+hospital.h_name+'&content=即将前往目的地&output=html&src=webapp.baidu.openAPIdemo', | |
| 							'https://m.amap.com/share/index/lnglat='+hospital.h_pos+'&name='+hospital.h_name+'&src=uriapi&innersrc=uriapi', | |
| 						] | |
| 						// return; | |
| 						location.href = mapList[res.tapIndex] | |
| 					}, | |
| 					fail: function (res) { | |
| 					} | |
| 				}); | |
| 			}, | |
| 			setLoginUserInfo(info) { | |
| 				var uinfo = new Object(); | |
| 				uni.setStorageSync("uinfo", JSON.stringify(info)); | |
| 			}, | |
| 			login() { | |
| 				this.$http.req('common/get_user_info', {code:this.code,state:this.state}, 'POST').then(data=>{ | |
| 					if(data == -1) return | |
| 					uni.setStorageSync('token', data.jwttoken) | |
| 					this.setLoginUserInfo(data) | |
| 					this.getDoctorInfo() | |
| 					// var rebackPagePath = uni.getStorageSync('rebackPagePath') | |
| 					// if(rebackPagePath){ | |
| 					// 	uni.navigateTo({ | |
| 					// 		url:rebackPagePath | |
| 					// 	}) | |
| 					// } | |
| 				}); | |
| 				 | |
| 			}, | |
| 			async getDoctorInfo() { | |
| 				await this.$http.req('user/get_user_info', {}, 'GET').then(data=>{ | |
| 					if(data == -1) return | |
| 					this.pageShow = true | |
| 					this.doctorInfo = data | |
| 					if(this.doctorInfo.doctor_info && this.doctorInfo.doctor_info.depart_name.length>0){ | |
| 						this.doctor_dept = this.doctorInfo.doctor_info.depart_name | |
| 					} | |
| 
 | |
| 					if(this.doctorInfo.hospital_list && this.doctorInfo.hospital_list.length>0){ | |
| 						this.hospitals = this.doctorInfo.hospital_list | |
| 					} | |
| 					var docname = this.doctorInfo.doctor_info.name | |
| 					if(this.doctorInfo.appoint_list && this.doctorInfo.appoint_list.length>0){ | |
| 						this.recentAppoint = this.doctorInfo.appoint_list | |
| 					} | |
| 				}); | |
| 			}, | |
| 			enlargePicture(imgUrl) { | |
| 				  var list = new Array(); | |
| 				  list[0] = imgUrl; | |
| 				  uni.previewImage({ | |
| 					  loop: true, | |
| 					  urls: list | |
| 				  }); | |
| 			}, | |
| 			toVisitors(hospital){ | |
| 				uni.setStorageSync('depart_id', hospital.depart_id) | |
| 				uni.setStorageSync('depart', JSON.stringify(hospital)) | |
| 				uni.setStorageSync('doctor_info', JSON.stringify(this.doctorInfo)) | |
| 				uni.navigateTo({ | |
| 					url:"/pages/visitors/visitors?type=1" | |
| 				}) | |
| 			}, | |
| 			toPrebookList(){ | |
| 				uni.navigateTo({ | |
| 					url:"/pages/prebook_list/prebook_list" | |
| 				}) | |
| 			}, | |
| 			toPrebookDetail(){ | |
| 				uni.navigateTo({ | |
| 					url:"/pages/book_detail/book_detail" | |
| 				}) | |
| 			}, | |
| 			qqMapTransBMap(lng, lat) { | |
| 			      let x_pi = 3.14159265358979324 * 3000.0 / 180.0; | |
| 			      let x = lng; | |
| 			      let y = lat; | |
| 			      let z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi); | |
| 			      let theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi); | |
| 			      let lngs = z * Math.cos(theta) + 0.0065; | |
| 			      let lats = z * Math.sin(theta) + 0.006; | |
| 			      return { | |
| 			          lng: lngs, | |
| 			          lat: lats  | |
| 			      }  | |
| 			} | |
| 		} | |
| 	} | |
| </script> | |
| 
 | |
| <style lang="scss" scoped> | |
| 	.index-page{ | |
| 		.header-wrapper{ | |
| 			min-height: 208rpx; | |
| 			padding: 24rpx 40rpx 24rpx; | |
| 			box-sizing: border-box; | |
| 			.left{ | |
| 				width: 510rpx; | |
| 				.top{ | |
| 					overflow: hidden; | |
| 					margin-top: 31rpx; | |
| 					& view:first-of-type{ | |
| 						color: #000000; | |
| 						letter-spacing: 1rpx; | |
| 						margin-right: 27rpx; | |
| 						max-width: 250rpx; | |
| 					} | |
| 					& view:last-of-type{ | |
| 						view{ | |
| 							width: auto; | |
| 							padding: 0 15rpx; | |
| 							min-width: 125rpx; | |
| 							margin-top: 14rpx; | |
| 							line-height: 42rpx; | |
| 							text-align: center; | |
| 							font-size: 28rpx; | |
| 							background: linear-gradient( 288deg, #FFEED2 0%, #FED9A6 100%); | |
| 							border-radius: 8rpx; | |
| 							color: #7D501F; | |
| 						} | |
| 					} | |
| 				} | |
| 				.bt{ | |
| 					width: 480rpx; | |
| 					line-height: 40rpx; | |
| 					font-size: 28rpx; | |
| 					color: #38503F; | |
| 					margin-top: 21rpx; | |
| 				} | |
| 			} | |
| 			.right{ | |
| 				flex-grow: 1; | |
| 				display: block; | |
| 				border-radius: 100%; | |
| 				height: 160rpx; | |
| 				width: 160rpx; | |
| 			} | |
| 		} | |
| 		.block{ | |
| 			background: #FFFFFF; | |
| 			border-radius: 8rpx; | |
| 			padding: 36rpx 24rpx; | |
| 			box-sizing: border-box; | |
| 			margin: 0 auto; | |
| 			width: 714rpx; | |
| 			margin-bottom: 20rpx; | |
| 		} | |
| 		.desc-wrapper{ | |
| 			box-shadow: 0rpx 2rpx 24rpx 0rpx rgba(0,0,0,0.03); | |
| 			color: #949699; | |
| 			font-size: 30rpx; | |
| 			line-height: 50rpx; | |
| 			.con{ | |
| 				height: auto; | |
| 			} | |
| 		} | |
| 		.title-wrapper{ | |
| 			.title{ | |
| 				width: 117rpx; | |
| 				height: 42rpx; | |
| 				padding-left: 13rpx; | |
| 				margin-bottom: 36rpx; | |
| 				font-size: 26rpx; | |
| 				color: #FFFFFF; | |
| 				line-height: 42rpx; | |
| 				text-align: center; | |
| 				border-radius: 8rpx 0rpx 0rpx 8rpx; | |
| 				background: linear-gradient( 98deg, #53C184 0%, #5CD378 100%); | |
| 			} | |
| 			&.booklist .title{ | |
| 				margin-bottom: 0rpx; | |
| 			} | |
| 			img{ | |
| 				width: 48rpx; | |
| 				height: 42rpx; | |
| 			} | |
| 		} | |
| 		.hospital-wrapper{ | |
| 			.item{ | |
| 				&:last-child{ | |
| 					margin-bottom: 0rpx; | |
| 				} | |
| 				min-height: 207rpx; | |
| 				width: 100%; | |
| 				margin-bottom: 36rpx; | |
| 				.top{ | |
| 					min-height: 102rpx; | |
| 					.left{ | |
| 						flex-grow: 1; | |
| 						.title{ | |
| 							align-items: center; | |
| 							img{ | |
| 								width: 20rpx; | |
| 								height: 32rpx; | |
| 							} | |
| 						} | |
| 						.date{ | |
| 							line-height: 40rpx; | |
| 							font-size: 28rpx; | |
| 							color: #666666; | |
| 							margin-top: 14rpx; | |
| 						} | |
| 					} | |
| 					.right{ | |
| 						width: 200rpx; | |
| 						height: 100%; | |
| 						img{ | |
| 							width: 52rpx; | |
| 							height: 52rpx; | |
| 							background: #F4F4F4; | |
| 							border-radius: 6rpx; | |
| 							margin-right: 7rpx; | |
| 						} | |
| 						text{ | |
| 							width: 60rpx; | |
| 							height: 54rpx; | |
| 							display: block; | |
| 							font-size: 26rpx; | |
| 							color: #666666; | |
| 							line-height: 37rpx; | |
| 							text-align: center; | |
| 							margin-top: 5rpx; | |
| 						} | |
| 					} | |
| 				} | |
| 				.bot{ | |
| 					margin-top: 16rpx; | |
| 				} | |
| 			} | |
| 		} | |
| 		.visit-wrapper{ | |
| 			margin-bottom: 0; | |
| 			.header{ | |
| 				justify-content: space-between; | |
| 				.opt{ | |
| 					align-items: center; | |
| 					overflow: hidden; | |
| 					font-size: 26rpx; | |
| 					color: #949699; | |
| 					img{ | |
| 						width: 20rpx; | |
| 						height: 32rpx; | |
| 						margin-top: 8rpx; | |
| 						margin-left: 8rpx; | |
| 					} | |
| 				} | |
| 			} | |
| 		} | |
| 		.preg-books{ | |
| 			width: 714rpx; | |
| 			margin: 0 auto; | |
| 		} | |
| 	} | |
| </style>
 | |
| 
 |