任务待办

This commit is contained in:
shidongli 2024-07-19 17:54:42 +08:00
parent 52c50929e6
commit 141f9a4e28

View File

@ -1,33 +1,81 @@
<template>
<div class="app-container" ref="layout">
<el-tabs v-model="queryParams.nodeExecuteStatus" @tab-click="handleClick" style="flex: 1;">
<el-tabs
v-model="queryParams.nodeExecuteStatus"
@tab-click="handleClick"
style="flex: 1"
>
<el-tab-pane label="未执行" name="UNEXECUTED"></el-tab-pane>
<el-tab-pane label="已执行" name="EXECUTED"></el-tab-pane>
</el-tabs>
<div ref="topform" class="form">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch">
<el-form
:model="queryParams"
ref="queryForm"
size="small"
:inline="true"
v-show="showSearch"
>
<el-form-item label="执行时间" prop="startDate">
<el-date-picker v-model="intentionalTime" type="daterange" range-separator="" start-placeholder="开始日期"
style="width: 300px" value-format="yyyy-MM-dd" end-placeholder="结束日期" @change="chooseTime">
<el-date-picker
v-model="intentionalTime"
type="daterange"
range-separator="至"
start-placeholder="开始日期"
style="width: 300px"
value-format="yyyy-MM-dd"
end-placeholder="结束日期"
@change="chooseTime"
>
</el-date-picker>
</el-form-item>
<el-form-item label="姓名" prop="patientName">
<el-input v-model="queryParams.patientName" placeholder="请输入姓名" clearable @keyup.enter.native="handleQuery" />
<el-input
v-model="queryParams.patientName"
placeholder="请输入姓名"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="电话" prop="patientPhone">
<el-input v-model="queryParams.patientPhone" placeholder="请输入电话" clearable
@keyup.enter.native="handleQuery" />
<el-input
v-model="queryParams.patientPhone"
placeholder="请输入电话"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="医院" prop="hospitalAgencyId">
<el-select v-model="queryParams.hospitalAgencyId" filterable placeholder="请选择医院" style="width: 200px"
clearable @clear="clearhospitalAgency" @change="changehospitalAgency">
<el-option v-for="item in hospitalAgencylist" :key="item.id" :label="item.agencyName" :value="item.id">
<el-select
v-model="queryParams.hospitalAgencyId"
filterable
placeholder="请选择医院"
style="width: 200px"
clearable
@clear="clearhospitalAgency"
@change="changehospitalAgency"
>
<el-option
v-for="item in hospitalAgencylist"
:key="item.id"
:label="item.agencyName"
:value="item.id"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="就诊方式" prop="visitMethod">
<el-select v-model="queryParams.visitMethod" placeholder="请选择就诊方式" clearable>
<el-option v-for="dict in dict.type.visit_method" :key="dict.value" :label="dict.label" :value="dict.value" />
<el-select
v-model="queryParams.visitMethod"
placeholder="请选择就诊方式"
clearable
>
<el-option
v-for="dict in dict.type.visit_method"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<!-- <el-form-item label="就诊类型" prop="suitRange">
@ -37,8 +85,12 @@
</el-select>
</el-form-item> -->
<el-form-item label="就诊流水号" prop="visitSerialNumber">
<el-input v-model="queryParams.visitSerialNumber" placeholder="请输入就诊流水号" clearable
@keyup.enter.native="handleQuery" />
<el-input
v-model="queryParams.visitSerialNumber"
placeholder="请输入就诊流水号"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<!-- <el-form-item label="门诊/出院时间" prop="intentionalTimeStart">
<el-date-picker @change="mzchange" v-model="mzTime" type="daterange" range-separator=""
@ -51,76 +103,201 @@
</el-date-picker>
</el-form-item> -->
<el-form-item label="诊断" prop="mainDiagnosis">
<el-input v-model="queryParams.mainDiagnosis" placeholder="请选择诊断" clearable
@keyup.enter.native="handleQuery" />
<el-input
v-model="queryParams.mainDiagnosis"
placeholder="请选择诊断"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="院区" prop="campusAgencyId">
<el-select v-model="queryParams.campusAgencyId" filterable placeholder="请选择院区" style="width: 200px" clearable
@clear="clearcampusAgency" @change="changecampusAgency">
<el-option v-for="item in campusAgencylist" :key="item.id" :label="item.agencyName" :value="item.id">
<el-select
v-model="queryParams.campusAgencyId"
filterable
placeholder="请选择院区"
style="width: 200px"
clearable
@clear="clearcampusAgency"
@change="changecampusAgency"
>
<el-option
v-for="item in campusAgencylist"
:key="item.id"
:label="item.agencyName"
:value="item.id"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="科室" prop="departmentId">
<el-select v-model="queryParams.departmentId" filterable placeholder="请选择科室" style="width: 200px" clearable
@clear="cleardepartment" @change="changedepartment">
<el-option v-for="item in departmentlist" :key="item.id" :label="item.departmentName" :value="item.id">
<el-select
v-model="queryParams.departmentId"
filterable
placeholder="请选择科室"
style="width: 200px"
clearable
@clear="cleardepartment"
@change="changedepartment"
>
<el-option
v-for="item in departmentlist"
:key="item.id"
:label="item.departmentName"
:value="item.id"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="病区" prop="wardId">
<el-select v-model="queryParams.wardId" filterable placeholder="请选择病区" style="width: 200px" clearable>
<el-option v-for="item in wardlist" :key="item.id" :label="item.departmentName" :value="item.id">
<el-select
v-model="queryParams.wardId"
filterable
placeholder="请选择病区"
style="width: 200px"
clearable
>
<el-option
v-for="item in wardlist"
:key="item.id"
:label="item.departmentName"
:value="item.id"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="主治医生" prop="attendingPhysicianId">
<el-select v-model="queryParams.attendingPhysicianId" style="width: 200px" filterable placeholder="请选择主治医生"
clearable>
<el-option v-for="item in attendingPhysicianlist" :key="item.userId" :label="item.nickName"
:value="item.userId">
<el-select
v-model="queryParams.attendingPhysicianId"
style="width: 200px"
filterable
placeholder="请选择主治医生"
clearable
>
<el-option
v-for="item in attendingPhysicianlist"
:key="item.userId"
:label="item.nickName"
:value="item.userId"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="任务名称" prop="manageRouteName">
<el-input v-model="queryParams.manageRouteName" placeholder="请输入任务名称" clearable style="width: 200px"
@keyup.enter.native="handleQuery" />
<el-input
v-model="queryParams.manageRouteName"
placeholder="请输入任务名称"
clearable
style="width: 200px"
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item
label=""
prop="manageRouteName"
v-if="queryParams.nodeExecuteStatus == 'UNEXECUTED'"
>
<el-switch
v-model="timeSignshow"
active-color="#1890ff"
inactive-color="#DCDFE6"
@change="changeswitch"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
<el-button
type="primary"
icon="el-icon-search"
size="mini"
@click="handleQuery"
>搜索</el-button
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
>重置</el-button
>
</el-form-item>
</el-form>
</div>
<div ref="table">
<el-table :max-height="maxTableHeight" v-loading="loading" :data="taskExecuteRecordList"
@selection-change="handleSelectionChange">
<el-table
:max-height="maxTableHeight"
v-loading="loading"
:data="taskExecuteRecordList"
@selection-change="handleSelectionChange"
>
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="姓名" align="center" prop="patientName" width="50" />
<el-table-column label="电话" align="center" prop="patientPhone" width="120" />
<el-table-column label="性别" align="center" prop="visitSerialNumber" width="50">
<el-table-column
label="姓名"
align="center"
prop="patientName"
width="50"
/>
<el-table-column
label="电话"
align="center"
prop="patientPhone"
width="120"
/>
<el-table-column
label="性别"
align="center"
prop="visitSerialNumber"
width="50"
>
<template slot-scope="scope">
{{ scope.row.sex == "MALE" ? "男" : "" }}
{{ scope.row.sex == "FEMALE" ? "女" : "" }}
</template>
</el-table-column>
<el-table-column label="医院" align="center" prop="hospitalAgencyName" width="105" />
<el-table-column
label="医院"
align="center"
prop="hospitalAgencyName"
width="105"
/>
<el-table-column label="院区" align="center" prop="campusAgencyName" />
<el-table-column label="科室名称" align="center" prop="departmentName" />
<el-table-column
label="科室名称"
align="center"
prop="departmentName"
/>
<el-table-column label="病区名称" align="center" prop="wardName" />
<el-table-column label="门诊/住院号" align="center" prop="inHospitalNumber" width="120"
:show-overflow-tooltip="true" />
<el-table-column label="就诊流水号" align="center" prop="visitSerialNumber" width="120"
:show-overflow-tooltip="true" />
<el-table-column label="诊断" align="center" prop="mainDiagnosis" width="120" :show-overflow-tooltip="true" />
<el-table-column
label="门诊/住院号"
align="center"
prop="inHospitalNumber"
width="120"
:show-overflow-tooltip="true"
/>
<el-table-column
label="就诊流水号"
align="center"
prop="visitSerialNumber"
width="120"
:show-overflow-tooltip="true"
/>
<el-table-column
label="诊断"
align="center"
prop="mainDiagnosis"
width="120"
:show-overflow-tooltip="true"
/>
<el-table-column label="手术名称" align="center" prop="surgicalName" />
<el-table-column label="主治医生" align="center" prop="attendingPhysicianName" width="80" />
<el-table-column
label="主治医生"
align="center"
prop="attendingPhysicianName"
width="80"
/>
<el-table-column label="就诊方式" align="center" prop="visitMethod">
<template slot-scope="scope">
<span>{{ scope.row.visitMethod == "OUTPATIENT_SERVICE" ? "门诊" : "" }}
<span
>{{ scope.row.visitMethod == "OUTPATIENT_SERVICE" ? "门诊" : "" }}
{{ scope.row.visitMethod == "BE_IN_HOSPITAL" ? "住院" : "" }}
</span>
</template></el-table-column>
</template></el-table-column
>
<!-- <el-table-column label="就诊类型" align="center" prop="suitRange" width="80">
<template slot-scope="scope">
<span>
@ -129,64 +306,158 @@
{{ scope.row.suitRange == "DISCHARGE" ? "出院" : "" }}
</span>
</template></el-table-column> -->
<el-table-column label="入院时间" align="center" prop="admissionTime" width="100">
<el-table-column
label="入院时间"
align="center"
prop="admissionTime"
width="100"
>
<template slot-scope="scope">
{{scope.row.visitMethod == "BE_IN_HOSPITAL"? parseTime(scope.row.admissionTime, "{y}-{m}-{d}"):'' }}
{{
scope.row.visitMethod == "BE_IN_HOSPITAL"
? parseTime(scope.row.admissionTime, "{y}-{m}-{d}")
: ""
}}
<!-- <span>{{ parseTime(scope.row.admissionTime, "{y}-{m}-{d}") }}</span> -->
</template>
</el-table-column>
<el-table-column label="门诊/出院时间" align="center" prop="visitTime" width="105">
<el-table-column
label="门诊/出院时间"
align="center"
prop="visitTime"
width="105"
>
<template slot-scope="scope">
<span>
{{scope.row.visitMethod == "OUTPATIENT_SERVICE"? parseTime(scope.row.visitTime, "{y}-{m}-{d}"):'' }}
{{scope.row.visitMethod == "BE_IN_HOSPITAL"? parseTime(scope.row.dischargeTime, "{y}-{m}-{d}"):'' }}
{{
scope.row.visitMethod == "OUTPATIENT_SERVICE"
? parseTime(scope.row.visitTime, "{y}-{m}-{d}")
: ""
}}
{{
scope.row.visitMethod == "BE_IN_HOSPITAL"
? parseTime(scope.row.dischargeTime, "{y}-{m}-{d}")
: ""
}}
</span>
</template>
</el-table-column>
<el-table-column label="任务名称" align="center" prop="manageRouteName" width="110">
<el-table-column
label="任务名称"
align="center"
prop="manageRouteName"
width="110"
>
</el-table-column>
<el-table-column label="任务节点名称" align="center" prop="routeNodeName" width="110">
<el-table-column
label="任务节点名称"
align="center"
prop="routeNodeName"
width="110"
>
<template slot-scope="scope">
<span v-if="scope.row.routeNodeName == 'AFTER_DISCHARGE'">出院后<span v-if="scope.row.routeNodeDay">{{scope.row.routeNodeDay}}</span></span>
<span v-if="scope.row.routeNodeName == 'AFTER_ADMISSION'">入院后<span v-if="scope.row.routeNodeDay">{{scope.row.routeNodeDay}}</span></span>
<span v-if="scope.row.routeNodeName == 'AFTER_CONSULTATION'">就诊后<span v-if="scope.row.routeNodeDay">{{scope.row.routeNodeDay}}</span></span>
<span v-if=" scope.row.routeNodeName == 'AFTER_VISIT_DISCHARGE'">就诊/出院后<span v-if="scope.row.routeNodeDay">{{scope.row.routeNodeDay}}</span></span>
<span v-if="scope.row.routeNodeName == 'PREOPERATIVE'">术前<span v-if="scope.row.routeNodeDay">{{scope.row.routeNodeDay}}</span></span>
<span v-if=" scope.row.routeNodeName == 'POSTOPERATIVE'">术后<span v-if="scope.row.routeNodeDay">{{scope.row.routeNodeDay}}</span></span>
<span v-if="scope.row.routeNodeName == 'AFTER_DISCHARGE'"
>出院后<span v-if="scope.row.routeNodeDay"
>{{ scope.row.routeNodeDay }}</span
></span
>
<span v-if="scope.row.routeNodeName == 'AFTER_ADMISSION'"
>入院后<span v-if="scope.row.routeNodeDay"
>{{ scope.row.routeNodeDay }}</span
></span
>
<span v-if="scope.row.routeNodeName == 'AFTER_CONSULTATION'"
>就诊后<span v-if="scope.row.routeNodeDay"
>{{ scope.row.routeNodeDay }}</span
></span
>
<span v-if="scope.row.routeNodeName == 'AFTER_VISIT_DISCHARGE'"
>就诊/出院后<span v-if="scope.row.routeNodeDay"
>{{ scope.row.routeNodeDay }}</span
></span
>
<span v-if="scope.row.routeNodeName == 'PREOPERATIVE'"
>术前<span v-if="scope.row.routeNodeDay"
>{{ scope.row.routeNodeDay }}</span
></span
>
<span v-if="scope.row.routeNodeName == 'POSTOPERATIVE'"
>术后<span v-if="scope.row.routeNodeDay"
>{{ scope.row.routeNodeDay }}</span
></span
>
</template>
</el-table-column>
<el-table-column label="任务内容" align="center" prop="taskNodeType" :show-overflow-tooltip="true">
<el-table-column
label="任务内容"
align="center"
prop="taskNodeType"
:show-overflow-tooltip="true"
>
<template slot-scope="scope">
<span>
{{ scope.row.taskNodeType == "PHONE_OUTBOUND" ? "电话外呼" : "" }}
{{ scope.row.taskNodeType == "QUESTIONNAIRE_SCALE" ? "问卷量表" : "" }}
{{ scope.row.taskNodeType == "PROPAGANDA_ARTICLE" ? "宣教文章" : "" }}
{{
scope.row.taskNodeType == "QUESTIONNAIRE_SCALE"
? "问卷量表"
: ""
}}
{{
scope.row.taskNodeType == "PROPAGANDA_ARTICLE" ? "宣教文章" : ""
}}
{{ scope.row.taskNodeType == "TEXT_REMIND" ? "文字提醒" : "" }}
<!-- {{ scope.row.taskType == "ARTIFICIAL_FOLLOW_UP" ? "人工随访" : "" }} -->
</span>
</template>
</el-table-column>
<el-table-column label="执行时间" align="center" prop="executeTime" width="80">
<el-table-column
label="执行时间"
align="center"
prop="executeTime"
width="80"
>
<template slot-scope="scope">
<span>{{ parseTime(scope.row.executeTime, "{y}-{m}-{d}") }}</span>
</template>
</el-table-column>
<!-- <el-table-column label="随访模板" align="center" prop="templateName" width="110">
</el-table-column> -->
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" fixed="right">
<el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
fixed="right"
>
<template slot-scope="scope">
<el-button v-if="queryParams.nodeExecuteStatus == 'UNEXECUTED'" size="mini" type="text"
icon="el-icon-bank-card" @click="handleUpdate(scope.row)">处理</el-button>
<el-button v-if="queryParams.nodeExecuteStatus == 'EXECUTED'" size="mini" type="text"
icon="el-icon-notebook-2" @click="handleadtail(scope.row)">详情</el-button>
<el-button
v-if="queryParams.nodeExecuteStatus == 'UNEXECUTED'"
size="mini"
type="text"
icon="el-icon-bank-card"
@click="handleUpdate(scope.row)"
>处理</el-button
>
<el-button
v-if="queryParams.nodeExecuteStatus == 'EXECUTED'"
size="mini"
type="text"
icon="el-icon-notebook-2"
@click="handleadtail(scope.row)"
>详情</el-button
>
</template>
</el-table-column>
</el-table>
</div>
<!-- <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize" @pagination="getList" /> -->
<myPagination v-show="total > 0" :total="total" :pageSize="queryParams.pageSize"
:indexFromWrap="queryParams.pageNum" @updateCPage="updateCPage"></myPagination>
<myPagination
v-show="total > 0"
:total="total"
:pageSize="queryParams.pageSize"
:indexFromWrap="queryParams.pageNum"
@updateCPage="updateCPage"
></myPagination>
</div>
</template>
<script>
@ -238,9 +509,11 @@ export default {
//
open: false,
//
timeSignshow: true,
queryParams: {
pageNum: 1,
pageSize: 10,
timeSign: 'TODAY',
nodeExecuteStatus: 'UNEXECUTED',
followStartTime: null,
followEndTime: null,
@ -307,6 +580,16 @@ export default {
this.screenChange()
},
methods: {
changeswitch(e) {
if (e == true) {
this.queryParams.timeSign = 'TODAY'
this.getList()
} else {
this.queryParams.timeSign = 'WHOLE'
this.getList()
}
},
updateCPage(index, size) {
this.queryParams.pageNum = index
this.queryParams.pageSize = size
@ -334,6 +617,15 @@ export default {
this.queryParams.departmentId = null
this.queryParams.wardId = null
this.queryParams.patientPhone = null
if (this.queryParams.nodeExecuteStatus == 'EXECUTED') {
this.queryParams.timeSign = null
} else {
this.queryParams.timeSign = 'TODAY'
}
console.log(this.queryParams.nodeExecuteStatus, 'nodeExecuteStatus')
this.getList();
},
change(e) {
@ -464,7 +756,7 @@ export default {
//
reset() {
this.form = {
nodeExecuteStatus: 'UNEXECUTED',
nodeExecuteStatus: '',
id: null,
patientId: null,
manageRouteId: null,
@ -540,10 +832,13 @@ export default {
/** 重置按钮操作 */
resetQuery() {
this.resetForm("queryForm");
this.queryParams = {
//
if (this.queryParams.nodeExecuteStatus == 'UNEXECUTED') {
this.queryParams = {
pageNum: 1,
pageSize: 10,
nodeExecuteStatus: 'UNEXECUTED',
timeSign:"today",
followStartTime: null,
followEndTime: null,
clinicalStartTime: null,
@ -572,6 +867,45 @@ export default {
departmentId: null,
wardId: null,
}
this.timeSignshow = true
} else {
this.queryParams = {
pageNum: 1,
pageSize: 10,
nodeExecuteStatus: 'EXECUTED',
followStartTime: null,
followEndTime: null,
clinicalStartTime: null,
clinicalEndTime: null,
admissionEndTime: null,
admissionStartTime: null,
mainDiagnosis: null,
visitSerialNumber: null,
attendingPhysicianId: null,
patientId: null,
suitRange: null,
manageRouteId: null,
manageRouteNodeId: null,
patientName: null,
startDate: null,
endDate: null,
manageRouteName: null,
manageRouteNodeName: null,
taskContent: null,
executeTime: null,
executePerson: null,
executeType: null,
executeRemark: null,
hospitalAgencyId: null,
campusAgencyId: null,
departmentId: null,
wardId: null,
}
// this.timeSignshow=true
// this.queryParams.nodeExecuteStatus = 'EXECUTED'
}
this.handleQuery();
this.intentionalTime = [];
this.mzTime = [];