528 lines
12 KiB
Vue
528 lines
12 KiB
Vue
<template>
|
||
<view class="u-page">
|
||
<z-paging
|
||
ref="paging"
|
||
inside-more
|
||
loading-more-no-more-text="咱也是有底线的!"
|
||
:auto-show-back-to-top="true"
|
||
v-model="dataList"
|
||
@query="queryList"
|
||
>
|
||
<template #top>
|
||
<navBarSearch :searchWord="keyWord" :navName="navName" :type="'case'" @changeWord="changeWord"></navBarSearch>
|
||
<!-- <view class="databox">
|
||
<view class="cell">
|
||
<view class="num">22</view>
|
||
<view class="name">文章</view>
|
||
</view>
|
||
<view class="cell">
|
||
<view class="num">11</view>
|
||
<view class="name">视频</view>
|
||
</view>
|
||
<view class="cell">
|
||
<view class="num">44</view>
|
||
<view class="name">阅读量</view>
|
||
</view>
|
||
</view> -->
|
||
<!-- <view class="detail" v-if="total>0">
|
||
<view class="desc" v-if="isArticle">检索到:<text class="red">{{total}}篇文章</text></view>
|
||
<view class="desc" v-else>检索到:<text class="red">{{total}}个视频</text></view>
|
||
<view class="desc" v-if="keyWord">检索词:<text class="red">{{ keyWord }}</text></view>
|
||
</view> -->
|
||
<view class="filterbox">
|
||
<!-- <view class="type" @click="swicthType">{{!isArticle?'文章':'视频'}}<up--image :src="switchImg" width="31rpx" height="31rpx"></up--image></view> -->
|
||
<up-dropdown class="u-dropdown" ref="uDropdownRef">
|
||
<up-dropdown-item
|
||
|
||
:title="dropTitle"
|
||
|
||
|
||
>
|
||
<view class="dropcontent">
|
||
<up-radio-group
|
||
@change="changeDate"
|
||
v-model="orderFilter"
|
||
iconPlacement="right"
|
||
placement="column"
|
||
>
|
||
<view
|
||
class="column"
|
||
v-for="item in options"
|
||
:key="item.value"
|
||
:class="[orderFilter==item.value?'active':'']"
|
||
>
|
||
<up-radio
|
||
activeColor="#3CC7C0"
|
||
:label="item.label"
|
||
:name="item.value"
|
||
></up-radio>
|
||
</view>
|
||
</up-radio-group>
|
||
</view>
|
||
</up-dropdown-item>
|
||
<!-- <up-dropdown-item
|
||
v-model="order.read_num"
|
||
title="阅读量"
|
||
@change="changeRead"
|
||
:options="options"
|
||
></up-dropdown-item> -->
|
||
</up-dropdown>
|
||
|
||
|
||
</view>
|
||
</template>
|
||
<view class="listbox">
|
||
<view class="item" v-for="(item, index) in dataList" :key="index" @click="goDetail(item.label_iden,item.label_name)">
|
||
<view class="title ellipsis">{{item.label_name}}</view>
|
||
<!-- <view class="tagsbox">
|
||
<view class="tag" v-for="tag in item.author" :key="tag.author_id">{{ tag.doctor_name }}</view>
|
||
</view> -->
|
||
<view class="deal">
|
||
<view class="left">
|
||
<view class="count">
|
||
病例数:{{ item.video_num+item.article_num}}<up--image :src="arrowrightImg" width="32rpx" height="32rpx"></up--image></view>
|
||
</view>
|
||
<view class="time">
|
||
|
||
<!-- <up-icon name="clock" color="#6B7280" size="28rpx"></up-icon> -->
|
||
<view class="num">更新时间:{{formatdate(item.last_push_date) }}</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</z-paging>
|
||
</view>
|
||
|
||
</template>
|
||
|
||
<script setup>
|
||
import { ref, reactive} from "vue";
|
||
import navBarSearch from "@/components/navBarSearch/navBarSearch.vue";
|
||
import list from "@/uni_modules/z-paging/components/z-paging/z-paging";
|
||
import api from "@/api/api";
|
||
import { onLoad,onShow} from "@dcloudio/uni-app";
|
||
import dayjs from "dayjs";
|
||
import switchImg from "@/static/switch.png";
|
||
import navTo from "@/utils/navTo.js";
|
||
import arrowrightImg from "@/static/arrowright.png";
|
||
const paging = ref(null);
|
||
const uDropdownRef=ref(null);
|
||
const dataList = ref([]);
|
||
const total = ref(0);
|
||
const value = ref("");
|
||
const keyWord = ref("");
|
||
const isArticle=ref(true)
|
||
const type=ref('doctor')
|
||
const dropTitle=ref('更新时间');
|
||
const navName=ref('疾病临床病例库');
|
||
const orderFilter=ref('1')
|
||
const options= ref([
|
||
{
|
||
label: "更新时间",
|
||
value: '1',
|
||
},
|
||
{
|
||
label: "疾病名称",
|
||
value: '2',
|
||
},
|
||
{
|
||
label: "病例数",
|
||
value: '3',
|
||
},
|
||
]);
|
||
|
||
const order=reactive({
|
||
updated_at:'desc'
|
||
})
|
||
|
||
onLoad((options) => {
|
||
if(options.type=='hospital'){
|
||
type.value ='hospital';
|
||
}
|
||
keyWord.value=options.name;
|
||
if(options.name){
|
||
navName.value=options.name+'临床病例库'
|
||
}
|
||
if((options.name='医生' || options.name=='医院') && !options.id){
|
||
keyWord.value='';
|
||
}
|
||
if(options.order=='new'){
|
||
order.push_date='asc'
|
||
};
|
||
if(options.order=='read'){
|
||
order.article_num='desc'
|
||
};
|
||
});
|
||
onShow(()=>{
|
||
paging.value?.refresh();
|
||
})
|
||
const changeDate=(e)=>{
|
||
if(e==1){
|
||
order.updated_at='desc';
|
||
order.label_name='';
|
||
order.article_num='';
|
||
dropTitle.value="更新时间"
|
||
}else if(e==2){
|
||
order.updated_at='';
|
||
order.label_name='asc';
|
||
order.article_num='';
|
||
dropTitle.value="疾病名称"
|
||
}else if(e==3){
|
||
order.updated_at='';
|
||
order.label_name='';
|
||
order.article_num='desc';
|
||
dropTitle.value="病例数"
|
||
}
|
||
orderFilter.value=e;
|
||
uDropdownRef.value.close();
|
||
paging.value.reload();
|
||
}
|
||
|
||
const formatdate=(date)=>{
|
||
return dayjs(date).format('YYYY-MM-DD')
|
||
}
|
||
|
||
const searchList = async(params) => {
|
||
let searchForm={
|
||
label_name: keyWord.value,
|
||
}
|
||
if(!order.article_num){
|
||
delete order.article_num
|
||
}
|
||
if(!order.updated_at){
|
||
delete order.updated_at
|
||
}
|
||
if(!order.label_name){
|
||
delete order.label_name
|
||
}
|
||
if(order.article_num || order.updated_at || order.label_name){
|
||
searchForm.order=order
|
||
}
|
||
api.getSearchLabel({
|
||
...searchForm,
|
||
...params
|
||
}).then((res)=>{
|
||
paging.value.complete(res.data.data.data);
|
||
total.value=res.data.data.total;
|
||
}).catch(err=>{
|
||
paging.value.complete(false);
|
||
})
|
||
}
|
||
const queryList = (pageNo, pageSize) => {
|
||
const params = {
|
||
page: pageNo,
|
||
page_size: pageSize,
|
||
};
|
||
searchList(params);
|
||
};
|
||
const goDetail=(id,name)=>{
|
||
let url=`/pages/search/search?case_id=${id}&case_name=${name}`
|
||
navTo({
|
||
url:url,
|
||
});
|
||
}
|
||
/**
|
||
* 修改关键词并更新界面
|
||
*
|
||
* @param value 输入的关键词
|
||
*/
|
||
const changeWord=(value)=>{
|
||
navName.value='疾病临床病例库';
|
||
keyWord.value=value;
|
||
dataList.value=[];
|
||
order.updated_at='desc';
|
||
order.article_num='';
|
||
order.label_name='';
|
||
paging.value.reload();
|
||
|
||
|
||
}
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
.dropcontent{
|
||
padding-top: 40rpx;
|
||
padding-bottom: 20rpx;
|
||
background-color: #fff;
|
||
:deep(.u-radio){
|
||
margin-bottom: 6px!important;
|
||
margin-top: 16px!important;
|
||
}
|
||
.column {
|
||
padding: 0 30rpx;
|
||
border-top: 2rpx solid #e5e7eb;
|
||
:deep(.u-radio__text){
|
||
color: #333 !important;
|
||
}
|
||
}
|
||
.column.active{
|
||
:deep(.u-radio__text){
|
||
color: #3CC7C0 !important;
|
||
}
|
||
}
|
||
|
||
}
|
||
.votepop {
|
||
.confirm {
|
||
margin: 39rpx 30rpx 0;
|
||
height: 92rpx;
|
||
background: #3cc7c0;
|
||
border-radius: 15rpx;
|
||
display: flex;
|
||
align-items: center;
|
||
font-size: 31rpx;
|
||
color: #ffffff;
|
||
justify-content: center;
|
||
}
|
||
.del {
|
||
margin: 30rpx 30rpx 30rpx;
|
||
height: 92rpx;
|
||
background: #fff;
|
||
border-radius: 15rpx;
|
||
font-size: 31rpx;
|
||
color: #666666;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: center;
|
||
}
|
||
.tips {
|
||
margin-top: 30rpx;
|
||
font-size: 27rpx;
|
||
color: #9ca3af;
|
||
line-height: 38rpx;
|
||
padding: 0 30rpx;
|
||
}
|
||
.add {
|
||
margin: 0 30rpx;
|
||
display: flex;
|
||
align-items: center;
|
||
height: 92rpx;
|
||
justify-content: center;
|
||
background: #f5f5f5;
|
||
border-radius: 15rpx;
|
||
font-size: 31rpx;
|
||
color: #4b5563;
|
||
.desc {
|
||
margin-left: 10rpx;
|
||
}
|
||
}
|
||
.titlebox {
|
||
padding: 0 30rpx;
|
||
height: 86rpx;
|
||
display: flex;
|
||
align-items: center;
|
||
justify-content: space-between;
|
||
border-bottom: 2rpx solid #f3f4f6;
|
||
.left {
|
||
font-size: 31rpx;
|
||
color: #4b5563;
|
||
}
|
||
.right {
|
||
font-size: 31rpx;
|
||
color: #3cc7c0;
|
||
}
|
||
}
|
||
.votecon {
|
||
max-height: calc(100vh - 530rpx);
|
||
overflow-y: scroll;
|
||
.row {
|
||
display: flex;
|
||
align-items: center;
|
||
.iconbox {
|
||
margin-left: 15rpx;
|
||
align-items: center;
|
||
}
|
||
}
|
||
.titlebox {
|
||
border: none;
|
||
margin: 30rpx 0 20rpx;
|
||
.title {
|
||
font-size: 31rpx;
|
||
color: #111827;
|
||
}
|
||
.desc {
|
||
font-size: 27rpx;
|
||
color: #9ca3af;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
.casepop{
|
||
display: flex;
|
||
flex-direction: column;
|
||
max-height: calc(100vh - 400rpx);
|
||
.continue{
|
||
color: #2878ff !important;
|
||
}
|
||
}
|
||
.casecon {
|
||
flex:1;
|
||
overflow-y: scroll;
|
||
padding-top: 10rpx;
|
||
min-height: 350rpx;
|
||
|
||
.column {
|
||
padding: 0 30rpx;
|
||
border-bottom: 2rpx solid #e5e7eb;
|
||
}
|
||
}
|
||
.databox {
|
||
height: 162rpx;
|
||
background: #ffffff;
|
||
display: flex;
|
||
margin-bottom: 20rpx;
|
||
// padding: 0 30rpx;
|
||
justify-content: space-between;
|
||
.cell {
|
||
flex: 1;
|
||
padding: 35rpx 0;
|
||
|
||
text-align: center;
|
||
|
||
.num {
|
||
font-size: 38rpx;
|
||
color: #3cc7c0;
|
||
}
|
||
.name {
|
||
margin-top: 18rpx;
|
||
font-size: 28rpx;
|
||
color: #4b5563;
|
||
}
|
||
}
|
||
}
|
||
.listbox{
|
||
background: #F8F9FA;
|
||
overflow: hidden;
|
||
}
|
||
.filterbox{
|
||
display: flex;
|
||
height:128rpx;
|
||
background:#fff;
|
||
border-bottom: 2rpx solid rgba(0,0,0,0.08);
|
||
align-items: center;
|
||
position: relative;
|
||
.type{
|
||
position: absolute;
|
||
left:30rpx;
|
||
top:24rpx;
|
||
display: flex;
|
||
justify-content: center;
|
||
align-items: center;
|
||
background: #F3F4F6;
|
||
border-radius: 15rpx;
|
||
height: 74rpx;
|
||
padding:0 25rpx;
|
||
z-index:2;
|
||
}
|
||
}
|
||
.u-page {
|
||
:deep(.z-paging-content-fixed){
|
||
background: #F8F9FA!important;
|
||
}
|
||
:deep(.u-flex) {
|
||
display: flex;
|
||
flex-direction:row;
|
||
overflow: hidden;
|
||
}
|
||
:deep(.u-image){
|
||
background: none!important;
|
||
}
|
||
:deep(.u-dropdown__menu){
|
||
|
||
background: #fff;
|
||
z-index:1;
|
||
margin-left:0rpx;
|
||
|
||
}
|
||
:deep(.u-dropdown__menu__item__text){
|
||
font-size: 14px!important;
|
||
color:#3CC7C0!important;
|
||
}
|
||
:deep(.u-dropdown__menu__item){
|
||
|
||
height:74rpx;
|
||
padding:0 20rpx;
|
||
background: #F3F4F6;
|
||
border-radius: 15rpx;
|
||
flex:none;
|
||
margin-left: 30rpx;
|
||
|
||
}
|
||
.deal {
|
||
margin-top: 20rpx;
|
||
display: flex;
|
||
color: #6b7280;
|
||
background:#fff;
|
||
font-size: 24rpx;
|
||
justify-content: space-between;
|
||
.left {
|
||
display: flex;
|
||
align-items: center;
|
||
font-size: 27rpx;
|
||
.count{
|
||
|
||
display: flex;
|
||
align-items: center;
|
||
}
|
||
}
|
||
.collect {
|
||
display: flex;
|
||
align-items: center;
|
||
}
|
||
.eyebox {
|
||
width: 160rpx;
|
||
display: flex;
|
||
align-items: center;
|
||
}
|
||
.time {
|
||
display: flex;
|
||
align-items: center;
|
||
}
|
||
.num {
|
||
margin-left: 8rpx;
|
||
}
|
||
}
|
||
.item {
|
||
margin:30rpx;
|
||
background: #fff;
|
||
padding:30rpx;
|
||
box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.08);
|
||
border-radius: 23rpx;
|
||
|
||
.title {
|
||
font-size: 30rpx;
|
||
color: #111827;
|
||
line-height: 46rpx;
|
||
}
|
||
}
|
||
.tagsbox {
|
||
margin-top: 20rpx;
|
||
display: flex;
|
||
flex-wrap: wrap;
|
||
.tag {
|
||
padding: 0 10rpx;
|
||
margin-right: 16rpx;
|
||
height: 46rpx;
|
||
line-height: 46rpx;
|
||
text-align: center;
|
||
background: rgba(60, 199, 192, 0.1);
|
||
border-radius: 8rpx;
|
||
font-weight: 400;
|
||
font-size: 24rpx;
|
||
color: #3cc7c0;
|
||
}
|
||
}
|
||
}
|
||
.detail {
|
||
background: #f9f9f9;
|
||
padding: 12rpx 30rpx;
|
||
.desc {
|
||
font-size: 26rpx;
|
||
color: #4b5563;
|
||
line-height: 40rpx;
|
||
}
|
||
.red{
|
||
color: #FF0000;
|
||
}
|
||
}
|
||
</style> |