微信公众号前端模版
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.

450 lines
21 KiB

<!-- 问诊医生列表 -->
<template>
<div class="doct-list__wrap">
<section class="header__box">
<nav-header title="医生列表"
:showTab="false"></nav-header>
</section>
<div style="height: 42px;"></div>
<div style="width: 100%; background: #ffffff">
<div class="header">
<div class="search">
<van-field v-model="searchText"
clearable
size="large"
label=""
left-icon="search"
placeholder="请输入医生名称查询"
enterkeyhint="send"
style="background: #f7f8fa;border-radius: 4px; width: calc(100% - 48px);align-items: center;padding: 0 10px;height: 34px;"
@clear="getDoctList('reflush')"
@keydown.enter="getDoctList('reflush')" />
<van-button type="primary"
size="small"
style="margin-top: 2px"
@click="getDoctList('reflush')">搜索</van-button>
</div>
<van-dropdown-menu active-color="#1989fa">
<van-dropdown-item v-model="job"
:title="job === -1 ? '职称' : ''"
:options="jobList"
@change="getDoctList('reflush')">
</van-dropdown-item>
<van-dropdown-item v-model="sort"
:title="sort === -1 ? '排序' : ''"
:options="sortList"
@change="getDoctList('reflush')" />
</van-dropdown-menu>
</div>
</div>
<div class="doctor-list__box">
<van-list id="list"
v-model:loading="loading"
:finished="finished"
:immediate-check="false"
finished-text=">_< 到底啦,别拉了~"
@load="onLoad"
style="flex-direction: column">
<div v-for="item in doctList"
:key="item.id">
<div class="item"
@click="handleTo(item)">
<template v-if="!item.headImg">
<div style="min-width: 65px;height: 65px;position: relative;overflow: hidden;border-radius: 50%;background-color: #fff;border: #fff solid 2px;">
<van-image class="doc__avatar"
:width="65"
:height="65"
round
src="" />
</div>
</template>
<template v-else>
<div style="min-width: 66px;height: 66px;position: relative;overflow: hidden;border-radius: 50%;background-color: #fff;border: #fff solid 2px;">
<van-image class="doc__avatar"
:width="66"
:height="88"
style="transform:translateY(-5px);clip-path: circle(31px at 33px 40px);"
:src="(item.headImg.indexOf('data:image/') !== -1 ? item.headImg : (UPLOAD_URL + item.headImg))" />
</div>
</template>
<div class="item__right">
<van-cell class="flex__row"
style="position: relative">
<div class="flex__row flex__row__between">
<section>
<span class="name">{{ item.doctName }}</span>
<span class="job_title">{{ item.title }}</span>
</section>
<span v-if="item.onlineState && item.onlineState === 1"
class="stop">可约</span>
</div>
</van-cell>
<van-cell class="flex__row">
<span class="department">{{ item.deptName }}</span>
</van-cell>
<van-cell class="flex__row">
<span class="label">咨询
<span class="number">{{
!item.consultNum ? 0 : item.consultNum
}}</span></span>
<span class="label"
style="margin: 0 15px">粉丝
<span class="number">{{
!item.concernNum ? 0 : item.concernNum
}}</span></span>
<span class="label">访问
<span class="number">{{
!item.visitNum ? 0 : item.visitNum
}}</span></span>
</van-cell>
<van-cell v-if="item.skill"
class="flex__row flex__row__warp">
<span class="label">擅长:</span><span style="font-size: 12px">{{
!item.skill ? "" : item.skill.replace("擅长:", "")
}}</span>
</van-cell>
<van-cell>
<div class="flex__row flex__row__between">
<section>
<span class="price">¥{{
item.consultMoney === undefined ||
item.consultMoney === null
? " - "
: item.consultMoney
}}
元起</span>
</section>
<div v-if="false"
style="padding-right: 10px; font-size: 13px; color: #7d7d7d;">
0个
</div>
</div>
</van-cell>
</div>
</div>
</div>
</van-list>
</div>
</div>
</template>
<script>
import { reactive, toRefs } from 'vue';
import { useRoute, useRouter } from 'vue-router';
import { axios, UPLOAD_URL } from 'axios'
export default {
components: {
'nav-header': VueConfig.vueLoader('@/components/tab-router.vue'),
},
setup(props, context) {
const route = useRoute();
const router = useRouter();
const state = reactive({
searchText: '', // 搜索内容
jobList: [
{ text: '不限', value: -1 },
{ text: '主任医师', value: 231 },
{ text: '副主任医师', value: 232 },
{ text: '主治医师', value: 233 },
{ text: '医师', value: 234 }
],
sortList: [
{ text: '不限', value: 0 },
{ text: '咨询次数', value: 1 },
{ text: '关注人数', value: 2 },
{ text: '访问次数', value: 3 }
],
job: -1,
sort: 0,
loading: false, // 列表加载状态
finished: false, // 列表加载全部
doctList: [], // 医生列表,
pageNum: 1,
deptCode: route.query.deptCode, // 科室列表
refresh_loading: false // 下拉加载
})
const isTest = route.query.isTest === undefined || !eval(route.query.isTest) ? false : true
/**
* 跳转到医生详情页
* @param {Object} item 医生
*/
function handleTo(item) {
if (item.consultMoney === undefined || item.consultMoney === null) return vant.Toast.fail({ duration: 1000, message: '【提示】该医生的问诊订单价格未录入' })
if (!item.onlineState) return vant.Toast.fail({ duration: 1000, message: '【提示】该医生暂未开启在线咨询' })
router.push({
path: '/doctor-home',
query: {
doctCode: item.doctCode,
isAddVisit: true
}
})
}
/**
* 获取医生列表
*/
async function getDoctList(status) {
if (status === 'reflush') {
state.pageNum = 1
state.finished = false
state.doctList = []
comTime = new Date().getTime()
}
const resp = await axios.RGet('/micro/online_doctor/getOLDocList', {
pageNum: state.pageNum,
pageSize: 20,
deptCode: state.deptCode === -1 ? '' : state.deptCode,
doctTitleCode: state.job === -1 ? '' : state.job,
sortState: state.sort === -1 ? '' : state.sort,
key: state.searchText,
isTest: isTest
})
if (resp.code === 200) {
if (status === 'reflush') {
state.doctList = resp.data.list
state.loading = false
} else {
setTimeout(() => {
resp.data.list.forEach(item => {
state.doctList.push(item)
})
state.loading = false
}, 500)
}
if (state.doctList.length === resp.data.total) {
state.finished = true
}
}
state.refresh_loading = false
}
getDoctList('reflush')
/**
* 滚动加载医生数据
*/
let comTime = 0
function onLoad() {
if (new Date().getTime() - comTime < 1000) {
return
} else if (state.pageNum === 1) {
comTime = new Date().getTime()
}
state.pageNum += 1
getDoctList('add')
}
/**
* 下来刷新
*/
function onRefresh() {
getDoctList('reflush')
}
return {
...toRefs(state),
handleTo,
getDoctList,
onLoad,
UPLOAD_URL,
onRefresh
}
},
}
</script>
<style scoped>
.doct-list__wrap {
height: calc(100vh - 30px);
overflow-x: hidden;
overflow-y: hidden;
width: 100%;
max-width: 767px;
background: #fff;
}
.header__box {
background: #fff;
z-index: 2;
position: fixed;
width: 100%;
margin: 0 auto;
max-width: 767px;
box-shadow: 2px 2px 9px rgba(0, 0, 0, 0.15);
}
.header {
width: 100%;
/* margin-top: 40px; */
border-bottom: 1px solid rgb(245, 244, 244);
/* margin-bottom: 5px; */
}
.search {
padding: 10px 10px 10px 12px;
display: flex;
justify-content: space-between;
}
.search>>>.van-field__control {
margin: auto 0;
}
.search__input>>>.van-search__content {
border-radius: 6px;
}
.van-dropdown-menu {
width: calc(100% - 0px);
margin: 0 auto 5px;
}
.doct-list__wrap>>>.van-dropdown-menu__bar {
background: #ffffff;
box-shadow: none;
}
.doct-list__wrap>>>.van-dropdown-menu__bar {
height: 28px;
}
.doct-list__wrap>>>.van-dropdown-menu__title {
font-size: 12px;
color: #89898a;
}
.doct-list__wrap>>>#van-dropdown-menu-3-0::after,
.doct-list__wrap>>>#van-dropdown-menu-3-1::after {
position: relative;
content: '';
height: 70%;
width: 1px;
left: 30px;
background: rgb(239, 239, 239);
}
.doct-list__wrap :deep(.van-dropdown-item--down) {
max-width: 767px;
margin: 0 auto;
}
.doctor-list__box {
width: 100%;
height: calc(100vh - 162px);
box-sizing: border-box;
padding: 10px;
overflow-y: auto;
box-sizing: border-box;
}
.item {
width: calc(100% - 0px);
display: flex;
flex-direction: row;
justify-content: space-around;
padding: 10px 0;
border-bottom: 1px solid rgb(245, 244, 244);
position: relative;
}
.item__left {
text-align: center;
min-height: 90px;
min-width: 70px;
margin-top: 7px;
}
.gray {
-webkit-filter: grayscale(95%);
-moz-filter: grayscale(95%);
-ms-filter: grayscale(95%);
-o-filter: grayscale(95%);
filter: grayscale(95%);
filter: gray;
}
.item__right {
width: calc(100% - 70px);
font-size: 12px !important;
margin-left: 5px;
}
.van-cell {
padding: 0px 5px;
}
.van-cell:after {
border-bottom: 0px;
}
.item__right .name {
font-size: 13px;
font-weight: 550;
margin-right: 10px;
}
.item__right .department {
font-size: 12px;
color: #0e0d0d;
}
.item__right .job_title {
font-size: 12px;
color: #b4b4b6;
}
.item__right .hospital {
font-size: 12px;
color: #b4b4b6;
}
.item__right .label {
font-size: 12px;
color: #848485;
}
.item__right .number {
font-size: 13px;
color: #0e0d0d;
}
.item__right .price {
font-size: 13px;
color: #e88d82;
}
.item__right .pay__times {
font-size: 12px;
margin-left: 10px;
}
.van-tag {
margin: 0 5px 5px 0;
padding: 4px 10px;
border-radius: 5px;
}
.van-tag--plain:before {
border-color: #e9e9e9;
}
.van-tag--danger {
background: #cf6046;
}
.stop {
margin: 0 8px;
padding: 0px 4px;
border-radius: 4px;
background-color: var(--color-primary);
color: #fff;
font-size: 12px;
}
.doc__avatar {
border-radius: 50%;
}
</style>