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
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>
|
|
|