<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-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="患者姓名" 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-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-upload2" 
 | 
                size="medium" 
 | 
                @click="handleExport" 
 | 
                >导出</el-button 
 | 
              > 
 | 
            </div> 
 | 
          </div> 
 | 
        </el-col> 
 | 
        <el-col :span="1.5"> 
 | 
          <el-button 
 | 
            type="primary" 
 | 
                        icon="el-icon-plus" 
 | 
            size="medium" 
 | 
            @click="handleAdd" 
 | 
            >新增</el-button 
 | 
          > 
 | 
        </el-col> 
 | 
  
 | 
        <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-col :span="1.5"> 
 | 
          <div class="documentf"> 
 | 
            <div class="document"> 
 | 
              <el-button 
 | 
                type="success" 
 | 
                plain 
 | 
                size="medium" 
 | 
                @click="buidegetTasklist()" 
 | 
                >待办服务</el-button 
 | 
              > 
 | 
            </div> 
 | 
          </div> 
 | 
        </el-col> 
 | 
        <el-col :span="1.5"> 
 | 
          <div class="documentf"> 
 | 
            <div class="document"> 
 | 
              <el-button 
 | 
                type="primary" 
 | 
                plain 
 | 
                size="medium" 
 | 
                @click="affiliation()" 
 | 
                >本人所属服务</el-button 
 | 
              > 
 | 
            </div> 
 | 
          </div> 
 | 
        </el-col> 
 | 
        <el-col :span="1.5"> 
 | 
          <div class="documentf"> 
 | 
            <div class="document"> 
 | 
              <el-button type="success" size="medium" @click="onthatday()" 
 | 
                >当日服务</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="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="120" 
 | 
          align="center" 
 | 
          key="drname" 
 | 
          prop="drname" 
 | 
        /> 
 | 
        <el-table-column 
 | 
          label="随访人员" 
 | 
          align="center" 
 | 
          key="updateBy" 
 | 
          prop="updateBy" 
 | 
          width="120" 
 | 
        /> 
 | 
        <el-table-column 
 | 
          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" 
 | 
          sortable 
 | 
          key="medicalRecordNo" 
 | 
          prop="medicalRecordNo" 
 | 
          width="120" 
 | 
        /> --> 
 | 
  
 | 
        <!-- <el-table-column label="年龄" align="center" key="age" prop="age" /> --> 
 | 
        <!-- <el-table-column label="性别"width="100" align="center" key="sex" prop="sex" /> --> 
 | 
        <!-- <el-table-column label="床号" align="center" key="badNo" prop="badNo" /> --> 
 | 
        <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="leavediagname" 
 | 
          prop="leavediagname" 
 | 
          width="120" 
 | 
          :show-overflow-tooltip="true" 
 | 
        > 
 | 
        </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="300" 
 | 
          class-name="small-padding fixed-width" 
 | 
        > 
 | 
          <template slot-scope="scope"> 
 | 
            <!-- <el-tooltip 
 | 
              class="item" 
 | 
              effect="dark" 
 | 
              content="再次随访" 
 | 
              placement="top" 
 | 
            > 
 | 
              <el-button 
 | 
                size="medium" 
 | 
                type="text" 
 | 
                v-if="scope.row.isVisitAgain!=2" 
 | 
                @click="followupvisit(scope.row)" 
 | 
                ><span class="button-bb" 
 | 
                  ><i class="el-icon-s-promotion"></i>再次随访</span 
 | 
                ></el-button 
 | 
              > 
 | 
            </el-tooltip> 
 | 
            <el-tooltip 
 | 
              v-if="scope.row.sendstate == 1 || scope.row.sendstate == 2" 
 | 
              class="item" 
 | 
              effect="dark" 
 | 
              content="暂停服务" 
 | 
              placement="top" 
 | 
            > 
 | 
              <el-button 
 | 
                size="medium" 
 | 
                type="text" 
 | 
                @click="handlestop(scope.row)" 
 | 
                v-hasPermi="['system:user:edit']" 
 | 
                ><span class="button-sc" 
 | 
                  ><i class="el-icon-remove-outline"></i>暂停服务</span 
 | 
                ></el-button 
 | 
              > 
 | 
            </el-tooltip> --> 
 | 
            <el-button size="medium" type="text" @click="Seedetails(scope.row)" 
 | 
              ><span class="button-zx" 
 | 
                ><i class="el-icon-s-order"></i>查看详情</span 
 | 
              ></el-button 
 | 
            > 
 | 
            <el-button 
 | 
              size="medium" 
 | 
              type="text" 
 | 
              @click="handleUpdate(scope.row)" 
 | 
              ><span class="button-textxga" 
 | 
                ><i class="el-icon-edit"></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> 
 | 
    <!-- 再次随访 --> 
 | 
  
 | 
  </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, 
 | 
      // 总条数 
 | 
      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: "", 
 | 
      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: "", 
 | 
      }, 
 | 
      topicoptionssort: [ 
 | 
        { 
 | 
          value: 0, 
 | 
          label: "出院时间(正序)", 
 | 
        }, 
 | 
        { 
 | 
          value: 1, 
 | 
          label: "出院时间(倒序)", 
 | 
        }, 
 | 
        { 
 | 
          value: 2, 
 | 
          label: "发送时间(正序)", 
 | 
        }, 
 | 
        { 
 | 
          value: 3, 
 | 
          label: "发送时间(倒序)", 
 | 
        }, 
 | 
      ], 
 | 
      // 查询参数 
 | 
      topqueryParams: { 
 | 
        pageNum: 1, 
 | 
        pageSize: 10, 
 | 
        sendstate: 6, 
 | 
        sort: 2, //0 出院时间(正序)    1 出院时间(倒序)   2 发送时间(正序)    3 发送时间(倒序) 
 | 
        serviceType: 15, 
 | 
        searchscope: 3, 
 | 
        visitCount: 1, 
 | 
        scopetype: [], 
 | 
        leaveldeptcodes: [], 
 | 
        leavehospitaldistrictcodes: [], 
 | 
      }, 
 | 
      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: 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: "1400466972205912064", 
 | 
            YongHuXM: "JNRMYY", 
 | 
            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.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.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.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; 
 | 
      }); 
 | 
    }, 
 | 
    affiliation() { 
 | 
      this.topqueryParams.drcode = store.getters.hisUserId; 
 | 
      this.topqueryParams.nurseId = store.getters.hisUserId; 
 | 
      this.topqueryParams.managementDoctor = store.getters.name; 
 | 
      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.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, 
 | 
        sendstate: 6, 
 | 
        sort: 2, //0 出院时间(正序)    1 出院时间(倒序)   2 发送时间(正序)    3 发送时间(倒序) 
 | 
        serviceType: 15, 
 | 
        searchscope: 3, 
 | 
        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: 15, 
 | 
        }, 
 | 
      }); 
 | 
    }, 
 | 
    //患者360跳转 
 | 
    gettoken360(sfzh, drcode, drname) { 
 | 
      this.$modal.msgWarning('360功能暂未开通'); 
 | 
  return; // 阻止后续代码执行 
 | 
      this.postData.YeWuXX.BingRenXX.ZhengJianHM = sfzh; 
 | 
      if (this.postData.XiaoXiTou.ZuHuMC == "丽水市中医院") { 
 | 
        this.postData.YeWuXX.YongHuXX.YongHuID = "1400398571877961728"; 
 | 
        this.postData.YeWuXX.YongHuXX.YongHuXM = "LSZYY"; 
 | 
      } 
 | 
      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.preachformson) { 
 | 
        if (row.preachformson.includes("3")) { 
 | 
          type = 1; 
 | 
        } 
 | 
      } 
 | 
      this.$router.push({ 
 | 
        path: "/followvisit/record/detailpage/", 
 | 
        query: { 
 | 
          taskid: row.taskid, 
 | 
          patid: row.patid, 
 | 
          id: row.id, 
 | 
          Voicetype: type, 
 | 
          visitCount: this.topqueryParams.visitCount, 
 | 
        }, 
 | 
      }); 
 | 
    }, 
 | 
  
 | 
    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"; 
 | 
      } 
 | 
      return ""; 
 | 
    }, 
 | 
  
 | 
    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; 
 | 
} 
 | 
  
 | 
.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.ysfleftvlue .el-card__body { 
 | 
  background: #d0fdd8; 
 | 
} 
 | 
::v-deep.ysfleftvlue .el-card__body:hover { 
 | 
  background: #8df8a4; 
 | 
  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: #4fabe9; 
 | 
  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> 
 |