WXL (wul)
昨天 21051d356bb8589ad088abb52492fd2a1909ed9e
测试完成
已重命名2个文件
已修改12个文件
已添加2个文件
5541 ■■■■■ 文件已修改
dist.zip 补丁 | 查看 | 原始文档 | blame | 历史
src/api/AiCentre/EChartsdata.js 1 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/CallButton/index.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/main.js 8 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/store/modules/user.js 18 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/utils/sipService.js 4 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/followvisit/Continue/ContinueFordetails.vue 2389 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/followvisit/Continue/index.vue 2094 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/followvisit/discharge/index.vue 58 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/followvisit/record/detailpage/index.vue 786 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/login-sy.vue 16 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/login.vue 111 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/patient/patient/behospitalized.vue 9 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/patient/patient/hospital.vue 3 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/sfstatistics/percentage/index.vue 40 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
vue.config.js 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
dist.zip
Binary files differ
src/api/AiCentre/EChartsdata.js
@@ -65,6 +65,7 @@
  return request({
    url: "/smartor/organization/list",
    method: "get",
    params: data,
  });
}
// å‘送短信
src/components/CallButton/index.vue
@@ -200,7 +200,7 @@
          this.sipConfig.sipUri = `${this.randomNum}@192.168.10.124`;
        } else if (orgName == "龙泉市人民医院") {
          this.sipConfig.sipUri = `${this.randomNum}@10.10.0.220`;
        } else if (orgName == "杭州市第一人民医院湖滨院区"||orgName == "杭州市第一人民医院吴山院区") {
        } else if (orgName == "第一人民医院湖滨院区"||orgName == "第一人民医院吴山院区") {
          this.sipConfig.sipUri = `${this.randomNum}@192.169.129.198`;
        }
      } catch (error) {
src/main.js
@@ -92,6 +92,14 @@
  Vue.filter(key, filters[key]);
}
import moment from "moment"
// 1. åœ¨main.js中添加错误监听
window.addEventListener('unhandledrejection', (event) => {
  if (event.reason && event.reason.message &&
      event.reason.message.includes('Loading chunk')) {
    // é‡æ–°åŠ è½½é¡µé¢
    window.location.reload();
  }
});
Vue.prototype.$moment = moment;
src/store/modules/user.js
@@ -209,13 +209,13 @@
              localStorage.setItem("YongHuID", "1512710152715767808");
              localStorage.setItem("YongHuXM", "LDRMYY");
            } else if (orgid == "1" && campusid == 1) {
              localStorage.setItem("orgname", "杭州市第一人民医院湖滨院区");
              localStorage.setItem("orgname", "第一人民医院湖滨院区");
              localStorage.setItem("ZuHuID", "");
              localStorage.setItem("deptCode", "");
              localStorage.setItem("YongHuID", "");
              localStorage.setItem("YongHuXM", "");
            } else if (orgid == "1" && campusid == 2) {
              localStorage.setItem("orgname", "杭州市第一人民医院吴山院区");
              localStorage.setItem("orgname", "第一人民医院吴山院区");
              localStorage.setItem("ZuHuID", "");
              localStorage.setItem("deptCode", "");
              localStorage.setItem("YongHuID", "");
@@ -223,6 +223,12 @@
            } else if (orgid == "47246116333112211A1001") {
              localStorage.setItem("orgname", "缙云县人民医院");
              localStorage.setItem("ZuHuID", "1429338802177000010");
              localStorage.setItem("deptCode", "");
              localStorage.setItem("YongHuID", "");
              localStorage.setItem("YongHuXM", "");
            } else if (orgid == "47226079133110211G1001") {
              localStorage.setItem("orgname", "丽水市妇幼保健院");
              localStorage.setItem("ZuHuID", "1429338802177000014");
              localStorage.setItem("deptCode", "");
              localStorage.setItem("YongHuID", "");
              localStorage.setItem("YongHuXM", "");
@@ -256,6 +262,14 @@
            commit("SET_nickNAME", user.nickName);
            commit("SET_Id", user.userId);
            commit("SET_hisUserId", user.hisUserId);
            // if (user.userName == "admin") {
            //   commit("SET_leaveldeptcodes", []);
            //   commit("SET_leavehospitaldistrictcodes", []);
            // } else {
            //   commit("SET_leavehospitaldistrictcodes", user.belongWards);
            //   commit("SET_leaveldeptcodes", user.belongDepts);
            // }
            commit("SET_leavehospitaldistrictcodes", user.belongWards);
            commit("SET_leaveldeptcodes", user.belongDepts);
            commit("SET_AVATAR", avatar);
src/utils/sipService.js
@@ -11,11 +11,11 @@
    wsUrl: "wss://10.10.0.220:7443",
    domain: "10.10.0.220",
  },
   æ­å·žå¸‚第一人民医院湖滨院区: {
   ç¬¬ä¸€äººæ°‘医院湖滨院区: {
    wsUrl: "wss://192.169.129.198:7443",
    domain: "192.169.129.198",
  },
  æ­å·žå¸‚第一人民医院吴山院区: {
  ç¬¬ä¸€äººæ°‘医院吴山院区: {
    wsUrl: "wss://192.169.129.198:7443",
    domain: "192.169.129.198",
  },
src/views/followvisit/Continue/ContinueFordetails.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,2389 @@
<template>
  <!-- å»¶ç»­æŠ¤ç†é¡µé¢ -->
  <div class="ContinuityCarePage" id="app-container">
    <!-- ç¬¬ä¸€éƒ¨åˆ†ï¼šæ‚£è€…基础信息 -->
    <div class="patient-info-section">
      <div class="headline">
        <div>患者基础信息</div>
      </div>
      <div class="patient-info-form">
        <el-form
          ref="patientForm"
          :model="patientForm"
          :rules="patientRules"
          label-width="120px"
        >
          <el-row :gutter="20">
            <el-col :span="8">
              <el-form-item label="患者姓名" prop="name">
                <el-input
                  v-model="patientForm.name"
                  placeholder="请输入患者姓名"
                  maxlength="30"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="性别" prop="sex">
                <el-select
                  v-model="patientForm.sex"
                  placeholder="请选择"
                  clearable
                >
                  <el-option label="男" :value="1"></el-option>
                  <el-option label="女" :value="2"></el-option>
                </el-select>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="年龄" prop="age">
                <el-input
                  v-model="patientForm.age"
                  placeholder="请输入年龄"
                  maxlength="3"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row :gutter="20">
            <el-col :span="8">
              <el-form-item label="联系电话" prop="telcode">
                <el-input
                  v-model="patientForm.telcode"
                  placeholder="请输入联系电话"
                  maxlength="20"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="住院号" prop="hospitalNumber">
                <el-input
                  v-model="patientForm.hospitalNumber"
                  placeholder="请输入住院号"
                  maxlength="50"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="出院日期" prop="dischargeDate">
                <el-date-picker
                  v-model="patientForm.dischargeDate"
                  type="date"
                  placeholder="选择出院日期"
                  value-format="yyyy-MM-dd"
                  style="width: 100%"
                >
                </el-date-picker>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row :gutter="20">
            <el-col :span="12">
              <el-form-item label="诊断名称" prop="diagnosis">
                <el-input
                  v-model="patientForm.diagnosis"
                  placeholder="请输入诊断名称"
                  maxlength="100"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item label="责任护士" prop="nurseName">
                <el-input
                  v-model="patientForm.nurseName"
                  placeholder="请输入责任护士"
                  maxlength="50"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row :gutter="20">
            <el-col :span="24">
              <el-form-item label="居住地址" prop="address">
                <el-input
                  v-model="patientForm.address"
                  placeholder="请输入详细居住地址"
                  maxlength="200"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <el-row :gutter="20">
            <el-col :span="12">
              <el-form-item label="亲属姓名" prop="relativeName">
                <el-input
                  v-model="patientForm.relativeName"
                  placeholder="请输入亲属姓名"
                  maxlength="30"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item label="亲属电话" prop="relativeTel">
                <el-input
                  v-model="patientForm.relativeTel"
                  placeholder="请输入亲属电话"
                  maxlength="20"
                  clearable
                ></el-input>
              </el-form-item>
            </el-col>
          </el-row>
          <!-- å»¶ç»­æŠ¤ç†æ±‡æ€»ä¿¡æ¯ -->
          <el-row :gutter="20" v-if="continuitySummary.continueCount > 0">
            <el-col :span="24">
              <el-form-item label="延续护理汇总">
                <div class="continuity-summary">
                  <div class="summary-item">
                    <span class="label">延续次数:</span>
                    <span class="value"
                      >{{ continuitySummary.continueCount }} æ¬¡</span
                    >
                  </div>
                  <div class="summary-item">
                    <span class="label">最新服务:</span>
                    <span class="value">{{
                      formatDisplayTime(continuitySummary.continueTimeNow)
                    }}</span>
                  </div>
                  <div class="summary-item">
                    <span class="label">下次服务:</span>
                    <span class="value">{{
                      formatDisplayTime(continuitySummary.continueTimeNext)
                    }}</span>
                  </div>
                </div>
              </el-form-item>
            </el-col>
          </el-row>
          <!-- æ“ä½œæŒ‰é’® -->
          <el-form-item>
            <el-button
              type="primary"
              @click="savePatientInfo"
              :loading="savingPatientInfo"
            >
              ä¿å­˜æ‚£è€…信息
            </el-button>
            <el-button @click="resetPatientInfo">重置</el-button>
          </el-form-item>
        </el-form>
      </div>
    </div>
    <!-- ç¬¬äºŒéƒ¨åˆ†ï¼šæœåŠ¡åŸºç¡€ä¿¡æ¯ -->
    <div class="basic-info-section">
      <div class="headline">
        <div>服务基础信息</div>
      </div>
      <div class="basic-info-container">
        <!-- å·¦åŠéƒ¨åˆ†ï¼šå½“前服务随访内容(只读) -->
        <div class="followup-content readonly-content">
          <div class="sub-headline">
            <i class="el-icon-document"></i> å½“前服务随访内容(只读)
            <el-button
              type="text"
              size="small"
              @click="toggleQuestionSelection"
              style="margin-left: 10px"
            >
              {{ showQuestionSelector ? "隐藏问题选取" : "选取延续问题" }}
            </el-button>
          </div>
          <!-- é—®é¢˜é€‰å–面板 -->
          <div v-if="showQuestionSelector" class="question-selector-panel">
            <div class="selector-header">
              <span>请选择延续问题(可多选):</span>
              <el-button
                type="primary"
                size="small"
                @click="confirmQuestionSelection"
              >
                ç¡®è®¤é€‰å–
              </el-button>
            </div>
            <div class="question-list">
              <el-checkbox-group v-model="selectedQuestionIds">
                <div
                  v-for="(question, index) in availableQuestions"
                  :key="question.id"
                  class="question-item"
                >
                  <el-checkbox :label="question.id">
                    <div class="question-content">
                      <span class="question-index"
                        >{{ question.index + 1 }}.</span
                      >
                      <span class="question-text">{{ question.text }}</span>
                    </div>
                  </el-checkbox>
                </div>
              </el-checkbox-group>
            </div>
          </div>
          <div class="content-container">
            <el-tabs v-model="activeName" type="border-card">
              <el-tab-pane name="wj">
                <span slot="label"
                  ><i class="el-icon-notebook-1"></i> é—®å·éšè®¿ç»“æžœ</span
                >
                <div class="CONTENT">
                  <div class="title">{{ taskname ? taskname : "问卷" }}</div>
                  <div class="preview-left" v-if="!Voicetype">
                    <div
                      class="topic-dev"
                      v-for="(item, index) in tableDatatop"
                      :key="item.id"
                    >
                      <!-- å•选 -->
                      <div
                        :class="getTopicClass(item)"
                        :key="index"
                        v-if="item.scriptType == 1 && !item.astrict"
                      >
                        <div class="dev-text">
                          {{ index + 1 }}、[单选]<span>{{
                            item.scriptContent
                          }}</span>
                        </div>
                        <div class="dev-xx">
                          <el-radio-group v-model="item.scriptResult" disabled>
                            <el-radio
                              v-for="(
                                items, indexs
                              ) in item.svyTaskTemplateTargetoptions"
                              :class="getOptionClass(items)"
                              :key="indexs"
                              :label="items.optioncontent"
                              >{{ items.optioncontent }}</el-radio
                            >
                          </el-radio-group>
                        </div>
                        <div
                          v-if="item.showAppendInput || item.answerps"
                          class="append-input-container"
                        >
                          <el-input
                            type="textarea"
                            :rows="2"
                            placeholder="请输入具体信息"
                            v-model="item.answerps"
                            readonly
                          ></el-input>
                        </div>
                        <div v-show="item.prompt">
                          <el-alert :title="item.prompt" type="warning">
                          </el-alert>
                        </div>
                      </div>
                      <!-- å¤šé€‰ -->
                      <div
                        :class="
                          item.isabnormal
                            ? 'scriptTopic-isabnormal'
                            : 'scriptTopic-dev'
                        "
                        :key="index"
                        v-if="item.scriptType == 2 && !item.astrict"
                      >
                        <div class="dev-text">
                          {{ index + 1 }}、[多选]<span>{{
                            item.scriptContent
                          }}</span>
                        </div>
                        <div class="dev-xx">
                          <el-checkbox-group
                            v-model="item.scriptResult"
                            disabled
                          >
                            <el-checkbox
                              :class="items.isabnormal ? 'red-star' : ''"
                              v-for="(
                                items, indexs
                              ) in item.svyTaskTemplateTargetoptions"
                              :key="indexs"
                              :label="items.optioncontent"
                            >
                              {{ items.optioncontent }}
                            </el-checkbox>
                          </el-checkbox-group>
                        </div>
                        <div v-show="item.prompt && item.scriptResult[0]">
                          <el-alert :title="item.prompt" type="warning">
                          </el-alert>
                        </div>
                      </div>
                      <!-- å¡«ç©º -->
                      <div
                        class="scriptTopic-dev"
                        :key="index"
                        v-if="item.scriptType == 4 && !item.astrict"
                      >
                        <div class="dev-text">
                          {{ index + 1 }}、[问答]<span>{{
                            item.scriptContent
                          }}</span>
                          <span v-if="item.valueType == 3">(只能输入数字)</span>
                        </div>
                        <div class="dev-xx" v-if="item.valueType == 3">
                          <el-input
                            type="text"
                            placeholder="请输入答案"
                            v-model="item.scriptResult"
                            readonly
                          >
                          </el-input>
                        </div>
                        <div class="dev-xx" v-else>
                          <el-input
                            type="textarea"
                            :rows="2"
                            placeholder="请输入答案"
                            v-model="item.scriptResult"
                            readonly
                          >
                          </el-input>
                        </div>
                      </div>
                    </div>
                  </div>
                  <div class="preview-left" v-else>
                    <div
                      class="topic-dev"
                      v-for="(item, index) in tableDatatop"
                      :key="item.id"
                    >
                      <div v-if="item.targetvalue">
                        <div class="dev-text">
                          {{ index + 1 }}、[单选]<span>{{
                            item.questiontext
                          }}</span>
                        </div>
                        <div class="dev-xx">
                          <el-radio-group v-model="item.matchedtext" disabled>
                            <el-radio
                              v-for="(items, index) in item.scriptResult"
                              :key="index"
                              :label="items"
                              :class="items.isabnormal ? 'red-star' : ''"
                              >{{ items }}</el-radio
                            >
                          </el-radio-group>
                        </div>
                        <div v-show="item.prompt">
                          <el-alert :title="item.prompt" type="warning">
                          </el-alert>
                        </div>
                      </div>
                      <div class="scriptTopic-dev" :key="index" v-else>
                        <div class="dev-text">
                          {{ index + 1 }}、[问答]<span>{{
                            item.scriptContent
                          }}</span>
                          <span v-if="item.valueType == 3">(只能输入数字)</span>
                        </div>
                        <div class="dev-xx" v-if="item.valueType == 3">
                          <el-input
                            type="text"
                            placeholder="请输入答案"
                            v-model="item.scriptResult"
                            readonly
                          >
                          </el-input>
                        </div>
                        <div class="dev-xx" v-else>
                          <el-input
                            type="textarea"
                            :rows="2"
                            placeholder="请输入答案"
                            v-model="item.scriptResult"
                            readonly
                          >
                          </el-input>
                        </div>
                      </div>
                    </div>
                  </div>
                </div>
              </el-tab-pane>
              <el-tab-pane name="yy">
                <span slot="label"
                  ><i class="el-icon-headset"></i> è¯­éŸ³éšè®¿è¯¦æƒ…</span
                >
                <div class="borderdiv">
                  <div class="title">{{ taskname ? taskname : "问卷" }}</div>
                  <div class="voice-audio">
                    å®Œæ•´è¯­éŸ³ï¼š
                    <mini-audio
                      :audio-source="
                        voice ? voice : '@assets/order/example.mp3'
                      "
                    ></mini-audio>
                  </div>
                  <div class="preview-left">
                    <div v-for="item in voiceDatatop">
                      <div class="leftside">
                        <i class="el-icon-phone-outline"></i
                        ><span>{{ item.questiontext }}</span>
                      </div>
                      <div class="offside">
                        <i class="el-icon-user"></i>
                        <div class="offside-value">
                          <el-input
                            type="textarea"
                            :autosize="{ minRows: 1 }"
                            v-model="item.asrtext"
                            readonly
                          ></el-input>
                          <div>
                            <mini-audio
                              :audio-source="
                                item.questionvoice
                                  ? item.questionvoice
                                  : '@assets/order/example.mp3'
                              "
                            ></mini-audio>
                          </div>
                        </div>
                      </div>
                    </div>
                  </div>
                </div>
              </el-tab-pane>
            </el-tabs>
          </div>
        </div>
        <!-- å³åŠéƒ¨åˆ†ï¼šåŽ†æ¬¡å»¶ç»­æŠ¤ç†æœåŠ¡ -->
        <!-- å³åŠéƒ¨åˆ†ï¼šåŽ†æ¬¡å»¶ç»­æŠ¤ç†æœåŠ¡ -->
        <div class="continuity-history">
          <div class="sub-headline">
            <i class="el-icon-time"></i> åŽ†æ¬¡å»¶ç»­æŠ¤ç†æœåŠ¡
            <el-button
              type="primary"
              size="small"
              icon="el-icon-plus"
              @click="addContinuityTab"
              style="margin-left: 10px"
              >新增延续护理</el-button
            >
          </div>
          <div class="history-content">
            <el-tabs
              v-model="activeContinuityTab"
              type="card"
              closable
              @tab-remove="removeContinuityTab"
              @tab-click="handleTabClick"
            >
              <el-tab-pane
                v-for="(item, index) in continuityTabs"
                :key="item.name"
                :label="item.title"
                :name="item.name"
              >
                <div class="continuity-form">
                  <el-form
                    :ref="'continuityForm' + index"
                    :model="item.form"
                    :rules="continuityRules"
                    label-width="120px"
                  >
                    <!-- å»¶ç»­é—®é¢˜è¡¨å• -->
                    <el-form-item label="延续问题" prop="continuityProblems">
                      <div class="continuity-problems-form">
                        <div class="problems-header">
                          <span>已选取的延续问题:</span>
                          <el-button
                            type="text"
                            size="small"
                            icon="el-icon-plus"
                            @click="addContinuityProblem(index)"
                          >
                            æ–°å¢žé—®é¢˜
                          </el-button>
                        </div>
                        <!-- å·²é€‰å–的问题列表 -->
                        <div
                          v-if="
                            item.form.continuityProblems &&
                            item.form.continuityProblems.length > 0
                          "
                          class="problems-list-container"
                        >
                          <div
                            v-for="(problem, problemIndex) in item.form
                              .continuityProblems"
                            :key="problemIndex"
                            class="problem-item"
                          >
                            <div class="problem-content">
                              <div class="problem-meta">
                                <span class="problem-index"
                                  >问题 {{ problemIndex + 1 }}</span
                                >
                                <el-select
                                  v-model="problem.questionId"
                                  placeholder="选择问题"
                                  size="small"
                                  style="width: 300px; margin: 0 10px"
                                  @change="
                                    handleProblemChange(
                                      index,
                                      problemIndex,
                                      $event
                                    )
                                  "
                                >
                                  <el-option
                                    v-for="q in availableQuestions"
                                    :key="q.id"
                                    :label="q.text"
                                    :value="q.id"
                                  >
                                    <span
                                      >{{ q.index + 1 }}.
                                      {{ truncateText(q.text, 40) }}</span
                                    >
                                  </el-option>
                                </el-select>
                                <!-- ä¿®å¤ï¼šä¼ é€’正确的索引 -->
                                <el-button
                                  type="danger"
                                  icon="el-icon-delete"
                                  size="mini"
                                  circle
                                  @click="
                                    removeContinuityProblem(index, problemIndex)
                                  "
                                >
                                </el-button>
                              </div>
                              <!-- é—®å·å¼é—®é¢˜å±•示区域 -->
                              <div
                                v-if="problem.questionId"
                                class="question-display-area"
                              >
                                <!-- æ ¹æ®é—®é¢˜ç±»åž‹åŠ¨æ€æ¸²æŸ“ -->
                                <div
                                  v-if="
                                    getQuestionOriginalData(problem.questionId)
                                  "
                                  class="question-render"
                                >
                                  <!-- å•选类型 -->
                                  <div
                                    v-if="
                                      getQuestionOriginalData(
                                        problem.questionId
                                      ).scriptType == 1
                                    "
                                    class="question-item-render"
                                  >
                                    <div class="question-text">
                                      <strong>[单选]</strong>
                                      <span>{{
                                        getQuestionOriginalData(
                                          problem.questionId
                                        ).scriptContent
                                      }}</span>
                                    </div>
                                    <div class="question-options">
                                      <el-radio-group
                                        v-model="problem.selectedOption"
                                      >
                                        <el-radio
                                          v-for="option in getQuestionOriginalData(
                                            problem.questionId
                                          ).svyTaskTemplateTargetoptions"
                                          :key="option.optioncontent"
                                          :label="option.optioncontent"
                                          :class="getOptionClass(option)"
                                        >
                                          {{ option.optioncontent }}
                                        </el-radio>
                                      </el-radio-group>
                                    </div>
                                    <!-- é™„加输入框 -->
                                    <div
                                      v-if="problem.showAppendInput"
                                      class="append-input"
                                      style="margin-top: 10px"
                                    >
                                      <el-input
                                        type="textarea"
                                        :rows="2"
                                        placeholder="请输入具体信息"
                                        v-model="problem.appendInput"
                                      ></el-input>
                                    </div>
                                  </div>
                                  <!-- å¤šé€‰ç±»åž‹ -->
                                  <div
                                    v-else-if="
                                      getQuestionOriginalData(
                                        problem.questionId
                                      ).scriptType == 2
                                    "
                                    class="question-item-render"
                                  >
                                    <div class="question-text">
                                      <strong>[多选]</strong>
                                      <span>{{
                                        getQuestionOriginalData(
                                          problem.questionId
                                        ).scriptContent
                                      }}</span>
                                    </div>
                                    <div class="question-options">
                                      <el-checkbox-group
                                        v-model="problem.selectedOptions"
                                      >
                                        <el-checkbox
                                          v-for="option in getQuestionOriginalData(
                                            problem.questionId
                                          ).svyTaskTemplateTargetoptions"
                                          :key="option.optioncontent"
                                          :label="option.optioncontent"
                                          :class="
                                            option.isabnormal ? 'red-star' : ''
                                          "
                                        >
                                          {{ option.optioncontent }}
                                        </el-checkbox>
                                      </el-checkbox-group>
                                    </div>
                                  </div>
                                  <!-- å¡«ç©º/问答类型 -->
                                  <div
                                    v-else-if="
                                      getQuestionOriginalData(
                                        problem.questionId
                                      ).scriptType == 4
                                    "
                                    class="question-item-render"
                                  >
                                    <div class="question-text">
                                      <strong>[问答]</strong>
                                      <span>{{
                                        getQuestionOriginalData(
                                          problem.questionId
                                        ).scriptContent
                                      }}</span>
                                      <span
                                        v-if="
                                          getQuestionOriginalData(
                                            problem.questionId
                                          ).valueType == 3
                                        "
                                        >(只能输入数字)</span
                                      >
                                    </div>
                                    <div class="question-options">
                                      <el-input
                                        v-if="
                                          getQuestionOriginalData(
                                            problem.questionId
                                          ).valueType == 3
                                        "
                                        type="text"
                                        placeholder="请输入答案"
                                        v-model="problem.answer"
                                        style="width: 200px"
                                      ></el-input>
                                      <el-input
                                        v-else
                                        type="textarea"
                                        :rows="2"
                                        placeholder="请输入答案"
                                        v-model="problem.answer"
                                        style="width: 100%"
                                      ></el-input>
                                    </div>
                                  </div>
                                </div>
                                <div v-else class="no-question-data">
                                  é—®é¢˜æ•°æ®åŠ è½½ä¸­...
                                </div>
                              </div>
                              <!-- åŽŸæœ‰çš„é—®é¢˜æè¿°ç­‰å­—æ®µ -->
                              <div class="problem-detail">
                                <div class="detail-row">
                                  <span class="detail-label">当前状态:</span>
                                  <el-select
                                    v-model="problem.status"
                                    placeholder="选择状态"
                                    size="small"
                                    style="width: 120px; margin-right: 20px"
                                  >
                                    <el-option
                                      label="未处理"
                                      value="pending"
                                    ></el-option>
                                    <el-option
                                      label="处理中"
                                      value="processing"
                                    ></el-option>
                                    <el-option
                                      label="已解决"
                                      value="resolved"
                                    ></el-option>
                                    <el-option
                                      label="持续关注"
                                      value="watching"
                                    ></el-option>
                                  </el-select>
                                  <span
                                    class="detail-label"
                                    v-if="problem.status === 'resolved'"
                                    style="margin-left: 20px"
                                  >
                                    è§£å†³æ—¥æœŸï¼š
                                  </span>
                                  <el-date-picker
                                    v-if="problem.status === 'resolved'"
                                    v-model="problem.resolvedDate"
                                    type="date"
                                    placeholder="选择解决日期"
                                    value-format="yyyy-MM-dd"
                                    size="small"
                                    style="width: 150px; margin-left: 10px"
                                  ></el-date-picker>
                                </div>
                                <!-- <div class="detail-row">
                                  <span class="detail-label">问题描述:</span>
                                  <el-input
                                    type="textarea"
                                    :rows="2"
                                    v-model="problem.description"
                                    placeholder="请详细描述该延续问题(可记录评估结果、处理建议等)"
                                    size="small"
                                    style="flex: 1"
                                  ></el-input>
                                </div> -->
                              </div>
                            </div>
                          </div>
                        </div>
                      </div>
                    </el-form-item>
                    <!-- å»¶ç»­æ€§æŠ¤ç†è®°å½• -->
                    <el-form-item label="护理记录" prop="careRecord">
                      <el-input
                        type="textarea"
                        :rows="4"
                        v-model="item.form.careRecord"
                        placeholder="请输入延续性护理记录"
                        clearable
                      ></el-input>
                    </el-form-item>
                    <!-- è´£ä»»æŠ¤å£«ã€å›žè®¿å½¢å¼ã€æœåŠ¡æ—¶é—´ -->
                    <el-row :gutter="20">
                      <el-col :span="12">
                        <el-form-item label="责任护士" prop="dutyNurse">
                          <el-input
                            v-model="item.form.dutyNurse"
                            placeholder="请输入责任护士"
                            clearable
                          ></el-input>
                        </el-form-item>
                      </el-col>
                      <el-col :span="12">
                        <el-form-item label="回访形式" prop="visitType">
                          <el-select
                            v-model="item.form.visitType"
                            placeholder="请选择回访形式"
                            style="width: 100%"
                            clearable
                          >
                            <el-option
                              label="电话回访"
                              value="phone"
                            ></el-option>
                            <el-option
                              label="上门回访"
                              value="home"
                            ></el-option>
                            <el-option
                              label="门诊回访"
                              value="clinic"
                            ></el-option>
                            <el-option
                              label="微信回访"
                              value="wechat"
                            ></el-option>
                            <el-option label="其他" value="other"></el-option>
                          </el-select>
                        </el-form-item>
                      </el-col>
                    </el-row>
                    <el-row :gutter="20">
                      <el-col :span="12">
                        <el-form-item
                          label="下次服务时间"
                          prop="nextServiceTime"
                        >
                          <el-date-picker
                            v-model="item.form.nextServiceTime"
                            type="datetime"
                            placeholder="选择下次延续服务时间"
                            value-format="yyyy-MM-dd HH:mm:ss"
                            style="width: 100%"
                          >
                          </el-date-picker>
                          <div
                            class="time-tip"
                            v-if="item.form.nextServiceTime"
                          >
                            è·ä¸‹æ¬¡æœåŠ¡è¿˜æœ‰
                            {{ calculateDaysLeft(item.form.nextServiceTime) }}
                            å¤©
                          </div>
                        </el-form-item>
                      </el-col>
                      <el-col :span="12">
                        <el-form-item label="服务时间" prop="serviceTime">
                          <el-date-picker
                            v-model="item.form.serviceTime"
                            type="datetime"
                            placeholder="选择服务时间"
                            value-format="yyyy-MM-dd HH:mm:ss"
                            style="width: 100%"
                          >
                          </el-date-picker>
                        </el-form-item>
                      </el-col>
                    </el-row>
                    <!-- ä¸‹æ¬¡å»¶ç»­æœåŠ¡æ—¶é—´ -->
                    <!-- æ“ä½œæŒ‰é’® -->
                    <el-form-item>
                      <el-button
                        type="primary"
                        @click="saveContinuityTab(index)"
                        :loading="item.saving"
                      >
                        ä¿å­˜
                      </el-button>
                      <el-button @click="resetContinuityTab(index)">
                        é‡ç½®
                      </el-button>
                    </el-form-item>
                  </el-form>
                </div>
              </el-tab-pane>
            </el-tabs>
          </div>
        </div>
      </div>
    </div>
  </div>
</template>
<script>
import {
  getsearchrResults,
  getPersonVoices,
  getTaskservelist,
  Editsingletaskson,
} from "@/api/AiCentre/index";
import {
  messagelistpatient,
  alterpatient,
  listcontactinformation,
} from "@/api/patient/homepage";
export default {
  dicts: ["sys_yujing"],
  data() {
    return {
      // è·¯ç”±å‚æ•°
      taskid: "",
      id: "",
      sendname: "",
      patid: "",
      Voicetype: 0,
      serviceType: "",
      // éšè®¿å†…容相关
      activeName: "wj",
      taskname: "",
      voice: "",
      tableDatatop: [],
      voiceDatatop: [],
      form: {},
      userform: {},
      // æ–°å¢žï¼šé—®é¢˜é€‰æ‹©ç›¸å…³
      showQuestionSelector: false,
      selectedQuestionIds: [],
      // æ‚£è€…基础信息表单
      patientForm: {
        name: "",
        sex: "",
        age: "",
        telcode: "",
        hospitalNumber: "",
        dischargeDate: "",
        diagnosis: "",
        nurseName: "",
        address: "",
        relativeName: "",
        relativeTel: "",
      },
      patientRules: {
        name: [{ required: true, message: "请输入患者姓名", trigger: "blur" }],
        age: [
          { required: true, message: "请输入年龄", trigger: "blur" },
          { pattern: /^\d+$/, message: "年龄必须为数字", trigger: "blur" },
        ],
        telcode: [
          { required: true, message: "请输入联系电话", trigger: "blur" },
          {
            pattern: /^1[3-9]\d{9}$/,
            message: "请输入正确的手机号码",
            trigger: "blur",
          },
        ],
      },
      savingPatientInfo: false,
      // å»¶ç»­æŠ¤ç†ç›¸å…³
      activeContinuityTab: "continuity-0",
      continuityTabs: [],
      continuityTabIndex: 0,
      continuityRules: {
        // ç§»é™¤continuityProblems的验证规则
        careRecord: [
          { required: true, message: "请输入护理记录", trigger: "blur" },
        ],
        dutyNurse: [
          { required: true, message: "请输入责任护士", trigger: "blur" },
        ],
        visitType: [
          { required: true, message: "请选择回访形式", trigger: "change" },
        ],
        serviceTime: [
          { required: true, message: "请选择服务时间", trigger: "change" },
        ],
        nextServiceTime: [
          { required: true, message: "请选择下次服务时间", trigger: "change" },
        ],
      },
      // å¯é€‰çš„延续问题(从左侧问卷中提取)
      availableQuestions: [],
      // å»¶ç»­æŠ¤ç†æ±‡æ€»ä¿¡æ¯
      continuitySummary: {
        continueCount: 0,
        continueTimeNow: "",
        continueTimeNext: "",
        continueContent: "",
      },
      // å…¶ä»–
      logsheetlist: [],
    };
  },
  created() {
    this.taskid = this.$route.query.taskid;
    this.id = this.$route.query.id;
    this.sendname = this.$route.query.sendname;
    this.patid = this.$route.query.patid;
    this.Voicetype = this.$route.query.Voicetype || 0;
    this.serviceType = this.$route.query.serviceType;
    this.getTaskservelist(this.id);
  },
  methods: {
    // èŽ·å–ä¸»é¢˜æ ·å¼ç±»
    getTopicClass(item) {
      console.log(item.isabnormal, "getTopicClass");
      if (item.isabnormal == 1) {
        return "scriptTopic-isabnormal";
      } else if (item.isabnormal == 2) {
        return "scriptTopic-warning";
      } else {
        return "scriptTopic-dev";
      }
    },
    // èŽ·å–é€‰é¡¹æ ·å¼ç±»
    getOptionClass(items) {
      if (items.isabnormal == 1) {
        return "red-star";
      } else if (items.isabnormal == 2) {
        return "yellow-star";
      }
      return "";
    },
    // èŽ·å–é—®å·æ•°æ®
    getsearchrResults(id) {
      getsearchrResults({
        taskid: this.taskid,
        patid: this.patid,
        subId: id ? id : this.id,
        isFinish: false,
      }).then((res) => {
        if (res.code === 200) {
          this.tableDatatop = res.data.scriptResult;
          this.tableDatatop.forEach((item) => {
            if (item.scriptType == 2) item.scriptResult = [];
            if (item.scriptResultId && item.scriptType != 2) {
              item.isoption = 3;
              item.scriptResult = item.scriptResult;
            } else if (item.scriptResultId && item.scriptType == 2) {
              item.scriptResult = item.scriptResult.split("&");
              item.isoption = 3;
            }
          });
          this.taskname = res.data.taskName;
          this.overdata();
          // æå–可选的延续问题
          this.extractAvailableQuestions();
        }
      });
    },
    overdata() {
      this.tableDatatop.forEach((item, index) => {
        var obj = item.svyTaskTemplateTargetoptions.find(
          (items) => items.optioncontent == item.scriptResult
        );
        if (obj) {
          console.log(obj, "obj");
          if (obj.isabnormal) {
            this.tableDatatop[index].isabnormal = obj.isabnormal;
          }
          this.$forceUpdate();
        }
      });
    },
    // æå–可选的延续问题
    extractAvailableQuestions() {
      this.availableQuestions = this.tableDatatop
        .filter(
          (item) => item.scriptContent && item.scriptContent.trim() !== ""
        )
        .map((item, index) => ({
          id: `question-${index}`,
          index: index,
          text: item.scriptContent,
          originalIndex: index,
        }));
    }, // åˆ‡æ¢é—®é¢˜é€‰æ‹©é¢æ¿æ˜¾ç¤º
    toggleQuestionSelection() {
      this.showQuestionSelector = !this.showQuestionSelector;
      if (this.showQuestionSelector) {
        // é‡ç½®é€‰æ‹©
        this.selectedQuestionIds = [];
      }
    },
    // æ·»åŠ å»¶ç»­é—®é¢˜
    addContinuityProblem(tabIndex) {
      this.continuityTabs[tabIndex].form.continuityProblems.push({
        questionId: "",
        status: "pending",
        description: "",
        resolvedDate: "",
        createTime: new Date().toISOString(),
        // æ–°å¢žå­—段,用于问卷式交互
        selectedOption: "", // å•选答案
        selectedOptions: [], // å¤šé€‰ç­”案
        answer: "", // å¡«ç©ºç­”案
        showAppendInput: false, // æ˜¯å¦æ˜¾ç¤ºé™„加输入框
        appendInput: "", // é™„加输入内容
      });
    },
    // æ ¹æ®é—®é¢˜ID获取原始问题数据
    getQuestionOriginalData(questionId) {
      if (!questionId) return null;
      const originalIndex = this.availableQuestions.find(
        (q) => q.id === questionId
      )?.originalIndex;
      if (originalIndex !== undefined && this.tableDatatop[originalIndex]) {
        return this.tableDatatop[originalIndex];
      }
      return null;
    },
    // ç§»é™¤å»¶ç»­é—®é¢˜
    removeContinuityProblem(tabIndex, problemIndex) {
      this.continuityTabs[tabIndex].form.continuityProblems.splice(
        problemIndex,
        1
      );
    },
    // å¤„理问题选择变更
    handleProblemChange(tabIndex, problemIndex, questionId) {
      const problem =
        this.continuityTabs[tabIndex].form.continuityProblems[problemIndex];
      if (!questionId) {
        problem.description = "";
        // æ¸…空答案字段
        problem.selectedOption = "";
        problem.selectedOptions = [];
        problem.answer = "";
        problem.showAppendInput = false;
        problem.appendInput = "";
        return;
      }
      // è‡ªåŠ¨å¡«å……é—®é¢˜æè¿°
      const question = this.availableQuestions.find((q) => q.id === questionId);
      if (question) {
        problem.description = `问题:${question.text}`;
      }
      // æ ¹æ®é—®é¢˜ç±»åž‹åˆå§‹åŒ–答案字段
      const originalData = this.getQuestionOriginalData(questionId);
      if (originalData) {
        // åˆå§‹åŒ–单选答案
        if (originalData.scriptType === 1) {
          problem.selectedOption = originalData.scriptResult || "";
          // æ£€æŸ¥æ˜¯å¦éœ€è¦æ˜¾ç¤ºé™„加输入框
          problem.showAppendInput = originalData.showAppendInput || false;
          problem.appendInput = originalData.answerps || "";
        }
        // åˆå§‹åŒ–多选答案
        else if (originalData.scriptType === 2) {
          problem.selectedOptions = Array.isArray(originalData.scriptResult)
            ? [...originalData.scriptResult]
            : originalData.scriptResult
            ? originalData.scriptResult.split("&")
            : [];
        }
        // åˆå§‹åŒ–填空答案
        else if (originalData.scriptType === 4) {
          problem.answer = originalData.scriptResult || "";
        }
      }
    },
    // æ ¹æ®é—®é¢˜ID获取问题文本
    getQuestionText(questionId) {
      if (!questionId) return "未选择问题";
      const question = this.availableQuestions.find((q) => q.id === questionId);
      return question
        ? `${question.index + 1}. ${question.text}`
        : "问题已删除";
    },
    // æˆªæ–­æ–‡æœ¬
    truncateText(text, length) {
      if (!text) return "";
      return text.length > length ? text.substring(0, length) + "..." : text;
    },
    // ç¡®è®¤é—®é¢˜é€‰æ‹©
    confirmQuestionSelection() {
      if (this.selectedQuestionIds.length === 0) {
        this.$modal.msgWarning("请至少选择一个延续问题");
        return;
      }
      // èŽ·å–å½“å‰æ¿€æ´»çš„æ ‡ç­¾é¡µç´¢å¼•
      const activeTabIndex = this.continuityTabs.findIndex(
        (tab) => tab.name === this.activeContinuityTab
      );
      if (activeTabIndex === -1) {
        this.$modal.msgError("未找到激活的延续护理标签页");
        return;
      }
      // æ·»åŠ é€‰ä¸­çš„é—®é¢˜åˆ°å½“å‰æ ‡ç­¾é¡µ
      this.selectedQuestionIds.forEach((questionId) => {
        // æ£€æŸ¥æ˜¯å¦å·²å­˜åœ¨ç›¸åŒé—®é¢˜
        const exists = this.continuityTabs[
          activeTabIndex
        ].form.continuityProblems.some(
          (problem) => problem.questionId === questionId
        );
        if (!exists) {
          this.continuityTabs[activeTabIndex].form.continuityProblems.push({
            questionId: questionId,
            status: "pending",
            description: "",
            resolvedDate: "",
            createTime: new Date().toISOString(),
          });
        }
      });
      // å…³é—­é€‰æ‹©é¢æ¿
      this.showQuestionSelector = false;
      this.selectedQuestionIds = [];
      this.$modal.msgSuccess(
        `已添加 ${this.selectedQuestionIds.length} ä¸ªå»¶ç»­é—®é¢˜`
      );
    },
    // ç§»é™¤å»¶ç»­é—®é¢˜
    removeContinuityProblem(tabIndex, problemIndex) {
      this.continuityTabs[tabIndex].form.continuityProblems.splice(
        problemIndex,
        1
      );
    },
    // èŽ·å–è¯­éŸ³æ•°æ®
    getPersonVoices(id) {
      let obj = {
        taskid: this.taskid,
        patid: this.patid,
        subId: id ? id : this.id,
      };
      getPersonVoices(obj).then((res) => {
        if (res.code == 200) {
          this.voiceDatatop = res.data.serviceSubtaskDetails;
          this.voice = res.data.voice;
          this.activeName = "yy";
          this.taskname = res.data.taskName;
          this.tableDatatop = res.data.filteredDetails;
          this.tableDatatop.forEach((item) => {
            if (item.targetvalue) {
              item.scriptResult = item.targetvalue.split("&");
            } else {
              item.scriptResult = [];
            }
          });
          // æå–可选的延续问题
          this.extractAvailableQuestions();
        }
      });
    },
    // èŽ·å–åŸºç¡€ä¿¡æ¯
    getuserinfo() {
      const queryParams = {
        pid: Number(this.patid),
        allhosp: "0",
      };
      messagelistpatient(queryParams).then((response) => {
        if (response.rows[0]) {
          this.userform = response.rows[0];
          this.initPatientForm();
        }
      });
      listcontactinformation({ patid: this.patid }).then((response) => {
        this.tableData = response.rows;
        if (this.tableData.length) {
          this.patientForm.relativeName = this.tableData[0].relation || "";
          this.patientForm.relativeTel = this.tableData[0].contactway || "";
        }
      });
    },
    // åˆå§‹åŒ–患者表单
    initPatientForm() {
      if (this.userform) {
        this.patientForm.name = this.userform.name || "";
        this.patientForm.sex = this.userform.sex || "";
        this.patientForm.age = this.userform.age || "";
        this.patientForm.telcode = this.userform.telcode || "";
        this.patientForm.address = this.userform.placeOfResidence || "";
        this.patientForm.hospitalNumber = this.userform.medicalRecordNo || "";
      }
      if (this.form) {
        this.patientForm.dischargeDate =
          this.formatTime(this.form.endtime) || "";
        this.patientForm.diagnosis = this.form.leavediagname || "";
        this.patientForm.nurseName = this.form.nurseName || "";
      }
    },
    // èŽ·å–æ‚£è€…è®°å½•
    getTaskservelist(id) {
      getTaskservelist({
        patid: this.patid,
        subId: id,
        pageSize: 100,
      }).then((res) => {
        if (res.code == 200) {
          this.form = res.rows[0].serviceSubtaskList.find(
            (item) => item.id == this.id
          );
          this.logsheetlist = res.rows[0].serviceSubtaskList;
          // åˆå§‹åŒ–患者信息
          this.initPatientForm();
          // åŠ è½½åŽ†å²å»¶ç»­æŠ¤ç†æ•°æ®
          this.loadContinuityHistory();
          this.getuserinfo();
        }
        if (this.Voicetype) {
          this.getPersonVoices();
        } else {
          this.getsearchrResults();
        }
      });
    },
    // åŠ è½½åŽ†å²å»¶ç»­æŠ¤ç†æ•°æ®
    loadContinuityHistory() {
      if (this.form && this.form.continueContent) {
        try {
          const historyData = JSON.parse(this.form.continueContent);
          this.continuityTabs = historyData.map((item, index) => ({
            name: `continuity-${index}`,
            title: `延续护理${index + 1}`,
            form: {
              continuityProblems: item.continuityProblems || [],
              careRecord: item.careRecord || "",
              dutyNurse: item.dutyNurse || "",
              visitType: item.visitType || "",
              serviceTime: item.serviceTime || "",
              nextServiceTime: item.nextServiceTime || "",
            },
            saving: false,
          }));
          if (this.continuityTabs.length > 0) {
            this.activeContinuityTab = this.continuityTabs[0].name;
          }
          // æ›´æ–°æ±‡æ€»ä¿¡æ¯
          this.updateContinuitySummary();
        } catch (error) {
          console.error("解析延续护理历史数据失败:", error);
        }
      }
    },
    // æ›´æ–°å»¶ç»­æŠ¤ç†æ±‡æ€»ä¿¡æ¯
    updateContinuitySummary() {
      if (this.form) {
        this.continuitySummary.continueCount = this.form.continueCount || 0;
        this.continuitySummary.continueTimeNow =
          this.form.continueTimeNow || "";
        this.continuitySummary.continueTimeNext =
          this.form.continueTimeNext || "";
        this.continuitySummary.continueContent =
          this.form.continueContent || "";
      }
    },
    // æ·»åŠ å»¶ç»­æŠ¤ç†æ ‡ç­¾é¡µ
    addContinuityTab() {
      console.log(this.continuityTabs.length);
      if (this.continuityTabs.length) {
        this.continuityTabIndex = this.continuityTabs.length;
      }
      const newIndex = this.continuityTabIndex + 1;
      const newTab = {
        name: `continuity-${newIndex}`,
        title: `延续护理${newIndex}`,
        form: {
          continuityProblems: [],
          careRecord: "",
          dutyNurse: "",
          visitType: "",
          serviceTime: "",
          nextServiceTime: "",
        },
        saving: false,
      };
      this.continuityTabs.push(newTab);
      this.continuityTabIndex = newIndex;
      this.activeContinuityTab = newTab.name;
    },
    // ç§»é™¤å»¶ç»­æŠ¤ç†æ ‡ç­¾é¡µ
    removeContinuityTab(targetName) {
      const tabs = this.continuityTabs;
      let activeName = this.activeContinuityTab;
      if (activeName === targetName) {
        tabs.forEach((tab, index) => {
          if (tab.name === targetName) {
            const nextTab = tabs[index + 1] || tabs[index - 1];
            if (nextTab) {
              activeName = nextTab.name;
            }
          }
        });
      }
      this.activeContinuityTab = activeName;
      this.continuityTabs = tabs.filter((tab) => tab.name !== targetName);
    },
    // å¤„理标签页点击
    handleTabClick(tab) {
      this.activeContinuityTab = tab.name;
    },
    // è®¡ç®—距离下次服务还有多少天
    calculateDaysLeft(nextServiceTime) {
      if (!nextServiceTime) return 0;
      const nextTime = new Date(nextServiceTime);
      const now = new Date();
      const diffTime = nextTime - now;
      const diffDays = Math.ceil(diffTime / (1000 * 60 * 60 * 24));
      return diffDays > 0 ? diffDays : 0;
    },
    // ä¿å­˜å»¶ç»­æŠ¤ç†æ ‡ç­¾é¡µ
    saveContinuityTab(index) {
      const formRef = this.$refs[`continuityForm${index}`];
      if (!formRef) return;
      // éªŒè¯åŸºæœ¬è¡¨å•
      formRef[0].validate((valid) => {
        if (valid) {
          // éªŒè¯å»¶ç»­é—®é¢˜æ˜¯å¦å®Œæ•´
          const problems = this.continuityTabs[index].form.continuityProblems;
          let hasError = false;
          problems.forEach((problem, problemIndex) => {
            if (!problem.questionId) {
              hasError = true;
              this.$modal.msgError(`第${problemIndex + 1}个延续问题未选择`);
            }
          });
          if (hasError) {
            return false;
          }
          this.continuityTabs[index].saving = true;
          // æ›´æ–°æ±‡æ€»ä¿¡æ¯
          this.updateContinuitySummaryFromTabs();
          // è°ƒç”¨ä¿å­˜API
          this.saveContinuityData();
        } else {
          this.$modal.msgError("请填写完整信息");
          return false;
        }
      });
    },
    // æ›´æ–°å»¶ç»­æŠ¤ç†æ±‡æ€»ä¿¡æ¯
    updateContinuitySummaryFromTabs() {
      if (this.continuityTabs.length === 0) return;
      // æ‰¾åˆ°æœ€æ–°çš„æœåŠ¡æ—¶é—´
      let latestTime = "";
      let nextTime = "";
      let totalProblems = 0;
      this.continuityTabs.forEach((tab) => {
        if (tab.form.serviceTime) {
          if (
            !latestTime ||
            new Date(tab.form.serviceTime) > new Date(latestTime)
          ) {
            latestTime = tab.form.serviceTime;
          }
        }
        if (tab.form.nextServiceTime) {
          if (
            !nextTime ||
            new Date(tab.form.nextServiceTime) < new Date(nextTime)
          ) {
            nextTime = tab.form.nextServiceTime;
          }
        }
        // ç»Ÿè®¡é—®é¢˜æ•°é‡
        totalProblems += tab.form.continuityProblems.length;
      });
      this.continuitySummary.continueCount = this.continuityTabs.length;
      this.continuitySummary.continueTimeNow = latestTime;
      this.continuitySummary.continueTimeNext = nextTime;
      // æž„建完整的延续护理数据
      const continuityData = this.continuityTabs.map((tab) => ({
        ...tab.form,
        tabTitle: tab.title,
        tabName: tab.name,
      }));
      this.continuitySummary.continueContent = JSON.stringify(continuityData);
      this.continuitySummary.totalProblems = totalProblems;
    },
    // ä¿å­˜å»¶ç»­æŠ¤ç†æ•°æ®
    saveContinuityData() {
      const vm = this;
      // éªŒè¯æ¯ä¸ªé—®é¢˜çš„questionId是否已选择
      let hasEmptyQuestion = false;
      this.continuityTabs.forEach((tab, tabIndex) => {
        tab.form.continuityProblems.forEach((problem, problemIndex) => {
          if (!problem.questionId) {
            hasEmptyQuestion = true;
            vm.$modal.msgError(
              `第${tabIndex + 1}个标签页的第${problemIndex + 1}个问题未选择`
            );
          }
        });
      });
      if (hasEmptyQuestion) {
        return;
      }
      const formData = {
        id: vm.id,
        patid: vm.patid,
        taskid: vm.taskid,
        continueFlag: 2,
        continueCount: vm.continuitySummary.continueCount,
        continueTimeNow: vm.continuitySummary.continueTimeNow,
        continueTimeNext: vm.continuitySummary.continueTimeNext,
        continueContent: vm.continuitySummary.continueContent,
        // å¯ä»¥æ·»åŠ é—®å·ç­”æ¡ˆçš„æ•´åˆ
        // questionnaireAnswers: vm.continuityTabs.map((tab) => ({
        //   tabName: tab.name,
        //   problems: tab.form.continuityProblems.map((problem) => ({
        //     questionId: problem.questionId,
        //     answer:
        //       problem.selectedOption ||
        //       problem.selectedOptions ||
        //       problem.answer,
        //     status: problem.status,
        //     description: problem.description,
        //   })),
        // })),
      };
      Editsingletaskson(formData)
        .then((res) => {
          if (res.code === 200) {
            vm.$modal.msgSuccess("延续护理记录保存成功");
            // é‡ç½®ä¿å­˜çŠ¶æ€
            vm.continuityTabs.forEach((tab) => {
              tab.saving = false;
            });
          } else {
            vm.$modal.msgError("保存失败");
          }
        })
        .catch((error) => {
          console.error("保存失败:", error);
          vm.$modal.msgError("保存失败");
          vm.continuityTabs.forEach((tab) => {
            tab.saving = false;
          });
        });
    },
    // é‡ç½®å»¶ç»­æŠ¤ç†æ ‡ç­¾é¡µ
    resetContinuityTab(index) {
      this.continuityTabs[index].form = {
        continuityProblems: [],
        careRecord: "",
        dutyNurse: "",
        visitType: "",
        serviceTime: "",
        nextServiceTime: "",
      };
      this.$refs[`continuityForm${index}`][0].clearValidate();
    },
    // ä¿å­˜æ‚£è€…信息
    savePatientInfo() {
      this.$refs.patientForm.validate((valid) => {
        if (valid) {
          this.savingPatientInfo = true;
          // æ›´æ–°userform数据
          const updatedUserform = {
            ...this.userform,
            name: this.patientForm.name,
            sex: this.patientForm.sex,
            age: this.patientForm.age,
            telcode: this.patientForm.telcode,
            placeOfResidence: this.patientForm.address,
            medicalRecordNo: this.patientForm.hospitalNumber,
          };
          alterpatient(updatedUserform)
            .then((res) => {
              if (res.code == 200) {
                this.$modal.msgSuccess("患者信息保存成功");
                this.userform = updatedUserform;
              } else {
                this.$modal.msgError("患者信息修改失败");
              }
              this.savingPatientInfo = false;
            })
            .catch((error) => {
              console.error("保存失败:", error);
              this.$modal.msgError("保存失败");
              this.savingPatientInfo = false;
            });
        } else {
          this.$modal.msgError("请填写完整信息");
          return false;
        }
      });
    },
    // é‡ç½®æ‚£è€…信息
    resetPatientInfo() {
      this.initPatientForm();
      this.$refs.patientForm.clearValidate();
    },
    // æ—¶é—´æ ¼å¼åŒ–
    formatTime(time) {
      if (!time) return "";
      return time.split(" ")[0];
    },
    // æ ¼å¼åŒ–显示时间
    formatDisplayTime(time) {
      if (!time) return "未设置";
      return time.replace(" ", " ");
    },
    // å¼‚常列渲染
    tableRowClassName({ row }) {
      if (row.id == this.id) {
        return "warning-row";
      }
      return "";
    },
  },
};
</script>
<style lang="scss" scoped>
.ContinuityCarePage {
  margin: 10px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.headline {
  font-size: 20px;
  height: 40px;
  border-left: 5px solid #41a1be;
  padding-left: 10px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  color: #333;
  font-weight: 600;
}
.sub-headline {
  font-size: 16px;
  height: 36px;
  padding-left: 8px;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  color: #409eff;
  font-weight: 500;
  border-bottom: 2px solid #e4e7ed;
  padding-bottom: 8px;
  i {
    margin-right: 8px;
    font-size: 18px;
  }
}
/* ç¬¬ä¸€éƒ¨åˆ†ï¼šæœåŠ¡åŸºç¡€ä¿¡æ¯ */
.basic-info-section {
  margin: 0 10px;
  padding: 20px;
  background: #fff;
  border: 1px solid #dcdfe6;
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), 0 0 6px 0 rgba(0, 0, 0, 0.04);
  border-radius: 4px;
  .basic-info-container {
    display: flex;
    gap: 20px;
    min-height: 1000px;
    @media screen and (max-width: 1200px) {
      flex-direction: column;
    }
  }
  .followup-content {
    flex: 1;
    min-width: 0;
    &.readonly-content {
      background: #f8f9fa;
      border-radius: 8px;
      padding: 15px;
      border: 1px solid #e4e7ed;
    }
    .content-container {
      height: calc(1000px - 60px);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      ::v-deep .el-tabs {
        flex: 1;
        display: flex;
        flex-direction: column;
        .el-tabs__content {
          flex: 1;
          overflow: hidden;
          .el-tab-pane {
            height: 100%;
            overflow: hidden;
            display: flex;
            flex-direction: column;
          }
        }
      }
    }
  }
  .continuity-history {
    flex: 1;
    min-width: 0;
    background: #fff;
    border-radius: 8px;
    padding: 15px;
    border: 1px solid #e4e7ed;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    .history-content {
      height: calc(1000px - 60px);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      ::v-deep .el-tabs {
        flex: 1;
        display: flex;
        flex-direction: column;
        .el-tabs__content {
          flex: 1;
          overflow-y: auto;
          padding: 15px 0;
          .continuity-form {
            padding: 0 10px;
            .el-form {
              .selected-problems {
                margin-top: 10px;
                padding: 10px;
                background: #f5f7fa;
                border-radius: 4px;
                border: 1px solid #e4e7ed;
              }
              .time-tip {
                margin-top: 5px;
                font-size: 12px;
                color: #67c23a;
                font-style: italic;
              }
            }
          }
        }
      }
    }
  }
}
.patient-info-section {
  margin: 0 10px 20px 10px;
  padding: 20px;
  background: #fff;
  border: 1px solid #dcdfe6;
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), 0 0 6px 0 rgba(0, 0, 0, 0.04);
  border-radius: 4px;
  .patient-info-form {
    .continuity-summary {
      padding: 15px;
      background: #ddf0f8;
      border-radius: 8px;
      border: 1px solid #b3e0f2;
      .summary-item {
        display: inline-block;
        margin-right: 30px;
        margin-bottom: 8px;
        .label {
          font-weight: 500;
          color: #333;
        }
        .value {
          color: #409eff;
          font-weight: 500;
        }
      }
    }
  }
}
/* å…±äº«æ ·å¼ */
.CONTENT {
  padding: 10px;
  height: 100%;
  display: flex;
  flex-direction: column;
  .title {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: center;
    color: #333;
  }
}
.preview-left {
  margin: 10px;
  padding: 20px;
  border: 1px solid #dcdfe6;
  border-radius: 4px;
  max-height: 800px;
  overflow-y: auto;
  background: #fff;
  flex: 1;
  .topic-dev {
    margin-bottom: 20px;
    font-size: 16px;
    .dev-text {
      margin-bottom: 10px;
      font-weight: 500;
      color: #333;
    }
  }
}
.scriptTopic-dev {
  padding: 15px;
  border-radius: 4px;
  background: #fafafa;
  border: 1px solid #e4e7ed;
  margin-bottom: 15px;
}
.scriptTopic-isabnormal {
  padding: 15px;
  border-radius: 4px;
  background: #fff5f5;
  border: 1px solid #f56c6c;
  color: #f56c6c;
  margin-bottom: 15px;
}
.scriptTopic-warning {
  padding: 15px;
  border-radius: 4px;
  background: #fff9e6;
  border: 1px solid #e6a23c;
  color: #e6a23c;
  margin-bottom: 15px;
}
.red-star {
  ::v-deep.el-radio__label {
    position: relative;
    padding-right: 10px;
  }
  ::v-deep.el-radio__label::after {
    content: "*";
    color: #f56c6c;
    position: absolute;
    right: -5px;
    top: 0;
  }
}
.yellow-star {
  ::v-deep.el-radio__label {
    position: relative;
    padding-right: 10px;
  }
  ::v-deep.el-radio__label::after {
    content: "*";
    color: #e6a23c;
    position: absolute;
    right: -5px;
    top: 0;
    font-weight: bold;
  }
}
.borderdiv {
  height: 100%;
  padding: 10px;
  display: flex;
  flex-direction: column;
  .title {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: center;
  }
  .voice-audio {
    display: flex;
    align-items: center;
    color: #59a0f0;
    margin-bottom: 20px;
    padding: 10px;
    background: #f5f7fa;
    border-radius: 4px;
  }
  .preview-left {
    flex: 1;
    margin: 0;
    .leftside {
      margin: 15px 0;
      span {
        display: inline-block;
        padding: 8px 12px;
        background: #409eff;
        color: #fff;
        border-radius: 8px;
        max-width: 80%;
        margin-left: 10px;
      }
    }
    .offside {
      display: flex;
      flex-direction: row-reverse;
      margin: 15px 0;
      .offside-value {
        padding: 8px 12px;
        background: #67c23a;
        color: #fff;
        border-radius: 8px;
        max-width: 80%;
        margin-right: 10px;
      }
    }
  }
}
/* å“åº”式设计 */
@media (max-width: 768px) {
  .ContinuityCarePage {
    margin: 5px;
    gap: 10px;
  }
  .basic-info-section,
  .patient-info-section {
    margin: 0 5px;
    padding: 10px;
  }
  .basic-info-container {
    gap: 10px !important;
  }
  .patient-info-form {
    .el-row {
      flex-direction: column;
    }
    .el-col {
      width: 100% !important;
      margin-bottom: 10px;
    }
  }
  .preview-left {
    margin: 5px;
    padding: 10px;
  }
}
/* é—®é¢˜é€‰æ‹©å™¨é¢æ¿ */
.question-selector-panel {
  margin-bottom: 20px;
  padding: 15px;
  background: #f8f9fa;
  border: 1px solid #e4e7ed;
  border-radius: 8px;
  .selector-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid #e4e7ed;
    span {
      font-weight: 500;
      color: #333;
    }
  }
  .question-list {
    max-height: 200px;
    overflow-y: auto;
    padding-right: 10px;
    .question-item {
      margin-bottom: 10px;
      padding: 8px 12px;
      background: #fff;
      border-radius: 6px;
      border: 1px solid #e4e7ed;
      transition: all 0.3s;
      &:hover {
        border-color: #409eff;
        background: #f0f7ff;
      }
      .question-content {
        display: flex;
        align-items: flex-start;
        .question-index {
          font-weight: 600;
          color: #409eff;
          min-width: 30px;
        }
        .question-text {
          flex: 1;
          line-height: 1.5;
        }
      }
    }
  }
}
/* å»¶ç»­é—®é¢˜è¡¨å• */
.continuity-problems-form {
  .problems-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid #e4e7ed;
    span {
      font-weight: 500;
      color: #333;
    }
  }
  .problems-list {
    .problem-item {
      margin-bottom: 20px;
      padding: 15px;
      background: #f8f9fa;
      border-radius: 8px;
      border: 1px solid #e4e7ed;
      &:last-child {
        margin-bottom: 0;
      }
      .problem-content {
        .problem-meta {
          display: flex;
          align-items: center;
          margin-bottom: 15px;
          padding-bottom: 10px;
          border-bottom: 1px dashed #e4e7ed;
          .problem-index {
            font-weight: 500;
            color: #409eff;
            min-width: 80px;
          }
        }
        .problem-detail {
          .detail-row {
            display: flex;
            align-items: flex-start;
            margin-bottom: 10px;
            &:last-child {
              margin-bottom: 0;
            }
            .detail-label {
              font-weight: 500;
              color: #666;
              min-width: 100px;
              line-height: 32px;
            }
            .detail-value {
              flex: 1;
              line-height: 1.5;
              color: #333;
              padding: 5px 0;
            }
          }
        }
      }
    }
  }
  .empty-problems {
    text-align: center;
    padding: 30px 0;
    background: #fafafa;
    border-radius: 8px;
    border: 1px dashed #e4e7ed;
  }
}
/* å»¶ç»­é—®é¢˜åˆ—表容器 - æ·»åŠ æ»šåŠ¨ */
.problems-list-container {
  max-height: 400px; /* æŽ§åˆ¶æœ€å¤§é«˜åº¦ */
  overflow-y: auto;
  padding-right: 10px;
  margin-bottom: 15px;
  &::-webkit-scrollbar {
    width: 6px;
  }
  &::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 3px;
  }
  &::-webkit-scrollbar-thumb {
    background: #c1c1c1;
    border-radius: 3px;
    &:hover {
      background: #a8a8a8;
    }
  }
}
/* é—®å·å¼é—®é¢˜å±•示 */
.question-display-area {
  margin: 15px 0;
  padding: 15px;
  background: #fff;
  border-radius: 8px;
  border: 1px solid #e4e7ed;
  .question-item-render {
    .question-text {
      margin-bottom: 15px;
      font-size: 14px;
      line-height: 1.5;
      color: #333;
      strong {
        color: #409eff;
        margin-right: 5px;
      }
      span {
        color: #666;
      }
    }
    .question-options {
      margin-left: 20px;
      .el-radio,
      .el-checkbox {
        display: block;
        margin-bottom: 8px;
        margin-right: 20px;
      }
    }
    .append-input {
      margin-left: 20px;
      margin-top: 10px;
    }
  }
  .no-question-data {
    text-align: center;
    color: #999;
    padding: 20px;
    font-style: italic;
  }
}
/* è°ƒæ•´é—®é¢˜è¯¦æƒ…布局 */
.problem-detail {
  margin-top: 5px;
  padding-top: 5px;
  padding-bottom: 20px;
  margin-bottom: 10px;
  border-bottom: 1px dashed #6e9af4;
  .detail-row {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
    &:last-child {
      margin-bottom: 0;
    }
    .detail-label {
      font-weight: 500;
      color: #666;
      min-width: 80px;
      white-space: nowrap;
    }
  }
}
/* å“åº”式调整 */
@media (max-width: 768px) {
  .problems-list-container {
    max-height: 300px;
  }
  .problem-detail {
    .detail-row {
      flex-direction: column;
      align-items: flex-start;
      .detail-label {
        margin-bottom: 5px;
        min-width: auto;
      }
      .el-select,
      .el-date-picker {
        width: 100% !important;
        margin: 5px 0 !important;
      }
    }
  }
}
/* å“åº”式调整 */
@media (max-width: 768px) {
  .question-selector-panel {
    padding: 10px;
    .question-list {
      .question-item {
        padding: 6px 8px;
      }
    }
  }
  .continuity-problems-form {
    .problems-list {
      .problem-item {
        padding: 10px;
        .problem-content {
          .problem-meta {
            flex-direction: column;
            align-items: flex-start;
            .el-select {
              width: 100% !important;
              margin: 10px 0;
            }
          }
          .problem-detail {
            .detail-row {
              flex-direction: column;
              align-items: flex-start;
              .detail-label {
                margin-bottom: 5px;
                min-width: auto;
              }
            }
          }
        }
      }
    }
  }
}
/* æ»šåŠ¨æ¡ç¾ŽåŒ– */
.preview-left,
.history-content .el-tabs__content,
.content-container .el-tabs__content {
  &::-webkit-scrollbar {
    width: 6px;
  }
  &::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 3px;
  }
  &::-webkit-scrollbar-thumb {
    background: #c1c1c1;
    border-radius: 3px;
    &:hover {
      background: #a8a8a8;
    }
  }
}
</style>
src/views/followvisit/Continue/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,2094 @@
<template>
  <div class="app-container">
    <!-- <div class="leftvlue" style="margin-bottom: 20px">
      <el-row :gutter="10">
        <el-col :span="2.5" v-for="(item, index) in cardlist" :key="index">
          <el-card
            shadow="hover"
            :body-style="item.router ? ' cursor: pointer' : 'cursor: default'"
          >
            <div style="padding: 8px" @click="$router.push(item.router)">
              <span>{{ item.name }}</span>
              <div
                style="
                  text-align: center;
                  font-size: 18px;
                  margin-top: 10px;
                  font-weight: 600;
                "
              >
                {{ item.value ? item.value : 0 }}
              </div>
            </div>
          </el-card>
        </el-col>
        <el-col :span="2.5">
          <div class="ysfleftvlue">
            <el-card shadow="hover">
              <div style="padding: 8px">
                <span>表单已发送</span>
                <div
                  style="
                    text-align: center;
                    font-size: 18px;
                    margin-top: 10px;
                    font-weight: 600;
                  "
                >
                  {{ yfsvalue }}
                </div>
              </div>
            </el-card>
          </div>
        </el-col>
        <el-col :span="2.5">
          <div class="errleftvlue">
            <el-card shadow="hover">
              <div style="padding: 8px">
                <span>异常</span>
                <div
                  style="
                    text-align: center;
                    font-size: 18px;
                    margin-top: 10px;
                    font-weight: 600;
                  "
                >
                  {{ ycvalue }}
                </div>
              </div>
            </el-card>
          </div>
        </el-col>
        <el-col :span="2.5" v-if="orgname == '省立同德翠苑院区'">
          <div class="jgleftvlue">
            <el-card shadow="hover ">
              <div style="padding: 8px">
                <span>警告</span>
                <div
                  style="
                    text-align: center;
                    font-size: 18px;
                    margin-top: 10px;
                    font-weight: 600;
                  "
                >
                  {{ jgvalue }}
                </div>
              </div>
            </el-card>
          </div>
        </el-col>
      </el-row>
    </div> -->
    <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.taskName"
            placeholder="请选择任务名称"
          ></el-input>
        </el-form-item>
        <el-form-item label="出院时间">
          <el-date-picker
            v-model="dateRange"
            style="width: 240px"
            value-format="yyyy-MM-dd"
            type="daterange"
            range-separator="-"
            start-placeholder="开始日期"
            end-placeholder="结束日期"
          ></el-date-picker>
        </el-form-item>
        <el-form-item label="应随访时间">
          <el-date-picker
            v-model="dateRangefs"
            style="width: 240px"
            value-format="yyyy-MM-dd"
            type="daterange"
            range-separator="-"
            start-placeholder="开始日期"
            end-placeholder="结束日期"
          ></el-date-picker>
        </el-form-item>
        <el-form-item label="患者姓名" prop="sendname">
          <el-input
            v-model="topqueryParams.sendname"
            placeholder="请输入患者姓名"
          ></el-input>
        </el-form-item>
        <el-form-item label="诊断名称" prop="leavediagname">
          <el-input
            v-model="topqueryParams.leavediagname"
            placeholder="请输入诊断名称"
          ></el-input>
        </el-form-item>
        <el-form-item label="随访人员" prop="updateBy">
          <el-input
            v-model="topqueryParams.updateBy"
            placeholder="请输入随访人员"
          ></el-input>
        </el-form-item>
        <!-- <el-form-item label="主治医生" prop="drname">
          <el-input
            v-model="topqueryParams.drname"
            placeholder="请输入主治医生"
          ></el-input>
        </el-form-item> -->
        <!-- <el-form-item label="经管医生" prop="managementDoctor">
          <el-input
            v-model="topqueryParams.managementDoctor"
            placeholder="请输入主治医生"
          ></el-input>
        </el-form-item> -->
        <!-- <el-form-item label="日期限制" prop="status">
          <el-select v-model="endOut" placeholder="请选择">
            <el-option
              v-for="item in endOuts"
              :key="item.value"
              :label="item.label"
              :value="item.value"
            >
            </el-option>
          </el-select>
        </el-form-item> -->
        <el-form-item label="患者范围" prop="status">
          <el-cascader
            v-model="topqueryParams.scopetype"
            placeholder="默认全部"
            :options="sourcetype"
            :props="{ expandTrigger: 'hover' }"
            @change="handleChange"
          ></el-cascader>
        </el-form-item>
        <el-form-item label="任务状态" prop="status">
          <el-select v-model="topqueryParams.sendstate" 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.sort" placeholder="请选择">
            <el-option
              v-for="item in topicoptionssort"
              :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(1)"
            >搜索</el-button
          >
          <el-button icon="el-icon-refresh" size="medium" @click="resetQuery"
            >重置</el-button
          >
        </el-form-item>
      </el-form>
      <el-divider></el-divider>
      <el-row :gutter="10" class="mb8">
        <el-col :span="1.5">
          <div class="documentf">
            <div class="document">
              <el-button
                type="warning"
                plain
                icon="el-icon-warning-outline"
                size="medium"
                @click="toleadExport(1)"
                >执行失败</el-button
              >
            </div>
          </div>
        </el-col>
        <el-col :span="1.5">
          <div class="documentf">
            <div class="document">
              <el-button
                type="danger"
                plain
                icon="el-icon-warning"
                size="medium"
                @click="toleadExport(2)"
                >结果异常</el-button
              >
            </div>
          </div>
        </el-col>
      </el-row>
      <el-table
        v-loading="loading"
        ref="userform"
        :data="userList"
        :row-class-name="tableRowClassName"
        @selection-change="handleSelectionChange"
      >
        <el-table-column type="selection" width="50" align="center" />
        <el-table-column
          label="任务名称"
          fixed
          width="150"
          show-overflow-tooltip
          align="center"
          key="taskName"
          prop="taskName"
        />
        <!-- <el-table-column label="序号" fixed align="center" key="id" prop="id" /> -->
        <el-table-column
          label="姓名"
          width="100"
          align="center"
          key="sendname"
          prop="sendname"
        >
          <template slot-scope="scope">
            <el-button
              size="medium"
              type="text"
              @click="
                gettoken360(scope.row.sfzh, scope.row.drcode, scope.row.drname)
              "
              ><span class="button-textsc">{{
                scope.row.sendname
              }}</span></el-button
            >
          </template>
        </el-table-column>
        <el-table-column
          label="诊断名称"
          align="center"
          key="leavediagname"
          prop="leavediagname"
          width="120"
          :show-overflow-tooltip="true"
        >
        </el-table-column>
        <el-table-column
          label="延续护理次数"
          align="center"
          key="continueCount"
          prop="continueCount"
          width="120"
          :show-overflow-tooltip="true"
        >
        </el-table-column>
        <el-table-column
          label="最新延续护理时间"
          sortable
          align="center"
          prop="finishtime"
          width="160"
        >
          <template slot-scope="scope">
            <span>{{ parseTime(scope.row.continueTimeNext) }}</span>
          </template>
        </el-table-column>
        <el-table-column
          label="下次延续护理时间"
          sortable
          align="center"
          prop="finishtime"
          width="160"
        >
          <template slot-scope="scope">
            <span>{{ parseTime(scope.row.continueTimeNow) }}</span>
          </template>
        </el-table-column>
        <el-table-column
          label="任务状态"
          align="center"
          key="sendstate"
          prop="sendstate"
          width="120"
        >
          <template slot-scope="scope">
            <el-tooltip
              class="item"
              effect="dark"
              :content="scope.row.remark"
              placement="top-start"
            >
              <div v-if="scope.row.sendstate == 1">
                <el-tag type="primary" :disable-transitions="false"
                  >表单已领取</el-tag
                >
              </div>
              <div v-if="scope.row.sendstate == 2">
                <el-tag type="primary" :disable-transitions="false"
                  >待随访</el-tag
                >
              </div>
              <div v-if="scope.row.sendstate == 3">
                <el-tag type="success" :disable-transitions="false"
                  >表单已发送</el-tag
                >
              </div>
              <div v-if="scope.row.sendstate == 4">
                <el-tag type="info" :disable-transitions="false">不执行</el-tag>
              </div>
              <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>
            </el-tooltip>
          </template>
        </el-table-column>
        <!-- <el-table-column
          label="任务异常说明"
          width="120"
          align="center"
          key="remark"
          prop="remark" -->
        />
        <el-table-column
          label="处理意见"
          align="center"
          key="suggest"
          prop="suggest"
          width="120"
        >
          <template slot-scope="scope">
            <dict-tag
              :options="dict.type.sys_suggest"
              :value="scope.row.suggest"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="首次随访完成时间"
          sortable
          align="center"
          prop="finishtime"
          width="160"
        >
          <template slot-scope="scope">
            <span>{{ parseTime(scope.row.finishtime) }}</span>
          </template>
        </el-table-column>
        <el-table-column
          label="出院日期"
          width="200"
          align="center"
          key="endtime"
          prop="endtime"
        >
          <template slot-scope="scope">
            <span>{{ formatTime(scope.row.endtime) }}</span>
          </template></el-table-column
        >
        <el-table-column
          label="应随访日期"
          width="200"
          align="center"
          key="longSendTime"
          prop="longSendTime"
        >
          <template slot-scope="scope">
            <span>{{ formatTime(scope.row.longSendTime) }}</span>
          </template></el-table-column
        >
        <el-table-column
          label="主治医生"
          width="120"
          align="center"
          key="drname"
          prop="drname"
        />
        <el-table-column
          v-if="orgname != '丽水市中医院'"
          label="随访人员"
          align="center"
          key="updateBy"
          prop="updateBy"
          width="120"
        />
        <el-table-column
          v-if="orgname != '丽水市中医院'"
          label="经管医生"
          align="center"
          key="managementDoctor"
          prop="managementDoctor"
          width="120"
        />
        <el-table-column
          label="出院天数"
          width="120"
          align="center"
          key="endDay"
          prop="endDay"
        >
          <template slot-scope="scope">
            <span>{{ scope.row.endDay ? scope.row.endDay + "天" : "" }}</span>
          </template>
        </el-table-column>
        <el-table-column
          label="身份证号码"
          width="200"
          align="center"
          key="sfzh"
          prop="sfzh"
        />
        <el-table-column
          label="联系电话"
          width="200"
          align="center"
          key="phone"
          prop="phone"
        />
        <el-table-column
          label="责任护士"
          width="120"
          align="center"
          key="nurseName"
          prop="nurseName"
        />
        <el-table-column
          label="科室"
          align="center"
          key="deptname"
          prop="deptname"
          width="120"
        >
        </el-table-column>
        <el-table-column
          label="病区"
          align="center"
          key="leavehospitaldistrictname"
          prop="leavehospitaldistrictname"
          width="120"
        >
        </el-table-column>
        <el-table-column
          label="出院随访模板名称"
          align="center"
          key="templatename"
          prop="templatename"
          width="200"
        />
        <el-table-column
          label="任务执行方式"
          align="center"
          key="preachform"
          prop="preachform"
          width="160"
          :show-overflow-tooltip="true"
        >
          <template slot-scope="scope">
            <span v-for="item in scope.row.preachform">{{ item }}、 </span>
          </template>
        </el-table-column>
        <!-- <el-table-column
          label="任务发送流程"
          align="center"
          key="serviceSubtaskRecordList"
          prop="serviceSubtaskRecordList"
          width="160"
          :show-overflow-tooltip="true"
        >
          <template slot-scope="scope">
            <span v-for="item in scope.row.serviceSubtaskRecordList"
              >{{ item.remark }}、
            </span>
          </template>
        </el-table-column> -->
        <el-table-column
          label="任务结果说明"
          width="220"
          align="center"
          key="remark"
          prop="remark"
        >
          <template slot-scope="scope" v-if="scope.row.remark">
            <el-tooltip
              :content="scope.row.remark"
              placement="top"
              effect="dark"
            >
              <el-tag
                type="warning"
                v-if="scope.row.sendstate != 5 && scope.row.sendstate != 4"
                >{{ scope.row.remark }}</el-tag
              >
              <el-tag type="warning" v-else>{{ scope.row.remark }}</el-tag>
            </el-tooltip>
          </template>
        </el-table-column>
        <el-table-column
          label="操作"
          align="center"
          fixed="right"
          width="120"
          class-name="small-padding fixed-width"
        >
          <template slot-scope="scope">
            <el-button size="medium" type="text" @click="Seedetails(scope.row)"
              ><span class="button-zx"
                ><i class="el-icon-s-order"></i>查看详情</span
              ></el-button
            >
          </template>
        </el-table-column>
      </el-table>
      <pagination
        v-show="total > 0"
        :total="total"
        :page.sync="topqueryParams.pageNum"
        :limit.sync="topqueryParams.pageSize"
        @pagination="getList"
      />
    </el-row>
    <!-- æ»¡æ„åº¦å¼¹æ¡† -->
    <el-dialog
      title="随访满意度评分"
      :visible.sync="scoreDialogVisible"
      width="80%"
      :close-on-click-modal="false"
    >
      <el-table :data="selectedRows" border style="width: 100%">
        <el-table-column
          label="姓名"
          width="100"
          align="center"
          prop="sendname"
        />
        <el-table-column
          label="任务名称"
          width="180"
          align="center"
          prop="taskName"
        />
        <!-- æ–°å¢žè¯„分列 -->
        <el-table-column
          label="真实性(20)"
          align="center"
          key="authenticity"
          prop="authenticity"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.authenticity"
              :min="0"
              :max="20"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="一周内完成(20)"
          align="center"
          key="weekFinish"
          prop="weekFinish"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.weekFinish"
              :min="0"
              :max="20"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="规范性(10)"
          align="center"
          key="standard"
          prop="standard"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.standard"
              :min="0"
              :max="10"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="及时性(10)"
          align="center"
          key="timeliness"
          prop="timeliness"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.timeliness"
              :min="0"
              :max="10"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="宣教情况(10)"
          align="center"
          key="library"
          prop="library"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.library"
              :min="0"
              :max="10"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="环境满意度(10)"
          align="center"
          key="environment"
          prop="environment"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.environment"
              :min="0"
              :max="10"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="医生满意度(10)"
          align="center"
          key="doctorSatisfaction"
          prop="doctorSatisfaction"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.doctorSatisfaction"
              :min="0"
              :max="10"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="护士满意度(10)"
          align="center"
          key="nurseSatisfaction"
          prop="nurseSatisfaction"
          width="150"
        >
          <template slot-scope="scope">
            <el-input-number
              v-model="scope.row.nurseSatisfaction"
              :min="0"
              :max="10"
              :step="1"
              size="small"
            />
          </template>
        </el-table-column>
        <el-table-column
          label="总分"
          align="center"
          key="total"
          prop="total"
          fixed="right"
        >
          <template slot-scope="scope">
            <span>{{ calculateTotal(scope.row) }}</span>
          </template>
        </el-table-column>
      </el-table>
      <div slot="footer" class="dialog-footer">
        <el-button @click="scoreDialogVisible = false">取消</el-button>
        <el-button type="primary" @click="saveScores">保存</el-button>
      </div>
    </el-dialog>
    <!-- æ·»åŠ æˆ–ä¿®æ”¹å½±åƒéšè®¿å¯¹è¯æ¡† -->
    <el-dialog
      :title="amendtag ? '修改患者信息' : '新增患者'"
      :visible.sync="Labelchange"
      width="900px"
    >
      <el-form ref="form" :model="form" :rules="rules" label-width="100px">
        <el-row>
          <el-col :span="8">
            <el-form-item label="姓名" width="100" prop="name">
              <el-input
                v-model="form.name"
                placeholder="请输入姓名"
                maxlength="30"
              />
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="性别" width="100" prop="sex">
              <el-select v-model="form.sex" placeholder="请选择性别">
                <el-option
                  v-for="dict in sextype"
                  :key="dict.value"
                  :label="dict.label"
                  :value="dict.value"
                ></el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="年龄" prop="age">
              <el-input
                v-model="form.age"
                placeholder="请输入年龄"
                maxlength="30"
              />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="8">
            <el-form-item label="过滤医生" width="100" prop="filterDrname">
              <el-input
                v-model="form.filterDrname"
                placeholder="请输入医生姓名"
                maxlength="30"
              />
            </el-form-item>
          </el-col>
        </el-row>
        <el-row>
          <el-col :span="24">
            <el-form-item label="过滤原因">
              <el-input
                v-model="form.notrequiredreason"
                type="textarea"
                placeholder="请输入过滤原因"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="submitForm">ç¡® å®š</el-button>
        <el-button @click="cancel">取 æ¶ˆ</el-button>
      </div>
    </el-dialog>
    <!-- ä¿®æ”¹å‘送时间对话框 -->
    <el-dialog
      title="发送时间设置"
      :visible.sync="modificationVisible"
      width="45%"
    >
      <div style="margin-bottom: 20px; color: red">
        ç»Ÿä¸€ä¿®æ”¹å½“天未发送的任务时间
      </div>
      <el-form
        :model="ruleForm"
        :rules="rules"
        ref="ruleForm"
        label-width="120px"
        class="demo-ruleForm"
      >
        <el-form-item label="发送日期">
          <el-date-picker
            v-model="ruleForm.value1"
            type="date"
            placeholder="选择日期"
          >
          </el-date-picker>
        </el-form-item>
        <el-form-item label="时间段" prop="type">
          <el-checkbox-group v-model="ruleForm.type">
            <el-checkbox label="上午" name="type"></el-checkbox>
            <el-checkbox label="下午" name="type"></el-checkbox>
            <el-checkbox label="晚上" name="type"></el-checkbox>
          </el-checkbox-group>
        </el-form-item>
        <el-form-item label="上午时间区间" required>
          <el-time-picker
            is-range
            v-model="ruleForm.value2"
            range-separator="至"
            start-placeholder="开始时间"
            end-placeholder="结束时间"
            placeholder="选择时间范围"
          >
          </el-time-picker>
        </el-form-item>
        <el-form-item label="下午时间区间" required>
          <el-time-picker
            is-range
            v-model="ruleForm.value3"
            range-separator="至"
            start-placeholder="开始时间"
            end-placeholder="结束时间"
            placeholder="选择时间范围"
          >
          </el-time-picker>
        </el-form-item>
        <el-form-item label="晚上时间区间" required>
          <el-time-picker
            is-range
            v-model="ruleForm.value4"
            range-separator="至"
            start-placeholder="开始时间"
            end-placeholder="结束时间"
            placeholder="选择时间范围"
          >
          </el-time-picker>
        </el-form-item>
      </el-form>
      <span slot="footer" class="dialog-footer">
        <el-button @click="modificationVisible = false">取 æ¶ˆ</el-button>
        <el-button type="primary" @click="modificationVisible = false"
          >ç¡® å®š</el-button
        >
      </span>
    </el-dialog>
    <!-- å†æ¬¡éšè®¿ -->
    <el-dialog title="患者再次随访" :visible.sync="dialogFormVisible">
      <el-form ref="zcform" :rules="zcrules" :model="zcform" label-width="80px">
        <el-form-item label="任务名称">
          <el-input
            style="width: 400px"
            disabled
            v-model="zcform.taskName"
          ></el-input>
        </el-form-item>
        <el-form-item label="患者名称">
          <el-input
            style="width: 400px"
            disabled
            v-model="zcform.sendname"
          ></el-input>
        </el-form-item>
        <el-form-item label="年龄">
          <el-input
            style="width: 400px"
            disabled
            v-model="zcform.age"
          ></el-input>
        </el-form-item>
        <el-form-item label="科室">
          <el-input
            style="width: 400px"
            disabled
            v-model="zcform.deptname"
          ></el-input>
        </el-form-item>
        <el-form-item label="病区">
          <el-input
            style="width: 400px"
            disabled
            v-model="zcform.leavehospitaldistrictname"
          ></el-input>
        </el-form-item>
        <el-form-item label="随访方式" prop="resource">
          <el-radio-group v-model="zcform.resource">
            <el-radio label="1">本病区随访</el-radio>
            <el-radio label="2">随访中心随访</el-radio>
          </el-radio-group>
        </el-form-item>
        <!-- <el-form-item label="即刻发送">
          <el-switch v-model="zcform.delivery"></el-switch>
        </el-form-item> -->
        <el-form-item label="出院时间">
          <el-input
            style="width: 400px"
            disabled
            v-model="zcform.endtime"
          ></el-input>
        </el-form-item>
        <el-form-item label="随访完成时间" prop="date1">
          <el-date-picker
            type="date"
            placeholder="选择日期"
            v-model="zcform.date1"
            style="width: 100%"
          ></el-date-picker>
        </el-form-item>
        <el-form-item label="随访记录">
          <el-input type="textarea" v-model="zcform.remark"></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>
<script>
import {
  delUser,
  addUser,
  updateUser,
  resetUserPwd,
  changeUserStatus,
} from "@/api/system/user";
import {
  getTaskservelist,
  buidegetTasklist,
  addserviceSubtask,
  query360PatInfo,
  addsatisfaction,
} from "@/api/AiCentre/index";
import { alterpatient, particularpatient } from "@/api/patient/homepage";
import Treeselect from "@riophae/vue-treeselect";
import store from "@/store";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
export default {
  name: "Discharge",
  dicts: ["sys_normal_disable", "sys_user_sex", "sys_yujing", "sys_suggest"],
  components: { Treeselect },
  data() {
    return {
      // é®ç½©å±‚
      loading: true,
      // é€‰ä¸­æ•°ç»„
      ids: [],
      // éžå•个禁用
      single: true,
      // éžå¤šä¸ªç¦ç”¨
      multiple: true,
      // æ˜¾ç¤ºæœç´¢æ¡ä»¶
      showSearch: true,
      dialogFormVisible: false,
      // æ€»æ¡æ•°
      total: 0,
      // ç”¨æˆ·è¡¨æ ¼æ•°æ®
      userList: null,
      // å¼¹å‡ºå±‚标题
      title: "新增影像随访",
      // æ˜¯å¦æ˜¾ç¤ºä¿®æ”¹ã€æ·»åŠ å¼¹å‡ºå±‚
      addalteropen: false,
      // ä¿®æ”¹å‘送时间对话框
      modificationVisible: false,
      // éƒ¨é—¨åç§°
      deptName: undefined,
      // é»˜è®¤å¯†ç 
      initPassword: undefined,
      // æ—¥æœŸèŒƒå›´
      dateRange: [],
      dateRangefs: [],
      // å²—位选项
      postOptions: [],
      ruleForm: {
        type: [],
      },
      zcform: {},
      dynamicTags: ["选项一", "选项二", "选项三"], //选项
      inputVisible: false,
      Labelchange: false,
      ycvalue: "",
      jgvalue: "",
      yfsvalue: "",
      inputValue: "",
      preachform: "",
      previewVisible: false, //影像随访预览弹框
      radio: "",
      radios: [],
      previewtype: 2, //预览影像随访类型
      total: 0, // æ€»æ¡æ•°
      // æ»¡æ„åº¦è°ƒæŸ¥æ•°æ®
      scoreDialogVisible: false,
      selectedRows: [],
      value: [],
      list: [],
      sourcetype: [
        {
          value: 1,
          label: "科室",
          children: [],
        },
        {
          value: 2,
          label: "病区",
          children: [],
        },
        {
          value: 3,
          label: "全部",
        },
      ],
      loading: false,
      cardlist: [
        {
          name: "出院服务总量",
          value: 0,
        },
        // {
        //   name: "患者过滤",
        //   value: 0,
        // },
        {
          name: "需随访",
          value: 0,
        },
        {
          name: "发送失败",
          value: 0,
        },
        {
          name: "待随访",
          value: 0,
        },
        // {
        //   name: "已发送",
        //   value: 0,
        // },
        // {
        //   name: "表单已发送",
        //   value: 0,
        // },
      ],
      zcrules: {
        date1: [
          { required: true, message: "请选择随访方式", trigger: "change" },
        ],
        resource: [
          { required: true, message: "请选择随访时间", trigger: "blur" },
        ],
      },
      // è¡¨å•参数
      form: {
        phonenumber: "",
        totagid: "",
        types: "",
        nickName: "",
        qystatus: "",
        btstatus: "",
      },
      // endOut: 1,
      endOut: localStorage.getItem("orgname") == "丽水市中医院" ? 0 : 1, //0 å‡ºé™¢æ—¶é—´(正序)    1 å‡ºé™¢æ—¶é—´(倒序)   2 å‘送时间(正序)    3 å‘送时间(倒序)  7应随访日期(倒序) åº”随访日期(正序)
      endOuts: [
        {
          value: 0,
          label: "截止至当日服务",
        },
        {
          value: 1,
          label: "全部服务",
        },
      ],
      topicoptionssort: [
        {
          value: 0,
          label: "出院时间(正序)",
        },
        {
          value: 1,
          label: "出院时间(倒序)",
        },
        {
          value: 2,
          label: "发送时间(正序)",
        },
        {
          value: 3,
          label: "发送时间(倒序)",
        },
        {
          value: 7,
          label: "应随访日期(正序)",
        },
        {
          value: 8,
          label: "应随访日期(倒序)",
        },
      ],
      // æŸ¥è¯¢å‚æ•°
      topqueryParams: {
        pageNum: 1,
        pageSize: 10,
        sort: localStorage.getItem("orgname") == "丽水市中医院" ? 8 : 2, //0 å‡ºé™¢æ—¶é—´(正序)    1 å‡ºé™¢æ—¶é—´(倒序)   2 å‘送时间(正序)    3 å‘送时间(倒序)  7应随访日期(倒序) åº”随访日期(正序)
        searchscope: 3,
        continueFlag: 2,
        visitCount: 1,
        scopetype: [],
        leaveldeptcodes: [],
        leavehospitaldistrictcodes: [],
      },
      orgname: "",
      propss: { multiple: true },
      options: [],
      topicoptions: [
        {
          value: null,
          label: "全部",
        },
        {
          value: 1,
          label: "表单已领取",
        },
        {
          value: 2,
          label: "待随访",
        },
        {
          value: 3,
          label: "表单已发送",
        },
        {
          value: 4,
          label: "不执行",
        },
        {
          value: 5,
          label: "发送失败",
        },
        {
          value: 6,
          label: "已完成",
        },
      ],
      sextype: [
        {
          value: 1,
          label: "男",
        },
        {
          value: 2,
          label: "女",
        },
      ],
      topicoptionsyj: [
        {
          value: 1,
          label: "异常",
        },
        {
          value: 2,
          label: "警告",
        },
        {
          value: 0,
          label: "正常",
        },
      ],
      url: "http://9.208.2.190:8090/smartor/serviceExternal/query360PatInfo",
      postData: {
        XiaoXiTou: {
          FaSongFCSJC: "ZJHES",
          FaSongJGID: localStorage.getItem("orgid"),
          FaSongJGMC: localStorage.getItem("orgname"),
          FaSongSJ: "2025-01-09 17:29:36",
          FaSongXTJC: "SUIFANGXT",
          FaSongXTMC: "随访系统",
          XiaoXiID: "5FA92AFB-9833-4608-87C7-F56A654AC171",
          XiaoXiLX: "SC_LC_360STCX",
          XiaoXiMC: "360 视图查询",
          ZuHuID: localStorage.getItem("ZuHuID"),
          ZuHuMC: localStorage.getItem("orgname"),
        },
        YeWuXX: {
          BingRenXX: {
            ZhengJianHM: "",
            ZhengJianLXDM: "01",
            ZhengJianLXMC: "居民身份证",
            ZuZhiJGID: localStorage.getItem("orgid"),
            ZuZhiJGMC: localStorage.getItem("orgname"),
          },
          YongHuXX: {
            XiTongID: "SUIFANGXT",
            XiTongMC: "随访系统",
            YongHuID: localStorage.getItem("YongHuID"),
            YongHuXM: localStorage.getItem("YongHuXM"),
            ZuZhiJGID: localStorage.getItem("orgid"),
            ZuZhiJGMC: localStorage.getItem("orgname"),
            idp: "lyra",
          },
        },
      },
      amendtag: false,
      errtype: "",
      leavehospitaldistrictcode: "",
      serviceState: [],
      checkboxlist: [],
      // è¡¨å•校验
      rules: {},
    };
  },
  watch: {},
  created() {
    this.serviceState = store.getters.serviceState;
    this.checkboxlist = store.getters.checkboxlist;
    this.errtype = this.$route.query.errtype;
    this.orgname = localStorage.getItem("orgname");
    this.leavehospitaldistrictcode =
      this.$route.query.leavehospitaldistrictcode;
    this.sourcetype[0].children = store.getters.belongDepts.map((dept) => {
      return {
        label: dept.deptName,
        value: dept.deptCode,
      };
    });
    this.sourcetype[1].children = store.getters.belongWards.map((dept) => {
      return {
        label: dept.districtName,
        value: dept.districtCode,
      };
    });
    if (this.errtype) {
      this.toleadExport(2);
    } else {
      this.getList(1);
    }
    this.getConfigKey("sys.user.initPassword").then((response) => {
      this.initPassword = response.msg;
    });
  },
  activated() {
    this.getList(1);
  },
  methods: {
    /** æŸ¥è¯¢éšè®¿æœåŠ¡åˆ—è¡¨ */
    getList(refresh) {
      // é»˜è®¤å…¨éƒ¨
      if (this.topqueryParams.searchscope == 3) {
        this.topqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
          (obj) => obj.deptCode
        );
        this.topqueryParams.leavehospitaldistrictcodes =
          store.getters.belongWards.map((obj) => obj.districtCode);
      }
      if (this.endOut == 0) {
        this.topqueryParams.endSendDateTime = this.formatDateToYYYYMMDDHHMMSS(
          this.getEndOfDay()
        );
      } else {
        // this.topqueryParams.endSendDateTime = null;
      }
      // æŽ¥å—异常跳转
      if (this.errtype) {
        this.topqueryParams.leavehospitaldistrictcodes.push(
          this.leavehospitaldistrictcode
        );
        console.log(this.topqueryParams.leavehospitaldistrictcodes, "11");
      }
      this.loading = true;
      if (
        this.topqueryParams.leavehospitaldistrictcodes[0] &&
        this.topqueryParams.leaveldeptcodes[0]
      ) {
        this.topqueryParams.deptOrDistrict = 2;
      } else {
        this.topqueryParams.deptOrDistrict = 1;
      }
      getTaskservelist(this.topqueryParams).then((response) => {
        this.userList = response.rows[0].serviceSubtaskList;
        this.total = response.total;
        if (refresh) {
          this.cardlist[0].value =
            Number(response.rows[0].wzx) + Number(response.rows[0].ysf);
          // this.cardlist[1].value = response.rows[0].wzx;
          this.cardlist[1].value = response.rows[0].ysf;
          this.ycvalue = response.rows[0].yc;
          this.jgvalue = response.rows[0].jg;
          this.cardlist[2].value = response.rows[0].fssb;
          this.cardlist[3].value = response.rows[0].dsf;
          // this.cardlist[4].value = response.rows[0].yfs2;
          this.yfsvalue = response.rows[0].yfs;
        }
        this.loading = false;
        this.userList.forEach((item) => {
          let idArray = null;
          if (item.endtime) {
            item.endDay = this.daysBetween(item.endtime);
          }
          if (item.preachform) {
            if (item.endtime) {
              item.preachformson = item.preachform;
              idArray = item.preachform.split(",");
            }
            item.preachform = idArray.map((value) => {
              // æŸ¥æ‰¾id对应的对象
              const item = this.checkboxlist.find(
                (item) => item.value == value
              );
              // å¦‚果找到对应的id,返回label值,否则返回null
              return item ? item.label : null;
            });
          }
        });
        this.total = response.total;
      });
    },
    // æ—¶é—´
    getEndOfDay() {
      const date = new Date(); // åˆ›å»ºä¸€ä¸ªè¡¨ç¤ºå½“前时间的Date对象
      date.setHours(23, 59, 59, 0); // å°†æ—¶é—´è®¾ç½®ä¸º23:59:59.000
      return date;
    },
    formatDateToYYYYMMDDHHMMSS(date) {
      const year = date.getFullYear();
      const month = String(date.getMonth() + 1).padStart(2, "0"); // æœˆä»½è¡¥é›¶
      const day = String(date.getDate()).padStart(2, "0"); // æ—¥æœŸè¡¥é›¶
      const hours = String(date.getHours()).padStart(2, "0");
      const minutes = String(date.getMinutes()).padStart(2, "0");
      const seconds = String(date.getSeconds()).padStart(2, "0");
      return `${year}-${month}-${day}`;
    },
    affiliation() {
      this.topqueryParams.managementDoctorCode = store.getters.hisUserId;
      this.getList(1);
    },
    onthatday() {
      this.topqueryParams.startSendDateTime = this.getCurrentDate();
      this.topqueryParams.endSendDateTime = this.getCurrentDate();
      this.getList(1);
    },
    getCurrentDate() {
      const now = new Date();
      return now.toISOString().slice(0, 10); // æˆªå–前10个字符,即 YYYY-MM-DD
    },
    buidegetTasklist(type) {
      if (this.topqueryParams.searchscope == 3) {
        this.topqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
          (obj) => obj.deptCode
        );
        this.topqueryParams.leavehospitaldistrictcodes =
          store.getters.belongWards.map((obj) => obj.districtCode);
      }
      // æŽ¥å—异常跳转
      if (this.errtype) {
        this.topqueryParams.leavehospitaldistrictcodes.push(
          this.leavehospitaldistrictcode
        );
      }
      let obj = {
        pageNum: 1,
        pageSize: 10,
        leavehospitaldistrictcodes:
          this.topqueryParams.leavehospitaldistrictcodes,
        sendstates: [2, 3],
        leaveldeptcodes: this.topqueryParams.leaveldeptcodes,
      };
      buidegetTasklist(obj).then((response) => {
        this.userList = response.rows[0].serviceSubtaskList;
        this.total = response.total;
        if (refresh) {
          this.cardlist[0].value =
            Number(response.rows[0].wzx) + Number(response.rows[0].ysf);
          this.cardlist[1].value = response.rows[0].wzx;
          this.cardlist[2].value = response.rows[0].ysf;
          this.ycvalue = response.rows[0].yc;
          this.jgvalue = response.rows[0].jg;
          this.cardlist[3].value = response.rows[0].fssb;
          this.cardlist[4].value = response.rows[0].dsf;
          // this.cardlist[5].value = response.rows[0].yfs2;
          this.yfsvalue = response.rows[0].yfs;
        }
        this.loading = false;
        this.userList.forEach((item) => {
          let idArray = null;
          if (item.endtime) {
            item.endDay = this.daysBetween(item.endtime);
          }
          if (item.preachform) {
            if (item.endtime) {
              item.preachformson = item.preachform;
              idArray = item.preachform.split(",");
            }
            item.preachform = idArray.map((value) => {
              // æŸ¥æ‰¾id对应的对象
              const item = this.checkboxlist.find(
                (item) => item.value == value
              );
              // å¦‚果找到对应的id,返回label值,否则返回null
              return item ? item.label : null;
            });
          }
        });
        this.total = response.total;
      });
    },
    // æŸ¥çœ‹é—¨è¯Šéšè®¿è¯¦æƒ…
    Referencequestion(row) {
      this.previewVisible = true;
    },
    // æ·»åŠ å¼¹æ¡†æœç´¢
    remoteMethod(query) {
      if (query !== "") {
        this.loading = true;
        setTimeout(() => {
          this.loading = false;
          this.options = this.list.filter((item) => {
            return item.label.toLowerCase().indexOf(query.toLowerCase()) > -1;
          });
        }, 200);
      } else {
        this.options = [];
      }
    },
    // å½±åƒéšè®¿çŠ¶æ€ä¿®æ”¹
    handleStatusChange(row) {
      let text = row.status === "0" ? "启用" : "停用";
      this.$modal
        .confirm('确认要"' + text + '""' + row.userName + '"用户吗?')
        .then(function () {
          return changeUserStatus(row.userId, row.status);
        })
        .then(() => {
          this.$modal.msgSuccess(text + "成功");
        })
        .catch(function () {
          row.status = row.status === "0" ? "1" : "0";
        });
    },
    // è¡¨å•重置
    reset() {
      this.form = {
        userId: undefined,
        deptId: undefined,
        userName: undefined,
        nickName: undefined,
        password: undefined,
        phonenumber: undefined,
        email: undefined,
        sex: undefined,
        status: "0",
        remark: undefined,
        postIds: [],
        roleIds: [],
      };
      this.resetForm("form");
    },
    /** æœç´¢æŒ‰é’®æ“ä½œ */
    handleQuery(refresh) {
      if (this.topqueryParams.searchscope == 3) {
        this.topqueryParams.leaveldeptcodes = store.getters.belongDepts.map(
          (obj) => obj.deptCode
        );
        this.topqueryParams.leavehospitaldistrictcodes =
          store.getters.belongWards.map((obj) => obj.districtCode);
      }
      this.topqueryParams.pageNum = 1;
      this.topqueryParams.startOutHospTime = this.dateRange[0];
      this.topqueryParams.endOutHospTime = this.dateRange[1];
      this.topqueryParams.startSendDateTime = this.dateRangefs[0];
      this.topqueryParams.endSendDateTime = this.dateRangefs[1];
      this.getList(refresh);
    },
    // æ‚£è€…范围处理
    handleChange(value) {
      let type = value[0];
      let code = value.slice(-1)[0];
      this.topqueryParams.leavehospitaldistrictcodes = [];
      this.topqueryParams.leaveldeptcodes = [];
      if (type == 1) {
        this.topqueryParams.leaveldeptcodes.push(code);
        this.topqueryParams.leavehospitaldistrictcodes = [];
        this.topqueryParams.searchscope = 1;
      } else if (type == 2) {
        this.topqueryParams.leavehospitaldistrictcodes.push(code);
        this.topqueryParams.leaveldeptcodes = [];
        this.topqueryParams.searchscope = 2;
      } else {
        this.topqueryParams.searchscope = 3;
      }
    },
    /** é‡ç½®æŒ‰é’®æ“ä½œ */
    resetQuery() {
      this.dateRange = [];
      this.dateRangefs = [];
      this.topqueryParams = {
        pageNum: 1,
        pageSize: 10,
        sort: 2, //0 å‡ºé™¢æ—¶é—´(正序)    1 å‡ºé™¢æ—¶é—´(倒序)   2 å‘送时间(正序)    3 å‘送时间(倒序)
        searchscope: 3,
        continueFlag: 2,
        visitCount: 1,
        scopetype: [],
        leaveldeptcodes: [],
        leavehospitaldistrictcodes: [],
      };
      this.handleQuery(1);
    },
    handleSelectionChange(rows) {
      this.selectedRows = rows.map((row) => {
        // åˆå§‹åŒ–评分字段
        return {
          ...row,
          authenticity: row.authenticity || 0,
          weekFinish: row.weekFinish || 0,
          standard: row.standard || 0,
          timeliness: row.timeliness || 0,
          library: row.library || 0,
          environment: row.environment || 0,
          doctorSatisfaction: row.doctorSatisfaction || 0,
          nurseSatisfaction: row.nurseSatisfaction || 0,
        };
      });
      if (this.selectedRows.length > 0) {
        this.multiple = false;
      } else {
        this.multiple = true;
      }
    },
    // è®¡ç®—总分
    calculateTotal(row) {
      return (
        (row.authenticity || 0) +
        (row.weekFinish || 0) +
        (row.standard || 0) +
        (row.timeliness || 0) +
        (row.library || 0) +
        (row.environment || 0) +
        (row.doctorSatisfaction || 0) +
        (row.nurseSatisfaction || 0)
      );
    },
    // ä¿å­˜è¯„分
    saveScores() {
      this.selectedRows.forEach((item) => {
        item.createBy = null;
        item.patName = item.sendname;
        item.hospitaldistrictname = item.leavehospitaldistrictname;
      });
      addsatisfaction(this.selectedRows).then((res) => {
        if (res.code == 200) {
          this.$message.success("评分保存成功");
          this.scoreDialogVisible = false;
          this.selectedRows = [];
          this.$refs.userform.clearSelection();
        } else {
          this.$modal.msgWarning("评分保存失败");
          this.scoreDialogVisible = false;
          this.selectedRows = [];
          this.$refs.userform.clearSelection();
        }
      });
      // è¿™é‡Œå¯ä»¥æ·»åŠ ä¿å­˜é€»è¾‘ï¼Œå¦‚è°ƒç”¨API保存评分
    },
    //删除选项
    handleClose(tag) {
      this.dynamicTags.splice(this.dynamicTags.indexOf(tag), 1);
    },
    //触发新增输入
    showInput() {
      this.inputVisible = true;
      this.$nextTick((_) => {
        this.$refs.saveTagInput.$refs.input.focus();
      });
    },
    //获取失去焦点触发
    handleInputConfirm() {
      let inputValue = this.inputValue;
      if (inputValue) {
        this.dynamicTags.push(inputValue);
      }
      this.inputVisible = false;
      this.inputValue = "";
    },
    /** æ–°å¢žæŒ‰é’®æ“ä½œ */
    handleAdd() {
      this.$router.push({
        path: "/followvisit/QuestionnaireTask",
        query: {
          type: 2,
          serviceType: 2,
        },
      });
    },
    //患者360跳转
    gettoken360(sfzh, drcode, drname) {
      // this.$modal.msgWarning("360功能暂未开通");
      this.postData.YeWuXX.BingRenXX.ZhengJianHM = sfzh;
      query360PatInfo(this.postData).then((res) => {
        if (res.data.url) {
          window.open(res.data.url, "_blank");
          // this.linkUrl = res.data.url;
        } else {
          this.$modal.msgWarning("360查询无结果");
        }
      });
    },
    /** é‡ç½®å¯†ç æŒ‰é’®æ“ä½œ */
    handleResetPwd(row) {
      this.$prompt('请输入"' + row.userName + '"的新密码', "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        closeOnClickModal: false,
        inputPattern: /^.{5,20}$/,
        inputErrorMessage: "用户密码长度必须介于 5 å’Œ 20 ä¹‹é—´",
      })
        .then(({ value }) => {
          resetUserPwd(row.userId, value).then((response) => {
            this.$modal.msgSuccess("修改成功,新密码是:" + value);
          });
        })
        .catch(() => {});
    },
    // å–消按钮
    cancel() {
      this.Labelchange = false;
      this.reset();
    },
    /** æäº¤æŒ‰é’® */
    submitForm: function () {
      this.$refs["form"].validate((valid) => {
        if (valid) {
          this.form.isoperation = 2;
          this.form.notrequiredFlag = 1;
          alterpatient(this.form)
            .then((response) => {
              console.log(response);
            })
            .then(() => {
              this.getList(1);
              this.$modal.msgSuccess("患者过滤成功");
            });
          this.reset();
          this.Labelchange = false;
        }
      });
    },
    /** åˆ é™¤æŒ‰é’®æ“ä½œ */
    handleDelete(row) {
      const userIds = row.userId || this.ids;
      this.$modal
        .confirm('是否确认删除用户编号为"' + userIds + '"的数据项?')
        .then(function () {
          return delUser(userIds);
        })
        .then(() => {
          this.getList(1);
          this.$modal.msgSuccess("删除成功");
        })
        .catch(() => {});
    },
    // å…¨éƒ¨åœæ­¢
    AllStop() {
      this.$modal
        .confirm("是否停止全部任务?")
        .then(function () {
          return console.log("停止成功");
        })
        .then(() => {
          this.getList(1);
          this.$modal.msgWarning("停止成功");
        })
        .catch(() => {});
    },
    // å…¨éƒ¨å¼€å§‹
    AllStarted() {
      this.$modal
        .confirm("是否开启全部任务?")
        .then(function () {
          return console.log("开启成功");
        })
        .then(() => {
          this.getList(1);
          this.$modal.msgSuccess("开启成功");
        })
        .catch(() => {});
    },
    // ä»»åŠ¡é‡ç½®
    TaskReset() {
      this.$modal
        .confirm("是否重置选中的任务项?")
        .then(function () {
          return console.log("选中成功");
        })
        .then(() => {
          this.getList(1);
          this.$modal.msgSuccess("重置成功");
        })
        .catch(() => {});
    },
    // è®¾ç½®å‘送时间
    Sendtimesetting() {
      this.modificationVisible = true;
    },
    // è·³è½¬è¯¦æƒ…页
    Seedetails(row) {
      let type = "";
      console.log(row, "rwo");
      if (row.type == 1) {
        type = 1;
      }
      this.$router.push({
        path: "/followvisit/ContinueFordetails/",
        query: {
          taskid: row.taskid,
          patid: row.patid,
          id: row.id,
          Voicetype: type,
          visitCount: this.topqueryParams.visitCount,
        },
      });
    },
    // å†æ¬¡éšè®¿
    followupvisit(row) {
      this.zcform = row;
      this.zcform.endtime = this.formatTime(this.zcform.endtime);
      this.dialogFormVisible = true;
    },
    onSubmit() {},
    // æš‚停服务
    handlestop(row) {
      let objson = row;
      this.$modal
        .confirm(
          '是否确认暂停任务名称为"' +
            row.taskName +
            '患者名称为"' +
            row.sendname +
            '"的数据项?'
        )
        .then(() => {
          getTaskservelist({
            patid: row.patid,
            taskid: row.taskid,
          }).then((res) => {
            if (res.code == 200) {
              objson.sendstate = 4;
              objson.remark = "服务暂停";
              Editsingletaskson(objson).then((res) => {
                if (res.code) {
                  this.$modal.msgSuccess("记录成功");
                  this.getList(1);
                }
              });
            }
          });
        })
        .catch(() => {});
    },
    // æ‚£è€…过滤触发
    handleUpdate(row) {
      particularpatient(row.patid).then((response) => {
        this.form = response.data;
        this.form.filterDrname = store.getters.nickName;
      });
      this.amendtag = true;
      this.Labelchange = true;
    },
    // ä¾¿æ·æŒ‰é’®
    toleadExport(too) {
      if (too == 1) {
        this.topqueryParams.sendstate = 4;
        this.topqueryParams.excep = null;
      } else if (too == 2) {
        this.topqueryParams.excep = 1;
      }
      this.handleQuery();
    },
    /** å¯¼å‡ºæŒ‰é’®æ“ä½œ */
    handleExport() {
      this.topqueryParams.pageNum = null;
      this.topqueryParams.pageSize = null;
      this.download(
        "smartor/serviceSubtask/patItemExport",
        {
          ...this.topqueryParams,
        },
        `user_${new Date().getTime()}.xlsx`
      );
    },
    // å¼‚常列渲染
    tableRowClassName({ row, rowIndex }) {
      if (row.excep == 1) {
        return "warning-row";
      } else if (row.excep == 2) {
        return "remind-row";
      }
      return "";
    },
    // åˆ›å»ºå†æ¬¡éšè®¿æœåŠ¡
    setupsubtask() {
      this.$refs["zcform"].validate((valid) => {
        if (valid) {
          this.zcform.remark =
            this.zcform.remark + "【" + this.getCurrentTime() + "】";
          let form = structuredClone(this.zcform);
          form.longSendTime = this.formatTime(form.date1);
          form.finishtime = "";
          if (form.resource) {
            if (form.resource == 2) {
              form.serviceType = 13;
            }
          } else {
            this.$modal.msgError("未选择随访方式");
          }
          form.id = null;
          form.sendstate = 2;
          form.preachform = form.preachformson;
          form.longTask = 0;
          addserviceSubtask(form).then((res) => {
            if (res.code == 200) {
              this.$modal.msgSuccess("创建成功");
            } else {
              this.$modal.msgError("创建失败");
            }
            this.dialogFormVisible = false;
          });
        }
      });
    },
    getCurrentTime() {
      const now = new Date();
      const year = now.getFullYear();
      const month = String(now.getMonth() + 1).padStart(2, "0");
      const day = String(now.getDate()).padStart(2, "0");
      const hours = String(now.getHours()).padStart(2, "0");
      const minutes = String(now.getMinutes()).padStart(2, "0");
      const seconds = String(now.getSeconds()).padStart(2, "0");
      return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
    },
  },
};
</script>
<style lang="scss" scoped>
.el-button--primary.is-plain {
  color: #ffffff;
  background: #409eff;
  border-color: #4fabe9;
}
.document {
  // width: 100px;
  height: 50px;
}
::v-deep.el-table .warning-row {
  background: #eec4c4;
}
::v-deep.el-table .remind-row {
  background: #fcf5aa;
}
.documentf {
  display: flex;
  justify-content: flex-end;
}
.download {
  text-align: center;
  .el-upload__tip {
    font-size: 23px;
  }
  .el-upload__text {
    font-size: 23px;
  }
}
.uploading {
  margin-top: 20px;
  margin: 20px;
  padding: 30px;
  background: #ffffff;
  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);
}
.el-tag + .el-tag {
  margin-left: 10px;
}
.button-new-tag {
  margin-left: 10px;
  height: 32px;
  line-height: 30px;
  padding-top: 0;
  padding-bottom: 0;
}
.input-new-tag {
  width: 90px;
  margin-left: 10px;
  vertical-align: bottom;
}
.drexamine {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px;
  background: #daeaf5;
  img {
    width: 100px;
    height: 100px;
  }
}
.qrcode-dialo {
  // text-align: center;
  //   display: flex;
  margin: 20px;
  padding: 30px;
  background: #edf1f7;
  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 {
    margin-bottom: 25px;
    font-size: 20px !important;
    .dev-text {
      margin-bottom: 10px;
    }
  }
}
::v-deep.leftvlue .el-card__body {
  background: #f2f8ff;
  color: #324a9b;
}
::v-deep.leftvlue .el-card__body:hover {
  background: #3664d9;
  color: #fff;
  cursor: pointer; /* é¼ æ ‡æ‚¬æµ®æ—¶å˜ä¸ºæ‰‹å½¢ */
}
::v-deep.errleftvlue .el-card__body {
  background: #fdd0d7;
}
::v-deep.errleftvlue .el-card__body:hover {
  background: #f88d96;
  cursor: pointer; /* é¼ æ ‡æ‚¬æµ®æ—¶å˜ä¸ºæ‰‹å½¢ */
}
::v-deep.jgleftvlue .el-card__body:hover {
  background: #f7f075;
  cursor: pointer; /* é¼ æ ‡æ‚¬æµ®æ—¶å˜ä¸ºæ‰‹å½¢ */
}
::v-deep.ysfleftvlue .el-card__body {
  background: #d0fdd8;
}
::v-deep.ysfleftvlue .el-card__body:hover {
  background: #0abc54;
  cursor: pointer; /* é¼ æ ‡æ‚¬æµ®æ—¶å˜ä¸ºæ‰‹å½¢ */
}
.button-bb {
  font-weight: 500;
  background-color: #2ba05c;
  padding: 5px;
  border-radius: 1px;
  color: #ffffff;
}
.button-xq {
  font-weight: 500;
  background-color: #409eff;
  padding: 5px;
  border-radius: 1px;
  color: #ffffff;
}
.button-sc {
  font-weight: 500;
  background-color: #b3a21f;
  padding: 5px;
  border-radius: 1px;
  color: #ffffff;
}
.button-zx {
  background: #324a9b;
  padding: 5px;
  border-radius: 1px;
  color: #ffffff;
}
::v-deep.el-radio-group {
  span {
    font-size: 24px;
  }
}
.purple-button {
  background-color: #7e22ce;
  border-color: #7e22ce;
  color: #fff;
}
.purple-button:hover,
.purple-button:focus {
  background-color: #9333ea;
  border-color: #9333ea;
}
.purple-button:active {
  background-color: #6b21a8;
  border-color: #6b21a8;
}
.button-textxga {
  color: #de7897;
}
.purple-button.is-disabled {
  background-color: #d8b4fe;
  border-color: #d8b4fe;
  opacity: 1; /* ä¿æŒç¦ç”¨çŠ¶æ€é€æ˜Žåº¦ */
}
// é€‰é¡¹å­—体放大
// ::v-deep.el-checkbox-group {
//   span {
//     font-size: 24px;
//   }
// }
</style>
src/views/followvisit/discharge/index.vue
@@ -60,6 +60,25 @@
            </el-card>
          </div>
        </el-col>
        <el-col :span="2.5" v-if="orgname == '省立同德翠苑院区'">
          <div class="jgleftvlue">
            <el-card shadow="hover ">
              <div style="padding: 8px">
                <span>警告</span>
                <div
                  style="
                    text-align: center;
                    font-size: 18px;
                    margin-top: 10px;
                    font-weight: 600;
                  "
                >
                  {{ jgvalue }}
                </div>
              </div>
            </el-card>
          </div>
        </el-col>
      </el-row>
    </div>
    <el-row :gutter="20">
@@ -274,7 +293,7 @@
            </div>
          </div>
        </el-col>
        <el-col :span="1.5">
        <el-col :span="1.5" v-if="orgname == '景宁畲族自治县人民医院'">
          <div class="documentf">
            <div class="document">
              <el-tooltip
@@ -1107,6 +1126,7 @@
      inputVisible: false,
      Labelchange: false,
      ycvalue: "",
      jgvalue: "",
      yfsvalue: "",
      inputValue: "",
      preachform: "",
@@ -1287,7 +1307,7 @@
          value: 1,
          label: "异常",
        },
         {
        {
          value: 2,
          label: "警告",
        },
@@ -1414,6 +1434,7 @@
          // this.cardlist[1].value = response.rows[0].wzx;
          this.cardlist[1].value = response.rows[0].ysf;
          this.ycvalue = response.rows[0].yc;
          this.jgvalue = response.rows[0].jg;
          this.cardlist[2].value = response.rows[0].fssb;
          this.cardlist[3].value = response.rows[0].dsf;
          // this.cardlist[4].value = response.rows[0].yfs2;
@@ -1499,17 +1520,16 @@
      buidegetTasklist(obj).then((response) => {
        this.userList = response.rows[0].serviceSubtaskList;
        this.total = response.total;
        if (refresh) {
          this.cardlist[0].value =
            Number(response.rows[0].wzx) + Number(response.rows[0].ysf);
          this.cardlist[1].value = response.rows[0].wzx;
          this.cardlist[2].value = response.rows[0].ysf;
          this.ycvalue = response.rows[0].yc;
          this.cardlist[3].value = response.rows[0].fssb;
          this.cardlist[4].value = response.rows[0].dsf;
          // this.cardlist[5].value = response.rows[0].yfs2;
          this.yfsvalue = response.rows[0].yfs;
        }
        this.cardlist[0].value =
          Number(response.rows[0].wzx) + Number(response.rows[0].ysf);
        this.cardlist[1].value = response.rows[0].wzx;
        this.cardlist[2].value = response.rows[0].ysf;
        this.ycvalue = response.rows[0].yc;
        this.jgvalue = response.rows[0].jg;
        this.cardlist[3].value = response.rows[0].fssb;
        this.cardlist[4].value = response.rows[0].dsf;
        // this.cardlist[5].value = response.rows[0].yfs2;
        this.yfsvalue = response.rows[0].yfs;
        this.loading = false;
        this.userList.forEach((item) => {
          let idArray = null;
@@ -1847,9 +1867,9 @@
    Seedetails(row) {
      let type = "";
      console.log(row, "rwo");
        if (row.type == 1) {
          type = 1;
        }
      if (row.type == 1) {
        type = 1;
      }
      this.$router.push({
        path: "/followvisit/record/detailpage/",
        query: {
@@ -1915,7 +1935,7 @@
      } else if (too == 2) {
        this.topqueryParams.excep = 1;
      }
      this.handleQuery();
      this.handleQuery(1);
    },
    /** å¯¼å‡ºæŒ‰é’®æ“ä½œ */
    handleExport() {
@@ -2095,6 +2115,10 @@
  background: #f88d96;
  cursor: pointer; /* é¼ æ ‡æ‚¬æµ®æ—¶å˜ä¸ºæ‰‹å½¢ */
}
::v-deep.jgleftvlue .el-card__body:hover {
  background: #f7f075;
  cursor: pointer; /* é¼ æ ‡æ‚¬æµ®æ—¶å˜ä¸ºæ‰‹å½¢ */
}
::v-deep.ysfleftvlue .el-card__body {
  background: #d0fdd8;
src/views/followvisit/record/detailpage/index.vue
@@ -549,76 +549,96 @@
      <!-- äººå·¥å¤„理 -->
      <div class="manual-action">
        <div class="Followuserinfos">
          <div>
          <!-- é¡¶éƒ¨æ“ä½œåŒºåŸŸ -->
          <div class="section-header">
            <h3><i class="el-icon-s-operation"></i> äººå·¥å¤„理</h3>
            <div class="header-actions">
              <!-- åŸºç¡€æ“ä½œæŒ‰é’®ç»„ -->
              <div class="action-group basic-actions">
                <el-button
                  type="primary"
                  plain
                  @click="Editsingletasksonyic('')"
                >
                  ä¿å­˜åŸºç¡€ä¿¡æ¯
                </el-button>
                <!-- æ–°å¢žï¼šå»¶ç»­æŠ¤ç†æŒ‰é’® -->
                <el-button
                  type="success"
                  plain
                  @click="handleContinuationCare"
                  v-if="showContinuationCareBtn"
                >
                  å»¶ç»­æŠ¤ç†
                </el-button>
                <el-button
                  type="primary"
                  round
                  @click="sendAgain"
                  v-if="form.isVisitAgain != 2"
                >
                  å†æ¬¡éšè®¿
                </el-button>
              </div>
              <!-- å¼‚常状态选择器 -->
              <div class="action-group tag-selector">
                <el-select
                  v-model="selectedTag"
                  placeholder="请选择异常状态"
                  clearable
                  style="width: 150px; margin-right: 10px"
                >
                  <el-option
                    v-for="item in tagOptions"
                    :key="item.value"
                    :label="item.label"
                    :value="item.value"
                  >
                    <span style="display: flex; align-items: center">
                      <span
                        class="color-indicator"
                        :style="{ backgroundColor: item.color }"
                      ></span>
                      <span>{{ item.label }}</span>
                    </span>
                  </el-option>
                </el-select>
                <!-- å½“前选择的颜色指示器 -->
                <div
                  v-if="selectedTag"
                  class="color-indicator selected-indicator"
                  :style="{ backgroundColor: getSelectedTagColor() }"
                ></div>
                <!-- æ ‡è®°è¯´æ˜Žæç¤º -->
                <el-tooltip
                  v-if="selectedTag"
                  effect="light"
                  :content="getSelectedDescription()"
                  placement="top"
                >
                  <i class="el-icon-info tag-info-icon"></i>
                </el-tooltip>
              </div>
            </div>
          </div>
          <!-- è¡¨å•区域 -->
          <div class="form-content">
            <el-form
              ref="userform"
              :model="form"
              :rules="userrules"
              label-width="120px"
              label-width="100px"
            >
              <div class="headline">
                <div>人工处理</div>
                <div style="margin: 0 30px">
                  <el-button
                    type="primary"
                    plain
                    @click="Editsingletasksonyic('')"
                    >保存基础信息</el-button
                  >
                </div>
                <div>
                  <el-button
                    type="primary"
                    round
                    v-if="this.form.isVisitAgain != 2"
                    @click="sendAgain()"
                    >再次随访</el-button
                  >
                </div>
                <div class="tag-selector-container">
                  <el-select
                    v-model="selectedTag"
                    placeholder="请选择异常状态"
                    clearable
                    style="width: 150px; margin-right: 10px"
                  >
                    <el-option
                      v-for="item in tagOptions"
                      :key="item.value"
                      :label="item.label"
                      :value="item.value"
                    >
                      <span style="display: flex; align-items: center">
                        <span
                          class="color-indicator"
                          :style="{ backgroundColor: item.color }"
                        ></span>
                        <span>{{ item.label }}</span>
                      </span>
                    </el-option>
                  </el-select>
                  <!-- å½“前选择的颜色指示器 -->
                  <div
                    v-if="selectedTag"
                    class="color-indicator selected-indicator"
                    :style="{ backgroundColor: getSelectedTagColor() }"
                  ></div>
                  <!-- æ ‡è®°è¯´æ˜Žæç¤º -->
                  <el-tooltip
                    v-if="selectedTag"
                    effect="light"
                    :content="getSelectedDescription()"
                    placement="top"
                  >
                    <i class="el-icon-info tag-info-icon"></i>
                  </el-tooltip>
                </div>
              </div>
              <!-- è”系信息行 -->
              <el-row>
                <el-col :span="14"
                  ><el-form-item label="联系电话">
                <el-col :span="14">
                  <el-form-item label="联系电话">
                    <el-input
                      placeholder="联系电话缺失"
                      v-model="userform.telcode"
@@ -629,12 +649,15 @@
                        @click="handleCall(userform.telcode, 'tel')"
                        :disabled="!isValidPhone(userform.telcode)"
                      ></el-button>
                    </el-input> </el-form-item
                ></el-col>
                    </el-input>
                  </el-form-item>
                </el-col>
              </el-row>
              <!-- è”系人信息行 -->
              <el-row>
                <el-col :span="14"
                  ><el-form-item label="联系人电话">
                <el-col :span="14">
                  <el-form-item label="联系人电话">
                    <el-input
                      placeholder="联系人电话缺失"
                      v-model="userform.relativetelcode"
@@ -646,17 +669,21 @@
                          handleCall(userform.relativetelcode, 'relative')
                        "
                        :disabled="!isValidPhone(userform.relativetelcode)"
                      ></el-button
                    ></el-input> </el-form-item
                ></el-col>
                <el-col :span="10"
                  ><el-form-item label="联系人关系">
                      ></el-button>
                    </el-input>
                  </el-form-item>
                </el-col>
                <el-col :span="9">
                  <el-form-item label="关系">
                    <el-input
                      placeholder="联系人关系缺失"
                      v-model="userform.relation"
                    ></el-input> </el-form-item
                ></el-col>
                    ></el-input>
                  </el-form-item>
                </el-col>
              </el-row>
              <!-- é€šè¯æŽ§åˆ¶åŒºåŸŸ -->
              <div class="call-controls">
                <CallButton
                  ref="callButton"
@@ -708,13 +735,15 @@
                  />
                </div>
              </div>
              <el-form-item label="随访内容" v-if="orgname == '丽水市中医院'">
                <el-input type="textarea" v-model="form.remark"></el-input>
              </el-form-item>
              <el-form-item label="随访记录" v-else>
              <!-- éšè®¿å†…容/记录 -->
              <el-form-item
                :label="orgname == '丽水市中医院' ? '随访内容' : '随访记录'"
              >
                <el-input type="textarea" v-model="form.remark"></el-input>
              </el-form-item>
              <!-- éšè®¿æƒ…况 -->
              <el-form-item label="随访情况" v-if="orgname == '丽水市中医院'">
                <el-radio-group v-model="form.taskSituation">
                  <el-radio
@@ -722,121 +751,136 @@
                    :label="city.value"
                    :value="city.value"
                    :key="city.value"
                    >{{ city.label }}</el-radio
                  >
                    {{ city.label }}
                  </el-radio>
                </el-radio-group>
              </el-form-item>
              <!-- å¤„理意见 -->
              <el-form-item label="处理意见">
                <div>
                <div class="opinion-buttons">
                  <el-button
                    plain
                    type="warning"
                    @click="Editsingletaskson('1')"
                    >暂不处理</el-button
                  >
                    æš‚不处理
                  </el-button>
                  <el-button
                    plain
                    type="success"
                    @click="Editsingletaskson('2')"
                    >病情稳定</el-button
                  >
                    ç—…情稳定
                  </el-button>
                  <el-button
                    plain
                    type="primary"
                    @click="Editsingletaskson('3')"
                    >通知就诊</el-button
                  >
                  <el-button plain type="info" @click="Editsingletaskson('5')"
                    >中心随访</el-button
                  >
                  <el-button type="primary" round @click="sendAgainmsg"
                    >短信发送</el-button
                  >
                    é€šçŸ¥å°±è¯Š
                  </el-button>
                  <el-button plain type="info" @click="Editsingletaskson('5')">
                    äººå·¥éšè®¿
                  </el-button>
                  <el-button type="primary" round @click="sendAgainmsg">
                    çŸ­ä¿¡å‘送
                  </el-button>
                </div>
              </el-form-item>
            </el-form>
          </div>
            <div class="detailed">
              <h3>患者档案信息</h3>
              <el-form ref="userform" :model="userform" label-width="100px">
                <el-row :gutter="20">
                  <el-col :span="12">
                    <el-form-item label="患者姓名" prop="name">
                      <el-input
                        v-model="userform.name"
                        placeholder="请输入姓名"
                        maxlength="30"
                      ></el-input> </el-form-item
                  ></el-col>
                </el-row>
                <el-row :gutter="20">
                  <el-col :span="12"
                    ><el-form-item label="性别" prop="telcode">
                      <el-select v-model="userform.sex" placeholder="请选择">
                        <el-option label="男" :value="1"> </el-option>
                        <el-option label="女" :value="2"> </el-option>
                      </el-select> </el-form-item
                  ></el-col>
                  <el-col :span="12">
                    <el-form-item label="年龄" prop="name">
                      <el-input
                        v-model="userform.age"
                        placeholder="请输入姓名"
                        maxlength="20"
                      ></el-input> </el-form-item
                  ></el-col>
                </el-row>
          <!-- æ‚£è€…档案信息 -->
          <div class="detailed">
            <h3>患者档案信息</h3>
            <el-form ref="userform" :model="userform" label-width="100px">
              <el-row :gutter="20">
                <el-col :span="12">
                  <el-form-item label="患者姓名" prop="name">
                    <el-input
                      v-model="userform.name"
                      placeholder="请输入姓名"
                      maxlength="30"
                    ></el-input>
                  </el-form-item>
                </el-col>
              </el-row>
              <el-row :gutter="20">
                <el-col :span="12">
                  <el-form-item label="性别" prop="sex">
                    <el-select v-model="userform.sex" placeholder="请选择">
                      <el-option label="男" :value="1"> </el-option>
                      <el-option label="女" :value="2"> </el-option>
                    </el-select>
                  </el-form-item>
                </el-col>
                <el-col :span="12">
                  <el-form-item label="年龄" prop="age">
                    <el-input
                      v-model="userform.age"
                      placeholder="请输入年龄"
                      maxlength="20"
                    ></el-input>
                  </el-form-item>
                </el-col>
              </el-row>
                <el-row :gutter="20">
                  <el-col :span="12"
                    ><el-form-item label="联系方式" prop="telcode">
                      <el-input
                        v-model="userform.telcode"
                        placeholder="请输入联系方式"
                        maxlength="20"
                      /> </el-form-item
                  ></el-col>
                  <el-col :span="12">
                    <el-form-item label="亲属联系方式" prop="name">
                      <el-input
                        v-model="userform.relativetelcode"
                        placeholder="请输入姓名"
                        maxlength="20"
                      ></el-input> </el-form-item
                  ></el-col>
                </el-row>
                <el-row :gutter="20">
                  <el-col :span="24">
                    <el-form-item label="诊断名称" prop="name">
                      <el-input
                        v-model="form.leavediagname"
                        placeholder="请输入诊断"
                        maxlength="50"
                      ></el-input> </el-form-item
                  ></el-col>
                </el-row>
                <el-row :gutter="20">
                  <el-col :span="24">
                    <el-form-item label="出生地" prop="birthplace">
                      <el-input
                        v-model="userform.birthplace"
                        placeholder="国、省、地市、区县、街道等详细信息"
                        maxlength="50"
                      /> </el-form-item
                  ></el-col>
                </el-row>
                <el-row :gutter="20">
                  <el-col :span="24"
                    ><el-form-item label="居住地" prop="placeOfResidence">
                      <el-input
                        v-model="userform.placeOfResidence"
                        placeholder="国、省、地市、区县、街道等详细信息"
                        maxlength="50"
                      /> </el-form-item
                  ></el-col>
                </el-row>
              </el-form>
            </div>
              <el-row :gutter="20">
                <el-col :span="12">
                  <el-form-item label="联系方式" prop="telcode">
                    <el-input
                      v-model="userform.telcode"
                      placeholder="请输入联系方式"
                      maxlength="20"
                    />
                  </el-form-item>
                </el-col>
                <el-col :span="12">
                  <el-form-item label="亲属联系方式" prop="relativetelcode">
                    <el-input
                      v-model="userform.relativetelcode"
                      placeholder="请输入亲属联系方式"
                      maxlength="20"
                    ></el-input>
                  </el-form-item>
                </el-col>
              </el-row>
              <el-row :gutter="20">
                <el-col :span="24">
                  <el-form-item label="诊断名称" prop="leavediagname">
                    <el-input
                      v-model="form.leavediagname"
                      placeholder="请输入诊断"
                      maxlength="50"
                    ></el-input>
                  </el-form-item>
                </el-col>
              </el-row>
              <el-row :gutter="20">
                <el-col :span="24">
                  <el-form-item label="出生地" prop="birthplace">
                    <el-input
                      v-model="userform.birthplace"
                      placeholder="国、省、地市、区县、街道等详细信息"
                      maxlength="50"
                    />
                  </el-form-item>
                </el-col>
              </el-row>
              <el-row :gutter="20">
                <el-col :span="24">
                  <el-form-item label="居住地" prop="placeOfResidence">
                    <el-input
                      v-model="userform.placeOfResidence"
                      placeholder="国、省、地市、区县、街道等详细信息"
                      maxlength="50"
                    />
                  </el-form-item>
                </el-col>
              </el-row>
            </el-form>
          </div>
        </div>
      </div>
@@ -1165,6 +1209,9 @@
      isEndingCall: false,
      CaldialogVisible: false,
      currentCall: null, // å½“前通话对象
      // æ–°å¢žåŠŸèƒ½æ•°æ®
      showPatientInfo: true,
      showContinuationCareBtn: false, // æŽ§åˆ¶å»¶ç»­æŠ¤ç†æŒ‰é’®æ˜¾ç¤º
      // è·¯ç”±ç›‘听相关
      routeWatcher: null,
      lastRoutePath: this.$route.path,
@@ -1439,6 +1486,10 @@
    this.visitCount = this.$route.query.visitCount;
    this.serviceType = this.$route.query.serviceType;
    this.orgname = localStorage.getItem("orgname");
    if (this.orgname == "省立同德翠苑院区") {
      this.showContinuationCareBtn = true;
    }
    if (this.orgname == "缙云县中医医院") {
      this.options = [
        {
@@ -1498,6 +1549,8 @@
  methods: {
    // èŽ·å–ä¸»é¢˜æ ·å¼ç±»
    getTopicClass(item) {
      console.log(item.isabnormal, "getTopicClass");
      // æ ¹æ®çŠ¶æ€å€¼è¿”å›žå¯¹åº”çš„æ ·å¼ç±»
      if (item.isabnormal == 1) {
        return "scriptTopic-isabnormal"; // å¼‚常 - çº¢è‰²
@@ -1736,6 +1789,7 @@
          scriptid: item.id,
          excep: excep,
          questiontext: item.scriptContent,
          categoryid: item.categoryid,
          answerps: item.answerps || null, // æ·»åŠ é™„åŠ ä¿¡æ¯
        };
        if (item.scriptType == 2 && item.scriptResult[0]) {
@@ -2496,6 +2550,34 @@
      // åˆ·æ–°æ•°æ®
      this.getTaskservelist();
    },
    // å»¶ç»­æŠ¤ç†
    handleContinuationCare() {
      if (this.form.continueFlag != 2) {
        this.$modal.confirm("是否为本次服务创建延续护理?").then(() => {
          this.$router.push({
            path: "/followvisit/ContinueFordetails/",
            query: {
              taskid: this.taskid,
              patid: this.patid,
              id: this.id,
              Voicetype: this.Voicetype,
              visitCount: this.visitCount,
            },
          });
        });
      } else {
        this.$router.push({
          path: "/followvisit/ContinueFordetails/",
          query: {
            taskid: this.taskid,
            patid: this.patid,
            id: this.id,
            Voicetype: this.Voicetype,
            visitCount: this.visitCount,
          },
        });
      }
    },
  },
  // deactivated() {
  //   console.log(11);
@@ -2826,7 +2908,7 @@
  padding: 30px;
  border: 1px solid #dcdfe6;
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), 0 0 6px 0 rgba(0, 0, 0, 0.04);
  max-height: 618px;
  max-height: 716px;
  /* è®¾ç½®æœ€å¤§é«˜åº¦ */
  overflow-y: auto;
  /* å†…容超过高度时显示滚动条 */
@@ -3234,4 +3316,366 @@
    margin-bottom: 20px;
  }
}
/* äººå·¥å¤„理部分样式 */
.manual-action {
  flex: 1;
  min-width: 0;
  height: 100%;
  overflow: hidden;
  .Followuserinfos {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 20px;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
    height: 100%;
    overflow-y: auto;
  }
}
/* å¤´éƒ¨åŒºåŸŸ */
.section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 15px;
  border-bottom: 2px solid #f0f0f0;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 15px;
  h3 {
    margin: 0;
    color: #409eff;
    font-size: 18px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    i {
      font-size: 20px;
    }
  }
  .header-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 15px;
    .action-group {
      display: flex;
      align-items: center;
      gap: 10px;
    }
  }
}
/* åŸºç¡€æ“ä½œæŒ‰é’® */
.basic-actions {
  .el-button {
    min-width: 100px;
  }
}
/* å¼‚常状态选择器 */
.tag-selector {
  display: flex;
  align-items: center;
  gap: 10px;
  .current-tag {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: #f8f9fa;
    border: 1px solid;
    border-radius: 4px;
    font-size: 12px;
    transition: all 0.3s;
    &:hover {
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    }
  }
}
.color-indicator {
  width: 16px;
  height: 16px;
  border-radius: 3px;
  margin-right: 8px;
  display: inline-block;
}
.selected-indicator {
  margin-left: 10px;
  width: 20px;
  height: 20px;
}
.tag-info-icon {
  margin-left: 10px;
  color: #909399;
  cursor: pointer;
  font-size: 16px;
}
/* è¡¨å•区域 */
.form-content {
  background: #f8f9fa;
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 20px;
  .el-form {
    .el-row {
      margin: 0 -10px;
    }
    .el-col {
      padding: 0 10px;
    }
  }
}
/* é€šè¯æŽ§åˆ¶åŒºåŸŸ */
.call-controls {
  margin: 15px 0;
  .hangup-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin: 15px 0;
  }
  .hangup-btn {
    width: 120px;
    height: 40px;
    font-size: 14px;
    border-radius: 20px;
    box-shadow: 0 2px 8px rgba(244, 67, 54, 0.3);
    transition: all 0.3s ease;
  }
  .hangup-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(244, 67, 54, 0.4);
  }
  .call-timer {
    font-size: 12px;
    color: #666;
    background: #f5f5f5;
    padding: 4px 12px;
    border-radius: 12px;
    font-family: "Courier New", monospace;
  }
  .call-status-container {
    margin: 10px 0;
  }
  .status-alert {
    border-radius: 8px;
    transition: all 0.3s ease;
  }
  .status-alert.status-calling {
    border-left: 4px solid #e6a23c;
  }
  .status-alert.status-connected {
    border-left: 4px solid #67c23a;
    animation: pulse 2s infinite;
  }
  .status-alert.status-ended {
    border-left: 4px solid #909399;
  }
  .sip-registering {
    margin: 10px 0;
  }
  .registering-alert {
    border-radius: 8px;
    background-color: #f4f4f5;
    border-left: 4px solid #909399;
  }
}
/* å¤„理意见按钮组 */
.opinion-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  .el-button {
    flex: 1;
    min-width: 120px;
  }
}
/* æ‚£è€…档案信息 */
.detailed {
  width: 100%;
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 20px;
  background-color: #ddf0f8;
  border: 1px solid #b3e0f2;
  h3 {
    margin: 0 0 20px 0;
    color: #333;
    font-size: 16px;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 8px;
    &:before {
      content: "";
      display: block;
      width: 4px;
      height: 16px;
      background: #409eff;
      border-radius: 2px;
    }
  }
  .el-form {
    .el-row {
      margin: 0 -10px;
    }
    .el-col {
      padding: 0 10px;
      margin-bottom: 15px;
    }
  }
}
/* åŠ¨ç”»æ•ˆæžœ */
@keyframes pulse {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
  100% {
    opacity: 1;
  }
}
/* å“åº”式设计 */
@media screen and (max-width: 1200px) {
  .section-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
  }
  .header-actions {
    width: 100%;
    justify-content: space-between;
  }
  .opinion-buttons {
    .el-button {
      min-width: calc(50% - 8px);
    }
  }
}
@media screen and (max-width: 768px) {
  .Followuserinfos {
    padding: 15px;
  }
  .form-content,
  .detailed {
    padding: 15px;
  }
  .header-actions {
    flex-direction: column;
    align-items: stretch;
    .action-group {
      flex-direction: column;
      align-items: stretch;
      .el-select {
        width: 100%;
        margin-right: 0;
      }
    }
  }
  .opinion-buttons {
    flex-direction: column;
    .el-button {
      width: 100%;
    }
  }
  .detailed {
    .el-form {
      .el-col {
        width: 100%;
      }
    }
  }
}
/* æ»šåŠ¨æ¡ç¾ŽåŒ– */
.Followuserinfos {
  &::-webkit-scrollbar {
    width: 6px;
  }
  &::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 3px;
  }
  &::-webkit-scrollbar-thumb {
    background: #c1c1c1;
    border-radius: 3px;
    &:hover {
      background: #a8a8a8;
    }
  }
}
/* æŒ‰é’®å›¾æ ‡ä¼˜åŒ– */
.el-icon-phone {
  transition: all 0.3s;
}
.el-button[disabled] .el-icon-phone {
  color: #c0c4cc;
}
.el-button:not([disabled]) .el-icon-phone {
  color: #409eff;
}
.el-button:not([disabled]):hover .el-icon-phone {
  color: #66b1ff;
  transform: scale(1.1);
}
</style>
src/views/login-sy.vue
ÎļþÃû´Ó src/views/login-ls.vue ÐÞ¸Ä
@@ -37,10 +37,10 @@
        </el-input>
      </el-form-item>
      <!-- ä¸½===================æ°´ -->
      <el-form-item prop="orgid">
      <el-form-item prop="medicalCode">
        <el-select
          style="width: 100%"
          v-model="loginForm.orgid"
          v-model="loginForm.medicalCode"
          placeholder="请选择院区"
        >
          <el-option
@@ -165,10 +165,11 @@
      });
    },
    getorganization() {
      getorganization().then((res) => {
      getorganization({ pageSize: 30 }).then((res) => {
        if (res.code == 200) {
          this.options = res.rows.map((item) => ({
            value: item.orgid,
            value: item.medicalCode,
            // value: item.medicalCode,
            label: item.organizationName,
          }));
        }
@@ -205,14 +206,19 @@
      }
      // åŠ¨æ€è®¾ç½® campusid å‚æ•°
      const selectedOrg = this.options.find(item => item.value === this.loginForm.orgid);
      const selectedOrg = this.options.find(item => item.value === this.loginForm.medicalCode);
      console.log(selectedOrg);
      if (selectedOrg) {
        if (selectedOrg.label.includes('湖滨')) {
          this.loginForm.campusid = 1;
          this.loginForm.orgid = 1;
        } else if (selectedOrg.label.includes('吴山')) {
          this.loginForm.campusid = 2;
          this.loginForm.orgid = 1;
        } else {
          this.loginForm.campusid = 1; // é»˜è®¤å€¼æˆ–其他处理
          this.loginForm.orgid = 1;
        }
      }
src/views/login.vue
@@ -37,10 +37,10 @@
        </el-input>
      </el-form-item>
      <!-- ä¸½===================æ°´ -->
      <el-form-item prop="medicalCode">
      <el-form-item prop="orgid">
        <el-select
          style="width: 100%"
          v-model="loginForm.medicalCode"
          v-model="loginForm.orgid"
          placeholder="请选择院区"
        >
          <el-option
@@ -118,8 +118,7 @@
        code: "",
        orgid: "H41010500003",
      },
      options: [
      ],
      options: [],
      loginRules: {
        username: [
          { required: true, trigger: "blur", message: "请输入您的账号" },
@@ -165,11 +164,10 @@
      });
    },
    getorganization() {
      getorganization().then((res) => {
      getorganization({ pageSize: 30 }).then((res) => {
        if (res.code == 200) {
          this.options = res.rows.map((item) => ({
            value: item.medicalCode,
            // value: item.medicalCode,
            value: item.orgid,
            label: item.organizationName,
          }));
        }
@@ -187,61 +185,58 @@
      };
    },
    handleLogin() {
  this.$refs.loginForm.validate((valid) => {
    if (valid) {
      this.loading = true;
      this.$refs.loginForm.validate((valid) => {
        if (valid) {
          this.loading = true;
      if (this.loginForm.rememberMe) {
        Cookies.set("username", this.loginForm.username, { expires: 30 });
        Cookies.set("password", encrypt(this.loginForm.password), {
          expires: 30,
        });
        Cookies.set("rememberMe", this.loginForm.rememberMe, {
          expires: 30,
        });
      } else {
        Cookies.remove("username");
        Cookies.remove("password");
        Cookies.remove("rememberMe");
      }
      // åŠ¨æ€è®¾ç½® campusid å‚æ•°
      const selectedOrg = this.options.find(item => item.value === this.loginForm.medicalCode);
      console.log(selectedOrg);
      if (selectedOrg) {
        if (selectedOrg.label.includes('湖滨')) {
          this.loginForm.campusid = 1;
          this.loginForm.orgid = 1;
        } else if (selectedOrg.label.includes('吴山')) {
          this.loginForm.campusid = 2;
          this.loginForm.orgid = 1;
        } else {
          this.loginForm.campusid = 1; // é»˜è®¤å€¼æˆ–其他处理
          this.loginForm.orgid = 1;
        }
      }
      this.$store
        .dispatch("Login", this.loginForm)
        .then((res) => {
          if (this.loginForm.username == "admin") {
            this.$router.push({ path: "/index" }).catch(() => {});
          if (this.loginForm.rememberMe) {
            Cookies.set("username", this.loginForm.username, { expires: 30 });
            Cookies.set("password", encrypt(this.loginForm.password), {
              expires: 30,
            });
            Cookies.set("rememberMe", this.loginForm.rememberMe, {
              expires: 30,
            });
          } else {
            this.$router
              .push({ path: "/followvisit/discharge" })
              .catch(() => {});
            Cookies.remove("username");
            Cookies.remove("password");
            Cookies.remove("rememberMe");
          }
        })
        .catch(() => {
          this.loading = false;
          if (this.captchaEnabled) {
            this.getCode();
          // åŠ¨æ€è®¾ç½® campusid å‚æ•°
          const selectedOrg = this.options.find(
            (item) => item.value === this.loginForm.orgid
          );
          if (selectedOrg) {
            if (selectedOrg.label.includes("湖滨")) {
              this.loginForm.campusid = 1;
            } else if (selectedOrg.label.includes("吴山")) {
              this.loginForm.campusid = 2;
            } else {
              this.loginForm.campusid = 1; // é»˜è®¤å€¼æˆ–其他处理
            }
          }
        });
    }
  });
}
          this.$store
            .dispatch("Login", this.loginForm)
            .then((res) => {
              if (this.loginForm.username == "admin") {
                this.$router.push({ path: "/index" }).catch(() => {});
              } else {
                this.$router
                  .push({ path: "/followvisit/discharge" })
                  .catch(() => {});
              }
            })
            .catch(() => {
              this.loading = false;
              if (this.captchaEnabled) {
                this.getCode();
              }
            });
        }
      });
    },
  },
};
</script>
src/views/patient/patient/behospitalized.vue
@@ -637,6 +637,9 @@
    this.queryParams.leaveldeptcodes = store.getters.belongDepts.map(
      (obj) => obj.deptCode
    );
    this.queryParams.leavehospitaldistrictcodes = store.getters.belongWards.map(
      (obj) => obj.districtCode
    );
    this.getList();
    // this.listDept();
    this.gettabList();
@@ -776,8 +779,8 @@
        leavehospitaldistrictcodes: [],
      };
      this.queryParams.leaveldeptcodes = store.getters.belongDepts.map(
      (obj) => obj.deptCode
    );
        (obj) => obj.deptCode
      );
      this.handleQuery();
    },
    // å¤šé€‰æ¡†é€‰ä¸­æ•°æ®
@@ -948,6 +951,6 @@
  }
}
.button-textsc {
  color: #3664D9;
  color: #3664d9;
}
</style>
src/views/patient/patient/hospital.vue
@@ -630,6 +630,9 @@
    this.queryParams.leaveldeptcodes = store.getters.belongDepts.map(
      (obj) => obj.deptCode
    );
    this.queryParams.leavehospitaldistrictcodes = store.getters.belongWards.map(
      (obj) => obj.districtCode
    );
    this.getList();
    // this.listDept();
    this.gettabList();
src/views/sfstatistics/percentage/index.vue
@@ -1168,6 +1168,20 @@
                  </template>
                </el-table-column>
                <el-table-column
                  label="任务执行方式"
                  align="center"
                  key="preachform"
                  prop="preachform"
                  width="160"
                  :show-overflow-tooltip="true"
                >
                  <template slot-scope="scope">
                    <span v-for="item in scope.row.preachform"
                      >{{ item }}、
                    </span>
                  </template>
                </el-table-column>
                <el-table-column
                  prop="visitTime"
                  align="center"
                  label="应随访时间"
@@ -1420,6 +1434,7 @@
      allDeptCodes: [],
      // å­˜å‚¨æ‰€æœ‰ç—…区代码
      allWardCodes: [],
      checkboxlist: [],
      // è¡¨å•参数
      form: {},
      forms: {
@@ -1469,6 +1484,7 @@
  created() {
    this.getDeptTree();
    this.getList();
    this.checkboxlist = store.getters.checkboxlist;
    this.orgname = localStorage.getItem("orgname");
  },
@@ -1487,12 +1503,14 @@
          ? this.allDeptCodes
          : this.queryParams.deptcodes,
      };
      this.loading = true;
      // ç§»é™¤å¯èƒ½å­˜åœ¨çš„"all"值
      delete params.leavehospitaldistrictcodes.all;
      delete params.deptcodes.all;
      getSfStatistics(params).then((response) => {
        console.log(response);
        this.loading = false;
        // this.total = response.total;
        this.userList = this.customSort(response.data);
      });
@@ -1851,7 +1869,25 @@
      this.infotitleVisible = true;
      this.infotitle = title;
      this.infotitlelist = row; // å‡è®¾row就是需要展示的详细数组
      console.log(this.infotitlelist, "this.infotitlelist");
      this.infotitlelist.forEach((item) => {
        let idArray = null;
        if (item.preachform) {
          if (item.endtime) {
            item.preachformson = item.preachform;
            idArray = item.preachform.split(",");
          }
          item.preachform = idArray.map((value) => {
            // æŸ¥æ‰¾id对应的对象
            const item = this.checkboxlist.find((item) => item.value == value);
            // å¦‚果找到对应的id,返回label值,否则返回null
            return item ? item.label : null;
          });
        }
      });
      // åˆå§‹åŒ–加载
      this.loadIndex = 0;
      this.currentDisplayList = [];
@@ -1865,6 +1901,8 @@
      // æ¨¡æ‹Ÿå¼‚步加载,实际可能是直接切片本地数据
      setTimeout(() => {
        console.log(this.infotitlelist, "this.infotitlelist");
        const nextChunk = this.infotitlelist.slice(
          this.loadIndex,
          this.loadIndex + this.pageSize
vue.config.js
@@ -36,7 +36,7 @@
      // detail: https://cli.vuejs.org/config/#devserver-proxy
      [process.env.VUE_APP_BASE_API]: {
        // target: `https://www.health-y.cn/lssf`,
        // target: `http://192.168.100.10:8098`,
        // target: `http://192.168.100.10:8096`,
        // target: `http://192.168.100.10:8094`,//省立同德
        // target: `http://192.168.100.10:8095`,//新华
        target:`http://localhost:8095`,