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.

481 lines
13 KiB

2 years ago
<template>
2 years ago
<view class="index-page btPadding" v-if="pageShow">
2 years ago
<view class="header-wrapper flex">
<view class="left">
<view class="flex top PfScMedium">
<view class="ft50 over2">{{doctorInfo.doctor_info.doctor_name}}</view>
<view v-if="doctor_dept">
<view class="over2">{{doctor_dept}}</view>
2 years ago
</view>
2 years ago
</view>
<view class="bt over2" v-if="doctorInfo.doctor_info.doctor_desc">
{{doctorInfo.doctor_info.doctor_desc}}
2 years ago
</view>
</view>
<img class="right" :src="doctorInfo.doctor_info.avator" alt="" @click="enlargePicture(doctorInfo.doctor_info.avator)" v-if="doctorInfo.doctor_info.avator">
2 years ago
</view>
<view class="block desc-wrapper" v-if="doctorInfo.doctor_info.doctor_detail">
2 years ago
<view class="title-wrapper flex">
<view class="title">
医生简介
</view>
<img :src="cssUrl+'right_bg.png'" alt="">
</view>
2 years ago
<view class="con">
<!-- <view class="con over2 over4"> -->
{{doctorInfo.doctor_info.doctor_detail}}
2 years ago
</view>
</view>
<view class="block hospital-wrapper" v-if="hospitals">
<view class="item" v-for="(item,key) in hospitals">
2 years ago
<view class="top flex">
<view class="left">
<view class="title flex">
<text class="over2 PfScMedium">{{item.hospital_name}} {{item.depart_name}}
<!-- {{item.depart_name}} -->
<!-- 科室 -->
</text>
<img :src="cssUrl+'index_comback.svg'" v-if="item.hospital_pos" @click="toLocation(item)">
2 years ago
</view>
11 months ago
<view class="date over2 over4">
出诊{{ item.workdate_desc }}
2 years ago
</view>
</view>
<view class="right">
<view class="flex right-wrapper" style="justify-content:flex-end;" v-if="item.hospital_pos">
<view class="" @click="toLocation(item)">
2 years ago
<img :src="cssUrl+'index_nav.svg'" alt="">
<view>导航</view>
</view>
</view>
2 years ago
</view>
</view>
2 years ago
<view class="bot primary btn btn2" hover-class="hover" @click="toVisitors(item)">
2 years ago
预约看诊
</view>
</view>
2 years ago
</view>
<view class="block visit-wrapper" v-if="recentAppoint">
2 years ago
<view class="header flex">
<view class="title-wrapper flex booklist">
2 years ago
<view class="title">
2 years ago
最近预约
2 years ago
</view>
<img :src="cssUrl+'right_bg.png'" alt="">
</view>
2 years ago
<view class="opt flex" @click="toPrebookList">
2 years ago
查看全部<img :src="cssUrl+'index_comback2.svg'" alt="">
</view>
</view>
2 years ago
</view>
<pre-book-list class="preg-books" :dataList="recentAppoint" :topnopadding="true"></pre-book-list>
<tabbar current="1" leftButtonText="预约"></tabbar>
2 years ago
</view>
</template>
<script>
2 years ago
import tabbar from '@/components/tabbar.vue'
import preBookList from '@/components/preBookList.vue'
2 years ago
export default {
data() {
return {
2 years ago
cssUrl:this.cssUrl,
code:'',
pageShow:false,
doctor_id:'',
doctorInfo:false,
doctor_dept:false,
hospitals:false,
recentAppoint:[],
12 months ago
loginToken:false,
state:'',
workdate:[],
workPlan:{
1:'上午',
2:'下午',
3:'全天',
},
visitlist:[
{
"id": "16",
"depart_id": "18",
"name": "暴富喽",
"date": "2024-09-28",
"week_desc": "六",
"time_interval": "08:00-08:30",
"status_desc": "就诊完成",
"hospital_name": "北京LY暴富",
"depart_name": "针灸科"
},
{
"id": "15",
"depart_id": "18",
"name": "刘老铁",
"date": "2024-09-28",
"week_desc": "六",
"time_interval": "08:30-09:00",
"status_desc": "候诊",
"hospital_name": "北京LY暴富",
"depart_name": "针灸科"
},
{
"id": "14",
"depart_id": "18",
"name": "首富哈",
"date": "2024-09-28",
"week_desc": "六",
"time_interval": "08:00-08:30",
"status_desc": "过号",
"hospital_name": "北京LY暴富",
"depart_name": "针灸科"
},
]
2 years ago
}
},
components:{
2 years ago
tabbar,
preBookList,
},
2 years ago
onLoad(option) {
12 months ago
if(option.code && option.state) {
this.code = option.code
this.state = option.state
}
2 years ago
},
1 year ago
async onShow() {
2 years ago
this.doctor_id = getApp().globalData.doctorId
if(!this.doctor_id) return
2 years ago
1 year ago
var title = '预约就诊'
2 years ago
if(this.code) title = '登录'
uni.setNavigationBarTitle({
title:title
})
var token = this.$token.getToken()
12 months ago
if(this.code && this.state && !token) {
var rebackPagePath = uni.getStorageSync('rebackPagePath')
this.login()
return
}
1 year ago
await this.getDoctorInfo()
2 years ago
},
// onReady() {
// // console.log(this.doctorInfo,'this.doctorInfo');
// uni.setNavigationBarTitle({
// title: + '医生预约就诊'
// })
// },
// "navigationBarTitleText": "预约就诊"
2 years ago
methods: {
toLocation(hospital){
var that = this
uni.showActionSheet({
itemList: ['腾讯地图', '百度地图', '高德地图'],
success: function (res) {
var lngLat = hospital.hospital_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.hospital_name,
'http://api.map.baidu.com/marker?location='+baiduLngLat.lat+','+baiduLngLat.lng+'&title='+hospital.hospital_name+'&content=即将前往目的地&output=html&src=webapp.baidu.openAPIdemo',
'https://m.amap.com/share/index/lnglat='+hospital.hospital_pos+'&name='+hospital.hospital_name+'&src=uriapi&innersrc=uriapi',
]
// return;
location.href = mapList[res.tapIndex]
},
fail: function (res) {
}
});
},
12 months ago
setLoginUserInfo(info) {
var uinfo = new Object();
this.$setuinfo.setUinfo(JSON.stringify(info))
12 months ago
},
2 years ago
login() {
12 months ago
this.$http.req('common/get_user_info', {code:this.code,state:this.state}, 'POST').then(data=>{
if(data == -1) return
this.$settoken.setToken(data.jwttoken)
12 months ago
this.setLoginUserInfo(data)
this.getDoctorInfo()
// var rebackPagePath = uni.getStorageSync('rebackPagePath')
// if(rebackPagePath){
// uni.navigateTo({
// url:rebackPagePath
// })
// }
});
2 years ago
},
1 year ago
async getDoctorInfo() {
await this.$http.req('user/index_info', {}, 'GET').then(data=>{
2 years ago
if(data == -1) return
this.pageShow = true;
let visitFlag = true;
this.doctorInfo = data;
console.log(data)
if(this.doctorInfo.doctor_info && this.doctorInfo.doctor_info.depart_name && this.doctorInfo.doctor_info.depart_name.length>0){
this.doctor_dept = this.doctorInfo.doctor_info.depart_name;
}
if(this.doctorInfo.hospital_departs && this.doctorInfo.hospital_departs.length>0){
this.hospitals = this.doctorInfo.hospital_departs;
this.doctor_dept = this.doctorInfo.hospital_departs[0]['depart_name'];
this.doctorInfo.doctor_info.depart_name = this.doctor_dept;
}else{
visitFlag = false;
}
if(this.doctorInfo.visit_list && this.doctorInfo.visit_list.length>0){
this.recentAppoint = this.doctorInfo.visit_list;
}
if(this.doctorInfo.workdate && Object.keys(this.doctorInfo.workdate).length > 0){
this.workdate = this.doctorInfo.workdate;
}else{
visitFlag = false;
}
// if(visitFlag){//暂时注释
// let workDatKeyArr = Object.keys(this.workdate);
// let workDateValArr = Object.values(this.workdate);
// let timeList = [];
this.hospital_departs = this.doctorInfo.hospital_departs.map((item,index)=>{
11 months ago
item.workdate_desc = this.doctorInfo.workdate_desc[item.depart_id]
// let indexofNum = workDatKeyArr.indexOf(item.depart_id);
// if(indexofNum > -1){
// let departCurItem = workDateValArr[indexofNum];
// let flag = Array.isArray(departCurItem)
// if(flag){
// item.visit_time = data.workdate_desc[item.depart_id]
// item.plan =0
// }else{
// for(let key in departCurItem){
// let dateItem = departCurItem[key];
// if(Number(dateItem.plan) === 0)continue
// timeList.push(dateItem.week_desc+this.workPlan[dateItem.plan])
// item.visit_time = timeList.join('、')
// }
// }
// }
return item
})
2 years ago
});
},
2 years ago
enlargePicture(imgUrl) {
var list = new Array();
list[0] = imgUrl;
uni.previewImage({
loop: true,
urls: list
});
2 years ago
},
toVisitors(hospital){
uni.setStorageSync('depart_id', hospital.depart_id)
uni.setStorageSync('depart', JSON.stringify(hospital))
uni.setStorageSync('doctor_info', JSON.stringify(this.doctorInfo))
2 years ago
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
}
2 years ago
}
2 years ago
}
}
</script>
2 years ago
<style lang="scss" scoped>
.index-page{
2 years ago
.header-wrapper{
2 years ago
min-height: 208rpx;
2 years ago
padding: 24rpx 40rpx 24rpx;
2 years ago
box-sizing: border-box;
2 years ago
.left{
width: 510rpx;
.top{
overflow: hidden;
2 years ago
margin-top: 31rpx;
2 years ago
& view:first-of-type{
color: #000000;
letter-spacing: 1rpx;
margin-right: 27rpx;
2 years ago
max-width: 250rpx;
2 years ago
}
& view:last-of-type{
2 years ago
view{
width: auto;
padding: 0 15rpx;
min-width: 125rpx;
margin-top: 5rpx;
2 years ago
line-height: 42rpx;
text-align: center;
2 years ago
font-size: 28rpx;
background: linear-gradient( 288deg, #FFEED2 0%, #FED9A6 100%);
border-radius: 8rpx;
color: #7D501F;
}
2 years ago
}
}
.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;
2 years ago
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;
overflow-y: auto;
max-height: 200rpx;
2 years ago
}
}
2 years ago
.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;
}
2 years ago
img{
width: 48rpx;
height: 42rpx;
}
}
2 years ago
.hospital-wrapper{
.item{
2 years ago
&:last-child{
margin-bottom: 0rpx;
}
2 years ago
min-height: 207rpx;
2 years ago
width: 100%;
2 years ago
margin-bottom: 36rpx;
2 years ago
.top{
min-height: 102rpx;
2 years ago
.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;
2 years ago
height: 100%;
color: #666666;
2 years ago
img{
width: 52rpx;
height: 52rpx;
background: #F4F4F4;
border-radius: 6rpx;
2 years ago
margin-right: 7rpx;
2 years ago
}
text{
width: 60rpx;
height: 54rpx;
display: block;
font-size: 26rpx;
color: #666666;
line-height: 37rpx;
2 years ago
text-align: center;
margin-top: 5rpx;
2 years ago
}
}
}
.bot{
margin-top: 16rpx;
}
2 years ago
}
2 years ago
}
2 years ago
.visit-wrapper{
2 years ago
margin-bottom: 0;
2 years ago
.header{
justify-content: space-between;
.opt{
2 years ago
align-items: center;
2 years ago
overflow: hidden;
2 years ago
font-size: 26rpx;
color: #949699;
2 years ago
img{
width: 20rpx;
height: 32rpx;
// margin-top: 8rpx;
2 years ago
margin-left: 8rpx;
}
}
}
2 years ago
}
.preg-books{
width: 714rpx;
margin: 0 auto;
2 years ago
}
2 years ago
}
</style>