WXL
2025-07-25 e353f0e17dc46203512dd272c5b559b094e40761
src/views/followvisit/record/detailpage/index.vue
@@ -14,7 +14,7 @@
                @click="getTaskservelist()"
                >查看患者全部服务</el-button
              >
              <el-button v-else type="success" @click="getTaskservelist(taskid)"
              <el-button v-else type="success" @click="getTaskservelist(id)"
                >查看患者本次服务信息</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="患者名称">
          <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,22 +545,22 @@
    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) => {
            console.log(item.scriptResultId,'scriptResultId');
            console.log(item.scriptResultId, "scriptResultId");
            if (item.scriptResultId && item.scriptType != 2) {
              item.isoption = 3;
@@ -495,12 +575,25 @@
        }
      });
    },
    // 获取基础信息
    getuserinfo() {
      const queryParams = {
        patid: Number(this.patid),
        allhosp: "0",
        pageNum: 1,
      };
      // 患者基础信息
      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");
@@ -509,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;
@@ -570,6 +663,7 @@
          subId: this.id,
          taskid: this.taskid,
          scriptid: item.id,
          templatequestionnum: item.scriptno,
          questiontext: item.scriptContent,
        };
        if (item.scriptType == 2 && item.scriptResult[0]) {
@@ -598,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("服务保存成功");
        }
      });
    },
    // 获取患者记录
    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 {
@@ -653,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];
@@ -661,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(() => {});
    },
@@ -733,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);
@@ -750,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;
@@ -828,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;
@@ -870,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;