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 | 872 ++++++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 600 insertions(+), 272 deletions(-) diff --git a/src/views/patient/propaganda/particty.vue b/src/views/patient/propaganda/particty.vue index 586d12d..40cb5fd 100644 --- a/src/views/patient/propaganda/particty.vue +++ b/src/views/patient/propaganda/particty.vue @@ -69,22 +69,31 @@ placeholder="璇疯緭鍏ヤ换鍔℃弿杩�" /> </el-form-item> - <el-form-item label="鏈嶅姟褰㈠紡"> - <el-checkbox-group + <!-- <el-form-item label="鏈嶅姟褰㈠紡"> + <el-radio-group v-model="checkList" @change="handleCheckedCitiesChange" > - <el-checkbox + <el-radio v-for="(item, index) in checkboxlist" :key="index" :label="item.value" - @change="checkboxChange($event, item.value)" > - {{ item.label }}</el-checkbox + {{ item.label }}</el-radio > - </el-checkbox-group> + </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"> + <!-- <div class="xinz-infs"> <el-form-item label="鏈嶅姟鎵ц椤哄簭" prop="daytime"> <el-tag :key="tag.label" @@ -94,16 +103,26 @@ :disable-transitions="false" @close="handleClosetag(tag)" > - ({{index+1}}){{ tag.label }} + ({{ index + 1 }}){{ tag.label }} </el-tag> </el-form-item> - </div> - <el-form-item label="鏄惁闀挎湡" prop="longTask"> + </div> --> + <el-form-item label="鎵ц鍛ㄦ湡" prop="longTask"> <el-radio-group v-model="form.longTask"> - <el-radio :label="0">鏅�氫换鍔�</el-radio> + <el-radio :label="0">鑷畾涔夊懆鏈�</el-radio> <el-radio :label="1">闀挎湡浠诲姟</el-radio> </el-radio-group> </el-form-item> + <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" @@ -204,13 +223,23 @@ </div> </div> </el-form-item> - <el-row> + <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="form.deptcode" + v-model="deptcodesWards" + @remove-tag="removetag" style="width: 400px" size="medium" + multiple filterable placeholder="璇烽�夋嫨绉戝" > @@ -225,28 +254,15 @@ </el-select> </el-form-item ></el-col> </el-row> - <el-row> + <el-row v-if="form.appltype == 2"> <el-col :span="20" ><el-form-item label="閫傜敤鐥呭尯" prop="region"> - <!-- <el-cascader - style="width: 400px" - v-model="form.leavehospitaldistrictcode" - :options="topicoptions" - :props="propstask" - :show-all-levels="false" - clearable - > - <template slot-scope="{ node, data }"> - <span>{{ data.deptName }}</span> - <span v-if="!node.isLeaf"> - ({{ data.children.length }}) - </span> - </template> - </el-cascader> --> <el-select - v-model="form.leavehospitaldistrictcode" + v-model="leavehospitaldistrictcodes" style="width: 400px" + @remove-tag="removehpsp" size="medium" + multiple filterable placeholder="璇烽�夋嫨鐥呭尯" > @@ -256,6 +272,65 @@ :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 @@ -297,6 +372,10 @@ placeholder="璇风偣鍑诲彸渚ч�夋嫨" /> <el-button + v-if=" + (form.templateid && form.sendState == 1) || + !form.templateid + " style="margin-left: 10px" type="primary" icon="el-icon-edit" @@ -305,10 +384,10 @@ ></el-button> <el-button - v-if="form.templatename" + v-if="form.templateid" type="success" icon="el-icon-search" - @click="previewfnmb" + @click="previewfnmb()" circle ></el-button> </el-form-item> @@ -401,7 +480,7 @@ size="medium" :disabled="!patientqueryParams.allhosp" @click="handleQuery" - >鏂板</el-button + >娣诲姞鎮h��</el-button > </el-col> @@ -444,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> @@ -470,6 +549,12 @@ v-show="showSearch" label-width="98px" > + <el-form-item label="涓绘不鍖荤敓锛�"> + <el-input + v-model="patientqueryParams.drname" + @keyup.enter.native="handleQuery" + ></el-input> + </el-form-item> <el-form-item label="鎮h�咃細"> <el-input v-model="patientqueryParams.name" @@ -568,7 +653,7 @@ <el-row :gutter="20"> <el-col :span="14"> <el-form-item label="鍙敤鐘舵��" prop="isenable"> - <el-radio-group v-model="objyl.usestate"> + <el-radio-group v-model="objyl.isenable"> <el-radio v-for="(item, index) in usable" :label="item.value" @@ -591,90 +676,6 @@ <el-input v-model="objyl.templateName"></el-input> </div> </el-form-item> - <el-form-item label="闅忚鏂瑰紡" prop="suitway"> - <el-select - style="width: 400px" - v-model="objyl.suitway" - size="medium" - multiple - filterable - placeholder="璇烽�夋嫨鍒嗙被" - > - <el-option - class="ruleFormaa" - v-for="item in mode" - :key="item.value" - :label="item.label" - :value="item.value" - > - </el-option> - </el-select> - </el-form-item> - <el-row :gutter="20" v-if="form.longTask"> - <el-col :span="14"> - <el-form-item label="闀挎湡浠诲姟" prop="longTemp"> - <el-radio-group v-model="objyl.longTemp"> - <el-radio - v-for="(item, index) in longtype" - :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.sendDay" - placeholder="榛樿5澶╁悗" - ></el-input> - </el-form-item> - </el-col> - </el-row> - <el-row> - <el-col :span="20" - ><el-form-item label="閫傜敤绉戝" prop="region"> - <el-select - style="width: 400px" - v-model="tempDetpRelevanceslist" - 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> - <el-col :span="20" - ><el-form-item label="閫傜敤鐥呭尯" prop="region"> - <el-select - v-model="tempbelongWards" - style="width: 400px" - 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> <div class="xinz-infs"> <el-form-item> @@ -794,8 +795,18 @@ <span slot="footer" class="dialog-footer"> <!-- <el-button @click="previewGo">淇濆瓨妯℃澘璇︽儏淇敼</el-button> --> - <el-button type="primary" @click="Departmenttreatment" - >淇濆瓨浣跨敤</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> @@ -871,6 +882,13 @@ </div> </div> </el-drawer> + <Optional-Form + ref="child" + :dialogVisiblepatient="dialogVisiblepatientjb" + :overallCase="diagglist" + @addoption="dialogVisiblepatientjb = false" + @kkoption="dialogVisiblepatientjb = true" + /> </div> </template> @@ -878,8 +896,9 @@ import { messagelistpatient } from "@/api/patient/homepage"; import store from "@/store"; import { - getTaskpatient, - getlibrarylist, + getTaskpatientQC, + getillnesslist, + getbaseopera, getFollowuplist, getvFollowup, Taskparticty, @@ -890,13 +909,22 @@ getillness, Editsingletask, getFollowupclassify, - depthospgetsonlist, + taskdepthospgetsonlist, + taskdepthospgetsondel, + taskoperhospgetsondel, + taskdiaghospgetsondel, + taskdiaggetlist, + taskopergetlist, } from "@/api/AiCentre/index"; +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暀鍐呭鍒楄〃", @@ -904,6 +932,8 @@ id: "", // previewid: "", //浠诲姟妯℃澘浼犻�抜d libName: "", + username: "", + templateor: false, objyl: {}, overallCase: [], //閫夋嫨鎮h�呮�� allpids: [], @@ -915,13 +945,24 @@ 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: "鍋滅敤" }, @@ -961,10 +1002,10 @@ ], tableLabelwj: [ + { label: "鍒涘缓浜�", width: "", prop: "createBy" }, { label: "妯℃澘鏍囬", width: "", prop: "templateName" }, { label: "闅忚鎻忚堪", width: "", prop: "note" }, { label: "淇敼鏃ユ湡", width: "", prop: "updateTime" }, - { label: "鍒涘缓浜�", width: "", prop: "createBy" }, ], // 鍙橀噺 tableLabelvariable: [ @@ -975,7 +1016,7 @@ preachform: [ { label: "澶氬獟浣�", value: 1 }, { label: "绾歌川", value: 2 }, - { label: "鐢佃瘽", value: 3 }, + { label: "鏅鸿兘璇煶", value: 3 }, { label: "鐭俊", value: 4 }, { label: "寰俊鍏紬鍙�", value: 5 }, { label: "寰俊灏忕▼搴�", value: 6 }, @@ -1011,6 +1052,8 @@ pageNum: 1, // pageSize: 10, topica: 1, //0鍏ㄩ儴1绉戝2鐥呭尯 + leaveldeptcodes: [], + leavehospitaldistrictcodes: [], }, topicoptions: [{ children: [{ children: [] }] }], showSearch: true, // @@ -1030,7 +1073,7 @@ sonuserList: [], //閫変腑鎮h�呭垪琛� delvariableList: [], //鍒犻櫎鍙橀噺涓存椂瀛樺偍 longtype: [ - { value: 0, label: "鏅�氫换鍔�" }, + { value: 0, label: "鑷畾涔夊懆鏈�" }, { value: 1, label: "闀挎湡浠诲姟" }, ], variableList: [ @@ -1083,16 +1126,19 @@ templatename: "", templateid: null, libtemplateid: null, - kcb: "浜茬埍鐨勬偅鑰�/瀹跺睘锛屾偍濂斤紒鎴戜滑鏄禉涓尰澶т簩闄㈢殑鍖绘姢浜哄憳锛屼负浜嗘洿濂藉湴浜嗚В鎮ㄧ殑搴峰鎯呭喌锛岃鎮ㄦ娊涓�鐐瑰疂璐垫椂闂达紝瑙傜湅杩欎唤瀹f暀璧勮銆�", - jsy: "璇锋偍娉ㄦ剰浼戞伅鍜岃惀鍏伙紝鐢熸椿涓婅鍔抽�哥粨鍚堬紝閫傚綋閿荤偧锛屾垝鐑熼檺閰掞紝淇濇寔蹇冩儏鑸掔晠锛屽畾鏈熷璇娿�傞偅鏈瀹f暀鍐呭灏卞埌杩欓噷锛岀鎮ㄨ韩浣撳仴搴凤紒", + kcb: + "浜茬埍鐨勬偅鑰�/瀹跺睘锛屾偍濂斤紒鎴戜滑鏄�" + + localStorage.getItem("orgname") + + "鐨勫尰鎶や汉鍛橈紝涓轰簡鏇村ソ鍦颁簡瑙f偍鐨勫悍澶嶆儏鍐碉紝璇锋偍鎶戒竴鐐瑰疂璐垫椂闂达紝杩涜鏈鍥炶鏈嶅姟銆�", + jsy: "璇锋偍娉ㄦ剰浼戞伅鍜岃惀鍏伙紝鐢熸椿涓婅鍔抽�哥粨鍚堬紝閫傚綋閿荤偧锛屾垝鐑熼檺閰掞紝淇濇寔蹇冩儏鑸掔晠锛屽畾鏈熷璇娿�傞偅鏈鍥炶鍐呭灏卞埌杩欓噷锛岀鎮ㄨ韩浣撳仴搴凤紒", }, taskoptions: [ { - value: "1", + value: "4", label: "鍑洪櫌鐥呬汉", }, { - value: "4", + value: "1", label: "鍦ㄩ櫌鐥呬汉", }, { @@ -1102,6 +1148,10 @@ { value: "3", label: "浣撴鐥呬汉", + }, + { + value: "5", + label: "鎵嬫湳鐥呬汉", }, ], source: [ @@ -1119,46 +1169,13 @@ }, ], - tasktypes: [ - { - value: 1, - label: "鐩戞祴璇勪及", - }, - { - value: 2, - label: "鍑洪櫌闅忚", - }, - { - value: 3, - label: "闂ㄨ瘖闅忚", - }, - { - value: 4, - label: "瀹f暀鍏虫��", - }, - { - value: 5, - label: "澶嶈瘖绠$悊", - }, - { - value: 6, - label: "婊℃剰搴﹁皟鏌�", - }, - { - value: 7, - label: "鎮h�呮姤鍛�", - }, - - { - value: 8, - label: "鍏朵粬閫氱煡", - }, - ], + tasktypes: store.getters.tasktypes, // 绉戝/鐥呭尯 - belongWards: [], belongWards: [], deptlist: [], hosplist: [], + diagglist: [], + operlist: [], tempDetpRelevanceslist: [], //绉戝鏁版嵁 tempDetpRelevanceslistform: [], //绉戝鏁版嵁 tempbelongWards: [], //鐥呭尯鏁版嵁 @@ -1176,22 +1193,30 @@ sendType: [ { required: true, message: "鍙戦�佽缃笉鑳戒负绌�", trigger: "blur" }, ], + // deptcode: [ + // { required: true, message: "閫傜敤绉戝涓嶈兘涓虹┖", trigger: "blur" }, + // ], + // leavehospitaldistrictcode: [ + // { required: true, message: "閫傜敤鐥呭尯涓嶈兘涓虹┖", trigger: "blur" }, + // ], }, // 绉戝闄㈠尯鏌ヨ鍏ュ弬 queryParamsdept: { tempid: "", - type: 11, + 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.newadd = this.$route.query.newadd; @@ -1199,12 +1224,23 @@ 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(); @@ -1212,11 +1248,6 @@ }, methods: { - // { - // 濮撳悕: { "${name}": "榫欏偛澶�" }, - // 鍦板潃: { "${dzz}": "榫欏" }, - // 鐢佃瘽: { "${dhh}": "鍏釜鍏�" }, - // } // 鍙橀噺杞崲瀵硅薄杞暟缁� convertFormat1ToFormat2(data) { let result = []; @@ -1240,6 +1271,26 @@ }); 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 = { @@ -1261,6 +1312,10 @@ label: "绾歌川", }, { + value: "4", + label: "鐭俊", + }, + { value: "5", label: "寰俊鍏紬鍙�", }, @@ -1269,7 +1324,7 @@ this.checkboxlist = [ { value: "3", - label: "鐢佃瘽", + label: "鏅鸿兘璇煶", }, { value: "4", @@ -1284,12 +1339,20 @@ label: "寰俊灏忕▼搴�", }, - { - value: "8", - label: "鏅鸿兘鏈哄櫒浜�", - }, + // { + // value: "8", + // label: "鏅鸿兘鏈哄櫒浜�", + // }, ]; - } else if (this.form.serviceType == 7 || this.form.serviceType == 5) { + } 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", @@ -1301,7 +1364,7 @@ }, { value: "3", - label: "鐢佃瘽", + label: "鏅鸿兘璇煶", }, { value: "4", @@ -1315,8 +1378,17 @@ value: "6", label: "寰俊灏忕▼搴�", }, + { + value: "7", + label: "鏈悗闅忚", + }, ]; - } else if (this.form.serviceType == 2 || this.form.serviceType == 3) { + } else if ( + this.form.serviceType == 2 || + this.form.serviceType == 3 || + this.form.serviceType == 16 || + this.form.serviceType == 4 + ) { this.checkboxlist = [ { value: "1", @@ -1324,7 +1396,7 @@ }, { value: "3", - label: "鐢佃瘽", + label: "鏅鸿兘璇煶", }, { value: "4", @@ -1339,10 +1411,10 @@ label: "寰俊灏忕▼搴�", }, - { - value: "8", - label: "鏅鸿兘鏈哄櫒浜�", - }, + // { + // value: "8", + // label: "鏅鸿兘鏈哄櫒浜�", + // }, ]; } getFollowuplist(this.topqueryParams).then((response) => { @@ -1362,7 +1434,8 @@ }); }, // 淇濆瓨 - submitForm(formName) { + submitForm(type) { + if (this.templateor && type) this.templateor = false; if (this.time4 && this.form.sendType == 3) this.form.showTimeMorn = this.time4; this.form.sendTimeslot = [ @@ -1372,20 +1445,53 @@ xh: 1, }, ]; - if (this.checkList[0]) { + 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.form.patTaskRelevances[0] && !this.form.longTask) { - this.$modal.msgError("璇烽�夋嫨鐥呬汉"); + + 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.templatename) { + // 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) || @@ -1408,18 +1514,18 @@ this.form.type = this.$route.query.type; } this.form.serviceType = this.serviceType; - this.form.leaveldeptcodes = store.getters.belongDepts.map( - (obj) => obj.deptCode - ); - this.form.leavehospitaldistrictcodes = store.getters.belongWards.map( - (obj) => obj.districtCode - ); + 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.puttaskid(res.data); this.$modal.msgSuccess("鏂板鎴愬姛"); } this.$router.push({ @@ -1429,24 +1535,7 @@ } }); }, - // 缁欎换鍔℃ā鏉胯祴鍊间换鍔d - puttaskid(data) { - getTaskparticty(this.form.templateid).then((res) => { - if (res.code == 200) { - this.objyl = res.data; - this.objyl.isoperation = 2; - this.objyl.taskid = data.taskId; - 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("閫夋嫨妯℃澘鎴愬姛"); - }); - } - }); - }, + // ----------------------琛ㄦ牸瀛愮粍浠朵簨浠� // 閫夋嫨棰勮 @@ -1459,13 +1548,13 @@ getvFollowup({ id: row.id }).then((res) => { if (res.code == 200) { this.objyl = res.data; - if (this.form.longTask) { - this.objyl.longTemp = 1; - } - this.queryParamsdept.type = 1; + // if (this.form.longTask) { + // this.objyl.sendDay = 5; + // } + this.queryParamsdept.type = 2; this.queryParamsdept.tempid = row.id; - this.listDept(); - + this.tempDetpRelevanceslist = []; + this.tempbelongWards = []; this.objyl.suitway = this.objyl.suitway.split(","); this.questionList = res.data.ivrLibaTemplateScriptVOList; this.getillness(row.id); @@ -1486,16 +1575,18 @@ if (this.objyl.suitway) this.objyl.suitway = this.objyl.suitway.split(","); this.queryParamsdept.tempid = this.form.templateid; - this.queryParamsdept.type = 11; + this.queryParamsdept.type = 21; + // 鐤剧梾 this.getillness(this.form.libtemplateid); - // 鎵ц鑾峰彇璇ヤ换鍔℃ā鏉縤d - this.listDept(); - this.previewtf = true; + 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 { } }); } @@ -1551,7 +1642,7 @@ { label: "鍑洪櫌鏃ユ湡", width: "150", prop: "endtime" }, { label: "鎮h��", width: "", prop: "name" }, { label: "韬唤璇�", width: "200", prop: "idcardno" }, - { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" }, + { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" }, { label: "鎬у埆", width: "", prop: "sex" }, { label: "骞撮緞", width: "", prop: "age" }, { label: "鍑洪櫌澶╂暟", width: "", prop: "endDay" }, @@ -1565,7 +1656,21 @@ { label: "鍏ラ櫌鏃ユ湡", width: "150", prop: "starttime" }, { label: "鎮h��", width: "", prop: "name" }, { label: "韬唤璇�", width: "200", prop: "idcardno" }, - { label: "鐢佃瘽鍙风爜", width: "180", prop: "telcode" }, + { 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" }, @@ -1580,11 +1685,11 @@ } 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.cry = 0; + // this.patientqueryParams.allhosp = "1"; } // 鏉ユ簮鍒ゆ柇 @@ -1604,7 +1709,7 @@ this.patientqueryParams.leavehospitaldistrictcodes = store.getters.belongWards.map((obj) => obj.districtCode); } - getTaskpatient(this.patientqueryParams).then((response) => { + getTaskpatientQC(this.patientqueryParams).then((response) => { this.patientuserList = response.rows; this.patientuserList.forEach((item) => { if (item.endtime) { @@ -1637,6 +1742,16 @@ 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); } @@ -1674,12 +1789,20 @@ 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; @@ -1692,9 +1815,38 @@ 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; @@ -1722,10 +1874,14 @@ this.form = { patTaskRelevances: [], sendType: 1, + sendDay: 5, templatename: "", templateid: null, libtemplateid: null, - kcb: "浜茬埍鐨勬偅鑰�/瀹跺睘锛屾偍濂斤紒鎴戜滑鏄禉涓尰澶т簩闄㈢殑鍖绘姢浜哄憳锛屼负浜嗘洿濂藉湴浜嗚В鎮ㄧ殑搴峰鎯呭喌锛岃鎮ㄦ娊涓�鐐瑰疂璐垫椂闂达紝瀹屾垚杩欎唤闅忚闅忚銆�", + kcb: + "浜茬埍鐨勬偅鑰�/瀹跺睘锛屾偍濂斤紒鎴戜滑鏄�" + + localStorage.getItem("orgname") + + "鐨勫尰鎶や汉鍛橈紝涓轰簡鏇村ソ鍦颁簡瑙f偍鐨勫悍澶嶆儏鍐碉紝璇锋偍鎶戒竴鐐瑰疂璐垫椂闂达紝杩涜鏈鍥炶鏈嶅姟銆�", jsy: "璇锋偍娉ㄦ剰浼戞伅鍜岃惀鍏伙紝鐢熸椿涓婅鍔抽�哥粨鍚堬紝閫傚綋閿荤偧锛屾垝鐑熼檺閰掞紝淇濇寔蹇冩儏鑸掔晠锛屽畾鏈熷璇娿�傞偅鏈鍥炶灏卞埌杩欓噷锛岀鎮ㄨ韩浣撳仴搴凤紒", }; @@ -1741,6 +1897,7 @@ : []; this.overallCase = this.form.patTaskRelevances.concat(); this.checkList = this.form.preachform.split(","); + this.selectedOrder = this.form.preachformList; this.overallCase.forEach((item) => { if (item.endtime) { @@ -1756,6 +1913,9 @@ 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) @@ -1765,7 +1925,6 @@ } else { this.$modal.msgError(res.code); } - if (this.newadd) { this.neWaddfn(); } @@ -1776,6 +1935,7 @@ neWaddfn() { this.id = null; this.form.taskName = ""; + this.form.sendState = null; this.form.taskid = null; this.overallCase = []; this.form.patTaskRelevances = []; @@ -1788,22 +1948,129 @@ }, // 鑾峰彇绉戝鍒楄〃 listDept() { - this.tempDetpRelevanceslist = []; - this.tempbelongWards = []; - depthospgetsonlist(this.queryParamsdept).then((res) => { + 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.tempDetpRelevanceslist.push(item.deptCode); + this.deptcodesWards.push(item.deptCode); } else if (item.deptType == 2) { this.hosplist.push(item); - this.tempbelongWards.push(item.deptCode); + 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) => { @@ -1900,11 +2167,17 @@ this.objyl.suitway = this.objyl.suitway.join(","); } this.objyl.ivrLibaTemplateScriptVOList.forEach((item) => { - item.ivrTaskTemplateTargetoptions = item.ivrLibaScriptTargetoptionList; + 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) { @@ -1914,7 +2187,16 @@ this.form.templateid = response.data; this.putbelongDepts(response.data); this.form.templatename = this.objyl.templateName; - this.$modal.msgSuccess("閫夋嫨妯℃澘鎴愬姛"); + this.$modal.msgSuccess("鏇挎崲妯℃澘鎴愬姛"); + this.drawermb = false; //閫夋嫨妯℃澘寮圭獥 + this.previewtf = false; //棰勮 + if (this.skip) { + // 璺宠浆鍓嶅線淇敼 + this.$router.push({ + path: "/knowledge/taskub/", + query: { id: response.data }, + }); + } }); } }); @@ -1926,6 +2208,15 @@ 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 }, + }); + } }); } }, @@ -1950,8 +2241,10 @@ } }); }, - checkboxChange(checked, value){ - + checkSelectionChange(selectedValues, selectedOrder) { + this.selectedOrder = selectedValues; + console.log("褰撳墠閫変腑:", selectedValues); + console.log("閫変腑椤哄簭:", selectedOrder); }, // 鏈嶅姟褰㈠紡閫夊彇 handleCheckedCitiesChange(row) { @@ -1965,36 +2258,71 @@ 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); - console.log(this.checkList, "checkList"); - + this.foncheckList = this.foncheckList.filter( + (obj) => obj.value !== tag.value + ); }, // 绉戝澶勭悊 Departmenttreatment() { - this.tempDetpRelevanceslist.forEach((item) => { - this.tempDetpRelevanceslistform.push({ - deptType: 1, - longTemp: this.form.longTask, - deptCode: item, - tempid: null, - type: 11, + 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; + }); + } else { + 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.tempbelongWards.forEach((item) => { - this.tempbelongWardsform.push({ - deptType: 2, - longTemp: this.form.longTask, - deptCode: item, - tempid: null, - type: 11, - }); - }); - console.log(33); - - setTimeout(() => { - this.previewFn(); - }, 1000); + } else { + this.$modal + .confirm("褰撳墠涓哄熀纭�棰勮鏄惁鍒涘缓浠诲姟妯℃澘骞跺墠寰�淇敼璇︽儏锛�") + .then(() => { + // 璧板彇鍏堢粦瀹氬悗淇敼鎿嶄綔 + this.Departmenttreatment(); + this.skip = true; + }); + } }, }, }; -- Gitblit v1.9.3