From 91f78c7a3c325b7627f269524cdf92f006948cdf Mon Sep 17 00:00:00 2001
From: WXL (wul) <wl_5969728@163.com>
Date: 星期一, 20 十月 2025 17:37:35 +0800
Subject: [PATCH] 景宁电话接入
---
src/views/patient/propaganda/particty.vue | 2209 ++++++++++++++++++++++++++++++++++++++++++----------------
1 files changed, 1,586 insertions(+), 623 deletions(-)
diff --git a/src/views/patient/propaganda/particty.vue b/src/views/patient/propaganda/particty.vue
index e3ad89e..40cb5fd 100644
--- a/src/views/patient/propaganda/particty.vue
+++ b/src/views/patient/propaganda/particty.vue
@@ -7,14 +7,13 @@
<el-step
icon="el-icon-edit"
title="鍩虹淇℃伅"
- description="閫夋嫨妯$増銆佸舰寮忕瓑鍩虹淇℃伅"
+ description="閫夋嫨妯℃澘銆佸舰寮忕瓑鍩虹淇℃伅"
></el-step>
<el-step
icon="el-icon-user"
title="浠诲姟涓讳綋"
description="鍦ㄦ湰閮ㄩ�夋嫨鏈嶅姟鎮h��"
></el-step>
- <el-step icon="el-icon-user" title="妯$増纭"></el-step>
</el-steps>
</div>
</div>
@@ -22,7 +21,7 @@
<div class="leftvlue" style="margin: 0 20px">
<!-- 鍩烘湰淇℃伅 -->
<div v-if="Editprogress == 1">
- <el-alert title="閫夋嫨妯$増銆佸舰寮忕瓑鍩虹淇℃伅" type="success" effect="dark">
+ <el-alert title="閫夋嫨妯℃澘銆佸舰寮忕瓑鍩虹淇℃伅" type="success" effect="dark">
</el-alert>
<div class="leftvlue-jbxx">
<!-- 鍩虹淇℃伅 -->
@@ -31,48 +30,115 @@
<div>鍩虹淇℃伅</div>
</div>
<div class="jic-value">
- <el-form ref="form" :model="form" label-width="105px">
+ <el-form
+ ref="form"
+ :model="form"
+ :rules="rules"
+ label-width="125px"
+ >
<el-row :gutter="20">
<el-col :span="12"
- ><el-form-item label="浠诲姟鍚嶇О">
+ ><el-form-item label="浠诲姟鍚嶇О" prop="taskName">
<el-input
style="width: 220px"
v-model="form.taskName"
placeholder="璇疯緭鍏ヤ换鍔″悕绉�"
/> </el-form-item
></el-col>
- <el-col :span="8"
- ><el-form-item label="妯$増鍚嶇О">
- <el-input
- style="width: 220px"
- :disabled="true"
- v-model="form.templatename"
- placeholder="璇峰湪涓嬪垪閫夋嫨"
- /> </el-form-item
+ <el-col :span="12"
+ ><el-form-item label="浠诲姟绫诲瀷">
+ <el-select
+ v-model="serviceType"
+ placeholder="璇烽�夋嫨鏂板绫诲瀷"
+ >
+ <el-option
+ v-for="item in tasktypes"
+ :key="item.value"
+ :label="item.label"
+ :value="item.value"
+ >
+ </el-option>
+ </el-select> </el-form-item
></el-col>
- <el-col :span="4">
- <el-button
- type="primary"
- icon="el-icon-edit"
- circle
- ></el-button>
- </el-col>
</el-row>
- <el-form-item label="浠诲姟鎻忚堪">
+ <el-form-item label="浠诲姟鎻忚堪" prop="taskDesc">
<el-input
type="textarea"
v-model="form.taskDesc"
placeholder="璇疯緭鍏ヤ换鍔℃弿杩�"
/>
</el-form-item>
- <el-form-item label="鍙戦�佽缃細" v-if="currenttype != 2">
- <el-radio-group v-model="form.sendType">
- <el-radio :label="1">鏃堕棿娈靛彂閫�</el-radio>
- <el-radio :label="3">鍗冲埢鍙戦��</el-radio>
+ <!-- <el-form-item label="鏈嶅姟褰㈠紡">
+ <el-radio-group
+ v-model="checkList"
+ @change="handleCheckedCitiesChange"
+ >
+ <el-radio
+ v-for="(item, index) in checkboxlist"
+ :key="index"
+ :label="item.value"
+ >
+ {{ item.label }}</el-radio
+ >
+ </el-radio-group>
+ </el-form-item> -->
+ <el-form-item label="鏈嶅姟褰㈠紡">
+ <SortCheckbox
+ v-model="checkList"
+ :options="checkboxlist"
+ :initialselectedOrder="selectedOrder"
+ value-key="value"
+ label-key="label"
+ @change="checkSelectionChange"
+ />
+ </el-form-item>
+ <!-- <div class="xinz-infs">
+ <el-form-item label="鏈嶅姟鎵ц椤哄簭" prop="daytime">
+ <el-tag
+ :key="tag.label"
+ type="success"
+ v-for="(tag, index) in foncheckList"
+ closable
+ :disable-transitions="false"
+ @close="handleClosetag(tag)"
+ >
+ ({{ index + 1 }}){{ tag.label }}
+ </el-tag>
+ </el-form-item>
+ </div> -->
+ <el-form-item label="鎵ц鍛ㄦ湡" prop="longTask">
+ <el-radio-group v-model="form.longTask">
+ <el-radio :label="0">鑷畾涔夊懆鏈�</el-radio>
+ <el-radio :label="1">闀挎湡浠诲姟</el-radio>
</el-radio-group>
</el-form-item>
- <el-form-item label="鍙戦�佹棩鏈燂細" v-if="form.sendType == 1">
+ <el-row :gutter="20" v-if="form.longTask">
+ <el-col :span="8">
+ <el-form-item label="鍛ㄦ湡鏃堕棿" prop="name">
+ <el-input
+ v-model="form.sendDay"
+ placeholder="榛樿5澶╁悗"
+ ></el-input>
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-form-item
+ label="鎵ц璁剧疆"
+ prop="sendType"
+ v-if="!form.longTask"
+ >
+ <el-radio-group v-model="form.sendType">
+ <el-radio :label="1">鏃堕棿娈垫墽琛�</el-radio>
+ <el-radio :label="3">鏃堕棿鐐规墽琛�</el-radio>
+ <el-radio :label="2">鍗冲埢鎵ц</el-radio>
+ </el-radio-group>
+ </el-form-item>
+ <el-form-item
+ label="鎵ц鏃ユ湡"
+ v-if="form.sendType == 1 && !form.longTask"
+ prop="daytime"
+ >
<el-date-picker
v-model="daytime"
@change="changeTimeday"
@@ -84,12 +150,34 @@
>
</el-date-picker>
</el-form-item>
- <el-form-item label="鍙戦�佹椂闂存锛�" v-if="form.sendType == 1">
+
+ <el-form-item
+ label="鎵ц鏃堕棿鐐�"
+ v-if="form.sendType == 3 && !form.longTask"
+ prop="daytime"
+ >
<div style="display: flex">
<div style="margin-right: 10px">
- <span style="font-size: 18px; margin-right: 10px"
- >鏃堕棿娈典竴</span
+ <el-date-picker
+ v-model="time4"
+ value-format="yyyy-MM-dd HH:mm:ss"
+ @change="Totaldate"
+ type="datetime"
+ placeholder="閫夋嫨鏃ユ湡鏃堕棿"
>
+ </el-date-picker>
+ </div>
+ </div>
+ </el-form-item>
+
+ <el-form-item
+ label="鎵ц鏃堕棿娈�"
+ v-if="form.sendType == 1 && !form.longTask"
+ prop="daytime"
+ >
+ <div style="display: flex">
+ <div style="margin-right: 10px">
+ <span style="font-size: 18px; margin-right: 10px">鈶�</span>
<el-time-picker
is-range
arrow-control
@@ -104,9 +192,7 @@
</el-time-picker>
</div>
<div style="margin-right: 10px">
- <span style="font-size: 18px; margin-right: 10px"
- >鏃堕棿娈典簩</span
- >
+ <span style="font-size: 18px; margin-right: 10px">鈶�</span>
<el-time-picker
is-range
arrow-control
@@ -121,9 +207,7 @@
</el-time-picker>
</div>
<div style="margin-right: 10px">
- <span style="font-size: 18px; margin-right: 10px"
- >鏃堕棿娈典笁</span
- >
+ <span style="font-size: 18px; margin-right: 10px">鈶�</span>
<el-time-picker
is-range
arrow-control
@@ -139,225 +223,182 @@
</div>
</div>
</el-form-item>
- <el-form-item label="鏈嶅姟褰㈠紡">
- <el-checkbox-group v-model="checkList">
- <el-checkbox
- v-for="(item, index) in checkboxlist"
- :key="index"
- :label="item"
- ></el-checkbox>
- </el-checkbox-group>
+ <el-form-item label="浠诲姟鍏宠仈" prop="longTask">
+ <el-radio-group v-model="form.appltype">
+ <el-radio label="1">绉戝鍏宠仈</el-radio>
+ <el-radio label="2">鐥呭尯鍏宠仈</el-radio>
+ <el-radio label="3">鐤剧梾鍏宠仈</el-radio>
+ <el-radio label="4">鎵嬫湳鍏宠仈</el-radio>
+ </el-radio-group>
</el-form-item>
+ <el-row v-if="form.appltype == 1">
+ <el-col :span="20"
+ ><el-form-item label="閫傜敤绉戝" prop="region">
+ <el-select
+ v-model="deptcodesWards"
+ @remove-tag="removetag"
+ style="width: 400px"
+ size="medium"
+ multiple
+ filterable
+ placeholder="璇烽�夋嫨绉戝"
+ >
+ <el-option
+ class="ruleFormaa"
+ v-for="item in belongDepts"
+ :key="item.deptCode"
+ :label="item.deptName"
+ :value="item.deptCode"
+ >
+ </el-option>
+ </el-select> </el-form-item
+ ></el-col>
+ </el-row>
+ <el-row v-if="form.appltype == 2">
+ <el-col :span="20"
+ ><el-form-item label="閫傜敤鐥呭尯" prop="region">
+ <el-select
+ v-model="leavehospitaldistrictcodes"
+ style="width: 400px"
+ @remove-tag="removehpsp"
+ size="medium"
+ multiple
+ filterable
+ placeholder="璇烽�夋嫨鐥呭尯"
+ >
+ <el-option
+ class="ruleFormaa"
+ v-for="item in belongWards"
+ :key="item.districtCode"
+ :label="item.districtName"
+ :value="item.districtCode"
+ >
+ </el-option>
+ </el-select> </el-form-item
+ ></el-col>
+ </el-row>
+ <el-row v-if="form.appltype == 3">
+ <div class="xinz-infs">
+ <el-form-item>
+ <template #label>
+ <el-tooltip
+ class="item"
+ effect="light"
+ content="閫夋嫨濂介�傜敤鐤剧梾鍚庯紝鍙互鏂逛究鎮ㄩ�氳繃鐤剧梾璇婃柇鏌ユ壘鍒板搴旂殑鐥呬汉!"
+ placement="top-start"
+ >
+ <i class="el-icon-warning-outline"></i>
+ </el-tooltip>
+ </template>
+ <div style="margin-bottom: 10px">
+ <el-button
+ type="warning"
+ @click="$refs.child.handleAddpatient()"
+ >娣诲姞鐤剧梾璇婃柇</el-button
+ >
+ </div>
+ <el-tag
+ v-for="tag in diagglist"
+ :key="tag.icdcode"
+ @close="removediagg(tag.icd10code)"
+ type="warning"
+ closable
+ :disable-transitions="false"
+ >
+ {{ tag.icdname }}
+ </el-tag>
+ <!-- <el-tag v-if="hasMore" type="info">+{{ remaining }} more</el-tag> -->
+ </el-form-item>
+ </div>
+ </el-row>
+ <el-row v-if="form.appltype == 4">
+ <el-col :span="20"
+ ><el-form-item label="閫傜敤鎵嬫湳" prop="region">
+ <el-select
+ v-model="operationcodes"
+ style="width: 400px"
+ @remove-tag="removeopera"
+ :remote-method="remoteopcode"
+ size="medium"
+ multiple
+ filterable
+ remote
+ placeholder="璇烽�夋嫨鎵嬫湳"
+ >
+ <el-option
+ class="ruleFormaa"
+ v-for="item in baseoperaList"
+ :key="item.icdcode"
+ :label="item.icdname"
+ :value="item.icdcode"
+ >
+ </el-option>
+ </el-select> </el-form-item
+ ></el-col>
+ </el-row>
+ <el-row>
+ <el-col :span="12"
+ ><el-form-item label="寮�鍦虹櫧" prop="kcb">
+ <el-input
+ type="textarea"
+ :rows="3"
+ v-model="form.kcb"
+ placeholder="璇疯緭鍏ュ紑鍦虹櫧"
+ /> </el-form-item
+ ></el-col>
+ <el-col :span="12"
+ ><el-form-item label="缁撴潫璇�" prop="jsy">
+ <el-input
+ type="textarea"
+ :rows="3"
+ v-model="form.jsy"
+ placeholder="璇疯緭鍏ョ粨鏉熻"
+ /> </el-form-item
+ ></el-col>
+ </el-row>
</el-form>
</div>
</div>
<div class="examine-jic">
<div class="headline">
- <div>{{ title }}</div>
- </div>
- <div class="examine-jic">
- <div class="jic-value">
- <el-row :gutter="20">
- <!--鐢ㄦ埛鏁版嵁-->
-
- <el-form
- :model="topqueryParams"
- ref="queryForm"
- size="small"
- :inline="true"
- v-show="showSearch"
- label-width="98px"
- >
- <el-form-item
- label="瀹f暀涓婚"
- v-if="currenttype == 1 || currenttype == 8"
- >
- <el-input v-model="topqueryParams.name"></el-input>
- </el-form-item>
- <el-form-item
- label="闅忚鍚嶇О"
+ <div>浠诲姟浣跨敤妯℃澘</div>
+ <div style="margin-left: 20px">
+ <el-form ref="forms">
+ <el-form-item label="">
+ <el-input
+ style="width: 300px"
+ :disabled="true"
+ v-model="form.templatename"
+ placeholder="璇风偣鍑诲彸渚ч�夋嫨"
+ />
+ <el-button
v-if="
- currenttype == 2 || currenttype == 3 || currenttype == 7
+ (form.templateid && form.sendState == 1) ||
+ !form.templateid
"
- >
- <el-input
- v-model="topqueryParams.name"
- ></el-input> </el-form-item
- ><el-form-item
- label="閫氱煡鍚嶇О"
- v-if="currenttype == 4 || currenttype == 5"
- >
- <el-input
- v-model="topqueryParams.name"
- ></el-input> </el-form-item
- ><el-form-item label="浣撴濂楅" v-if="currenttype == 5">
- <el-input v-model="topqueryParams.name"></el-input>
- </el-form-item>
- <el-form-item label="闂嵎涓婚" v-if="currenttype == 6">
- <el-input v-model="topqueryParams.name"></el-input>
- </el-form-item>
- <el-form-item label="閫傜敤鐤剧梾" v-if="currenttype != 5">
- <el-input v-model="topqueryParams.name"></el-input>
- </el-form-item>
+ style="margin-left: 10px"
+ type="primary"
+ icon="el-icon-edit"
+ @click="drawermb = true"
+ circle
+ ></el-button>
- <el-form-item
- label="瀹f暀绫诲瀷"
- prop="status"
- v-if="currenttype == 1 || currenttype == 8"
- >
- <el-select
- v-model="topqueryParams.topic"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in taskoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item
- label="閫氱煡绫诲瀷"
- prop="status"
- v-if="currenttype == 4 || currenttype == 5"
- >
- <el-select
- v-model="topqueryParams.topic"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in taskoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item
- label="闅忚绫诲瀷"
- prop="status"
- v-if="
- currenttype == 2 || currenttype == 3 || currenttype == 7
- "
- >
- <el-select
- v-model="topqueryParams.topic"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in taskoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item
- label="闂嵎绫诲瀷"
- prop="status"
- v-if="currenttype == 6"
- >
- <el-select
- v-model="topqueryParams.topic"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in taskoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="閫傜敤褰㈠紡" prop="status">
- <el-select
- v-model="topqueryParams.topica"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in taskoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
-
- <el-form-item label="閫傜敤绉戝" prop="status">
- <el-select
- v-model="topqueryParams.topicd"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in topicoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item>
- <el-button
- type="primary"
- icon="el-icon-search"
- size="medium"
- @click="handleQuery"
- >鎼滅储</el-button
- >
- <el-button
- icon="el-icon-refresh"
- size="medium"
- @click="resetQuery"
- >閲嶇疆</el-button
- >
- </el-form-item>
- </el-form>
- <el-divider></el-divider>
- <!-- 閫夋嫨妯$増鍒楄〃 -->
- <SFtable
- @selectfn="selectfn"
- :currentList="userList"
- :tableLabel="tableLabel"
- :controlsc="false"
- :multiplechoice="false"
- :typeinfo="1"
- />
- <pagination
- v-show="total > 0"
- :total="total"
- :page.sync="topqueryParams.pageNum"
- :limit.sync="topqueryParams.pageSize"
- @pagination="Acquisitiontype"
- />
- </el-row>
+ <el-button
+ v-if="form.templateid"
+ type="success"
+ icon="el-icon-search"
+ @click="previewfnmb()"
+ circle
+ ></el-button>
+ </el-form-item>
+ </el-form>
</div>
</div>
- </div>
- </div>
- <el-button type="success" @click="nextstep('ruleForm')">{{
- quote ? "绔嬪嵆鍒涘缓" : "浠诲姟璇︽儏閰嶇疆"
- }}</el-button>
- <el-button @click="resetForm('ruleForm')">閲嶇疆</el-button>
- </div>
- <!-- 浠诲姟璇︽儏 -->
- <div v-if="Editprogress == 2">
- <el-alert title="鍦ㄦ湰闃舵閫夋嫨瀹f暀鐥呬汉" type="success" effect="dark">
- </el-alert>
- <div class="leftvlue-jbxx">
- <div class="examine-jic">
- <div class="headline">
- <div>鍙橀噺鍖归厤閲忓弬</div>
- </div>
<div class="examine-jic">
<div class="jic-value">
+ <div style="margin-bottom: 10px">妯℃澘涓娇鐢ㄧ殑鍙橀噺锛�</div>
+
<el-row :gutter="20">
<el-table :data="variableList" style="width: 100%">
<el-table-column
@@ -397,6 +438,17 @@
</div>
</div>
</div>
+ </div>
+ <el-button type="success" @click="nextstep('ruleForm')">{{
+ quote ? "绔嬪嵆鍒涘缓" : "浠诲姟璇︽儏閰嶇疆"
+ }}</el-button>
+ <el-button @click="resetForm('ruleForm')">閲嶇疆</el-button>
+ </div>
+ <!-- 浠诲姟璇︽儏 -->
+ <div v-if="Editprogress == 2">
+ <el-alert title="鍦ㄦ湰闃舵閫夋嫨鐥呬汉" type="success" effect="dark">
+ </el-alert>
+ <div class="leftvlue-jbxx">
<div class="examine-jic">
<div class="headline">
<div>鎮h�呭垪琛�</div>
@@ -404,88 +456,6 @@
<div class="examine-jic">
<div class="jic-value">
<el-row :gutter="20">
- <!--鐢ㄦ埛鏁版嵁-->
- <el-form
- :model="topqueryParams"
- ref="queryForm"
- size="small"
- :inline="true"
- v-show="showSearch"
- label-width="98px"
- >
- <el-form-item label="鎮h�呭悕绉�">
- <el-input v-model="topqueryParams.name"></el-input>
- </el-form-item>
-
- <el-form-item label="鎮h�呰寖鍥�" prop="status">
- <el-select
- v-model="topqueryParams.topic"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in taskoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
-
- <el-form-item label="鎮h�呯姸鎬�" prop="status">
- <el-select
- v-model="topqueryParams.topic"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in topicoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="闅忚缁撴灉" prop="status">
- <el-select
- v-model="topqueryParams.topic"
- placeholder="璇烽�夋嫨"
- >
- <el-option
- v-for="item in topicoptions"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="鎮h�呯數璇�">
- <el-input v-model="topqueryParams.name"></el-input>
- </el-form-item>
- <el-form-item>
- <el-button
- type="primary"
- icon="el-icon-search"
- size="medium"
- @click="handleQuery"
- >鎼滅储</el-button
- >
- <el-button
- icon="el-icon-refresh"
- size="medium"
- @click="resetQuery"
- >閲嶇疆</el-button
- >
- <el-button
- icon="el-icon-upload2"
- size="medium"
- type="warning"
- >褰撳墠鎮h�呬竴閿彂閫�</el-button
- >
- </el-form-item>
- </el-form>
- <el-divider></el-divider>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-select
@@ -501,6 +471,7 @@
</el-option>
</el-select>
</el-col>
+
<el-col :span="1.5">
<el-button
type="primary"
@@ -508,12 +479,12 @@
icon="el-icon-plus"
size="medium"
:disabled="!patientqueryParams.allhosp"
- @click="handleAddpatient"
- >鏂板</el-button
+ @click="handleQuery"
+ >娣诲姞鎮h��</el-button
>
</el-col>
- <el-col :span="1.5">
+ <!-- <el-col :span="1.5">
<el-button
type="danger"
plain
@@ -523,7 +494,7 @@
@click="handleDelete"
>鍒犻櫎</el-button
>
- </el-col>
+ </el-col> -->
<!-- <el-col :span="1.5"> </el-col> -->
</el-row>
@@ -532,8 +503,9 @@
@details="detailhz"
@handleUpdate="handleUpdate"
:currentList="overallCase"
- :tableLabel="tableLabelhz"
+ :tableLabel="tableLabelhzwb"
:serialnumber="false"
+ :searchTrue="true"
:multiplechoice="false"
:controlxz="false"
:typeinfo="2"
@@ -551,7 +523,7 @@
</div>
</div>
<el-button type="primary" @click="laststep()">涓婁竴姝�</el-button>
- <el-button type="success" @click="submitForm('ruleForm')">{{
+ <el-button type="success" @click="submitForm('11')">{{
quote ? "绔嬪嵆鍒涘缓" : "纭浠诲姟閰嶇疆"
}}</el-button>
<el-button @click="resetForm('ruleForm')">閲嶇疆</el-button>
@@ -559,7 +531,7 @@
</div>
<!-- 娣诲姞鎮h�� -->
<el-dialog
- title="娣诲姞娲惧彂鎮h��"
+ title="閫夋嫨鎮h��"
:visible.sync="dialogVisiblepatient"
width="70%"
:before-close="handleClosehz"
@@ -577,30 +549,30 @@
v-show="showSearch"
label-width="98px"
>
- <el-form-item label="鎮h�呭悕绉帮細">
- <el-input v-model="patientqueryParams.name"></el-input>
+ <el-form-item label="涓绘不鍖荤敓锛�">
+ <el-input
+ v-model="patientqueryParams.drname"
+ @keyup.enter.native="handleQuery"
+ ></el-input>
</el-form-item>
-
- <el-form-item label="灏辫瘖绉戝" prop="status">
- <el-select
- v-model="patientqueryParams.topic"
- placeholder="璇烽�夋嫨"
+ <el-form-item label="鎮h�咃細">
+ <el-input
+ v-model="patientqueryParams.name"
+ @keyup.enter.native="handleQuery"
+ ></el-input>
+ </el-form-item>
+ <el-select
+ v-model="patientqueryParams.searchscope"
+ placeholder="璇烽�夋嫨鎮h�呰寖鍥�"
+ >
+ <el-option
+ v-for="item in source"
+ :key="item.value"
+ :label="item.label"
+ :value="item.value"
>
- <el-option-group
- v-for="group in topicoptions[0].children"
- :key="group.deptName"
- :label="group.deptName"
- >
- <el-option
- v-for="item in group.children"
- :key="item.deptId"
- :label="item.deptName"
- :value="item.deptId"
- >
- </el-option>
- </el-option-group>
- </el-select>
- </el-form-item>
+ </el-option>
+ </el-select>
<el-form-item>
<el-button
@@ -646,43 +618,277 @@
>
</span>
</el-dialog>
- <el-dialog title="妯$増棰勮" :visible.sync="previewtf" width="60%">
- <div class="preview-left">
- <!-- 鍗曢�� -->
- <div
- class="topic-dev"
- v-for="(item, index) in questionList"
- :key="item.aaa"
- >
- <div class="dev-text">
- {{ index + 1 }}銆�<span>{{ item.questionText }}</span>
- </div>
+ <!-- 妯℃澘棰勮 -->
+ <el-dialog title="妯℃澘棰勮" :visible.sync="previewtf" width="70%">
+ <el-tabs type="border-card">
+ <el-tab-pane label="妯℃澘鍩虹鏁版嵁"
+ ><div class="preview-left">
+ <el-form :model="objyl" label-width="100px" class="demo-objyl">
+ <el-row :gutter="10">
+ <el-col :span="14">
+ <el-form-item label="闅忚鍒嗙被" prop="assortid">
+ <el-select
+ v-model="objyl.assortid"
+ size="medium"
+ filterable
+ placeholder="璇烽�夋嫨鍒嗙被"
+ >
+ <el-option-group
+ v-for="group in optionsclass"
+ :key="group.id"
+ :label="group.indexAssortName"
+ >
+ <el-option
+ v-for="item in group.ivrLibaTemplateAssortList"
+ :key="item.id"
+ :label="item.indexAssortName"
+ :value="item.id"
+ >
+ </el-option>
+ </el-option-group>
+ </el-select>
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20">
+ <el-col :span="14">
+ <el-form-item label="鍙敤鐘舵��" prop="isenable">
+ <el-radio-group v-model="objyl.isenable">
+ <el-radio
+ v-for="(item, index) in usable"
+ :label="item.value"
+ >{{ item.label }}</el-radio
+ >
+ </el-radio-group>
+ </el-form-item>
+ </el-col>
+ <el-col :span="8">
+ <el-form-item label="鐗堟湰鍙�" prop="name">
+ <el-input
+ v-model="objyl.version"
+ placeholder="榛樿1.0"
+ ></el-input>
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-form-item label="闅忚鏍囬" prop="templateName">
+ <div style="width: 400px">
+ <el-input v-model="objyl.templateName"></el-input>
+ </div>
+ </el-form-item>
- <div class="dev-xx" v-if="item.valueType == 1">
- <el-radio-group v-model="item.radio">
- <el-radio
- v-for="(items, index) in item.ivrLibaScriptTargetoptionList"
- :key="items.id"
- :label="items.id"
- >{{ items.targetvalue }}</el-radio
+ <div class="xinz-infs">
+ <el-form-item>
+ <template #label>
+ 閫傜敤鐤剧梾
+ <el-tooltip
+ class="item"
+ effect="light"
+ content="閫夋嫨濂介�傜敤鐤剧梾鍚庯紝鍙互鏂逛究鎮ㄩ�氳繃鐤剧梾璇婃柇鏌ユ壘鍒板搴旂殑鐥呬汉!"
+ placement="top-start"
+ >
+ <i class="el-icon-warning-outline"></i>
+ </el-tooltip>
+ </template>
+
+ <el-tag
+ v-for="tag in illnesslist"
+ :key="tag.icdid"
+ type="warning"
+ :disable-transitions="false"
+ >
+ {{ tag.icdname }}
+ </el-tag>
+ <!-- <el-tag v-if="hasMore" type="info">+{{ remaining }} more</el-tag> -->
+ </el-form-item>
+ </div>
+ <el-form-item label="闅忚鎻忚堪" prop="description">
+ <el-input
+ type="textarea"
+ :rows="2"
+ placeholder="璇疯緭鍏ュ唴瀹�"
+ v-model="objyl.description"
+ >
+ </el-input
+ ></el-form-item>
+
+ <el-form-item label="闅忚缁撴潫璇�" prop="conclusion">
+ <el-input
+ type="textarea"
+ :rows="2"
+ placeholder="璇疯緭鍏ュ唴瀹�"
+ v-model="objyl.conclusion"
+ >
+ </el-input
+ ></el-form-item>
+ </el-form></div
+ ></el-tab-pane>
+ <el-tab-pane label="闂灞曠ず"
+ ><div class="preview-left">
+ <div v-for="item in questionList">
+ <!-- 鍗曢�� -->
+ <div
+ class="scriptTopic-dev"
+ :key="item.sort"
+ v-if="item.scriptType == 1"
>
- </el-radio-group>
- </div>
- <div v-else>
- <el-input
- type="textarea"
- placeholder="鏈幏鍙栧埌淇℃伅"
- v-model.sync="item.questionResult"
- :rows="2"
- />
- </div>
- </div>
- </div>
+ <div class="dev-text">
+ {{ item.sort }}銆乕鍗曢�塢<span>{{ item.scriptContent }}</span>
+ </div>
+ <div class="dev-xx">
+ <el-radio-group v-model="item.remark">
+ <el-radio
+ v-for="(
+ items, index
+ ) in item.ivrLibaScriptTargetoptionList"
+ :key="index"
+ :label="index"
+ >{{ items.targetvalue }}</el-radio
+ >
+ </el-radio-group>
+ </div>
+ </div>
+ <!-- 澶氶�� -->
+ <div
+ class="scriptTopic-dev"
+ :key="item.sort"
+ v-if="item.scriptType == 2"
+ >
+ <div class="dev-text">
+ {{ item.sort }}銆乕澶氶�塢<span>{{ item.scriptContent }}</span>
+ </div>
+ <div class="dev-xx">
+ <el-checkbox-group v-model="qremark">
+ <el-checkbox
+ v-for="(
+ items, index
+ ) in item.ivrLibaScriptTargetoptionList"
+ :key="index"
+ :label="index"
+ >
+ {{ items.targetvalue }}
+ </el-checkbox>
+ </el-checkbox-group>
+ </div>
+ </div>
+ <!-- 濉┖ -->
+ <div
+ class="scriptTopic-dev"
+ :key="item.sort"
+ v-if="item.scriptType == 4"
+ >
+ <div class="dev-text">
+ {{ item.sort }}銆乕闂瓟]<span>{{ item.scriptContent }}</span>
+ </div>
+ <div class="dev-xx">
+ <el-input
+ placeholder="璇疯緭鍏ョ瓟妗�"
+ v-model="item.radioas"
+ clearable
+ >
+ </el-input>
+ </div>
+ </div>
+ </div></div
+ ></el-tab-pane>
+ </el-tabs>
+
<span slot="footer" class="dialog-footer">
- <el-button @click="previewGo">鍓嶅線妯$増璇︽儏淇敼</el-button>
- <el-button type="primary" @click="previewFn">纭浣跨敤</el-button>
+ <!-- <el-button @click="previewGo">淇濆瓨妯℃澘璇︽儏淇敼</el-button> -->
+ <el-button
+ v-if="(form.templateid && form.sendState == 1) || !form.templateid"
+ type="primary"
+ @click="Departmenttreatment"
+ >{{ form.templateid ? "鏇挎崲浣跨敤" : "閫夋嫨浣跨敤" }}</el-button
+ >
+ <el-button
+ :type="previewtftype ? 'success' : 'warning'"
+ @click="Modifytemplate"
+ >{{
+ previewtftype ? "鍓嶅線淇敼宸查�夋嫨妯℃澘" : "鏂板淇濆瓨骞跺墠寰�淇敼"
+ }}</el-button
+ >
</span>
</el-dialog>
+ <el-drawer
+ title="闅忚鍐呭鍒楄〃"
+ :visible.sync="drawermb"
+ direction="rtl"
+ size="50%"
+ >
+ <div class="headline"></div>
+ <div class="examine-jic">
+ <div class="jic-value">
+ <el-row :gutter="20">
+ <!--鐢ㄦ埛鏁版嵁-->
+
+ <el-form
+ :model="topqueryParams"
+ ref="queryForm"
+ size="small"
+ :inline="true"
+ v-show="showSearch"
+ label-width="98px"
+ >
+ <el-form-item label="闅忚鍚嶇О">
+ <el-input v-model="topqueryParams.templateName"></el-input>
+ </el-form-item>
+ <!-- <el-form-item label="閫傜敤褰㈠紡" prop="status">
+ <el-select v-model="topqueryParams.topica" placeholder="璇烽�夋嫨">
+ <el-option
+ v-for="item in taskoptions"
+ :key="item.value"
+ :label="item.label"
+ :value="item.value"
+ >
+ </el-option>
+ </el-select>
+ </el-form-item> -->
+ <el-form-item>
+ <el-button
+ type="primary"
+ icon="el-icon-search"
+ size="medium"
+ @click="handleQuerymb"
+ >鎼滅储</el-button
+ >
+ <el-button
+ icon="el-icon-refresh"
+ size="medium"
+ @click="resetQuery"
+ >閲嶇疆</el-button
+ >
+ </el-form-item>
+ </el-form>
+ <el-divider></el-divider>
+ <!-- 閫夋嫨妯℃澘鍒楄〃 -->
+ <SFtable
+ @selectfn="selectfn"
+ :currentList="userList"
+ :tableLabel="tableLabel"
+ :serialnumber="false"
+ :controlsc="false"
+ :multiplechoice="false"
+ :typeinfo="1"
+ />
+ <pagination
+ v-show="total > 0"
+ :total="total"
+ :page.sync="topqueryParams.pageNum"
+ :limit.sync="topqueryParams.pageSize"
+ @pagination="Acquisitiontype"
+ />
+ </el-row>
+ </div>
+ </div>
+ </el-drawer>
+ <Optional-Form
+ ref="child"
+ :dialogVisiblepatient="dialogVisiblepatientjb"
+ :overallCase="diagglist"
+ @addoption="dialogVisiblepatientjb = false"
+ @kkoption="dialogVisiblepatientjb = true"
+ />
</div>
</template>
@@ -690,89 +896,116 @@
import { messagelistpatient } from "@/api/patient/homepage";
import store from "@/store";
import {
- getTaskpatient,
- getlibrarylist,
+ getTaskpatientQC,
+ getillnesslist,
+ getbaseopera,
getFollowuplist,
- getQtemplatelist,
- TaskTemplatecomit,
- getTaskInfo,
- gethetaskinfo,
- delhetaskinfo,
- Editsingletask,
getvFollowup,
+ Taskparticty,
+ deleteTaskparticty,
+ getTaskInfo,
+ getTaskparticty,
+ depthospgetson,
+ getillness,
+ Editsingletask,
+ getFollowupclassify,
+ taskdepthospgetsonlist,
+ taskdepthospgetsondel,
+ taskoperhospgetsondel,
+ taskdiaghospgetsondel,
+ taskdiaggetlist,
+ taskopergetlist,
} from "@/api/AiCentre/index";
-import { listDept } from "@/api/system/dept";
+import { deptTreeSelect } from "@/api/system/user";
+import OptionalForm from "@/components/OptionalForm";
+import SortCheckbox from "@/components/SortCheckbox"; //琛ㄦ牸缁勪欢
+import { MessageBox } from "element-ui";
import SFtable from "@/components/SFtable"; //琛ㄦ牸缁勪欢
export default {
- name: "ServiceDetails",
+ name: "particty",
data() {
return {
title: "瀹f暀鍐呭鍒楄〃",
- currenttype: 1, //1瀹f暀2闂ㄨ瘖3鍑洪櫌4澶嶈瘖5浣撴6闂嵎
+ currenttype: 1, //1瀹f暀2闂ㄨ瘖3鍑洪櫌4澶嶈瘖5浣撴6闅忚
id: "", //
- previewid: "", //浠诲姟妯$増浼犻�抜d
+ previewid: "", //浠诲姟妯℃澘浼犻�抜d
libName: "",
+ username: "",
+ templateor: false,
+ objyl: {},
overallCase: [], //閫夋嫨鎮h�呮��
allpids: [],
- libId: null, //妯℃澘搴撴ā鐗坕d
+ appraiselist: [],
+ optionsclass: [],
+ illnesslist: [],
+ mode: [],
+ libId: null, //妯℃澘搴撴ā鏉縤d
Editprogress: 1, //缂栬緫杩涘害
+ drawermb: false, //閫夋嫨妯℃澘寮圭獥
previewtf: false, //棰勮
+ previewtftype: 0, //棰勮鎯呭喌0鏂版ā鏉块瑙�1宸查�夋嫨妯℃澘淇敼
loading: false, // 閬僵灞�
patientloading: false, // 閬僵灞�
dialogVisiblepatient: false, //娣诲姞鎮h�呭脊妗�
+ dialogVisiblepatientjb: false,
+ deptcodesWards: [], //绉戝鏁版嵁
+ leavehospitaldistrictcodes: [], //鐥呭尯鏁版嵁
+ operationcodes: [], //鎵嬫湳鏁版嵁
+ illnesscodes: [], //鐤剧梾鏁版嵁
radio: 1,
checkboxlist: [],
tableLabel: [],
questionList: [],
+ skip: false,
+ donorchargeList: [],
+ baseoperaList: [],
+ selectedOrder: [],
+
+ usable: [
+ { value: "0", label: "鍙敤" },
+ { value: "1", label: "鍋滅敤" },
+ ],
+ required: [
+ { value: "1", label: "蹇呭~" },
+ { value: "2", label: "涓嶅繀濉�" },
+ ],
+ props: { multiple: true, value: "deptCode", label: "deptName" },
+ propstask: { value: "deptCode", label: "deptName" },
// 鎮h�呰〃鍗�
tableLabelhz: [
- { label: "搴忓彿", width: "", prop: "patid" },
- { label: "鎮h�呭悕绉�", width: "", prop: "name" },
+ { label: "鍑洪櫌鏃ユ湡", width: "150", prop: "inhosptime" },
+ { label: "鎮h��", width: "", prop: "name" },
+ { label: "韬唤璇�", width: "200", prop: "idcardno" },
+ { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" },
{ label: "鎬у埆", width: "", prop: "sex" },
{ label: "骞撮緞", width: "", prop: "age" },
- { label: "灏辫瘖绉戝", width: "", prop: "deptName" },
- { label: "鍏ラ櫌鏃ユ湡", width: "", prop: "inhosptime" },
- { label: "鍒涘缓浜猴紙缂猴級", width: "", prop: "update_by" },
+ { label: "璐d换鎶ゅ+", width: "", prop: "nurseName" },
+ { label: "涓绘不鍖荤敓", width: "", prop: "drname" },
+ { label: "绉戝", width: "240", prop: "dept" },
+ { label: "鐥呭尯", width: "240", prop: "leavehospitaldistrictname" },
],
- tableLabelxj: [
- { label: "瀹f暀鍚嶇О", width: "", prop: "preachname" },
- { label: "瀹f暀鎻忚堪", width: "", prop: "note" },
- { label: "瀹f暀褰㈠紡", width: "", prop: "playType" },
- { label: "閫傜敤鏂瑰紡", width: "", prop: "suitway" },
- { label: "淇敼鏃ユ湡", width: "", prop: "uploadTime" },
- { label: "鍒涘缓浜猴紙缂猴級", width: "", prop: "updateBy" },
+ // 鎮h�呰〃鍗�
+ tableLabelhzwb: [
+ { label: "鍑洪櫌鏃ユ湡", width: "150", prop: "endtime" },
+ { label: "鎮h��", width: "", prop: "name" },
+ { label: "韬唤璇�", width: "200", prop: "sfzh" },
+ { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" },
+ { label: "鎬у埆", width: "", prop: "sex" },
+ { label: "骞撮緞", width: "", prop: "age" },
+ { label: "鍑洪櫌澶╂暟", width: "", prop: "endDay" },
+ { label: "璐d换鎶ゅ+", width: "", prop: "nurseName" },
+ { label: "涓绘不鍖荤敓", width: "", prop: "drname" },
+ { label: "绉戝", width: "180", prop: "deptName" },
+ { label: "鐥呭尯", width: "150", prop: "leavehospitaldistrictname" },
],
- tableLabelmz: [
- { label: "闅忚鍚嶇О", width: "", prop: "templateName" },
- { label: "涓昏鍐呭", width: "", prop: "note" },
- { label: "淇敼鏃ユ湡", width: "", prop: "updateTime" },
- { label: "鍒涘缓浜猴紙缂猴級", width: "", prop: "updateBy" },
- ],
- tableLabelcy: [
- { label: "闅忚鍚嶇О", width: "", prop: "templateName" },
- { label: "闅忚璁″垝", width: "", prop: "impTemplate" },
- { label: "淇敼鏃ユ湡", width: "", prop: "uploadTime" },
- { label: "鍒涘缓浜猴紙缂猴級", width: "", prop: "updateBy" },
- ],
- tableLabelfz: [
- { label: "閫氱煡鍚嶇О", width: "", prop: "templateName" },
- { label: "閫氱煡妯$増", width: "", prop: "impTemplate" },
- { label: "淇敼鏃ユ湡", width: "", prop: "uploadTime" },
- { label: "鍒涘缓浜猴紙缂猴級", width: "", prop: "updateBy" },
- ],
- tableLabeltj: [
- { label: "閫氱煡鍚嶇О", width: "", prop: "name" },
- { label: "閫氱煡妯$増", width: "", prop: "impTemplate" },
- { label: "淇敼鏃ユ湡", width: "", prop: "uploadTime" },
- { label: "鍒涘缓浜猴紙缂猴級", width: "", prop: "updateBy" },
- ],
+
tableLabelwj: [
- { label: "闂嵎鍚嶇О", width: "", prop: "name" },
- { label: "闂嵎妯$増", width: "", prop: "impTemplate" },
- { label: "淇敼鏃ユ湡", width: "", prop: "uploadTime" },
- { label: "鍒涘缓浜猴紙缂猴級", width: "", prop: "updateBy" },
+ { label: "鍒涘缓浜�", width: "", prop: "createBy" },
+ { label: "妯℃澘鏍囬", width: "", prop: "templateName" },
+ { label: "闅忚鎻忚堪", width: "", prop: "note" },
+ { label: "淇敼鏃ユ湡", width: "", prop: "updateTime" },
],
// 鍙橀噺
tableLabelvariable: [
@@ -780,16 +1013,18 @@
{ label: "鍖归厤绗�", width: "", prop: "character" },
{ label: "鏇挎崲鍊�", width: "", prop: "Replacementvalue" },
],
- Serviceform: [
+ preachform: [
{ label: "澶氬獟浣�", value: 1 },
{ label: "绾歌川", value: 2 },
- { label: "鐢佃瘽", value: 3 },
+ { label: "鏅鸿兘璇煶", value: 3 },
{ label: "鐭俊", value: 4 },
{ label: "寰俊鍏紬鍙�", value: 5 },
{ label: "寰俊灏忕▼搴�", value: 6 },
{ label: "鏀粯瀹�", value: 7 },
{ label: "鏅鸿兘灏忕▼搴�", value: 8 },
{ label: "閽夐拤", value: 9 },
+ { label: "绾夸笅锛堢焊璐級", value: 10 },
+ { label: "绾夸笂锛堢煭淇�/閽夐拤鐨勬枃鏈�侀殢璁块摼鎺ワ級", value: 11 },
],
// 鏃堕棿澶勭悊
daytime: [], //鏃ユ湡
@@ -797,11 +1032,18 @@
time1: "", //涓婂崍鏃堕棿娈�
time2: "", //涓嬪崍鏃堕棿娈�
time3: "", //鏅氫笂鏃堕棿娈�
+ time4: "", //鏅氫笂鏃堕棿娈�
topqueryParams: {
pageNum: 1, //
pageSize: 10,
},
checkList: [],
+ foncheckList: [],
+ formatvalue: {
+ format1: "",
+ format2: "",
+ format3: "",
+ },
deliverytopqueryParams: {
pageNum: 1, //
pageSize: 10,
@@ -809,6 +1051,9 @@
patientqueryParams: {
pageNum: 1, //
pageSize: 10,
+ topica: 1, //0鍏ㄩ儴1绉戝2鐥呭尯
+ leaveldeptcodes: [],
+ leavehospitaldistrictcodes: [],
},
topicoptions: [{ children: [{ children: [] }] }],
showSearch: true, //
@@ -822,10 +1067,15 @@
// 闈炲涓鐢�
multiple: true,
// 鐢ㄦ埛琛ㄦ牸鏁版嵁
- userList: [], //妯$増鍒楄〃
+ userList: [], //妯℃澘鍒楄〃
+ multiplechoice: [], //澶氶�夌粨鏋�
patientuserList: [], //閫夋嫨鎮h�呭垪琛�
sonuserList: [], //閫変腑鎮h�呭垪琛�
delvariableList: [], //鍒犻櫎鍙橀噺涓存椂瀛樺偍
+ longtype: [
+ { value: 0, label: "鑷畾涔夊懆鏈�" },
+ { value: 1, label: "闀挎湡浠诲姟" },
+ ],
variableList: [
{
name: "濮撳悕",
@@ -871,15 +1121,25 @@
SelectPatientslist: [],
form: {
patTaskRelevances: [],
- sendType: 1,
+ sendType: 3,
+ longTask: 0,
templatename: "",
templateid: null,
libtemplateid: null,
+ kcb:
+ "浜茬埍鐨勬偅鑰�/瀹跺睘锛屾偍濂斤紒鎴戜滑鏄�" +
+ localStorage.getItem("orgname") +
+ "鐨勫尰鎶や汉鍛橈紝涓轰簡鏇村ソ鍦颁簡瑙f偍鐨勫悍澶嶆儏鍐碉紝璇锋偍鎶戒竴鐐瑰疂璐垫椂闂达紝杩涜鏈鍥炶鏈嶅姟銆�",
+ jsy: "璇锋偍娉ㄦ剰浼戞伅鍜岃惀鍏伙紝鐢熸椿涓婅鍔抽�哥粨鍚堬紝閫傚綋閿荤偧锛屾垝鐑熼檺閰掞紝淇濇寔蹇冩儏鑸掔晠锛屽畾鏈熷璇娿�傞偅鏈鍥炶鍐呭灏卞埌杩欓噷锛岀鎮ㄨ韩浣撳仴搴凤紒",
},
taskoptions: [
{
- value: "1",
+ value: "4",
label: "鍑洪櫌鐥呬汉",
+ },
+ {
+ value: "1",
+ label: "鍦ㄩ櫌鐥呬汉",
},
{
value: "2",
@@ -889,26 +1149,105 @@
value: "3",
label: "浣撴鐥呬汉",
},
+ {
+ value: "5",
+ label: "鎵嬫湳鐥呬汉",
+ },
],
+ source: [
+ {
+ value: 0,
+ label: "鎵�灞炴偅鑰�",
+ },
+ {
+ value: 1,
+ label: "绉戝鎮h��",
+ },
+ {
+ value: 2,
+ label: "鐥呭尯鎮h��",
+ },
+ ],
+
+ tasktypes: store.getters.tasktypes,
+ // 绉戝/鐥呭尯
+ belongWards: [],
+ deptlist: [],
+ hosplist: [],
+ diagglist: [],
+ operlist: [],
+ tempDetpRelevanceslist: [], //绉戝鏁版嵁
+ tempDetpRelevanceslistform: [], //绉戝鏁版嵁
+ tempbelongWards: [], //鐥呭尯鏁版嵁
+ tempbelongWardsform: [], //鐥呭尯鏁版嵁
+ rules: {
+ taskName: [
+ { required: true, message: "浠诲姟鍚嶇О涓嶈兘涓虹┖", trigger: "blur" },
+ {
+ min: 2,
+ max: 30,
+ message: "浠诲姟鍚嶇О闀垮害蹇呴』浠嬩簬 2 鍜� 30 涔嬮棿",
+ trigger: "blur",
+ },
+ ],
+ sendType: [
+ { required: true, message: "鍙戦�佽缃笉鑳戒负绌�", trigger: "blur" },
+ ],
+ // deptcode: [
+ // { required: true, message: "閫傜敤绉戝涓嶈兘涓虹┖", trigger: "blur" },
+ // ],
+ // leavehospitaldistrictcode: [
+ // { required: true, message: "閫傜敤鐥呭尯涓嶈兘涓虹┖", trigger: "blur" },
+ // ],
+ },
+ // 绉戝闄㈠尯鏌ヨ鍏ュ弬
+ queryParamsdept: {
+ tempid: "",
+ type: 2,
+ },
+ belongDepts: [],
quote: false,
+ serviceType: null,
};
},
- components: { SFtable },
+ components: { SFtable, OptionalForm, SortCheckbox },
created() {
+ this.appraiselist = store.getters.appraiselist;
+ this.belongWards = store.getters.belongWards;
+ this.belongDepts = store.getters.belongDepts;
+ this.username = store.getters.name;
+ this.mode = store.getters.Askmode;
this.id = this.$route.query.id;
- this.form.hospType = this.$route.query.type;
- this.listDept();
+ this.newadd = this.$route.query.newadd;
+ this.form.type = this.$route.query.type;
+ this.form.typename = this.$route.query.typename;
+ this.serviceType = Number(this.$route.query.serviceType);
+ this.form.serviceType = Number(this.$route.query.serviceType);
+ console.log(localStorage.getItem("orgid"), "orgid");
+
this.Acquisitiontype();
+ this.getillnesslist();
this.Getdetails();
+ this.getFollowupclassify();
+ },
+ activated() {
+ console.log(this.id, "CS", this.$route.query.id);
+ if (this.id != this.$route.query.id) {
+ this.id = this.$route.query.id;
+ this.newadd = this.$route.query.newadd;
+ this.form.type = this.$route.query.type;
+ this.form.typename = this.$route.query.typename;
+ this.serviceType = Number(this.$route.query.serviceType);
+ this.form.serviceType = Number(this.$route.query.serviceType);
+
+ this.Acquisitiontype();
+ this.Getdetails();
+ this.getFollowupclassify();
+ }
},
methods: {
- // {
- // 濮撳悕: { "${name}": "榫欏偛澶�" },
- // 鍦板潃: { "${dzz}": "榫欏" },
- // 鐢佃瘽: { "${dhh}": "鍏釜鍏�" },
- // }
// 鍙橀噺杞崲瀵硅薄杞暟缁�
convertFormat1ToFormat2(data) {
let result = [];
@@ -932,132 +1271,343 @@
});
return result;
},
+
+ flattenArray(multiArray) {
+ let result = [];
+
+ // 閫掑綊鍑芥暟锛岀敤浜庡皢澶氱骇鏁扮粍杞崲涓轰竴缁存暟缁勶紝鍙寘鍚渶搴曞眰鐨勫厓绱�
+ function flatten(element) {
+ // 濡傛灉褰撳墠鍏冪礌鏈夊瓙鍏冪礌锛岀户缁�掑綊
+ if (element.children && element.children.length > 0) {
+ element.children.forEach((child) => flatten(child));
+ } else {
+ // 鍏嬮殕鍏冪礌浠ラ伩鍏嶄慨鏀瑰師濮嬫暟鎹�
+ let item = JSON.parse(JSON.stringify(element));
+ result.push(item); // 灏嗘渶搴曞眰鐨勫厓绱犳坊鍔犲埌缁撴灉鏁扮粍
+ }
+ }
+
+ // 浠庨《灞傚厓绱犲紑濮嬮�掑綊
+ multiArray.forEach((element) => flatten(element));
+ return result; // 杩斿洖鍙寘鍚渶搴曞眰鍏冪礌鐨勪竴缁存暟缁�
+ },
// 鑾峰彇褰撳墠绫诲瀷
Acquisitiontype() {
let queryParams = {
pageNum: this.topqueryParams.pageNum,
pageSize: this.topqueryParams.pageSize,
- isavailable: "",
+ isenable: "",
};
this.currenttype = this.$route.query.type;
- console.log(this.currenttype, "1");
- if (this.currenttype == 1 || this.currenttype == 8) {
- // 鍖绘妧瀹f暀锛屾櫘閫氬鏁�
- this.title = "瀹f暀鍐呭鍒楄〃";
- this.tableLabel = this.tableLabelxj;
- this.checkboxlist = ["澶氬獟浣�", "绾歌川"];
- getlibrarylist(queryParams).then((response) => {
- this.userList = response.rows;
- this.total = response.total;
- });
- } else if (
- this.currenttype == 2 ||
- this.currenttype == 3 ||
- this.currenttype == 7
- ) {
- // 鍑洪櫌銆侀棬璇娿�佷笓鐥呴殢璁�
- this.title = "闅忚鍐呭鍒楄〃";
- this.tableLabel = this.tableLabelmz;
- this.checkboxlist = ["绾歌川", "澶氬獟浣�", "鐢佃瘽", "寰俊鍏紬鍙�"];
- getFollowuplist(queryParams).then((response) => {
- this.userList = response.rows;
- this.total = response.total;
- });
- } else if (this.currenttype == 4 || this.currenttype == 5) {
- // 澶嶈瘖銆佷綋妫�閫氱煡
- this.title = "閫氱煡鍐呭鍒楄〃";
- this.tableLabel = this.tableLabelfz;
- this.checkboxlist = ["绾夸笅", "AI璇煶澶栧懠", "浜哄伐鐢佃瘽", "鐭俊"];
- getFollowuplist(queryParams).then((response) => {
- this.userList = response.rows;
- this.total = response.total;
- });
- } else if (this.currenttype == 6) {
- this.title = "闂嵎鍐呭鍒楄〃";
- this.tableLabel = this.tableLabelwj;
+ this.title = "闅忚鍐呭鍒楄〃";
+ this.tableLabel = this.tableLabelwj;
+ if (this.form.serviceType == 1) {
this.checkboxlist = [
- "绾夸笅锛堢焊璐級",
- "绾夸笂锛堢煭淇�/閽夐拤鐨勬枃鏈�侀棶鍗烽摼鎺ワ級",
+ {
+ value: "1",
+ label: "浜哄伐",
+ },
+ {
+ value: "2",
+ label: "绾歌川",
+ },
+ {
+ value: "4",
+ label: "鐭俊",
+ },
+ {
+ value: "5",
+ label: "寰俊鍏紬鍙�",
+ },
];
- getQtemplatelist(queryParams).then((response) => {
- this.userList = response.rows;
- this.total = response.total;
- });
+ } else if (this.form.serviceType == 6) {
+ this.checkboxlist = [
+ {
+ value: "3",
+ label: "鏅鸿兘璇煶",
+ },
+ {
+ value: "4",
+ label: "鐭俊",
+ },
+ {
+ value: "5",
+ label: "寰俊鍏紬鍙�",
+ },
+ {
+ value: "6",
+ label: "寰俊灏忕▼搴�",
+ },
+
+ // {
+ // value: "8",
+ // label: "鏅鸿兘鏈哄櫒浜�",
+ // },
+ ];
+ } else if (
+ this.form.serviceType == 7 ||
+ this.form.serviceType == 5 ||
+ this.form.serviceType == 8 ||
+ this.form.serviceType == 9 ||
+ this.form.serviceType == 11 ||
+ this.form.serviceType == 12 ||
+ this.form.serviceType == 10
+ ) {
+ this.checkboxlist = [
+ {
+ value: "1",
+ label: "浜哄伐",
+ },
+ {
+ value: "2",
+ label: "绾歌川",
+ },
+ {
+ value: "3",
+ label: "鏅鸿兘璇煶",
+ },
+ {
+ value: "4",
+ label: "鐭俊",
+ },
+ {
+ value: "5",
+ label: "寰俊鍏紬鍙�",
+ },
+ {
+ value: "6",
+ label: "寰俊灏忕▼搴�",
+ },
+ {
+ value: "7",
+ label: "鏈悗闅忚",
+ },
+ ];
+ } else if (
+ this.form.serviceType == 2 ||
+ this.form.serviceType == 3 ||
+ this.form.serviceType == 16 ||
+ this.form.serviceType == 4
+ ) {
+ this.checkboxlist = [
+ {
+ value: "1",
+ label: "浜哄伐",
+ },
+ {
+ value: "3",
+ label: "鏅鸿兘璇煶",
+ },
+ {
+ value: "4",
+ label: "鐭俊",
+ },
+ {
+ value: "5",
+ label: "寰俊鍏紬鍙�",
+ },
+ {
+ value: "6",
+ label: "寰俊灏忕▼搴�",
+ },
+
+ // {
+ // value: "8",
+ // label: "鏅鸿兘鏈哄櫒浜�",
+ // },
+ ];
}
+ getFollowuplist(this.topqueryParams).then((response) => {
+ this.userList = response.rows;
+ this.total = response.total;
+ });
},
nextstep() {
- if (this.Editprogress <= 3) {
- return this.Editprogress++;
- }
+ this.$refs["form"].validate((valid) => {
+ if (valid) {
+ if (this.Editprogress <= 3) {
+ return this.Editprogress++;
+ }
+ } else {
+ this.$modal.msgError("琛ㄥ崟鍐呭鏈畬鍠勶紝璇锋鏌�");
+ }
+ });
},
// 淇濆瓨
- submitForm(formName) {
- // this.form.serviceform = this.checkList.join(",");
- this.formatFn(1);
- this.form.hospType = this.currenttype;
+ submitForm(type) {
+ if (this.templateor && type) this.templateor = false;
+ if (this.time4 && this.form.sendType == 3)
+ this.form.showTimeMorn = this.time4;
+ this.form.sendTimeslot = [
+ {
+ begantime: this.time4,
+ endtime: "",
+ xh: 1,
+ },
+ ];
+ if (this.form.appltype == 1) {
+ this.leavehospitaldistrictcodes = [];
+ this.operationcodes = [];
+ this.illnesscodes = [];
+ } else if (this.form.appltype == 2) {
+ this.deptcodesWards = [];
+ this.operationcodes = [];
+ this.illnesscodes = [];
+ } else if (this.form.appltype == 3) {
+ this.deptcodesWards = [];
+ this.leavehospitaldistrictcodes = [];
+ this.operationcodes = [];
+ } else if (this.form.appltype == 4) {
+ this.deptcodesWards = [];
+ this.illnesscodes = [];
+ this.leavehospitaldistrictcodes = [];
+ }
+ if (this.checkList) {
+ this.form.preachform = this.checkList.join(",");
+ this.form.preachformList = this.selectedOrder;
+ } else {
+ this.$modal.msgError("璇烽�夋嫨鏈嶅姟绫诲瀷");
+ return;
+ }
+
+ if (
+ this.deptcodesWards[0] ||
+ this.leavehospitaldistrictcodes[0] ||
+ this.diagglist[0] ||
+ this.operationcodes[0] ||
+ this.form.longTask == 2 ||
+ this.serviceType == 14
+ ) {
+ } else {
+ this.$modal.msgError("璇烽�夋嫨浠诲姟鍏宠仈鏉′欢");
+ return;
+ }
+ // if (!this.form.patTaskRelevances[0] && !this.form.longTask) {
+ // this.$modal.msgError("璇烽�夋嫨鐥呬汉");
+ // return;
+ // }
+
+ if (!this.form.templatename && !this.templateor) {
+ this.$modal.msgError("鏈�夋嫨妯℃澘");
+ return;
+ }
+
+ if ((this.form.sendType == 1 && this.time1) || this.form.sendType == 2) {
+ } else if (
+ (this.form.sendType == 3 && this.time4) ||
+ this.form.longTask
+ ) {
+ } else {
+ return this.$modal.msgError("鏃堕棿淇℃伅缂哄け");
+ }
const filteredArray = this.variableList.filter(
(item) =>
item.name !== "濮撳悕" && item.name !== "鐢佃瘽" && item.name !== "鍦板潃"
);
- console.log(filteredArray, "瀛樺墠鍙橀噺");
this.form.textParam = this.convertFormat2ToFormat1(filteredArray);
if (this.form.taskid) {
this.form.isoperation = 2;
} else {
this.form.isoperation = 1;
}
+ if (!this.form.type) {
+ this.form.type = this.$route.query.type;
+ }
+ this.form.serviceType = this.serviceType;
+ this.form.deptcode = this.deptcodesWards.join(",");
+ this.form.leavehospitaldistrictcode =
+ this.leavehospitaldistrictcodes.join(",");
+ this.form.opcode = this.operationcodes.join(",");
+ this.form.icd10code = this.diagglist
+ .map((item) => item.icdcode)
+ .join(",");
Editsingletask(this.form).then((res) => {
if (res.code == 200) {
if (this.form.taskid) {
- this.$modal.msgSuccess("鏂板鎴愬姛");
- } else {
this.$modal.msgSuccess("淇敼鎴愬姛");
+ } else {
+ this.$modal.msgSuccess("鏂板鎴愬姛");
}
- this.$router.go(-1);
+ this.$router.push({
+ path: "/followvisit/tasklist",
+ query: { tasktopic: this.form.serviceType },
+ });
}
});
},
+
// ----------------------琛ㄦ牸瀛愮粍浠朵簨浠�
- // 纭閫夋嫨妯$増鏀惧叆浠诲姟妯$増
+
+ // 閫夋嫨棰勮
selectfn(row, type) {
- // 妯$増鎯呭喌涓嬭幏鍙栨ā鐗堜俊鎭�
+ // 妯℃澘鎯呭喌涓嬭幏鍙栨ā鏉夸俊鎭�
if (type == 1) {
- if (
- this.currenttype == 2 ||
- this.currenttype == 4 ||
- this.currenttype == 3 ||
- currenttype == 5 ||
- currenttype == 7
- ) {
- this.libName = row.templateName;
- this.libId = row.id;
- } else if (this.currenttype == 1) {
- this.libName = row.preachname;
- this.libId = row.id;
- }
+ this.libName = row.templateName;
+ this.libId = row.id;
+ this.questionList = row.ivrLibaTemplateScriptVOList;
getvFollowup({ id: row.id }).then((res) => {
if (res.code == 200) {
- this.Tasktemplate = res.data;
- const data = res.data;
- this.questionList = data.ivrLibaTemplateScriptVOList;
+ this.objyl = res.data;
+ // if (this.form.longTask) {
+ // this.objyl.sendDay = 5;
+ // }
+ this.queryParamsdept.type = 2;
+ this.queryParamsdept.tempid = row.id;
+ this.tempDetpRelevanceslist = [];
+ this.tempbelongWards = [];
+ this.objyl.suitway = this.objyl.suitway.split(",");
+ this.questionList = res.data.ivrLibaTemplateScriptVOList;
+ this.getillness(row.id);
+ this.Variablehandling(res.data.ivrLibaTemplateScriptVOList, 1);
this.previewtf = true;
- this.previewid = data.id;
- console.log(this.questionList, "questionList");
- this.Variablehandling(data.ivrLibaTemplateScriptVOList, 1);
}
});
+ this.previewid = row.id;
} else if (type == 2) {
} else if (type == 3) {
+ }
+ },
+ // 棰勮
+ previewfnmb() {
+ getTaskparticty(this.form.templateid).then((res) => {
+ if (res.code == 200) {
+ this.objyl = res.data;
+ if (this.objyl.suitway)
+ this.objyl.suitway = this.objyl.suitway.split(",");
+ this.queryParamsdept.tempid = this.form.templateid;
+ this.queryParamsdept.type = 21;
+ // 鐤剧梾
+ this.getillness(this.form.libtemplateid);
+
+ getvFollowup({ id: this.form.libtemplateid }).then((res) => {
+ if (res.code == 200) {
+ this.previewtf = true;
+ this.previewtftype = 1;
+ this.questionList = res.data.ivrLibaTemplateScriptVOList;
+ this.objyl.ivrLibaTemplateScriptVOList =
+ res.data.ivrLibaTemplateScriptVOList;
+ } else {
+ }
+ });
+ }
+ });
+ },
+ getillness(id) {
+ if (id) {
+ getillness({ outid: id, type: 5 }).then((res) => {
+ this.illnesslist = res.rows;
+ this.illnesslist.forEach((item) => {
+ item.icdname = item.icd10name;
+ });
+ });
}
},
// 澶勭悊闂灞傚彉閲�
Variablehandling(arr, type) {
let Variablist = [];
if (type == 1) {
- console.log(arr);
// 寰幆闂
arr.forEach((res) => {
- console.log(JSON.parse(res.otherdata), "ss");
// 寰幆閫夐」
JSON.parse(res.otherdata).forEach((item) => {
if (item.default != 1) {
@@ -1069,33 +1619,103 @@
}
});
});
- console.log(Variablist, "Variablist");
+
const Aarr = Variablist.filter(
(obj, index, self) =>
index ===
self.findIndex((t) => t.name === obj.name && t.value === obj.value)
);
+
this.variableList = this.transitionList.concat(Aarr);
// this.form.textParam = this.convertFormat2ToFormat1(this.variableList);
}
},
// 瀛愪换鍔′簩绾у脊妗�
handleAddpatient(row) {
- console.log(this.overallCase, "ssaaa");
this.allpids = [];
this.overallCase.forEach((item) => {
this.allpids.push(item.patid);
});
+ if (this.patientqueryParams.allhosp == 1) {
+ this.tableLabelhz = [
+ // { label: "鍏ラ櫌鏃ユ湡", width: "170", prop: "starttime" },
+ { label: "鍑洪櫌鏃ユ湡", width: "150", prop: "endtime" },
+ { label: "鎮h��", width: "", prop: "name" },
+ { label: "韬唤璇�", width: "200", prop: "idcardno" },
+ { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" },
+ { label: "鎬у埆", width: "", prop: "sex" },
+ { label: "骞撮緞", width: "", prop: "age" },
+ { label: "鍑洪櫌澶╂暟", width: "", prop: "endDay" },
+ { label: "璐d换鎶ゅ+", width: "", prop: "nurseName" },
+ { label: "鍖荤敓", width: "", prop: "drname" },
+ { label: "绉戝", width: "180", prop: "dept" },
+ { label: "鐥呭尯", width: "150", prop: "leavehospitaldistrictname" },
+ ];
+ } else if (this.patientqueryParams.allhosp == 4) {
+ this.tableLabelhz = [
+ { label: "鍏ラ櫌鏃ユ湡", width: "150", prop: "starttime" },
+ { label: "鎮h��", width: "", prop: "name" },
+ { label: "韬唤璇�", width: "200", prop: "idcardno" },
+ { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" },
+ { label: "鎬у埆", width: "", prop: "sex" },
+ { label: "骞撮緞", width: "", prop: "age" },
+ { label: "鍑洪櫌澶╂暟", width: "", prop: "endDay" },
+ { label: "璐d换鎶ゅ+", width: "", prop: "nurseName" },
+ { label: "鍖荤敓", width: "", prop: "drname" },
+ { label: "绉戝", width: "180", prop: "dept" },
+ { label: "鐥呭尯", width: "150", prop: "leavehospitaldistrictname" },
+ ];
+ } else if (this.patientqueryParams.allhosp == 2) {
+ this.tableLabelhz = [
+ { label: "灏辫瘖鏃ユ湡", width: "150", prop: "admitdate" },
+ { label: "鎮h��", width: "", prop: "name" },
+ { label: "韬唤璇�", width: "200", prop: "idcardno" },
+ { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" },
+ { label: "鎬у埆", width: "", prop: "sex" },
+ { label: "骞撮緞", width: "", prop: "age" },
+ { label: "鍑洪櫌澶╂暟", width: "", prop: "endDay" },
+ { label: "璐d换鎶ゅ+", width: "", prop: "nurseName" },
+ { label: "鍖荤敓", width: "", prop: "drname" },
+ { label: "绉戝", width: "180", prop: "dept" },
+ { label: "鐥呭尯", width: "150", prop: "leavehospitaldistrictname" },
+ ];
+ }
if (this.allpids[0]) {
this.patientqueryParams.pids = this.allpids;
- console.log(this.patientqueryParams.pids);
} else {
this.patientqueryParams.pids = null;
}
+ if (this.patientqueryParams.allhosp == 1) {
+ this.patientqueryParams.cry = 1;
+ } else if (this.patientqueryParams.allhosp == 4) {
+ // this.patientqueryParams.cry = 0;
+ // this.patientqueryParams.allhosp = "1";
+ }
+ // 鏉ユ簮鍒ゆ柇
- getTaskpatient(this.patientqueryParams).then((response) => {
- console.log(response);
+ if (this.patientqueryParams.searchscope == 1) {
+ this.patientqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
+ (obj) => obj.deptCode
+ );
+ this.patientqueryParams.leavehospitaldistrictcodes = [];
+ } else if (this.patientqueryParams.searchscope == 2) {
+ this.patientqueryParams.leavehospitaldistrictcodes =
+ store.getters.belongWards.map((obj) => obj.districtCode);
+ this.patientqueryParams.leaveldeptcodes = [];
+ } else {
+ this.patientqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
+ (obj) => obj.deptCode
+ );
+ this.patientqueryParams.leavehospitaldistrictcodes =
+ store.getters.belongWards.map((obj) => obj.districtCode);
+ }
+ getTaskpatientQC(this.patientqueryParams).then((response) => {
this.patientuserList = response.rows;
+ this.patientuserList.forEach((item) => {
+ if (item.endtime) {
+ item.endDay = this.daysBetween(item.endtime);
+ }
+ });
this.patienttotal = response.total;
this.loading = false;
this.Restorecheck();
@@ -1105,12 +1725,9 @@
handleUpdate() {},
handleDelete() {},
handleExport() {},
- // 閫変腑鎮h�呰〃
- handlePitchionChange() {},
// 閫夋嫨鎮h�呰〃鏁版嵁
handleSelectionChange(selection) {
- console.log("澶氶�夋偅鑰�");
- this.SelectPatientslist = selection;
+ this.SelectPatientslist = structuredClone(selection);
this.multiple = !selection.length;
// 璧嬪�肩粰鏁翠綋閫変腑鏁扮粍
@@ -1118,6 +1735,23 @@
const isExist = this.overallCase.find((obj) => obj.name == item.name);
if (!isExist) {
item.isoperation = 1;
+ item.patid = item.id;
+ item.hospType = this.patientqueryParams.allhosp;
+ item.sfzh = item.idcardno;
+ item.deptCode = item.deptcode;
+ item.deptName = item.dept;
+ item.admindate = item.inhosptime;
+ item.sfzh = item.idcardno;
+ if (this.patientqueryParams.allhosp == 6) {
+ item.patfrom = 1;
+ }
+ if (this.patientqueryParams.allhosp == 1) {
+ item.visittime = item.endtime;
+ } else if (this.patientqueryParams.allhosp == 4) {
+ item.visittime = item.starttime;
+ } else if (this.patientqueryParams.allhosp == 2) {
+ item.visittime = item.admitdate;
+ }
this.overallCase.push(item);
this.form.patTaskRelevances.push(item);
}
@@ -1125,15 +1759,12 @@
},
// 鍒囨崲椤靛悗鎭㈠閫変腑
Restorecheck() {
- console.log(this.overallCase, "this.overallCase");
const allid = this.overallCase.map((item) => item.patid);
const overlap = this.patientuserList.filter((value) => {
return allid.includes(value.patid);
});
// 淇濇寔ids鍜屽綋鍓嶉〉闈㈢殑鍚屾鎬�
this.SelectPatientslist = overlap;
- console.log(this.SelectPatientslist, "杩涘叆鍒嗛〉SelectPatientslist");
-
this.toggleSelection(overlap);
},
// 鎸傝浇閫夋嫨鐘舵��
@@ -1146,7 +1777,6 @@
});
this.decision = false;
});
- console.log(123);
} else {
this.$refs.multipleTable.clearSelection();
}
@@ -1159,15 +1789,70 @@
let indexa = this.overallCase.indexOf(row);
let indexb = this.form.patTaskRelevances.indexOf(row);
this.overallCase.splice(indexa, 1);
- this.form.patTaskRelevances[indexb].isoperation = 3;
+ if (!this.form.taskid) {
+ this.form.patTaskRelevances.splice(indexa, 1);
+ } else {
+ this.form.patTaskRelevances[indexb].isoperation = 3;
+ }
this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
});
},
getList() {},
handleQuery() {
+ console.log(
+ "this.patientqueryParams.allhosp",
+ this.patientqueryParams.allhosp
+ );
+ if (this.patientqueryParams.topica == 0) {
+ this.patientqueryParams.leavehospitaldistrictcodes =
+ store.getters.leavehospitaldistrictcodes;
+ this.patientqueryParams.leaveldeptcodes = store.getters.leaveldeptcodes;
+ } else if (this.patientqueryParams.topica == 1) {
+ this.patientqueryParams.leavehospitaldistrictcodes = null;
+ this.patientqueryParams.leaveldeptcodes = store.getters.leaveldeptcodes;
+ } else if (this.patientqueryParams.topica == 2) {
+ this.patientqueryParams.leavehospitaldistrictcodes =
+ store.getters.leavehospitaldistrictcodes;
+ this.patientqueryParams.leaveldeptcodes = null;
+ }
+ if (
+ !this.patientqueryParams.leavehospitaldistrictcodes ||
+ !this.patientqueryParams.leavehospitaldistrictcodes[0]
+ )
+ this.patientqueryParams.leavehospitaldistrictcodes = null;
+ if (
+ !this.patientqueryParams.leaveldeptcodes ||
+ !this.patientqueryParams.leaveldeptcodes[0]
+ )
+ this.patientqueryParams.leaveldeptcodes = null;
this.handleAddpatient();
+
+ console.log(
+ "this.patientqueryParams.allhosp",
+ this.patientqueryParams.allhosp
+ );
},
- resetQuery() {},
+
+ resetQuerymb() {
+ this.topqueryParams = { svyname: "" };
+ this.handleQuerymb();
+ },
+ resetQuery() {
+ this.patientqueryParams = {
+ pageNum: 1, //
+ pageSize: 10,
+ topica: 1, //0鍏ㄩ儴1绉戝2鐥呭尯
+ leaveldeptcodes: [],
+ leavehospitaldistrictcodes: [],
+ };
+ this.handleQuery();
+ },
+ handleQuerymb() {
+ getFollowuplist(this.topqueryParams).then((response) => {
+ this.userList = response.rows;
+ this.total = response.total;
+ });
+ },
handleClosehz() {
this.dialogVisiblepatient = false;
},
@@ -1179,43 +1864,217 @@
resetForm(formName) {
this.$refs[formName].resetFields();
},
- // 棰勮妯$増
+ // 棰勮妯℃澘
PreviewTemplate() {},
Acknowledgereference() {
this.quote = true;
},
// 鑾峰彇璇︽儏
Getdetails() {
+ this.form = {
+ patTaskRelevances: [],
+ sendType: 1,
+ sendDay: 5,
+ templatename: "",
+ templateid: null,
+ libtemplateid: null,
+ kcb:
+ "浜茬埍鐨勬偅鑰�/瀹跺睘锛屾偍濂斤紒鎴戜滑鏄�" +
+ localStorage.getItem("orgname") +
+ "鐨勫尰鎶や汉鍛橈紝涓轰簡鏇村ソ鍦颁簡瑙f偍鐨勫悍澶嶆儏鍐碉紝璇锋偍鎶戒竴鐐瑰疂璐垫椂闂达紝杩涜鏈鍥炶鏈嶅姟銆�",
+ jsy: "璇锋偍娉ㄦ剰浼戞伅鍜岃惀鍏伙紝鐢熸椿涓婅鍔抽�哥粨鍚堬紝閫傚綋閿荤偧锛屾垝鐑熼檺閰掞紝淇濇寔蹇冩儏鑸掔晠锛屽畾鏈熷璇娿�傞偅鏈鍥炶灏卞埌杩欓噷锛岀鎮ㄨ韩浣撳仴搴凤紒",
+ };
+
+ this.questionList = [];
if (this.id) {
getTaskInfo({ taskid: this.id }).then((res) => {
let filteredArray = "";
- console.log(2233);
if (res.code == 200) {
this.form = res.data;
+ this.form.serviceType = this.serviceType;
+ this.form.patTaskRelevances = this.form.patTaskRelevances
+ ? this.form.patTaskRelevances
+ : [];
this.overallCase = this.form.patTaskRelevances.concat();
- this.formatFn(2);
- console.log(this.form.showDate, "this.form");
- this.daytime = this.form.showDate.split(",");
- if (this.form.showTimeMorn)
- this.time1 = this.form.showTimeMorn.split(",");
+ this.checkList = this.form.preachform.split(",");
+ this.selectedOrder = this.form.preachformList;
+
+ this.overallCase.forEach((item) => {
+ if (item.endtime) {
+ item.endDay = this.daysBetween(item.endtime);
+ }
+ });
+ if (this.form.showDate)
+ this.daytime = this.form.showDate.split(",");
+ if (this.form.showTimeMorn) {
+ if (this.form.sendType == 3) {
+ this.time4 = this.form.showTimeMorn;
+ } else {
+ this.time1 = this.form.showTimeMorn.split(",");
+ }
+ }
+ if (this.form.taskid) {
+ this.listDept();
+ }
if (this.form.showTimeNoon)
this.time2 = this.form.showTimeNoon.split(",");
if (this.form.showTimeNight)
this.time3 = this.form.showTimeNight.split(",");
- console.log(1122);
filteredArray = this.convertFormat1ToFormat2(this.form.textParam);
this.variableList = this.transitionList.concat(filteredArray);
} else {
this.$modal.msgError(res.code);
}
+ if (this.newadd) {
+ this.neWaddfn();
+ }
});
}
},
+ // 渚濈収鏂板鏃跺鐞�
+ neWaddfn() {
+ this.id = null;
+ this.form.taskName = "";
+ this.form.sendState = null;
+ this.form.taskid = null;
+ this.overallCase = [];
+ this.form.patTaskRelevances = [];
+ this.daytime = []; //鏃ユ湡
+ this.applydaytime = []; //璁$畻鏃ユ湡
+ this.time1 = ""; //涓婂崍鏃堕棿娈�
+ this.time2 = ""; //涓嬪崍鏃堕棿娈�
+ this.time3 = ""; //鏅氫笂鏃堕棿娈�
+ this.time4 = ""; //鏅氫笂鏃堕棿娈�
+ },
// 鑾峰彇绉戝鍒楄〃
listDept() {
- listDept().then((res) => {
- this.topicoptions = this.handleTree(res.data, "deptId");
- console.log(this.topicoptions, "topicoptions");
+ this.leavehospitaldistrictcodes = [];
+ this.deptcodesWards = [];
+ this.queryParamsdept.taskId = this.form.taskid;
+ taskdepthospgetsonlist(this.queryParamsdept).then((res) => {
+ if (res.code == 200) {
+ let arr = res.rows;
+ arr.forEach((item) => {
+ if (item.deptType == 1) {
+ this.deptlist.push(item);
+ this.deptcodesWards.push(item.deptCode);
+ } else if (item.deptType == 2) {
+ this.hosplist.push(item);
+ this.leavehospitaldistrictcodes.push(item.deptCode);
+ }
+ });
+ }
+ });
+ taskdiaggetlist(this.queryParamsdept).then((res) => {
+ if (res.code == 200) {
+ let arr = res.rows;
+ arr.forEach((item) => {
+ getillnesslist({
+ icdcode: item.icd10code,
+ }).then((res) => {
+ item.icdname = res.rows[0].icdname;
+ this.diagglist.push(item);
+ });
+ this.illnesscodes.push(item.icd10code);
+ });
+ }
+ });
+ taskopergetlist(this.queryParamsdept).then((res) => {
+ if (res.code == 200) {
+ let arr = res.rows;
+ arr.forEach((item) => {
+ this.operlist.push(item);
+ this.operationcodes.push(item.opcode);
+ });
+ }
+ });
+ },
+ getillnesslist() {
+ getillnesslist({
+ pageNum: 1,
+ pageSize: 1000,
+ }).then((row) => {
+ this.donorchargeList = res.rows;
+ });
+ getbaseopera({
+ pageNum: 1,
+ pageSize: 1000,
+ }).then((row) => {
+ this.baseoperaList = res.rows;
+ });
+ },
+ // 鎵嬫湳鏌ヨ
+ remoteopcode(name) {
+ if (name) {
+ getbaseopera({
+ pageNum: 1,
+ pageSize: 1000,
+ opdesc: name,
+ }).then((res) => {
+ this.baseoperaList = res.rows;
+ });
+ }
+ },
+
+ // 浠诲姟绉戝鍒犻櫎瑙﹀彂
+ removetag(row) {
+ let result = this.deptlist
+ .filter((item) => item.deptCode == row)
+ .map((item) => item.id);
+
+ if (result.length) {
+ taskdepthospgetsondel(result).then((res) => {
+ if (res.code) {
+ this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+ }
+ });
+ }
+ },
+ // 闄㈠尯鍒犻櫎鍒犻櫎瑙﹀彂
+ removehpsp(row) {
+ let result = this.hosplist
+ .filter((item) => item.deptCode == row)
+ .map((item) => item.id);
+ if (result.length) {
+ taskdepthospgetsondel(result).then((res) => {
+ if (res.code) {
+ this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+ }
+ });
+ }
+ },
+ // 鎵嬫湳鍒犻櫎瑙﹀彂
+ removeopera(row) {
+ let result = this.operlist
+ .filter((item) => item.opcode == row)
+ .map((item) => item.id);
+ if (result.length) {
+ taskoperhospgetsondel(result).then((res) => {
+ if (res.code) {
+ this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+ }
+ });
+ }
+ },
+ // 鐤剧梾鍒犻櫎瑙﹀彂
+ removediagg(row) {
+ let result = this.diagglist
+ .filter((item) => item.icd10code == row)
+ .map((item) => item.id);
+ if (result.length) {
+ taskdiaghospgetsondel(result).then((res) => {
+ if (res.code) {
+ this.diagglist = this.diagglist.filter(
+ (item) => item.icd10code != row
+ );
+ this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+ }
+ });
+ }
+ },
+ getFollowupclassify() {
+ getFollowupclassify({}).then((res) => {
+ this.optionsclass = res.rows;
});
},
// 鏂板娲鹃�佹偅鑰�
@@ -1232,12 +2091,14 @@
this.variableList.splice(index, 1);
row.isoperation = 3;
this.delvariableList.push(row);
- console.log(index, row);
},
// 鏃堕棿----------
changeTime(row) {
- console.log(row, "鏃堕棿");
this.processingTime();
+ },
+ Totaldate(row) {
+ this.form.sendTimeslot = [{ begantime: row, endtime: row, xh: 1 }];
+ this.form.showTimeMorn = row;
},
changeTimeday(row) {
const startDate = new Date(row[0]);
@@ -1298,61 +2159,169 @@
if (this.time1) this.form.showTimeMorn = this.time1.join(",");
if (this.time2) this.form.showTimeNoon = this.time2.join(",");
if (this.time3) this.form.showTimeNight = this.time3.join(",");
- console.log(combinedData, "combinedData");
},
- // 鏌ョ湅妯$増
- previewGo() {
- this.$router.push({
- path: "/knowledge/templateku/configurat/",
- query: { id: this.previewid, task: true, data: this.form },
- });
- },
+
+ // 淇濆瓨/鏇存柊浠诲姟妯℃澘
previewFn() {
- let id = this.Tasktemplate.id;
- this.Tasktemplate.id = null;
- this.Tasktemplate.ivrLibaTemplateScriptVOList.ivrTaskScriptTargetoptionList =
- this.Tasktemplate.ivrLibaTemplateScriptVOList.ivrLibaScriptTargetoptionList;
- this.Tasktemplate.ivrTaskTemplateScriptVOList =
- this.Tasktemplate.ivrLibaTemplateScriptVOList;
- this.Tasktemplate.ivrLibaTemplateTagList = null;
- this.Tasktemplate.tempDetpRelevances = null;
- this.Tasktemplate.libtemplateid = id;
- this.Tasktemplate.isoperation = 1;
- this.Tasktemplate.libtemplatename = this.Tasktemplate.templateName;
- TaskTemplatecomit(this.Tasktemplate).then((response) => {
- console.log(response);
- this.previewtf = false;
- this.form.templateid = response.data;
- this.form.libtemplateid = this.libId;
- this.form.templatename = this.libName;
- this.$modal.msgSuccess("閫夋嫨妯$増鎴愬姛");
+ if (Array.isArray(this.objyl.suitway)) {
+ this.objyl.suitway = this.objyl.suitway.join(",");
+ }
+ this.objyl.ivrLibaTemplateScriptVOList.forEach((item) => {
+ item.ivrTaskScriptTargetoptionList = item.ivrLibaScriptTargetoptionList;
+ });
+ this.objyl.ivrTaskTemplateScriptVOList =
+ this.objyl.ivrLibaTemplateScriptVOList;
+ this.objyl.isoperation = 1;
+ if (this.form.id) {
+ this.objyl.taskid = this.form.id;
+ }
+ // if (!this.objyl.sendDay) {
+ // this.objyl.sendDay = "5";
+ // }
+ if (this.form.templateid) {
+ deleteTaskparticty(this.form.templateid).then((res) => {
+ if (res.code == 200) {
+ Taskparticty(this.objyl).then((response) => {
+ this.previewtf = false;
+ this.form.libtemplateid = this.objyl.id;
+ this.form.templateid = response.data;
+ this.putbelongDepts(response.data);
+ this.form.templatename = this.objyl.templateName;
+ this.$modal.msgSuccess("鏇挎崲妯℃澘鎴愬姛");
+ this.drawermb = false; //閫夋嫨妯℃澘寮圭獥
+ this.previewtf = false; //棰勮
+ if (this.skip) {
+ // 璺宠浆鍓嶅線淇敼
+ this.$router.push({
+ path: "/knowledge/taskub/",
+ query: { id: response.data },
+ });
+ }
+ });
+ }
+ });
+ } else {
+ Taskparticty(this.objyl).then((response) => {
+ this.previewtf = false;
+ this.form.libtemplateid = this.objyl.id;
+ this.form.templateid = response.data;
+ this.putbelongDepts(response.data);
+ this.form.templatename = this.objyl.templateName;
+ this.$modal.msgSuccess("閫夋嫨妯℃澘鎴愬姛");
+ this.drawermb = false; //閫夋嫨妯℃澘寮圭獥
+ this.previewtf = false; //棰勮
+ if (this.skip) {
+ // 璺宠浆鍓嶅線淇敼
+ this.$router.push({
+ path: "/knowledge/taskub/",
+ query: { id: response.data },
+ });
+ }
+ });
+ }
+ },
+ // 淇濆瓨绉戝/鐥呭尯
+ putbelongDepts(id) {
+ this.tempDetpRelevanceslistform.forEach((item) => {
+ item.tempid = id;
+ });
+ this.tempbelongWardsform.forEach((item) => {
+ item.tempid = id;
+ });
+ depthospgetson(this.tempDetpRelevanceslistform).then((res) => {
+ if (res.code == 200) {
+ this.$modal.msgSuccess("绉戝鏇存柊鎴愬姛");
+ this.tempDetpRelevanceslistform = [];
+ }
+ });
+ depthospgetson(this.tempbelongWardsform).then((res) => {
+ if (res.code == 200) {
+ this.$modal.msgSuccess("鐥呭尯鏇存柊鎴愬姛");
+ this.tempbelongWardsform = [];
+ }
});
},
- // 澶勭悊鏈嶅姟褰㈠紡
- formatFn(type) {
- console.log(this.Serviceform);
- console.log(this.checkList);
- let list = [];
- let formlist = [];
- if (type == 1) {
- this.Serviceform.forEach((item) => {
- this.checkList.forEach((obj) => {
- if (item.label == obj) {
- list.push(item.value);
+ checkSelectionChange(selectedValues, selectedOrder) {
+ this.selectedOrder = selectedValues;
+ console.log("褰撳墠閫変腑:", selectedValues);
+ console.log("閫変腑椤哄簭:", selectedOrder);
+ },
+ // 鏈嶅姟褰㈠紡閫夊彇
+ handleCheckedCitiesChange(row) {
+ console.log(row, "鏈嶅姟");
+ this.foncheckList = this.checkboxlist.filter((obj) =>
+ row.includes(obj.value)
+ );
+ },
+ // 鏈嶅姟褰㈠紡鍒犻櫎
+ handleClosetag(tag) {
+ console.log(tag, "tag");
+ console.log(this.foncheckList, "foncheckList");
+ this.checkList = this.checkList.filter((item) => item != tag.value);
+ this.foncheckList = this.foncheckList.filter(
+ (obj) => obj.value !== tag.value
+ );
+ },
+ // 绉戝澶勭悊
+ Departmenttreatment() {
+ if (!this.form.taskid) {
+ this.templateor = true;
+ MessageBox.confirm(
+ "褰撳墠涓烘柊澧炰换鍔℃湭淇濆瓨涓嶅彲鍏宠仈妯℃澘锛屾槸鍚﹀厛鏆傚瓨妯℃澘淇濆瓨浠诲姟鍚庣敓鏁堬紵",
+ "鍔熻兘鎻愮ず",
+ {
+ confirmButtonText: "鏆傚瓨妯℃澘",
+ cancelButtonText: "鍙栨秷",
+ type: "warning",
+ }
+ )
+ .then(() => {
+ if (Array.isArray(this.objyl.suitway)) {
+ this.objyl.suitway = this.objyl.suitway.join(",");
}
+ this.objyl.templateid = this.objyl.id;
+ this.objyl.isoperation = 1;
+ this.objyl.ivrLibaTemplateScriptVOList.forEach((item) => {
+ item.ivrTaskScriptTargetoptionList =
+ item.ivrLibaScriptTargetoptionList;
+ });
+ this.objyl.ivrTaskTemplateScriptVOList =
+ this.objyl.ivrLibaTemplateScriptVOList;
+ this.form.ivrTaskTemplateVO = this.objyl;
+ this.form.templatename = this.objyl.templateName;
+ this.$modal.msgSuccess("鏆傚瓨鎴愬姛淇濆瓨浠诲姟鍚庢ā鏉垮け鏁�");
+ this.drawermb = false;
+ this.previewtf = false;
+ })
+ .catch(() => {
+ this.drawermb = false;
+ this.previewtf = false;
});
- });
- this.form.preachform = list.join(",");
} else {
- formlist = this.form.preachform.split(",");
- this.Serviceform.forEach((item) => {
- formlist.forEach((obj) => {
- if (item.value == obj) {
- list.push(item.label);
- }
+ setTimeout(() => {
+ this.previewFn();
+ }, 1000);
+ }
+ },
+ // 鍓嶅線淇敼
+ Modifytemplate() {
+ if (this.form.templateid && this.previewtftype) {
+ this.$modal.confirm("鏄惁鍓嶅線淇敼浠诲姟妯℃澘璇︾粏鍐呭锛�").then(() => {
+ this.drawermb = false; //閫夋嫨妯℃澘寮圭獥
+ this.previewtf = false; //棰勮
+ this.$router.push({
+ path: "/knowledge/taskub/",
+ query: { id: this.form.templateid },
});
});
- this.checkList = list;
+ } else {
+ this.$modal
+ .confirm("褰撳墠涓哄熀纭�棰勮鏄惁鍒涘缓浠诲姟妯℃澘骞跺墠寰�淇敼璇︽儏锛�")
+ .then(() => {
+ // 璧板彇鍏堢粦瀹氬悗淇敼鎿嶄綔
+ this.Departmenttreatment();
+ this.skip = true;
+ });
}
},
},
@@ -1389,13 +2358,15 @@
0 0 6px 0 rgba(0, 0, 0, 0.04);
}
.examine-jic {
+ margin: 20px;
.headline {
font-size: 24px;
+ height: 40px;
border-left: 5px solid #41a1be;
padding-left: 5px;
margin-bottom: 10px;
display: flex;
- justify-content: space-between;
+ // justify-content: space-between;
.Add-details {
font-size: 18px;
color: #02a7f0;
@@ -1430,32 +2401,24 @@
}
}
}
-// .leftvlue-jbxx {
-// margin-bottom: 50px;
-// font-size: 20px;
-// span {
-// position: absolute;
-// right: 80px;
-// }
-// .demo-cascader {
-// margin-right: 20px;
-// }
-// .PreviewTemplate {
-// color: #02a7f0;
-// cursor: pointer;
-// font-size: 20px;
-// margin: 0 20px;
-// }
-// }
+.xinz-infs {
+ font-size: 18px;
+ line-height: 48px;
+
+ .el-tag + .el-tag {
+ margin-left: 10px;
+ }
+}
+
.preview-left {
margin: 20px;
// margin: 20px;
padding: 30px;
background: #ffff;
- border: 1px solid #dcdfe6;
- -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12),
- 0 0 6px 0 rgba(0, 0, 0, 0.04);
- .topic-dev {
+ // border: 1px solid #dcdfe6;
+ // -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12),
+ // 0 0 6px 0 rgba(0, 0, 0, 0.04);
+ .scriptTopic-dev {
margin-bottom: 25px;
font-size: 20px !important;
.dev-text {
@@ -1524,7 +2487,7 @@
// }
::v-deep.el-radio-group {
span {
- font-size: 24px;
+ font-size: 18px;
}
}
::v-deep.el-input.is-disabled .el-input__inner {
@@ -1535,7 +2498,7 @@
}
::v-deep.el-checkbox-group {
span {
- font-size: 24px;
+ font-size: 18px;
}
}
</style>
--
Gitblit v1.9.3