From 99b062eeca471bdcbfcacd88e308fab9972cd6ec Mon Sep 17 00:00:00 2001 From: WXL (wul) <wl_5969728@163.com> Date: 星期二, 19 八月 2025 14:21:33 +0800 Subject: [PATCH] 展示优化 --- src/views/followvisit/record/detailpage/index.vue | 375 ++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 270 insertions(+), 105 deletions(-) diff --git a/src/views/followvisit/record/detailpage/index.vue b/src/views/followvisit/record/detailpage/index.vue index acd20aa..609d2d1 100644 --- a/src/views/followvisit/record/detailpage/index.vue +++ b/src/views/followvisit/record/detailpage/index.vue @@ -14,7 +14,7 @@ @click="getTaskservelist()" >鏌ョ湅鎮h�呭叏閮ㄦ湇鍔�</el-button > - <el-button v-else type="success" @click="getTaskservelist(taskid)" + <el-button v-else type="success" @click="getTaskservelist(id)" >鏌ョ湅鎮h�呮湰娆℃湇鍔′俊鎭�</el-button > </div> @@ -25,6 +25,14 @@ <div> <el-table :data="logsheetlist" style="width: 100%"> <el-table-column prop="sendname" align="center" label="濮撳悕"> + </el-table-column> + <el-table-column + prop="taskName" + align="center" + width="200" + show-overflow-tooltip + label="浠诲姟鍚嶇О" + > </el-table-column> <el-table-column prop="sendstate" @@ -55,9 +63,12 @@ <el-tag type="danger" :disable-transitions="false" >鍙戦�佸け璐�</el-tag > - </div><div v-if="scope.row.sendstate == 6"> - <el-tag type="success" :disable-transitions="false">宸插畬鎴�</el-tag> - </div> + </div> + <div v-if="scope.row.sendstate == 6"> + <el-tag type="success" :disable-transitions="false" + >宸插畬鎴�</el-tag + > + </div> </template> </el-table-column> <el-table-column @@ -122,14 +133,6 @@ /> </template> </el-table-column> - <el-table-column - prop="taskName" - align="center" - width="200" - show-overflow-tooltip - label="浠诲姟鍚嶇О" - > - </el-table-column> <el-table-column prop="templatename" @@ -147,7 +150,7 @@ width="210" > </el-table-column> - <!-- <el-table-column + <el-table-column label="鎿嶄綔" fixed="right" align="center" @@ -159,41 +162,73 @@ size="medium" type="text" @click="Seedetails(scope.row)" - v-hasPermi="['system:user:edit']" ><span class="button-zx" - ><i class="el-icon-s-order"></i>鏌ョ湅鏈嶅姟</span + ><i class="el-icon-s-order"></i>鏌ョ湅鏈嶅姟缁撴灉</span ></el-button > </template> - </el-table-column> --> + </el-table-column> </el-table> </div> </div> - <div class="Followuserinfo"> + <div :class="form.serviceType == 2 ? 'Followuserinfo' : 'Followuserinfos'"> <div> - <div class="headline"> - <div>浜哄伐澶勭悊鎰忚</div> - </div> - <div style="margin-left: 30px"> - <el-button type="warning" @click="Editsingletaskson('1')" - >鏆備笉澶勭悊</el-button - > - <el-button type="success" @click="Editsingletaskson('2')" - >鐥呮儏绋冲畾</el-button - > - <el-button type="primary" @click="Editsingletaskson('3')" - >閫氱煡灏辫瘖</el-button - > - <!-- <el-button type="danger" @click="Editsingletaskson('4')" - >澶辫</el-button - > --> - <el-button type="info" @click="Editsingletaskson('5')" - >浜哄伐闅忚</el-button - > - </div> + <el-form ref="form" :model="form" label-width="120px"> + <div class="headline"> + <div>浜哄伐澶勭悊</div> + <el-row :gutter="20"> + <el-col :span="12" + ><el-form-item label="鑱旂郴鐢佃瘽"> + <el-input + disabled + placeholder="鑱旂郴鐢佃瘽缂哄け" + v-model="userform.telcode" + ></el-input> </el-form-item + ></el-col> + <el-col :span="12" + ><el-form-item label="鑱旂郴浜虹數璇�"> + <el-input + disabled + placeholder="鑱旂郴浜虹數璇濈己澶�" + v-model="userform.relativetelcode" + ></el-input> </el-form-item + ></el-col> + </el-row> + <!-- <div style="margin-left: 30px"> + <el-button type="warning">涓�閿懠鍙�</el-button> + </div> --> + </div> + + <el-form-item label="闅忚璁板綍"> + <el-input type="textarea" v-model="form.remark"></el-input> + </el-form-item> + + <el-form-item label="澶勭悊鎰忚"> + <div> + <el-button plain type="warning" @click="Editsingletaskson('1')" + >鏆備笉澶勭悊</el-button + > + <el-button plain type="success" @click="Editsingletaskson('2')" + >鐥呮儏绋冲畾</el-button + > + <el-button plain type="primary" @click="Editsingletaskson('3')" + >閫氱煡灏辫瘖</el-button + > + <!-- <el-button type="danger" @click="Editsingletaskson('4')" + >澶辫</el-button + > --> + <el-button plain type="info" @click="Editsingletaskson('5')" + >涓績闅忚</el-button + > + <el-button type="primary" round @click="sendAgain()" + >鐭俊鍥炲</el-button + > + </div> + </el-form-item> + </el-form> </div> </div> - <div> + <div v-if="form.serviceType == 2"> <el-tabs v-model="activeName" type="border-card"> <el-tab-pane name="wj"> <span class="mulsz" slot="label" @@ -201,7 +236,7 @@ > <div class="CONTENT"> <div class="title">{{ taskname ? taskname : "闂嵎" }}</div> - <!-- 闂嵎浠诲姟灞曠ず --> + <div class="preview-left" v-if="!Voicetype"> <!-- 鍗曢�� --> <div @@ -298,9 +333,8 @@ </div> </div> </div> - <!-- 璇煶闂嵎褰㈠紡灞曠ず --> + <div class="preview-left" v-else> - <!-- 鍗曢�� --> <div class="topic-dev" v-for="(item, index) in tableDatatop" @@ -328,7 +362,6 @@ </div> </div> - <!-- 濉┖ --> <div class="scriptTopic-dev" :key="index" v-else> <div class="dev-text"> {{ index + 1 }}銆乕闂瓟]<span>{{ item.questiontext }}</span> @@ -354,7 +387,7 @@ > </div> </el-tab-pane> - <!-- 璇煶闅忚璇︽儏---------------------- --> + <el-tab-pane name="yy"> <span class="mulsz" slot="label" ><i class="el-icon-headset"></i> 璇煶闅忚璇︽儏</span @@ -390,10 +423,7 @@ :autosize="{ minRows: 1 }" v-model="item.asrtext" ></el-input> - <!-- <el-radio v-model="radio" label="1">寰堟</el-radio> - <el-radio v-model="radio" label="2">杩樺彲浠�</el-radio> - <el-radio v-model="radio" label="3">涓嶅お濂�</el-radio> - <el-radio v-model="radio" label="4">姣旇緝宸�</el-radio> --> + <div> <mini-audio :audio-source=" @@ -417,6 +447,48 @@ </el-tab-pane> </el-tabs> </div> + <el-dialog title="鐭俊鍙戦��" :visible.sync="dialogFormVisible"> + <el-form ref="form" :model="form" label-width="80px"> + <el-form-item label="鎮h�呭悕绉�"> + <el-input + style="width: 400px" + disabled + v-model="form.sendname" + ></el-input> + </el-form-item> + <el-form-item label="骞撮緞"> + <el-input style="width: 400px" disabled v-model="form.age"></el-input> + </el-form-item> + <el-form-item label="鐢佃瘽"> + <el-input + style="width: 400px" + disabled + v-model="userform.telcode" + ></el-input> + </el-form-item> + <el-form-item label="绉戝"> + <el-input + style="width: 400px" + disabled + v-model="form.deptname" + ></el-input> + </el-form-item> + <el-form-item label="鐥呭尯"> + <el-input + style="width: 400px" + disabled + v-model="form.leavehospitaldistrictname" + ></el-input> + </el-form-item> + <el-form-item label="鐭俊鍐呭"> + <el-input type="textarea" v-model="form.content"></el-input> + </el-form-item> + </el-form> + <div slot="footer" class="dialog-footer"> + <el-button @click="dialogFormVisible = false">鍙� 娑�</el-button> + <el-button type="primary" @click="setupsubtask">纭鍙戦��</el-button> + </div> + </el-dialog> </div> </template> @@ -424,14 +496,16 @@ import { getsearchrResults, getPersonVoices, + addserviceSubtask, getTaskservelist, getTaskFollowup, Editsingletaskson, serviceSubtaskDetailedit, serviceSubtaskDetailadd, - updatePersonVoices, + sendMsg, addPersonVoices, } from "@/api/AiCentre/index"; +import { messagelistpatient } from "@/api/patient/homepage"; export default { dicts: ["sys_normal_disable", "sys_user_sex", "sys_yujing", "sys_suggest"], data() { @@ -443,9 +517,15 @@ activeName: "wj", voice: "", templateid: "", + zcform: {}, + form: {}, tableDatatop: [], //棰樼洰琛� voiceDatatop: [], //棰樼洰琛� + dynamicTags: [], + + userform: {}, Whetherall: false, //鏄惁鍏ㄩ儴璁板綍灞曠ず + dialogFormVisible: false, Voicetype: 0, //鏄惁涓鸿闊虫湇鍔� logsheetlist: [], topicobj: {}, @@ -465,25 +545,27 @@ this.Voicetype = this.$route.query.Voicetype; this.serviceType = this.$route.query.serviceType; - this.getTaskservelist(this.taskid); + this.getTaskservelist(this.id); }, methods: { // 鑾峰彇闂嵎鏁版嵁 - getsearchrResults() { + getsearchrResults(id) { getsearchrResults({ taskid: this.taskid, patid: this.patid, - subId: this.id, + subId: id ? id : this.id, isFinish: false, }).then((res) => { if (res.code === 200) { - this.tableDatatop = res.data.scriptResult.script; + this.tableDatatop = res.data.scriptResult; this.tableDatatop.forEach((item) => { - if (item.scriptResult && item.scriptType != 2) { + console.log(item.scriptResultId, "scriptResultId"); + + if (item.scriptResultId && item.scriptType != 2) { item.isoption = 3; - item.scriptResult = JSON.parse(item.scriptResult); - } else if (item.scriptResult && item.scriptType == 2) { + item.scriptResult = item.scriptResult; + } else if (item.scriptResultId && item.scriptType == 2) { item.scriptResult = item.scriptResult.split("&"); item.isoption = 3; } @@ -493,12 +575,25 @@ } }); }, + // 鑾峰彇鍩虹淇℃伅 + getuserinfo() { + const queryParams = { + patid: Number(this.patid), + allhosp: "0", + pageNum: 1, + }; + // 鎮h�呭熀纭�淇℃伅 + messagelistpatient(queryParams).then((response) => { + this.userform = response.rows[0]; + this.dynamicTags = response.rows[0].tagList.map(this.processElement); + }); + }, // 鑾峰彇璇煶鏁版嵁 - getPersonVoices() { + getPersonVoices(id) { let obj = { taskid: this.taskid, patid: this.patid, - subId: this.id, + subId: id ? id : this.id, }; console.log(this.voiceDatatop, "111"); @@ -507,7 +602,7 @@ if (res.code == 200) { this.voiceDatatop = res.data.serviceSubtaskDetails; this.voice = res.data.voice; - // this.activeName = "yy"; + // // this.activeName = "yy"; this.taskname = res.data.taskName; // 闂嵎灞曠ず鏁版嵁澶勭悊 this.tableDatatop = res.data.filteredDetails; @@ -556,9 +651,10 @@ var objs = item.svyLibTemplateTargetoptions.find( (items) => items.optioncontent == item.scriptResult ); - - if (objs.isabnormal) { - excep = 1; + if (obj) { + if (objs.isabnormal) { + excep = 1; + } } let obj = { @@ -567,12 +663,13 @@ subId: this.id, taskid: this.taskid, scriptid: item.id, + templatequestionnum: item.scriptno, questiontext: item.scriptContent, }; if (item.scriptType == 2 && item.scriptResult[0]) { obj.asrtext = item.scriptResult.join("&"); } else if (item.scriptType != 2 && item.scriptResult) { - obj.asrtext = JSON.stringify(item.scriptResult); + obj.asrtext = item.scriptResult; } if (item.isoption == 3) { @@ -595,50 +692,56 @@ this.Editsingletasksonyic(excep); }, yuyingetdetail() { - this.tableDatatop.forEach((item, index) => { - console.log(item.scriptResult, "scriptResult"); - item.scriptResult = item.scriptResult.join("&"); - item.templatequestionnum = index + 1; - item.subId = this.id; - item.taskid = this.taskid; - item.asrtext = item.matchedtext; - if (!item.id) { - item.isoperation = 1; - } - item.patid = this.patid; - item.templateid = item.templateID; - }); - let obj ={ - serviceSubtaskDetailList: this.tableDatatop, - param1: this.taskid, - param2: this.patid, - subId: this.id, - } + this.tableDatatop.forEach((item, index) => { + console.log(item.scriptResult, "scriptResult"); + item.scriptResult = item.scriptResult.join("&"); + // item.templatequestionnum = index + 1; + item.subId = this.id; + item.taskid = this.taskid; + item.asrtext = item.matchedtext; + item.templatequestionnum = item.scriptno; + item.targetid = item.targetid; + item.scriptid = item.id; + if (!item.id) { + item.isoperation = 1; + } + item.patid = this.patid; + item.templateid = item.templateID; + }); + let obj = { + serviceSubtaskDetailList: this.tableDatatop, + param1: this.taskid, + param2: this.patid, + subId: this.id, + }; - addPersonVoices(obj).then((res) => { - if (res.code == 200) { - this.$modal.msgSuccess("鏈嶅姟淇濆瓨鎴愬姛"); - } - }); - - }, + addPersonVoices(obj).then((res) => { + if (res.code == 200) { + this.$modal.msgSuccess("鏈嶅姟淇濆瓨鎴愬姛"); + } + }); + }, // 鑾峰彇鎮h�呰褰� - getTaskservelist(taskid) { - this.taskid = taskid; - if (taskid) { + getTaskservelist(id) { + this.id = id; + if (id) { this.Whetherall = false; } else { this.Whetherall = true; } + getTaskservelist({ patid: this.patid, - taskid: taskid, + subid: id, }).then((res) => { if (res.code == 200) { + this.form = res.rows[0].serviceSubtaskList[0]; this.logsheetlist = res.rows[0].serviceSubtaskList; this.templateid = this.logsheetlist[0].templateid; + console.log(this.form.serviceType, "serviceType"); } + this.getuserinfo(); if (this.Voicetype) { this.getPersonVoices(); } else { @@ -650,7 +753,7 @@ let objson = {}; getTaskservelist({ patid: this.patid, - taskid: this.taskid, + subId: this.id, }).then((res) => { if (res.code == 200) { objson = res.rows[0].serviceSubtaskList[0]; @@ -658,39 +761,46 @@ Editsingletaskson(objson).then((res) => { if (res.code) { this.$modal.msgSuccess("璁板綍鎴愬姛"); - this.getTaskservelist(this.taskid); + this.getTaskservelist(this.id); } }); } }); }, - Editsingletasksonyic(excep) { + Editsingletasksonyic(sendstate) { let objson = {}; getTaskservelist({ patid: this.patid, - taskid: this.taskid, + subId: this.id, }).then((res) => { if (res.code == 200) { objson = res.rows[0].serviceSubtaskList[0]; - console.log(objson, "obj"); - - objson.excep = excep; + objson.remark = this.form.remark; + if (sendstate) objson.sendstate = sendstate; Editsingletaskson(objson).then((res) => { if (res.code) { this.$modal.msgSuccess("鏈嶅姟淇敼鎴愬姛"); - this.getTaskservelist(this.taskid); + this.getTaskservelist(this.id); } }); } }); }, - // 鏇存敼寮傚父鐘舵�� + // 璋冭捣鍐嶆鍙戦�� + sendAgain() { + this.dialogFormVisible = true; + }, + // 鏌ョ湅璇︽儏 Seedetails(row) { this.$modal - .confirm('鏄惁鏌ョ湅浠诲姟涓�"' + optionids + '"鐨勬湇鍔¢」锛�') - .then(function () {}) + .confirm('鏄惁鏌ョ湅浠诲姟涓�"' + row.taskName + '"鐨勬湇鍔¤鎯呮暟鎹紵') .then(() => { - this.getList(); + this.taskid = row.taskid; + this.id = row.id; + this.patid = row.patid; + this.Voicetype = row.type; + this.serviceType = row.serviceType; + this.getTaskservelist(this.id); }) .catch(() => {}); }, @@ -730,7 +840,20 @@ } }); }, - + // 鍙戦�侀殢璁垮悗鐭俊 + setupsubtask() { + sendMsg({ + phoneNumber: this.userform.telcode, + content: this.form.content, + }).then((res) => { + if (res.code == 200) { + this.$modal.msgSuccess("鍙戦�佹垚鍔�"); + } else { + this.$modal.msgError("鍒涘缓澶辫触"); + } + this.dialogFormVisible = false; + }); + }, updateScore(a, b, c) { console.log(a); console.log(b); @@ -747,6 +870,27 @@ .Followuserinfo { margin: 20px 10px; align-items: center; + 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); + .userinfo-text { + font-size: 20px; + margin-right: 20px; + margin-bottom: 10px; + } + .userinfo-value { + color: rgb(15, 139, 211); + span { + margin-right: 20px; + } + } +} +.Followuserinfos { + margin: 20px 10px; + align-items: center; + height: 300px; padding: 30px; background: #ffff; border: 1px solid #dcdfe6; @@ -825,6 +969,21 @@ .scriptTopic-isabnormal { color: red; } +.detailed { + width: 88%; + border-radius: 8px; + padding: 30px; + margin-bottom: 30px; + background-color: #ddf0f8; + .bg-purple { + margin-bottom: 20px; + } + .spanvalue { + display: inline-block; + min-width: 200px; + border-bottom: 1px solid rgb(172, 172, 172); + } +} .headline { font-size: 24px; height: 40px; @@ -867,9 +1026,15 @@ top: 0; } } +::v-deep.el-input.is-disabled .el-input__inner { + color: #02a7f0; +} ::v-deep.offside-value .el-radio__label { color: #fff; } +::v-deep.el-link.el-link--default { + color: #02a7f0 !important; +} .mulsz { font-size: 25px; margin-top: 20px; -- Gitblit v1.9.3