From e353f0e17dc46203512dd272c5b559b094e40761 Mon Sep 17 00:00:00 2001
From: WXL <1785969728@qq.com>
Date: 星期五, 25 七月 2025 15:02:36 +0800
Subject: [PATCH] 测试完成

---
 src/views/followvisit/record/detailpage/index.vue |  403 +++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 303 insertions(+), 100 deletions(-)

diff --git a/src/views/followvisit/record/detailpage/index.vue b/src/views/followvisit/record/detailpage/index.vue
index 8f53179..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>
@@ -26,21 +26,34 @@
         <el-table :data="logsheetlist" style="width: 100%">
           <el-table-column prop="sendname" align="center" label="濮撳悕">
           </el-table-column>
-          <el-table-column prop="sendstate" align="center" label="鏈嶅姟鐘舵��">
+          <el-table-column
+            prop="taskName"
+            align="center"
+            width="200"
+            show-overflow-tooltip
+            label="浠诲姟鍚嶇О"
+          >
+          </el-table-column>
+          <el-table-column
+            prop="sendstate"
+            align="center"
+            width="200"
+            label="鏈嶅姟鐘舵��"
+          >
             <template slot-scope="scope">
               <div v-if="scope.row.sendstate == 1">
                 <el-tag type="primary" :disable-transitions="false"
-                  >琚鍙�</el-tag
+                  >琛ㄥ崟宸查鍙�</el-tag
                 >
               </div>
               <div v-if="scope.row.sendstate == 2">
                 <el-tag type="primary" :disable-transitions="false"
-                  >寰呭彂閫�</el-tag
+                  >寰呮墽琛�</el-tag
                 >
               </div>
               <div v-if="scope.row.sendstate == 3">
                 <el-tag type="success" :disable-transitions="false"
-                  >宸插彂閫佹湭棰嗗彇</el-tag
+                  >琛ㄥ崟宸插彂閫�</el-tag
                 >
               </div>
               <div v-if="scope.row.sendstate == 4">
@@ -49,6 +62,11 @@
               <div v-if="scope.row.sendstate == 5">
                 <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>
             </template>
@@ -115,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"
@@ -140,7 +150,7 @@
             width="210"
           >
           </el-table-column>
-          <!-- <el-table-column
+          <el-table-column
             label="鎿嶄綔"
             fixed="right"
             align="center"
@@ -152,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"
@@ -194,7 +236,7 @@
           >
           <div class="CONTENT">
             <div class="title">{{ taskname ? taskname : "闂嵎" }}</div>
-            <!-- 闂嵎浠诲姟灞曠ず -->
+
             <div class="preview-left" v-if="!Voicetype">
               <!-- 鍗曢�� -->
               <div
@@ -291,9 +333,8 @@
                 </div>
               </div>
             </div>
-            <!-- 璇煶闂嵎褰㈠紡灞曠ず -->
+
             <div class="preview-left" v-else>
-              <!-- 鍗曢�� -->
               <div
                 class="topic-dev"
                 v-for="(item, index) in tableDatatop"
@@ -321,7 +362,6 @@
                   </div>
                 </div>
 
-                <!-- 濉┖ -->
                 <div class="scriptTopic-dev" :key="index" v-else>
                   <div class="dev-text">
                     {{ index + 1 }}銆乕闂瓟]<span>{{ item.questiontext }}</span>
@@ -347,7 +387,7 @@
             >
           </div>
         </el-tab-pane>
-        <!-- 璇煶闅忚璇︽儏---------------------- -->
+
         <el-tab-pane name="yy">
           <span class="mulsz" slot="label"
             ><i class="el-icon-headset"></i> 璇煶闅忚璇︽儏</span
@@ -383,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="
@@ -410,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>
 
@@ -417,13 +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() {
@@ -434,10 +516,16 @@
       taskname: "",
       activeName: "wj",
       voice: "",
-      templateid:'',
+      templateid: "",
+      zcform: {},
+      form: {},
       tableDatatop: [], //棰樼洰琛�
       voiceDatatop: [], //棰樼洰琛�
+      dynamicTags: [],
+
+      userform: {},
       Whetherall: false, //鏄惁鍏ㄩ儴璁板綍灞曠ず
+      dialogFormVisible: false,
       Voicetype: 0, //鏄惁涓鸿闊虫湇鍔�
       logsheetlist: [],
       topicobj: {},
@@ -456,30 +544,28 @@
     this.patid = this.$route.query.patid;
     this.Voicetype = this.$route.query.Voicetype;
     this.serviceType = this.$route.query.serviceType;
-    if (this.Voicetype) {
-      this.getPersonVoices();
-    } else {
-      this.getsearchrResults();
-    }
-    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;
             }
@@ -489,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");
 
@@ -503,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;
@@ -515,7 +614,7 @@
             }
           });
           if (!this.tableDatatop.length) {
-          this.puttaskid(this.templateid);
+            this.puttaskid(this.templateid);
           }
         }
       });
@@ -526,11 +625,14 @@
         if (res.code == 200) {
           this.tableDatatop = res.data.ivrTaskTemplateScriptVOList;
           this.tableDatatop.forEach((item) => {
+            item.id = null;
             // 绫诲瀷鍒ゆ柇璧嬪��
             if (item.ivrTaskScriptTargetoptionList) {
-              item.targetvalue=1;
-              item.questiontext=item.scriptContent;
-              item.targetvalue = item.ivrTaskScriptTargetoptionList.map(obj => obj.targetvalue).join('&');
+              item.targetvalue = 1;
+              item.questiontext = item.scriptContent;
+              item.targetvalue = item.ivrTaskScriptTargetoptionList
+                .map((obj) => obj.targetvalue)
+                .join("&");
             }
             if (item.targetvalue) {
               item.scriptResult = item.targetvalue.split("&");
@@ -538,8 +640,7 @@
               item.scriptResult = [];
             }
           });
-          console.log(this.tableDatatop,'this.tableDatatop');
-
+          console.log(this.tableDatatop, "this.tableDatatop");
         }
       });
     },
@@ -550,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 = {
@@ -561,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) {
@@ -589,30 +692,60 @@
       this.Editsingletasksonyic(excep);
     },
     yuyingetdetail() {
-      this.tableDatatop.forEach((item) => {
+      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;
       });
-      updatePersonVoices(this.tableDatatop).then((res) => {
+      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("鏈嶅姟淇敼鎴愬姛");
+          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
+          this.templateid = this.logsheetlist[0].templateid;
+          console.log(this.form.serviceType, "serviceType");
+        }
+        this.getuserinfo();
+        if (this.Voicetype) {
+          this.getPersonVoices();
+        } else {
+          this.getsearchrResults();
         }
       });
     },
@@ -620,54 +753,69 @@
       let objson = {};
       getTaskservelist({
         patid: this.patid,
-        taskid: this.taskid,
+        subId: this.id,
       }).then((res) => {
         if (res.code == 200) {
-          objson = res.rows[0];
+          objson = res.rows[0].serviceSubtaskList[0];
           objson.suggest = son;
           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(() => {});
     },
     handleOptionChange(a, b, c) {
-      var obj = this.tableDatatop[b].svyLibTemplateTargetoptions.find(
-        (item) => item.optioncontent == a
-      );
+      console.log(this.tableDatatop[b], "this.tableDatatop[b]");
+
+      if (this.Voicetype) {
+        var obj = this.tableDatatop[b].ivrTaskScriptTargetoptionList.find(
+          (item) => item.optioncontent == a
+        );
+      } else {
+        var obj = this.tableDatatop[b].svyLibTemplateTargetoptions.find(
+          (item) => item.optioncontent == a
+        );
+      }
       if (obj.isabnormal) {
         this.tableDatatop[b].isabnormal = true;
       } else {
@@ -692,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);
@@ -709,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;
@@ -787,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;
@@ -829,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