| <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="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="updateBy" | 
|           prop="updateBy" | 
|           width="120" | 
|         /> | 
|   | 
|         <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: 7, | 
|           label: "应随访日期(正序)", | 
|         }, | 
|         { | 
|           value: 8, | 
|           label: "应随访日期(倒序)", | 
|         }, | 
|       ], | 
|       // 查询参数 | 
|       topqueryParams: { | 
|         pageNum: 1, | 
|         pageSize: 10, | 
|         sendstate: 6, | 
|         sort: localStorage.getItem("orgname") == "丽水市中医院" ? 8 : 2, //0 出院时间(正序)    1 出院时间(倒序)   2 发送时间(正序)    3 发送时间(倒序)  7应随访日期(倒序) 应随访日期(正序) | 
|         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: 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.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.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.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功能暂未开通'); | 
|   | 
|       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.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> |