|  |  |  | 
|---|
|  |  |  | >查看患者全部服务</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button v-else type="success" @click="getTaskservelist(id)" | 
|---|
|  |  |  | >查看患者本次服务信息</el-button | 
|---|
|  |  |  | >只展示本次服务信息</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div style="margin-left: 20px; color: #59a0f0"> | 
|---|
|  |  |  | <!-- <div style="margin-left: 20px; color: #59a0f0"> | 
|---|
|  |  |  | <el-link | 
|---|
|  |  |  | href="https://9.208.2.207:6060/search-homepage" | 
|---|
|  |  |  | target="_blank" | 
|---|
|  |  |  | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 前往CDSS查询 | 
|---|
|  |  |  | </el-link> | 
|---|
|  |  |  | </div> --> | 
|---|
|  |  |  | <div class="merge-controls" v-if="Whetherall"> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | @click="toggleMergeMode" | 
|---|
|  |  |  | :disabled="selectedServices.length < 2" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {{ isMergeMode ? "取消合并" : "合并编辑问卷" }} | 
|---|
|  |  |  | </el-button> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | v-if="isMergeMode" | 
|---|
|  |  |  | type="success" | 
|---|
|  |  |  | @click="openMergeDialog" | 
|---|
|  |  |  | :disabled="selectedServices.length < 2" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 开始合并 (已选 {{ selectedServices.length }} 个服务) | 
|---|
|  |  |  | </el-button> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- <el-button type="success">随访后短信</el-button> --> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-table :data="logsheetlist" style="width: 100%"> | 
|---|
|  |  |  | <el-table | 
|---|
|  |  |  | :data="logsheetlist" | 
|---|
|  |  |  | :row-class-name="tableRowClassName" | 
|---|
|  |  |  | :max-height="350" | 
|---|
|  |  |  | style="width: 100%" | 
|---|
|  |  |  | @selection-change="handleSelectionChange" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | type="selection" | 
|---|
|  |  |  | width="55" | 
|---|
|  |  |  | :selectable="checkSelectable" | 
|---|
|  |  |  | v-if="Whetherall" | 
|---|
|  |  |  | ></el-table-column> | 
|---|
|  |  |  | <el-table-column | 
|---|
|  |  |  | prop="sendname" | 
|---|
|  |  |  | align="center" | 
|---|
|  |  |  | label="姓名" | 
|---|
|  |  |  | width="100" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <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 | 
|---|
|  |  |  | prop="taskName" | 
|---|
|  |  |  | 
|---|
|  |  |  | size="medium" | 
|---|
|  |  |  | type="text" | 
|---|
|  |  |  | @click="Seedetails(scope.row)" | 
|---|
|  |  |  | v-hasPermi="['system:user:edit']" | 
|---|
|  |  |  | ><span class="button-zx" | 
|---|
|  |  |  | ><i class="el-icon-s-order"></i>查看</span | 
|---|
|  |  |  | ></el-button | 
|---|
|  |  |  | 
|---|
|  |  |  | </el-table> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="Followuserinfos"> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-form ref="form" :model="form" label-width="120px"> | 
|---|
|  |  |  | <!-- 添加合并编辑对话框 --> | 
|---|
|  |  |  | <el-dialog | 
|---|
|  |  |  | title="合并编辑问卷" | 
|---|
|  |  |  | :visible.sync="mergeDialogVisible" | 
|---|
|  |  |  | width="80%" | 
|---|
|  |  |  | top="5vh" | 
|---|
|  |  |  | v-dialogDrag | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <MergeAndModify | 
|---|
|  |  |  | v-if="mergeDialogVisible" | 
|---|
|  |  |  | :selected-services="selectedServices" | 
|---|
|  |  |  | :patid="patid" | 
|---|
|  |  |  | @save="handleMergeSave" | 
|---|
|  |  |  | @cancel="mergeDialogVisible = false" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | </el-dialog> | 
|---|
|  |  |  | <div class="action-container"> | 
|---|
|  |  |  | <!-- 随访内容 --> | 
|---|
|  |  |  | <div class="call-action"> | 
|---|
|  |  |  | <div class="call-container"> | 
|---|
|  |  |  | <!-- <div class="call-header"> | 
|---|
|  |  |  | <h2>一键呼叫功能</h2> | 
|---|
|  |  |  | </div> --> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="headline"> | 
|---|
|  |  |  | <div>人工处理</div> | 
|---|
|  |  |  | <el-row :gutter="20"> | 
|---|
|  |  |  | <el-col :span="12" | 
|---|
|  |  |  | ><el-form-item label="联系电话"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | placeholder="联系电话缺失" | 
|---|
|  |  |  | v-model="userform.telcode" | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | <el-col :span="12" | 
|---|
|  |  |  | ><el-form-item label="联系人电话"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | placeholder="联系人电话缺失" | 
|---|
|  |  |  | v-model="userform.relativetelcode" | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <div style="margin-left: 30px"> | 
|---|
|  |  |  | <el-button type="primary" plain @click="Editsingletasksonyic('')" | 
|---|
|  |  |  | >保存服务</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div>随访内容</div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-tabs v-model="activeName" type="border-card"> | 
|---|
|  |  |  | <el-tab-pane name="wj"> | 
|---|
|  |  |  | <span class="mulsz" slot="label" | 
|---|
|  |  |  | ><i class="el-icon-notebook-1"></i> 问卷随访结果</span | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="CONTENT"> | 
|---|
|  |  |  | <div class="title">{{ taskname ? taskname : "问卷" }}</div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-form-item label="随访记录"> | 
|---|
|  |  |  | <el-input type="textarea" v-model="form.remark"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <div class="preview-left" v-if="!Voicetype"> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="topic-dev" | 
|---|
|  |  |  | v-for="(item, index) in tableDatatop" | 
|---|
|  |  |  | :key="item.id" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <!-- 单选 --> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | :class=" | 
|---|
|  |  |  | item.isabnormal | 
|---|
|  |  |  | ? 'scriptTopic-isabnormal' | 
|---|
|  |  |  | : 'scriptTopic-dev' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | :key="index" | 
|---|
|  |  |  | v-if="item.scriptType == 1 && !item.astrict" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[单选]<span>{{ | 
|---|
|  |  |  | item.scriptContent | 
|---|
|  |  |  | }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-radio-group | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | @change=" | 
|---|
|  |  |  | handleOptionChange( | 
|---|
|  |  |  | $event, | 
|---|
|  |  |  | index, | 
|---|
|  |  |  | item.svyTaskTemplateTargetoptions, | 
|---|
|  |  |  | item | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | " | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-radio | 
|---|
|  |  |  | v-for="( | 
|---|
|  |  |  | items, indexs | 
|---|
|  |  |  | ) in item.svyTaskTemplateTargetoptions" | 
|---|
|  |  |  | :class="items.isabnormal ? 'red-star' : ''" | 
|---|
|  |  |  | :key="indexs" | 
|---|
|  |  |  | :label="items.optioncontent" | 
|---|
|  |  |  | @click.native.prevent="handleRadioToggle(item, items.optioncontent)" | 
|---|
|  |  |  | >{{ items.optioncontent }}</el-radio | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-radio-group> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | v-if="item.showAppendInput || item.answerps" | 
|---|
|  |  |  | class="append-input-container" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :rows="2" | 
|---|
|  |  |  | placeholder="请输入具体信息" | 
|---|
|  |  |  | v-model="item.answerps" | 
|---|
|  |  |  | clearable | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div v-show="item.prompt"> | 
|---|
|  |  |  | <el-alert :title="item.prompt" type="warning"> | 
|---|
|  |  |  | </el-alert> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- 多选 --> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | :class=" | 
|---|
|  |  |  | item.isabnormal | 
|---|
|  |  |  | ? 'scriptTopic-isabnormal' | 
|---|
|  |  |  | : 'scriptTopic-dev' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | :key="index" | 
|---|
|  |  |  | v-if="item.scriptType == 2 && !item.astrict" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[多选]<span>{{ | 
|---|
|  |  |  | item.scriptContent | 
|---|
|  |  |  | }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-checkbox-group | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | @change="updateScore($event, index, item)" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-checkbox | 
|---|
|  |  |  | :class="items.isabnormal ? 'red-star' : ''" | 
|---|
|  |  |  | @change="$forceUpdate()" | 
|---|
|  |  |  | v-for="( | 
|---|
|  |  |  | items, indexs | 
|---|
|  |  |  | ) in item.svyTaskTemplateTargetoptions" | 
|---|
|  |  |  | :key="indexs" | 
|---|
|  |  |  | :label="items.optioncontent" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {{ items.optioncontent }} | 
|---|
|  |  |  | </el-checkbox> | 
|---|
|  |  |  | </el-checkbox-group> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div v-show="item.prompt && item.scriptResult[0]"> | 
|---|
|  |  |  | <el-alert :title="item.prompt" type="warning"> | 
|---|
|  |  |  | </el-alert> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- 填空 --> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="scriptTopic-dev" | 
|---|
|  |  |  | :key="index" | 
|---|
|  |  |  | v-if="item.scriptType == 4 && !item.astrict" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[问答]<span>{{ | 
|---|
|  |  |  | item.scriptContent | 
|---|
|  |  |  | }}</span> | 
|---|
|  |  |  | <span v-if="item.valueType == 3">(只能输入数字)</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx" v-if="item.valueType == 3"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="text" | 
|---|
|  |  |  | v-numeric-only | 
|---|
|  |  |  | placeholder="请输入答案" | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-input> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx" v-else> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :rows="2" | 
|---|
|  |  |  | placeholder="请输入答案" | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | clearable | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-input> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-form-item label="处理意见"> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-button plain type="warning" @click="Editsingletaskson('1')" | 
|---|
|  |  |  | >暂不处理</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button plain type="success" @click="Editsingletaskson('2')" | 
|---|
|  |  |  | >病情稳定</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button plain type="primary" @click="Editsingletaskson('3')" | 
|---|
|  |  |  | >通知就诊</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <!-- <el-button type="danger" @click="Editsingletaskson('4')" | 
|---|
|  |  |  | >失访</el-button | 
|---|
|  |  |  | > --> | 
|---|
|  |  |  | <el-button plain type="info" @click="Editsingletaskson('5')" | 
|---|
|  |  |  | >中心随访</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button type="primary" round @click="sendAgain()" | 
|---|
|  |  |  | >再次随访</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  | <el-collapse> | 
|---|
|  |  |  | <el-collapse-item title="查看当前患者信息" name="1"> | 
|---|
|  |  |  | <div class="preview-left" v-else> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="topic-dev" | 
|---|
|  |  |  | v-for="(item, index) in tableDatatop" | 
|---|
|  |  |  | :key="item.id" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div v-if="item.targetvalue"> | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[单选]<span>{{ | 
|---|
|  |  |  | item.questiontext | 
|---|
|  |  |  | }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-radio-group | 
|---|
|  |  |  | v-model="item.matchedtext" | 
|---|
|  |  |  | @change=" | 
|---|
|  |  |  | handleOptionChange( | 
|---|
|  |  |  | $event, | 
|---|
|  |  |  | index, | 
|---|
|  |  |  | item.ivrTaskScriptTargetoptionList, | 
|---|
|  |  |  | item | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | " | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-radio | 
|---|
|  |  |  | v-for="(items, index) in item.scriptResult" | 
|---|
|  |  |  | :key="items" | 
|---|
|  |  |  | :label="items" | 
|---|
|  |  |  | @click.native.prevent="handleRadioToggle(item, items.optioncontent)" | 
|---|
|  |  |  | >{{ items }}</el-radio | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-radio-group> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div v-show="item.prompt"> | 
|---|
|  |  |  | <el-alert :title="item.prompt" type="warning"> | 
|---|
|  |  |  | </el-alert> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="scriptTopic-dev" :key="index" v-else> | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[问答]<span>{{ | 
|---|
|  |  |  | item.scriptContent | 
|---|
|  |  |  | }}</span> | 
|---|
|  |  |  | <span v-if="item.valueType == 3">(只能输入数字)</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx" v-if="item.valueType == 3"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="text" | 
|---|
|  |  |  | v-numeric-only | 
|---|
|  |  |  | placeholder="请输入答案" | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-input> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx" v-else> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :rows="2" | 
|---|
|  |  |  | placeholder="请输入答案" | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | clearable | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-input> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | v-if="Voicetype" | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | @click="yuyingetdetail" | 
|---|
|  |  |  | >保存服务详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button v-else type="primary" @click="getdetail" | 
|---|
|  |  |  | >保存服务详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-tab-pane> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-tab-pane name="yy"> | 
|---|
|  |  |  | <span class="mulsz" slot="label" | 
|---|
|  |  |  | ><i class="el-icon-headset"></i> 语音随访详情</span | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="borderdiv"> | 
|---|
|  |  |  | <div class="title">{{ taskname ? taskname : "问卷" }}</div> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | style=" | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | text-align: center; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | color: #59a0f0; | 
|---|
|  |  |  | " | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 完整语音: | 
|---|
|  |  |  | <mini-audio | 
|---|
|  |  |  | :audio-source=" | 
|---|
|  |  |  | voice ? voice : '@assets/order/example.mp3' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | ></mini-audio> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="preview-left"> | 
|---|
|  |  |  | <div v-for="item in voiceDatatop"> | 
|---|
|  |  |  | <div class="leftside"> | 
|---|
|  |  |  | <i class="el-icon-phone-outline"></i | 
|---|
|  |  |  | ><span>{{ item.questiontext }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="offside"> | 
|---|
|  |  |  | <i class="el-icon-user"></i> | 
|---|
|  |  |  | <div class="offside-value"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :autosize="{ minRows: 1 }" | 
|---|
|  |  |  | v-model="item.asrtext" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <mini-audio | 
|---|
|  |  |  | :audio-source=" | 
|---|
|  |  |  | item.questionvoice | 
|---|
|  |  |  | ? item.questionvoice | 
|---|
|  |  |  | : '@assets/order/example.mp3' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | ></mini-audio> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | v-if="Voicetype" | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | @click="yuyingetdetail" | 
|---|
|  |  |  | >保存随访详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button v-else type="primary" @click="getdetail" | 
|---|
|  |  |  | >保存随访详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-tab-pane> | 
|---|
|  |  |  | </el-tabs> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- 人工处理 --> | 
|---|
|  |  |  | <div class="manual-action"> | 
|---|
|  |  |  | <div class="Followuserinfos"> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-form | 
|---|
|  |  |  | ref="userform" | 
|---|
|  |  |  | :model="form" | 
|---|
|  |  |  | :rules="userrules" | 
|---|
|  |  |  | label-width="120px" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="headline"> | 
|---|
|  |  |  | <div>人工处理</div> | 
|---|
|  |  |  | <div style="margin: 0 30px"> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | plain | 
|---|
|  |  |  | @click="Editsingletasksonyic('')" | 
|---|
|  |  |  | >保存基础信息</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | round | 
|---|
|  |  |  | v-if="this.form.isVisitAgain != 2" | 
|---|
|  |  |  | @click="sendAgain()" | 
|---|
|  |  |  | >再次随访</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="tag-selector-container"> | 
|---|
|  |  |  | <el-select | 
|---|
|  |  |  | v-model="selectedTag" | 
|---|
|  |  |  | placeholder="请选择异常状态" | 
|---|
|  |  |  | clearable | 
|---|
|  |  |  | style="width: 150px; margin-right: 10px" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-option | 
|---|
|  |  |  | v-for="item in tagOptions" | 
|---|
|  |  |  | :key="item.value" | 
|---|
|  |  |  | :label="item.label" | 
|---|
|  |  |  | :value="item.value" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <span style="display: flex; align-items: center"> | 
|---|
|  |  |  | <span | 
|---|
|  |  |  | class="color-indicator" | 
|---|
|  |  |  | :style="{ backgroundColor: item.color }" | 
|---|
|  |  |  | ></span> | 
|---|
|  |  |  | <span>{{ item.label }}</span> | 
|---|
|  |  |  | </span> | 
|---|
|  |  |  | </el-option> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!-- 当前选择的颜色指示器 --> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | v-if="selectedTag" | 
|---|
|  |  |  | class="color-indicator selected-indicator" | 
|---|
|  |  |  | :style="{ backgroundColor: getSelectedTagColor() }" | 
|---|
|  |  |  | ></div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!-- 标记说明提示 --> | 
|---|
|  |  |  | <el-tooltip | 
|---|
|  |  |  | v-if="selectedTag" | 
|---|
|  |  |  | effect="light" | 
|---|
|  |  |  | :content="getSelectedDescription()" | 
|---|
|  |  |  | placement="top" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <i class="el-icon-info tag-info-icon"></i> | 
|---|
|  |  |  | </el-tooltip> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <el-row> | 
|---|
|  |  |  | <el-col :span="14" | 
|---|
|  |  |  | ><el-form-item label="联系电话"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | placeholder="联系电话缺失" | 
|---|
|  |  |  | v-model="userform.telcode" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | slot="append" | 
|---|
|  |  |  | icon="el-icon-phone" | 
|---|
|  |  |  | @click="handleCall(userform.telcode, 'tel')" | 
|---|
|  |  |  | :disabled="!isValidPhone(userform.telcode)" | 
|---|
|  |  |  | ></el-button | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <el-row> | 
|---|
|  |  |  | <el-col :span="14" | 
|---|
|  |  |  | ><el-form-item label="联系人电话"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | placeholder="联系人电话缺失" | 
|---|
|  |  |  | v-model="userform.relativetelcode" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | slot="append" | 
|---|
|  |  |  | icon="el-icon-phone" | 
|---|
|  |  |  | @click=" | 
|---|
|  |  |  | handleCall(userform.relativetelcode, 'relative') | 
|---|
|  |  |  | " | 
|---|
|  |  |  | :disabled="!isValidPhone(userform.relativetelcode)" | 
|---|
|  |  |  | ></el-button | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | <el-col :span="10" | 
|---|
|  |  |  | ><el-form-item label="联系人关系"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | placeholder="联系人关系缺失" | 
|---|
|  |  |  | v-model="userform.relation" | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <div class="call-controls"> | 
|---|
|  |  |  | <CallButton | 
|---|
|  |  |  | ref="callButton" | 
|---|
|  |  |  | :phoneNumber="currentPhoneNumber" | 
|---|
|  |  |  | style="display: none" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div v-if="callStatus === 'connected'" class="hangup-btn"> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | type="danger" | 
|---|
|  |  |  | icon="el-icon-phone" | 
|---|
|  |  |  | @click="endCurrentCall" | 
|---|
|  |  |  | :loading="isEndingCall" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 挂断电话 | 
|---|
|  |  |  | </el-button> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="call-status" v-if="callStatus !== 'idle'"> | 
|---|
|  |  |  | <el-alert | 
|---|
|  |  |  | :title="callStatusText" | 
|---|
|  |  |  | :type="callStatusType" | 
|---|
|  |  |  | :closable="false" | 
|---|
|  |  |  | show-icon | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <el-form-item label="随访内容" v-if="orgname == '丽水市中医院'"> | 
|---|
|  |  |  | <el-input type="textarea" v-model="form.remark"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="随访记录" v-else> | 
|---|
|  |  |  | <el-input type="textarea" v-model="form.remark"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-form-item label="随访情况" v-if="orgname == '丽水市中医院'"> | 
|---|
|  |  |  | <el-radio-group v-model="form.taskSituation"> | 
|---|
|  |  |  | <el-radio | 
|---|
|  |  |  | v-for="city in cities" | 
|---|
|  |  |  | :label="city.value" | 
|---|
|  |  |  | :value="city.value" | 
|---|
|  |  |  | :key="city.value" | 
|---|
|  |  |  | >{{ city.label }}</el-radio | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-radio-group> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="处理意见"> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | plain | 
|---|
|  |  |  | type="warning" | 
|---|
|  |  |  | @click="Editsingletaskson('1')" | 
|---|
|  |  |  | >暂不处理</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | plain | 
|---|
|  |  |  | type="success" | 
|---|
|  |  |  | @click="Editsingletaskson('2')" | 
|---|
|  |  |  | >病情稳定</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button | 
|---|
|  |  |  | plain | 
|---|
|  |  |  | type="primary" | 
|---|
|  |  |  | @click="Editsingletaskson('3')" | 
|---|
|  |  |  | >通知就诊</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button plain type="info" @click="Editsingletaskson('5')" | 
|---|
|  |  |  | >中心随访</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button type="primary" round @click="sendAgainmsg" | 
|---|
|  |  |  | >短信发送</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="detailed"> | 
|---|
|  |  |  | <h3>患者档案信息</h3> | 
|---|
|  |  |  | <el-form ref="userform" :model="userform" label-width="100px"> | 
|---|
|  |  |  | <el-row :gutter="20"> | 
|---|
|  |  |  | <el-col :span="12"> | 
|---|
|  |  |  | 
|---|
|  |  |  | maxlength="30" | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <el-row :gutter="20"> | 
|---|
|  |  |  | <el-col :span="12" | 
|---|
|  |  |  | ><el-form-item label="性别" prop="telcode"> | 
|---|
|  |  |  | <el-select v-model="userform.sex" placeholder="请选择"> | 
|---|
|  |  |  | <el-option label="男" :value="1"> </el-option> | 
|---|
|  |  |  | <el-option label="女" :value="2"> </el-option> | 
|---|
|  |  |  | </el-select> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | <el-col :span="12"> | 
|---|
|  |  |  | <el-form-item label="年龄" prop="name"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | v-model="userform.age" | 
|---|
|  |  |  | placeholder="请输入姓名" | 
|---|
|  |  |  | maxlength="20" | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-row :gutter="20"> | 
|---|
|  |  |  | <el-col :span="12" | 
|---|
|  |  |  | ><el-form-item label="联系方式" prop="telcode"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | v-model="userform.telcode" | 
|---|
|  |  |  | placeholder="请输入联系方式" | 
|---|
|  |  |  | maxlength="30" | 
|---|
|  |  |  | maxlength="20" | 
|---|
|  |  |  | /> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | <el-col :span="12"> | 
|---|
|  |  |  | <el-form-item label="亲属联系方式" prop="name"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | v-model="userform.relativetelcode" | 
|---|
|  |  |  | placeholder="请输入姓名" | 
|---|
|  |  |  | maxlength="20" | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <el-row :gutter="20"> | 
|---|
|  |  |  | <el-col :span="24"> | 
|---|
|  |  |  | <el-form-item label="诊断名称" prop="name"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | v-model="form.leavediagname" | 
|---|
|  |  |  | placeholder="请输入诊断" | 
|---|
|  |  |  | maxlength="50" | 
|---|
|  |  |  | ></el-input> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <el-row :gutter="20"> | 
|---|
|  |  |  | 
|---|
|  |  |  | /> </el-form-item | 
|---|
|  |  |  | ></el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <!-- <el-row :gutter="20"> | 
|---|
|  |  |  | <el-col :span="24"> | 
|---|
|  |  |  | <el-form-item label="标签" prop="desc"> | 
|---|
|  |  |  | <div class="xinz-inf"> | 
|---|
|  |  |  | <el-tag | 
|---|
|  |  |  | :key="tag.tagname" | 
|---|
|  |  |  | type="success" | 
|---|
|  |  |  | v-for="tag in dynamicTags" | 
|---|
|  |  |  | :disable-transitions="false" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {{ tag.tagname }} | 
|---|
|  |  |  | </el-tag> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | </el-row> --> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-collapse-item> | 
|---|
|  |  |  | </el-collapse> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <el-tabs v-model="activeName" type="border-card"> | 
|---|
|  |  |  | <el-tab-pane name="wj"> | 
|---|
|  |  |  | <span class="mulsz" slot="label" | 
|---|
|  |  |  | ><i class="el-icon-notebook-1"></i> 问卷随访结果</span | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="CONTENT"> | 
|---|
|  |  |  | <div class="title">{{ taskname ? taskname : "问卷" }}</div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="preview-left" v-if="!Voicetype"> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="topic-dev" | 
|---|
|  |  |  | v-for="(item, index) in tableDatatop" | 
|---|
|  |  |  | :key="item.id" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <!-- 单选 --> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | :class=" | 
|---|
|  |  |  | item.isabnormal | 
|---|
|  |  |  | ? 'scriptTopic-isabnormal' | 
|---|
|  |  |  | : 'scriptTopic-dev' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | :key="index" | 
|---|
|  |  |  | v-if="item.scriptType == 1" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[单选]<span>{{ item.scriptContent }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-radio-group | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | @change="handleOptionChange($event, index, item)" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-radio | 
|---|
|  |  |  | v-for="( | 
|---|
|  |  |  | items, index | 
|---|
|  |  |  | ) in item.svyLibTemplateTargetoptions" | 
|---|
|  |  |  | :class="items.isabnormal ? 'red-star' : ''" | 
|---|
|  |  |  | :key="index" | 
|---|
|  |  |  | :label="items.optioncontent" | 
|---|
|  |  |  | >{{ items.optioncontent }}</el-radio | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-radio-group> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div v-show="item.prompt"> | 
|---|
|  |  |  | <el-alert :title="item.prompt" type="warning"> </el-alert> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- 多选 --> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | :class=" | 
|---|
|  |  |  | item.isabnormal | 
|---|
|  |  |  | ? 'scriptTopic-isabnormal' | 
|---|
|  |  |  | : 'scriptTopic-dev' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | :key="index" | 
|---|
|  |  |  | v-if="item.scriptType == 2" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[多选]<span>{{ item.scriptContent }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-checkbox-group | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | @change="updateScore($event, index, item)" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-checkbox | 
|---|
|  |  |  | :class="items.isabnormal ? 'red-star' : ''" | 
|---|
|  |  |  | @change="$forceUpdate()" | 
|---|
|  |  |  | v-for="( | 
|---|
|  |  |  | items, indexs | 
|---|
|  |  |  | ) in item.svyLibTemplateTargetoptions" | 
|---|
|  |  |  | :key="indexs" | 
|---|
|  |  |  | :label="items.optioncontent" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | {{ items.optioncontent }} | 
|---|
|  |  |  | </el-checkbox> | 
|---|
|  |  |  | </el-checkbox-group> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div v-show="item.prompt && item.scriptResult[0]"> | 
|---|
|  |  |  | <el-alert :title="item.prompt" type="warning"> </el-alert> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- 填空 --> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="scriptTopic-dev" | 
|---|
|  |  |  | :key="index" | 
|---|
|  |  |  | v-if="item.scriptType == 4" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[问答]<span>{{ item.scriptContent }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :rows="2" | 
|---|
|  |  |  | placeholder="请输入答案" | 
|---|
|  |  |  | v-model="item.scriptResult" | 
|---|
|  |  |  | clearable | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-input> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="preview-left" v-else> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | class="topic-dev" | 
|---|
|  |  |  | v-for="(item, index) in tableDatatop" | 
|---|
|  |  |  | :key="item.id" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div v-if="item.targetvalue"> | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[单选]<span>{{ item.questiontext }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-radio-group | 
|---|
|  |  |  | v-model="item.matchedtext" | 
|---|
|  |  |  | @change="handleOptionChange($event, index, item)" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-radio | 
|---|
|  |  |  | v-for="(items, index) in item.scriptResult" | 
|---|
|  |  |  | :key="items" | 
|---|
|  |  |  | :label="items" | 
|---|
|  |  |  | >{{ items }}</el-radio | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-radio-group> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div v-show="item.prompt"> | 
|---|
|  |  |  | <el-alert :title="item.prompt" type="warning"> </el-alert> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div class="scriptTopic-dev" :key="index" v-else> | 
|---|
|  |  |  | <div class="dev-text"> | 
|---|
|  |  |  | {{ index + 1 }}、[问答]<span>{{ item.questiontext }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="dev-xx"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :rows="2" | 
|---|
|  |  |  | placeholder="请输入答案" | 
|---|
|  |  |  | v-model="item.matchedtext" | 
|---|
|  |  |  | clearable | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-input> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <el-button v-if="Voicetype" type="primary" @click="yuyingetdetail" | 
|---|
|  |  |  | >保存服务详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button v-else type="primary" @click="getdetail" | 
|---|
|  |  |  | >保存服务详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-tab-pane> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-tab-pane name="yy"> | 
|---|
|  |  |  | <span class="mulsz" slot="label" | 
|---|
|  |  |  | ><i class="el-icon-headset"></i> 语音随访详情</span | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <div class="borderdiv"> | 
|---|
|  |  |  | <div class="title">{{ taskname ? taskname : "问卷" }}</div> | 
|---|
|  |  |  | <div | 
|---|
|  |  |  | style=" | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | text-align: center; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | color: #59a0f0; | 
|---|
|  |  |  | " | 
|---|
|  |  |  | > | 
|---|
|  |  |  | 完整语音: | 
|---|
|  |  |  | <mini-audio | 
|---|
|  |  |  | :audio-source=" | 
|---|
|  |  |  | voice ? voice : 'https://example.com/example.mp3' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | ></mini-audio> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="preview-left"> | 
|---|
|  |  |  | <div v-for="item in voiceDatatop"> | 
|---|
|  |  |  | <div class="leftside"> | 
|---|
|  |  |  | <i class="el-icon-phone-outline"></i | 
|---|
|  |  |  | ><span>{{ item.questiontext }}</span> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <div class="offside"> | 
|---|
|  |  |  | <i class="el-icon-user"></i> | 
|---|
|  |  |  | <div class="offside-value"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | :autosize="{ minRows: 1 }" | 
|---|
|  |  |  | v-model="item.asrtext" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <div> | 
|---|
|  |  |  | <mini-audio | 
|---|
|  |  |  | :audio-source=" | 
|---|
|  |  |  | item.questionvoice | 
|---|
|  |  |  | ? item.questionvoice | 
|---|
|  |  |  | : 'https://example.com/example.mp3' | 
|---|
|  |  |  | " | 
|---|
|  |  |  | ></mini-audio> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <el-button v-if="Voicetype" type="primary" @click="yuyingetdetail" | 
|---|
|  |  |  | >保存随访详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button v-else type="primary" @click="getdetail" | 
|---|
|  |  |  | >保存随访详情</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-tab-pane> | 
|---|
|  |  |  | </el-tabs> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | <!-- 短信发送对话框 --> | 
|---|
|  |  |  | <el-dialog title="短信发送" :visible.sync="smsDialogVisible"> | 
|---|
|  |  |  | <!-- 注意这里使用了 smsDialogVisible 以区分已有的 dialogFormVisible --> | 
|---|
|  |  |  | <el-form ref="smsForm" :model="form" label-width="80px"> | 
|---|
|  |  |  | <el-form-item label="患者名称"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | style="width: 400px" | 
|---|
|  |  |  | disabled | 
|---|
|  |  |  | v-model="form.sendname" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="年龄"> | 
|---|
|  |  |  | <el-input style="width: 400px" disabled v-model="form.age"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="电话"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | style="width: 400px" | 
|---|
|  |  |  | disabled | 
|---|
|  |  |  | v-model="userform.telcode" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | <!-- 注意这里可能使用 userform.telcode --> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="科室"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | style="width: 400px" | 
|---|
|  |  |  | disabled | 
|---|
|  |  |  | v-model="form.deptname" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="病区"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | style="width: 400px" | 
|---|
|  |  |  | disabled | 
|---|
|  |  |  | v-model="form.leavehospitaldistrictname" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <el-form-item label="短信内容"> | 
|---|
|  |  |  | <el-input type="textarea" v-model="smsContent"></el-input> | 
|---|
|  |  |  | <!-- 建议使用独立的 smsContent 变量 --> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  | <div slot="footer" class="dialog-footer"> | 
|---|
|  |  |  | <el-button @click="smsDialogVisible = false">取 消</el-button> | 
|---|
|  |  |  | <el-button type="primary" @click="sendSms">确认发送</el-button> | 
|---|
|  |  |  | <!-- 注意方法名改为 sendSms --> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-dialog> | 
|---|
|  |  |  | <el-dialog | 
|---|
|  |  |  | title="患者再次随访" | 
|---|
|  |  |  | v-dialogDrags | 
|---|
|  |  |  | 
|---|
|  |  |  | v-model="form.endtime" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <div class="headline">上次随访</div> | 
|---|
|  |  |  | <el-divider></el-divider> | 
|---|
|  |  |  | <el-row> | 
|---|
|  |  |  | <el-col :span="12"> | 
|---|
|  |  |  | <el-form-item label="随访方式"> | 
|---|
|  |  |  | <el-select | 
|---|
|  |  |  | v-model="form.visitType2" | 
|---|
|  |  |  | filterable | 
|---|
|  |  |  | allow-create | 
|---|
|  |  |  | default-first-option | 
|---|
|  |  |  | disabled | 
|---|
|  |  |  | placeholder="请选择随访方式" | 
|---|
|  |  |  | class="custom-disabled" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-option | 
|---|
|  |  |  | v-for="item in options" | 
|---|
|  |  |  | :key="item.value" | 
|---|
|  |  |  | :label="item.label" | 
|---|
|  |  |  | :value="item.value" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-option> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | <el-col :span="12"> | 
|---|
|  |  |  | <el-form-item label="随访时间"> | 
|---|
|  |  |  | <el-date-picker | 
|---|
|  |  |  | type="date" | 
|---|
|  |  |  | disabled | 
|---|
|  |  |  | placeholder="选择日期" | 
|---|
|  |  |  | :picker-options="pickerOptions" | 
|---|
|  |  |  | align="right" | 
|---|
|  |  |  | v-model="form.date2" | 
|---|
|  |  |  | class="custom-disabled" | 
|---|
|  |  |  | ></el-date-picker> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-form-item label="随访记录"> | 
|---|
|  |  |  | <el-input | 
|---|
|  |  |  | class="custom-disabled" | 
|---|
|  |  |  | type="textarea" | 
|---|
|  |  |  | disabled | 
|---|
|  |  |  | v-model="form.remark2" | 
|---|
|  |  |  | ></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <div class="headline">下次随访</div> | 
|---|
|  |  |  | <el-divider></el-divider> | 
|---|
|  |  |  | <el-row> | 
|---|
|  |  |  | <el-col :span="12"> | 
|---|
|  |  |  | <el-form-item label="随访方式" prop="date1"> | 
|---|
|  |  |  | <el-select | 
|---|
|  |  |  | v-model="form.visitType" | 
|---|
|  |  |  | filterable | 
|---|
|  |  |  | allow-create | 
|---|
|  |  |  | default-first-option | 
|---|
|  |  |  | @change="visitChange" | 
|---|
|  |  |  | placeholder="请选择随访方式(依出院时间技计算)" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-option | 
|---|
|  |  |  | v-for="item in options" | 
|---|
|  |  |  | :key="item.value" | 
|---|
|  |  |  | :label="item.label" | 
|---|
|  |  |  | :value="item.value" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | </el-option> | 
|---|
|  |  |  | </el-select> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | <el-col :span="12"> | 
|---|
|  |  |  | <el-form-item label="随访时间" prop="date1"> | 
|---|
|  |  |  | <el-date-picker | 
|---|
|  |  |  | type="date" | 
|---|
|  |  |  | placeholder="选择日期" | 
|---|
|  |  |  | :picker-options="pickerOptions" | 
|---|
|  |  |  | align="right" | 
|---|
|  |  |  | v-model="form.date1" | 
|---|
|  |  |  | class="custom-disabled" | 
|---|
|  |  |  | ></el-date-picker> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-col> | 
|---|
|  |  |  | </el-row> | 
|---|
|  |  |  | <el-form-item label="随访方式" prop="resource"> | 
|---|
|  |  |  | <el-radio-group v-model="form.resource"> | 
|---|
|  |  |  | <el-radio label="1">本病区随访</el-radio> | 
|---|
|  |  |  | <el-radio label="2">随访中心随访</el-radio> | 
|---|
|  |  |  | </el-radio-group> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | <!-- <el-form-item label="即刻发送"> | 
|---|
|  |  |  | <el-switch v-model="zcform.delivery"></el-switch> | 
|---|
|  |  |  | </el-form-item> --> | 
|---|
|  |  |  | <el-form-item label="随访时间" prop="date1"> | 
|---|
|  |  |  | <el-date-picker | 
|---|
|  |  |  | type="date" | 
|---|
|  |  |  | placeholder="选择日期" | 
|---|
|  |  |  | v-model="form.date1" | 
|---|
|  |  |  | style="width: 100%" | 
|---|
|  |  |  | ></el-date-picker> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <el-form-item label="随访记录"> | 
|---|
|  |  |  | <el-input type="textarea" v-model="form.remark"></el-input> | 
|---|
|  |  |  | </el-form-item> | 
|---|
|  |  |  | </el-form> | 
|---|
|  |  |  | <div slot="footer" class="dialog-footer"> | 
|---|
|  |  |  | <el-button @click="dialogFormVisible = false">取 消</el-button> | 
|---|
|  |  |  | <el-button type="warning" @click="dialogFormVisible = false" | 
|---|
|  |  |  | >取 消</el-button | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <el-button type="primary" @click="setupsubtask">确认创建服务</el-button> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </el-dialog> | 
|---|
|  |  |  | <div class="main-content" v-if="orgname == '景宁畲族自治县人民医院'"> | 
|---|
|  |  |  | <!-- <el-button @click="CaldialogVisible = true">打开弹框</el-button> --> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <!-- 弹框调用 --> | 
|---|
|  |  |  | <el-dialog | 
|---|
|  |  |  | title="呼叫功能框" | 
|---|
|  |  |  | :visible.sync="CaldialogVisible" | 
|---|
|  |  |  | width="60%" | 
|---|
|  |  |  | > | 
|---|
|  |  |  | <CallCenterLs | 
|---|
|  |  |  | ref="callCenterModal" | 
|---|
|  |  |  | :initial-phone="currentPhoneNumber" | 
|---|
|  |  |  | /> | 
|---|
|  |  |  | </el-dialog> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | serviceSubtaskDetailadd, | 
|---|
|  |  |  | updatePersonVoices, | 
|---|
|  |  |  | addPersonVoices, | 
|---|
|  |  |  | query360PatInfo, | 
|---|
|  |  |  | sendMsg, | 
|---|
|  |  |  | } from "@/api/AiCentre/index"; | 
|---|
|  |  |  | import { messagelistpatient, alterpatient } from "@/api/patient/homepage"; | 
|---|
|  |  |  | import { | 
|---|
|  |  |  | messagelistpatient, | 
|---|
|  |  |  | alterpatient, | 
|---|
|  |  |  | listcontactinformation, | 
|---|
|  |  |  | } from "@/api/patient/homepage"; | 
|---|
|  |  |  | import CallButton from "@/components/CallButton"; | 
|---|
|  |  |  | import MergeAndModify from "./MergeAndModify.vue"; | 
|---|
|  |  |  | import CallCenterLs from "@/components/CallCenterLs"; | 
|---|
|  |  |  | export default { | 
|---|
|  |  |  | components: { | 
|---|
|  |  |  | CallButton, | 
|---|
|  |  |  | MergeAndModify, | 
|---|
|  |  |  | CallCenterLs, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | directives: { | 
|---|
|  |  |  | numericOnly: { | 
|---|
|  |  |  | bind(el, binding, vnode) { | 
|---|
|  |  |  | // 尝试获取实际的input元素 | 
|---|
|  |  |  | const input = el.tagName === "INPUT" ? el : el.querySelector("input"); | 
|---|
|  |  |  | if (!input) { | 
|---|
|  |  |  | console.warn("v-numeric-only: 未找到input元素"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const handleInput = function (event) { | 
|---|
|  |  |  | const oldValue = input.value; | 
|---|
|  |  |  | const newValue = oldValue.replace(/[^\d]/g, ""); | 
|---|
|  |  |  | if (newValue !== oldValue) { | 
|---|
|  |  |  | input.value = newValue; | 
|---|
|  |  |  | // 触发input事件,通知v-model更新 | 
|---|
|  |  |  | input.dispatchEvent(new Event("input", { bubbles: true })); // 注意bubbles | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | const handlePaste = function (event) { | 
|---|
|  |  |  | event.preventDefault(); | 
|---|
|  |  |  | const clipboardData = event.clipboardData || window.clipboardData; | 
|---|
|  |  |  | const pastedData = clipboardData.getData("text"); | 
|---|
|  |  |  | const numericValue = pastedData.replace(/[^\d]/g, ""); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 模拟在光标位置插入纯数字文本 | 
|---|
|  |  |  | const start = input.selectionStart; | 
|---|
|  |  |  | const end = input.selectionEnd; | 
|---|
|  |  |  | input.value = | 
|---|
|  |  |  | input.value.substring(0, start) + | 
|---|
|  |  |  | numericValue + | 
|---|
|  |  |  | input.value.substring(end); | 
|---|
|  |  |  | // 调整光标位置 | 
|---|
|  |  |  | const newCursorPos = start + numericValue.length; | 
|---|
|  |  |  | input.setSelectionRange(newCursorPos, newCursorPos); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 触发input事件 | 
|---|
|  |  |  | input.dispatchEvent(new Event("input", { bubbles: true })); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | input.addEventListener("input", handleInput); | 
|---|
|  |  |  | input.addEventListener("paste", handlePaste); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 存储引用以便解绑 | 
|---|
|  |  |  | el._numericOnly = { | 
|---|
|  |  |  | inputHandle: handleInput, | 
|---|
|  |  |  | pasteHandle: handlePaste, | 
|---|
|  |  |  | inputEl: input, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | unbind(el) { | 
|---|
|  |  |  | if (el._numericOnly) { | 
|---|
|  |  |  | const { inputHandle, pasteHandle, inputEl } = el._numericOnly; | 
|---|
|  |  |  | inputEl.removeEventListener("input", inputHandle); | 
|---|
|  |  |  | inputEl.removeEventListener("paste", pasteHandle); | 
|---|
|  |  |  | delete el._numericOnly; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | dicts: ["sys_normal_disable", "sys_user_sex", "sys_yujing", "sys_suggest"], | 
|---|
|  |  |  | data() { | 
|---|
|  |  |  | const validatePhone = (rule, value, callback) => { | 
|---|
|  |  |  | if (!value) { | 
|---|
|  |  |  | return callback(new Error("请输入联系电话")); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | setTimeout(() => { | 
|---|
|  |  |  | if (!/^1[3-9]\d{9}$/.test(value)) { | 
|---|
|  |  |  | callback(new Error("请输入正确的11位手机号码")); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | callback(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, 300); | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | userid: "", | 
|---|
|  |  |  | currentPhoneNumber: "", | 
|---|
|  |  |  | callType: "", // 用于区分是哪个电话 | 
|---|
|  |  |  | // 已有数据... | 
|---|
|  |  |  | callStatus: "idle", // idle, calling, connected, ended, failed | 
|---|
|  |  |  | isEndingCall: false, | 
|---|
|  |  |  | CaldialogVisible: false, | 
|---|
|  |  |  | currentCall: null, // 当前通话对象 | 
|---|
|  |  |  | input: "今天身体还不错", | 
|---|
|  |  |  | radio: "2", | 
|---|
|  |  |  | taskname: "", | 
|---|
|  |  |  | activeName: "wj", | 
|---|
|  |  |  | voice: "", | 
|---|
|  |  |  | templateid: "", | 
|---|
|  |  |  | again: "", | 
|---|
|  |  |  | orgname: "", | 
|---|
|  |  |  | zcform: {}, | 
|---|
|  |  |  | form: {}, | 
|---|
|  |  |  | cities: [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: "正常语音", | 
|---|
|  |  |  | value: "1", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: "患者拒接或拒访", | 
|---|
|  |  |  | value: "2", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: "面访或者接诊", | 
|---|
|  |  |  | value: "3", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: "微信随访", | 
|---|
|  |  |  | value: "4", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: "随访电话不正确", | 
|---|
|  |  |  | value: "5", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | label: "其他情况不宜随访", | 
|---|
|  |  |  | value: "6", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | tableDatatop: [], //题目表 | 
|---|
|  |  |  | voiceDatatop: [], //题目表 | 
|---|
|  |  |  | dynamicTags: [], | 
|---|
|  |  |  | isMergeMode: false, | 
|---|
|  |  |  | mergeDialogVisible: false, | 
|---|
|  |  |  | selectedServices: [], // 选中的服务列表 | 
|---|
|  |  |  | selectedTag: "", | 
|---|
|  |  |  | tagOptions: [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "0", | 
|---|
|  |  |  | label: "正常", | 
|---|
|  |  |  | type: "normal", | 
|---|
|  |  |  | color: "#7ff5e1", | 
|---|
|  |  |  | description: "患者情况正常,无需特别关注", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "1", | 
|---|
|  |  |  | label: "异常", | 
|---|
|  |  |  | type: "abnormal", | 
|---|
|  |  |  | color: "#f75c5c", | 
|---|
|  |  |  | description: "患者存在异常情况,需要重点关注", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "2", | 
|---|
|  |  |  | label: "警告", | 
|---|
|  |  |  | type: "warning", | 
|---|
|  |  |  | color: "#fbfb4a", | 
|---|
|  |  |  | description: "患者情况需要警告注意,可能存在风险", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | zcrules: { | 
|---|
|  |  |  | date1: [ | 
|---|
|  |  |  | resource: [ | 
|---|
|  |  |  | { required: true, message: "请选择随访方式", trigger: "change" }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | resource: [ | 
|---|
|  |  |  | { required: true, message: "请选择随访时间", trigger: "blur" }, | 
|---|
|  |  |  | date1: [{ required: true, message: "请选择随访时间", trigger: "blur" }], | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | userrules: { | 
|---|
|  |  |  | telcode: [{ validator: validatePhone, trigger: "blur" }], | 
|---|
|  |  |  | relativetelcode: [{ validator: validatePhone, trigger: "blur" }], | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 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", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | pickerOptions: { | 
|---|
|  |  |  | disabledDate(time) { | 
|---|
|  |  |  | // 禁用今天及之前的日期 | 
|---|
|  |  |  | return time.getTime() < Date.now() - 24 * 60 * 60 * 1000; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | shortcuts: [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | text: "七天后", | 
|---|
|  |  |  | onClick(picker) { | 
|---|
|  |  |  | const date = new Date(); | 
|---|
|  |  |  | date.setTime(date.getTime() + 3600 * 1000 * 24 * 7); | 
|---|
|  |  |  | picker.$emit("pick", date); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | text: "15天后", | 
|---|
|  |  |  | onClick(picker) { | 
|---|
|  |  |  | const date = new Date(); | 
|---|
|  |  |  | date.setTime(date.getTime() + 3600 * 1000 * 24 * 15); | 
|---|
|  |  |  | picker.$emit("pick", date); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | text: "一个月后", | 
|---|
|  |  |  | onClick(picker) { | 
|---|
|  |  |  | const date = new Date(); | 
|---|
|  |  |  | date.setTime(date.getTime() + 3600 * 1000 * 24 * 30); | 
|---|
|  |  |  | picker.$emit("pick", date); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | text: "三个月后", | 
|---|
|  |  |  | onClick(picker) { | 
|---|
|  |  |  | const date = new Date(); | 
|---|
|  |  |  | date.setTime(date.getTime() + 3600 * 1000 * 24 * 90); | 
|---|
|  |  |  | picker.$emit("pick", date); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | text: "六个月后", | 
|---|
|  |  |  | onClick(picker) { | 
|---|
|  |  |  | const date = new Date(); | 
|---|
|  |  |  | date.setTime(date.getTime() + 3600 * 1000 * 24 * 180); | 
|---|
|  |  |  | picker.$emit("pick", date); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | text: "一年后", | 
|---|
|  |  |  | onClick(picker) { | 
|---|
|  |  |  | const date = new Date(); | 
|---|
|  |  |  | date.setTime(date.getTime() + 3600 * 1000 * 24 * 365); | 
|---|
|  |  |  | picker.$emit("pick", date); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | options: [ | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "七天后", | 
|---|
|  |  |  | label: "七天后", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "15天后", | 
|---|
|  |  |  | label: "15天后", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "一个月后", | 
|---|
|  |  |  | label: "一个月后", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "三个月后", | 
|---|
|  |  |  | label: "三个月后", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "六个月后", | 
|---|
|  |  |  | label: "六个月后", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | { | 
|---|
|  |  |  | value: "一年后", | 
|---|
|  |  |  | label: "一年后", | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | ], | 
|---|
|  |  |  | userform: {}, | 
|---|
|  |  |  | Whetherall: false, //是否全部记录展示 | 
|---|
|  |  |  | smsDialogVisible: false, // 控制短信对话框显示 | 
|---|
|  |  |  | smsContent: "", // 存储短信内容 | 
|---|
|  |  |  | Whetherall: true, //是否全部记录展示 | 
|---|
|  |  |  | dialogFormVisible: false, | 
|---|
|  |  |  | Voicetype: 0, //是否为语音服务 | 
|---|
|  |  |  | visitCount: null, | 
|---|
|  |  |  | logsheetlist: [], | 
|---|
|  |  |  | topicobj: {}, | 
|---|
|  |  |  | sendname: null, | 
|---|
|  |  |  | 
|---|
|  |  |  | patid: null, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | computed: { | 
|---|
|  |  |  | callStatusText() { | 
|---|
|  |  |  | const statusMap = { | 
|---|
|  |  |  | idle: "准备呼叫", | 
|---|
|  |  |  | calling: `正在呼叫 ${this.currentPhoneNumber}...`, | 
|---|
|  |  |  | connected: `已接通 ${this.currentPhoneNumber}`, | 
|---|
|  |  |  | ended: "通话已结束", | 
|---|
|  |  |  | failed: "呼叫失败", | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | return statusMap[this.callStatus]; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | callStatusType() { | 
|---|
|  |  |  | const typeMap = { | 
|---|
|  |  |  | idle: "info", | 
|---|
|  |  |  | calling: "warning", | 
|---|
|  |  |  | connected: "success", | 
|---|
|  |  |  | ended: "info", | 
|---|
|  |  |  | failed: "error", | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | return typeMap[this.callStatus]; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created() { | 
|---|
|  |  |  | this.taskid = this.$route.query.taskid; | 
|---|
|  |  |  | this.id = this.$route.query.id; | 
|---|
|  |  |  | this.sendname = this.$route.query.sendname; | 
|---|
|  |  |  | this.patid = this.$route.query.patid; | 
|---|
|  |  |  | this.again = this.$route.query.again; | 
|---|
|  |  |  | this.Voicetype = this.$route.query.Voicetype; | 
|---|
|  |  |  | this.visitCount = this.$route.query.visitCount; | 
|---|
|  |  |  | this.serviceType = this.$route.query.serviceType; | 
|---|
|  |  |  | console.log(this.id, this.patid); | 
|---|
|  |  |  | this.orgname = localStorage.getItem("orgname"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.getTaskservelist(this.id); | 
|---|
|  |  |  | this.getTaskservelist(); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | methods: { | 
|---|
|  |  |  | 
|---|
|  |  |  | isFinish: false, | 
|---|
|  |  |  | }).then((res) => { | 
|---|
|  |  |  | if (res.code === 200) { | 
|---|
|  |  |  | // 针对再次随访服务进行删除结果赋值 | 
|---|
|  |  |  | if (this.again && res.data.upScriptResult) { | 
|---|
|  |  |  | res.data.upScriptResult.forEach((itemA) => { | 
|---|
|  |  |  | const itemB = res.data.scriptResult.find( | 
|---|
|  |  |  | (item) => item.scriptContent === itemA.scriptContent | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if (itemB) { | 
|---|
|  |  |  | itemB.scriptResult = itemA.scriptResult; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.tableDatatop = res.data.scriptResult; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.tableDatatop.forEach((item) => { | 
|---|
|  |  |  | if (item.scriptType == 2) item.scriptResult = []; | 
|---|
|  |  |  | if (item.scriptResult && item.scriptType != 2) { | 
|---|
|  |  |  | if (item.scriptResultId && item.scriptType != 2) { | 
|---|
|  |  |  | item.isoption = 3; | 
|---|
|  |  |  | item.scriptResult = item.scriptResult; | 
|---|
|  |  |  | } else if (item.scriptResult && item.scriptType == 2) { | 
|---|
|  |  |  | } else if (item.scriptResultId && item.scriptType == 2) { | 
|---|
|  |  |  | item.scriptResult = item.scriptResult.split("&"); | 
|---|
|  |  |  | item.isoption = 3; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | //患者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查询无结果"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 获取基础信息 | 
|---|
|  |  |  | getuserinfo() { | 
|---|
|  |  |  | const queryParams = { | 
|---|
|  |  |  | pid: Number(this.patid), | 
|---|
|  |  |  | allhosp: "0", | 
|---|
|  |  |  | pageNum: 1, | 
|---|
|  |  |  | allhosp: "0", //1住院2门诊3体检4出院 | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | // 患者基础信息 | 
|---|
|  |  |  | messagelistpatient(queryParams).then((response) => { | 
|---|
|  |  |  | 
|---|
|  |  |  | // this.dynamicTags = response.rows[0].tagList.map(this.processElement); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | listcontactinformation({ patid: this.patid }).then((response) => { | 
|---|
|  |  |  | this.tableData = response.rows; | 
|---|
|  |  |  | if (this.tableData.length) { | 
|---|
|  |  |  | this.userform.relativetelcode = this.tableData[0].contactway; | 
|---|
|  |  |  | this.userform.relation = this.tableData[0].relation; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 再次随访时间选取 | 
|---|
|  |  |  | visitChange(value) { | 
|---|
|  |  |  | // 根据选择的随访方式设置时间 | 
|---|
|  |  |  | const now = new Date(); | 
|---|
|  |  |  | if (value.includes("七天后")) { | 
|---|
|  |  |  | this.form.date1 = new Date( | 
|---|
|  |  |  | Date.parse(this.form.endtime) + 3600 * 1000 * 24 * 7 | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } else if (value.includes("15天后")) { | 
|---|
|  |  |  | this.form.date1 = new Date( | 
|---|
|  |  |  | Date.parse(this.form.endtime) + 3600 * 1000 * 24 * 15 | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } else if (value.includes("一个月后")) { | 
|---|
|  |  |  | this.form.date1 = new Date( | 
|---|
|  |  |  | Date.parse(this.form.endtime) + 3600 * 1000 * 24 * 30 | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } else if (value.includes("三个月后")) { | 
|---|
|  |  |  | this.form.date1 = new Date( | 
|---|
|  |  |  | Date.parse(this.form.endtime) + 3600 * 1000 * 24 * 90 | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } else if (value.includes("六个月后")) { | 
|---|
|  |  |  | this.form.date1 = new Date( | 
|---|
|  |  |  | Date.parse(this.form.endtime) + 3600 * 1000 * 24 * 180 | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } else if (value.includes("一年后")) { | 
|---|
|  |  |  | this.form.date1 = new Date( | 
|---|
|  |  |  | Date.parse(this.form.endtime) + 3600 * 1000 * 24 * 365 | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 获取语音数据 | 
|---|
|  |  |  | getPersonVoices(id) { | 
|---|
|  |  |  | let obj = { | 
|---|
|  |  |  | 
|---|
|  |  |  | patid: this.patid, | 
|---|
|  |  |  | subId: id ? id : this.id, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | console.log(this.voiceDatatop, "111"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | getPersonVoices(obj).then((res) => { | 
|---|
|  |  |  | console.log("222"); | 
|---|
|  |  |  | if (res.code == 200) { | 
|---|
|  |  |  | this.voiceDatatop = res.data.serviceSubtaskDetails; | 
|---|
|  |  |  | this.voice = res.data.voice; | 
|---|
|  |  |  | 
|---|
|  |  |  | item.scriptResult = []; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | console.log(this.tableDatatop, "this.tableDatatop"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!this.tableDatatop.length) { | 
|---|
|  |  |  | this.puttaskid(this.templateid); | 
|---|
|  |  |  | 
|---|
|  |  |  | item.scriptResult = []; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | console.log(this.tableDatatop, "this.tableDatatop"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | 
|---|
|  |  |  | let excep = ""; | 
|---|
|  |  |  | const promises = []; | 
|---|
|  |  |  | this.tableDatatop.forEach((item) => { | 
|---|
|  |  |  | var objs = item.svyLibTemplateTargetoptions.find( | 
|---|
|  |  |  | if (item.valueType == 3 && item.scriptResult) { | 
|---|
|  |  |  | // 验证是否为有效数字 | 
|---|
|  |  |  | if (!/^\d+$/.test(item.scriptResult)) { | 
|---|
|  |  |  | this.$message.error(`问题 "${item.scriptContent}" 必须输入数字`); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | var objs = item.svyTaskTemplateTargetoptions.find( | 
|---|
|  |  |  | (items) => items.optioncontent == item.scriptResult | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if (obj) { | 
|---|
|  |  |  | 
|---|
|  |  |  | scriptid: item.id, | 
|---|
|  |  |  | excep: excep, | 
|---|
|  |  |  | questiontext: item.scriptContent, | 
|---|
|  |  |  | answerps: item.answerps || null, // 添加附加信息 | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | if (item.scriptType == 2 && item.scriptResult[0]) { | 
|---|
|  |  |  | obj.asrtext = item.scriptResult.join("&"); | 
|---|
|  |  |  | 
|---|
|  |  |  | promises.push(serviceSubtaskDetailadd(obj)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 使用 Promise.all 等待所有异步操作完成 | 
|---|
|  |  |  | Promise.all(promises) | 
|---|
|  |  |  | .then((results) => { | 
|---|
|  |  |  | 
|---|
|  |  |  | .confirm( | 
|---|
|  |  |  | '任务保存成功是否针对患者:"' + | 
|---|
|  |  |  | this.logsheetlist[0].sendname + | 
|---|
|  |  |  | '"再次随访?' | 
|---|
|  |  |  | '"再次随访?', | 
|---|
|  |  |  | "确认", | 
|---|
|  |  |  | { | 
|---|
|  |  |  | confirmButtonText: "确定", | 
|---|
|  |  |  | cancelButtonText: "取消", | 
|---|
|  |  |  | showCancelButton: true, | 
|---|
|  |  |  | dangerouslyUseHTMLString: true, | 
|---|
|  |  |  | confirmButtonClass: "custom-confirm-button", // 自定义确认按钮的类名 | 
|---|
|  |  |  | cancelButtonClass: "custom-cancel-button", // 自定义取消按钮的类名 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | .then(() => { | 
|---|
|  |  |  | document.querySelector("#app").scrollTo(0, 0); | 
|---|
|  |  |  | this.formtidy(); | 
|---|
|  |  |  | this.dialogFormVisible = true; | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(() => {}); | 
|---|
|  |  |  | .catch(() => { | 
|---|
|  |  |  | if (this.form.serviceType == 13) { | 
|---|
|  |  |  | if (this.visitCount != 1) { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/logisticsservice/zbAgain", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/logisticsservice/record", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if (this.form.serviceType == 2) { | 
|---|
|  |  |  | if (this.visitCount != 1) { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/logisticsservice/again", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/followvisit/discharge", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch((error) => { | 
|---|
|  |  |  | // 如果有任何一个异步操作失败,会进入这里 | 
|---|
|  |  |  | console.error("发生错误:", error); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 电话============================ | 
|---|
|  |  |  | // 验证电话号码格式并返回错误信息 | 
|---|
|  |  |  | validatePhoneNumber(phone) { | 
|---|
|  |  |  | if (!phone) { | 
|---|
|  |  |  | return { isValid: false, message: "请输入电话号码" }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 手机号正则 | 
|---|
|  |  |  | const mobileRegex = /^1[3-9]\d{9}$/; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 带区号的固定电话(完整格式) | 
|---|
|  |  |  | const landlineFullRegex = /^0\d{2,3}-?\d{7,8}$/; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 不带区号的固定电话(仅本地号码) | 
|---|
|  |  |  | const landlineLocalRegex = /^\d{7,8}$/; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (mobileRegex.test(phone)) { | 
|---|
|  |  |  | return { isValid: true, type: "mobile" }; | 
|---|
|  |  |  | } else if (landlineFullRegex.test(phone)) { | 
|---|
|  |  |  | return { isValid: true, type: "landline" }; | 
|---|
|  |  |  | } else if (landlineLocalRegex.test(phone)) { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | isValid: false, | 
|---|
|  |  |  | message: "本地号码请添加区号(如028-1234567)", | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | isValid: false, | 
|---|
|  |  |  | message: "请输入正确的电话号码(手机号或带区号的固定电话)", | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 使用示例 | 
|---|
|  |  |  | isValidPhone(phone) { | 
|---|
|  |  |  | return this.validatePhoneNumber(phone).isValid; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | handleCall(phone, type) { | 
|---|
|  |  |  | if (!this.isValidPhone(phone)) { | 
|---|
|  |  |  | this.$message.error("请输入正确的手机号码"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.currentPhoneNumber = phone; | 
|---|
|  |  |  | // 呼叫判断 | 
|---|
|  |  |  | if (this.orgname == "景宁畲族自治县人民医院") { | 
|---|
|  |  |  | this.CaldialogVisible = true; | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.callType = type; | 
|---|
|  |  |  | this.callStatus = "calling"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.$nextTick(() => { | 
|---|
|  |  |  | this.$refs.callButton.startCall(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 监听通话状态变化 | 
|---|
|  |  |  | this.$refs.callButton.$on("call-status-change", (status) => { | 
|---|
|  |  |  | this.handleCallStatusChange(status); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 处理通话状态变化 | 
|---|
|  |  |  | handleCallStatusChange(status) { | 
|---|
|  |  |  | console.log(status, "status"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.callStatus = status.type; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (status.type === "connected") { | 
|---|
|  |  |  | this.currentCall = { | 
|---|
|  |  |  | phone: this.currentPhoneNumber, | 
|---|
|  |  |  | type: this.callType, | 
|---|
|  |  |  | startTime: new Date(), | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | } else if (status.type === "ended" || status.type === "failed") { | 
|---|
|  |  |  | this.currentCall = null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 可以根据状态执行其他操作 | 
|---|
|  |  |  | if (status.type === "failed") { | 
|---|
|  |  |  | this.$message.error(`呼叫失败: ${status.text}`); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 结束当前通话 | 
|---|
|  |  |  | endCurrentCall() { | 
|---|
|  |  |  | if (!this.currentCall) return; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.isEndingCall = true; | 
|---|
|  |  |  | this.$refs.callButton.endCall(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 3秒后重置状态 | 
|---|
|  |  |  | setTimeout(() => { | 
|---|
|  |  |  | this.isEndingCall = false; | 
|---|
|  |  |  | }, 3000); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | yuyingetdetail() { | 
|---|
|  |  |  | this.tableDatatop.forEach((item, index) => { | 
|---|
|  |  |  | console.log(item.scriptResult, "scriptResult"); | 
|---|
|  |  |  | const dataToSubmit = JSON.parse(JSON.stringify(this.tableDatatop)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | dataToSubmit.forEach((item, index) => { | 
|---|
|  |  |  | // 对拷贝的数据进行操作,不影响原始的 scriptResult 数组 | 
|---|
|  |  |  | item.scriptResult = item.scriptResult.join("&"); | 
|---|
|  |  |  | item.templatequestionnum = index + 1; | 
|---|
|  |  |  | item.subId = this.id; | 
|---|
|  |  |  | 
|---|
|  |  |  | item.patid = this.patid; | 
|---|
|  |  |  | item.templateid = item.templateID; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | let obj = { | 
|---|
|  |  |  | serviceSubtaskDetailList: this.tableDatatop, | 
|---|
|  |  |  | serviceSubtaskDetailList: dataToSubmit, // 提交处理后的副本 | 
|---|
|  |  |  | param1: this.taskid, | 
|---|
|  |  |  | param2: this.patid, | 
|---|
|  |  |  | subId: this.id, | 
|---|
|  |  |  | 
|---|
|  |  |  | this.$modal.msgSuccess("服务保存成功"); | 
|---|
|  |  |  | this.$modal | 
|---|
|  |  |  | .confirm( | 
|---|
|  |  |  | '任务保存成功是否针对患者:"' + this.userform.name + '"再次随访?' | 
|---|
|  |  |  | '任务保存成功是否针对患者:"' + | 
|---|
|  |  |  | this.userform.name + | 
|---|
|  |  |  | '"再次随访?', | 
|---|
|  |  |  | "确认", | 
|---|
|  |  |  | { | 
|---|
|  |  |  | confirmButtonText: "确定", | 
|---|
|  |  |  | cancelButtonText: "取消", | 
|---|
|  |  |  | showCancelButton: true, | 
|---|
|  |  |  | dangerouslyUseHTMLString: true, | 
|---|
|  |  |  | confirmButtonClass: "custom-confirm-button", // 自定义确认按钮的类名 | 
|---|
|  |  |  | cancelButtonClass: "custom-cancel-button", // 自定义取消按钮的类名 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | .then(() => { | 
|---|
|  |  |  | document.querySelector("#app").scrollTo(0, 0); | 
|---|
|  |  |  | this.formtidy(); | 
|---|
|  |  |  | this.dialogFormVisible = true; | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(() => {}); | 
|---|
|  |  |  | .catch(() => { | 
|---|
|  |  |  | if (this.form.serviceType == 13) { | 
|---|
|  |  |  | if (this.visitCount != 1) { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/logisticsservice/zbAgain", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/logisticsservice/record", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if (form.serviceType == 2) { | 
|---|
|  |  |  | if (this.visitCount != 1) { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/followvisit/again", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/followvisit/discharge", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 再次随访数据更替 | 
|---|
|  |  |  | formtidy() { | 
|---|
|  |  |  | this.form.visitType2 = this.form.visitType; | 
|---|
|  |  |  | this.form.date2 = this.form.longSendTime; | 
|---|
|  |  |  | this.form.remark2 = this.form.remark; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 获取患者记录 | 
|---|
|  |  |  | getTaskservelist(id) { | 
|---|
|  |  |  | console.log(id, "idsub"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (id) { | 
|---|
|  |  |  | this.Whetherall = false; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | 
|---|
|  |  |  | getTaskservelist({ | 
|---|
|  |  |  | patid: this.patid, | 
|---|
|  |  |  | subId: id, | 
|---|
|  |  |  | pageSize: 100, | 
|---|
|  |  |  | }).then((res) => { | 
|---|
|  |  |  | if (res.code == 200) { | 
|---|
|  |  |  | this.form = res.rows[0].serviceSubtaskList[0]; | 
|---|
|  |  |  | this.form = res.rows[0].serviceSubtaskList.find( | 
|---|
|  |  |  | (item) => item.id == this.id | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | console.log(this.form, "serviceType"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.logsheetlist = res.rows[0].serviceSubtaskList; | 
|---|
|  |  |  | this.templateid = this.logsheetlist[0].templateid; | 
|---|
|  |  |  | this.templateid = this.form.templateid; | 
|---|
|  |  |  | this.selectedTag = this.form.excep; | 
|---|
|  |  |  | const targetDate = new Date(this.form.longSendTime); // 目标日期 | 
|---|
|  |  |  | const now = new Date(); // 当前时间 | 
|---|
|  |  |  | this.form.endtime = this.formatTime(this.form.endtime); | 
|---|
|  |  |  | if (now < targetDate && this.form.sendstate == 2) { | 
|---|
|  |  |  | this.$confirm("当前服务未到发送时间请谨慎修改", "提示", { | 
|---|
|  |  |  | confirmButtonText: "确定", | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.getuserinfo(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | console.log(this.Voicetype, "this.Voicetype"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (this.Voicetype) { | 
|---|
|  |  |  | this.getPersonVoices(); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.getsearchrResults(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 调起短信发送对话框 | 
|---|
|  |  |  | sendAgainmsg() { | 
|---|
|  |  |  | this.smsDialogVisible = true; | 
|---|
|  |  |  | // 可以在这里初始化 smsContent,例如 this.smsContent = ''; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 发送短信的方法 | 
|---|
|  |  |  | sendSms() { | 
|---|
|  |  |  | // 这里调用你的短信发送 API | 
|---|
|  |  |  | // 假设 API 为 sendMsg,参数可能需要根据实际情况调整 | 
|---|
|  |  |  | sendMsg({ | 
|---|
|  |  |  | phone: this.userform.telcode, // 确保电话号码字段正确 | 
|---|
|  |  |  | content: this.smsContent, | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .then((res) => { | 
|---|
|  |  |  | if (res.code == 200) { | 
|---|
|  |  |  | this.$modal.msgSuccess("发送成功"); | 
|---|
|  |  |  | this.smsDialogVisible = false; // 关闭对话框 | 
|---|
|  |  |  | this.smsContent = ""; // 清空内容 | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$modal.msgError("发送失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch((error) => { | 
|---|
|  |  |  | console.error("发送短信失败:", error); | 
|---|
|  |  |  | this.$modal.msgError("发送失败"); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | Editsingletaskson(son) { | 
|---|
|  |  |  | let objson = {}; | 
|---|
|  |  |  | 
|---|
|  |  |  | Editsingletaskson(objson).then((res) => { | 
|---|
|  |  |  | if (res.code) { | 
|---|
|  |  |  | this.$modal.msgSuccess("服务记录成功"); | 
|---|
|  |  |  | this.getTaskservelist(this.id); | 
|---|
|  |  |  | this.getTaskservelist(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | Editsingletasksonyic(sendstate) { | 
|---|
|  |  |  | console.log(sendstate, "sendstate"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | let objson = {}; | 
|---|
|  |  |  | getTaskservelist({ | 
|---|
|  |  |  | patid: this.patid, | 
|---|
|  |  |  | subId: this.id, | 
|---|
|  |  |  | }).then((res) => { | 
|---|
|  |  |  | if (res.code == 200) { | 
|---|
|  |  |  | objson = res.rows[0].serviceSubtaskList[0]; | 
|---|
|  |  |  | objson = res.rows[0].serviceSubtaskList.find( | 
|---|
|  |  |  | (item) => item.id == this.id | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | objson.remark = this.form.remark; | 
|---|
|  |  |  | objson.taskSituation = this.form.taskSituation; | 
|---|
|  |  |  | objson.excep = this.selectedTag; | 
|---|
|  |  |  | if (sendstate) objson.sendstate = sendstate; | 
|---|
|  |  |  | Editsingletaskson(objson).then((res) => { | 
|---|
|  |  |  | if (res.code) { | 
|---|
|  |  |  | 
|---|
|  |  |  | this.$modal.msgError("基础信息修改失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | this.getTaskservelist(this.id); | 
|---|
|  |  |  | this.getTaskservelist(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 异常列渲染 | 
|---|
|  |  |  | tableRowClassName({ row, rowIndex }) { | 
|---|
|  |  |  | if (row.id == this.id) { | 
|---|
|  |  |  | return "warning-row"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return ""; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getSelectedTagType() { | 
|---|
|  |  |  | if (!this.selectedTag) return ""; | 
|---|
|  |  |  | const tag = this.tagOptions.find( | 
|---|
|  |  |  | (item) => item.value === this.selectedTag | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | return tag ? tag.type : ""; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | getSelectedTagColor() { | 
|---|
|  |  |  | if (!this.selectedTag) return ""; | 
|---|
|  |  |  | const tag = this.tagOptions.find( | 
|---|
|  |  |  | (item) => item.value === this.selectedTag | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | return tag ? tag.color : ""; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | getSelectedDescription() { | 
|---|
|  |  |  | if (!this.selectedTag) return ""; | 
|---|
|  |  |  | const tag = this.tagOptions.find( | 
|---|
|  |  |  | (item) => item.value === this.selectedTag | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | return tag ? tag.description : ""; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 调起再次发送 | 
|---|
|  |  |  | sendAgain() { | 
|---|
|  |  |  | document.querySelector("#app").scrollTo(0, 0); | 
|---|
|  |  |  | document.querySelector("#app").scrollTo(0, 0); | 
|---|
|  |  |  | // scrollTo(0, 0) | 
|---|
|  |  |  | this.formtidy(); | 
|---|
|  |  |  | this.dialogFormVisible = true; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 查看详情 | 
|---|
|  |  |  | 
|---|
|  |  |  | this.Voicetype = 1; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | console.log(this.Voicetype, "this.Voicetype"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.taskid = row.taskid; | 
|---|
|  |  |  | this.id = row.id; | 
|---|
|  |  |  | this.patid = row.patid; | 
|---|
|  |  |  | this.serviceType = row.serviceType; | 
|---|
|  |  |  | this.getTaskservelist(this.id); | 
|---|
|  |  |  | this.getTaskservelist(); | 
|---|
|  |  |  | }) | 
|---|
|  |  |  | .catch(() => {}); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | handleOptionChange(a, b, c) { | 
|---|
|  |  |  | console.log(this.tableDatatop[b], "this.tableDatatop[b]"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | aahandleOptionChange(a, b, c) { | 
|---|
|  |  |  | const result = c.find((item) => item.optioncontent == a); | 
|---|
|  |  |  | if (result.nextQuestion == 0) { | 
|---|
|  |  |  | this.tableDatatop = this.tableDatatop.reduce((acc, item, i) => { | 
|---|
|  |  |  | acc.push(i > b ? { ...item, astrict: 1 } : item); | 
|---|
|  |  |  | return acc; | 
|---|
|  |  |  | }, []); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.tableDatatop = this.tableDatatop.reduce((acc, item, i) => { | 
|---|
|  |  |  | acc.push(i > b ? { ...item, astrict: 0 } : item); | 
|---|
|  |  |  | return acc; | 
|---|
|  |  |  | }, []); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (this.Voicetype) { | 
|---|
|  |  |  | var obj = this.tableDatatop[b].ivrTaskScriptTargetoptionList.find( | 
|---|
|  |  |  | (item) => item.optioncontent == a | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | var obj = this.tableDatatop[b].svyLibTemplateTargetoptions.find( | 
|---|
|  |  |  | var obj = this.tableDatatop[b].svyTaskTemplateTargetoptions.find( | 
|---|
|  |  |  | (item) => item.optioncontent == a | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.$forceUpdate(); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 新增的切换选中/取消选中方法 | 
|---|
|  |  |  | handleRadioToggle(questionItem, optionValue) { | 
|---|
|  |  |  | // 如果点击的是当前已选中的选项,则取消选中 | 
|---|
|  |  |  | if (questionItem.scriptResult === optionValue) { | 
|---|
|  |  |  | questionItem.scriptResult = ""; // 清空选中值 | 
|---|
|  |  |  | // 同时重置与选项相关的状态 | 
|---|
|  |  |  | questionItem.isabnormal = false; | 
|---|
|  |  |  | questionItem.showAppendInput = false; | 
|---|
|  |  |  | // 注意:取消选中时,我们通常不希望触发题目跳转逻辑,所以直接返回 | 
|---|
|  |  |  | // 如果需要,可以在这里添加取消选中后的特定逻辑,例如重置题目序列 | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 如果点击的是未选中的选项,则通过更改绑定值来触发原始的 handleOptionChange 方法 | 
|---|
|  |  |  | // 这里只需要改变 v-model 绑定的值,change事件会自动触发 | 
|---|
|  |  |  | questionItem.scriptResult = optionValue; | 
|---|
|  |  |  | // 后续的跳转等复杂逻辑会在 handleOptionChange 中正常执行 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // 在methods部分,修改handleOptionChange方法: | 
|---|
|  |  |  | handleOptionChange(selectedOption, questionIndex, options, a) { | 
|---|
|  |  |  | if (document.activeElement) { | 
|---|
|  |  |  | document.activeElement.blur(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 找到被选中的选项对象 | 
|---|
|  |  |  | const selectedOptionObj = options.find( | 
|---|
|  |  |  | (item) => item.optioncontent == selectedOption | 
|---|
|  |  |  | ); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 处理异常状态高亮 | 
|---|
|  |  |  | this.tableDatatop[questionIndex].isabnormal = | 
|---|
|  |  |  | !!selectedOptionObj.isabnormal; | 
|---|
|  |  |  | // 处理附加输入框显示 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.tableDatatop[questionIndex].showAppendInput = | 
|---|
|  |  |  | selectedOptionObj.appendflag == 1; | 
|---|
|  |  |  | console.log(this.tableDatatop); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // if (!this.tableDatatop[questionIndex].showAppendInput) { | 
|---|
|  |  |  | //   this.tableDatatop[questionIndex].answerps = ""; // 清除附加信息 | 
|---|
|  |  |  | // } | 
|---|
|  |  |  | // 保存当前题目之前已经隐藏的题目状态 | 
|---|
|  |  |  | const previouslyHiddenBeforeCurrent = this.tableDatatop | 
|---|
|  |  |  | .slice(0, questionIndex) | 
|---|
|  |  |  | .map((item, index) => (item.astrict ? index : -1)) | 
|---|
|  |  |  | .filter((index) => index !== -1); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 保存之前因nextQuestion=0而隐藏的题目范围 | 
|---|
|  |  |  | const previouslyHiddenByEnd = this.tableDatatop | 
|---|
|  |  |  | .map((item, index) => (item.hiddenByEnd ? index : -1)) | 
|---|
|  |  |  | .filter((index) => index !== -1); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 如果branchFlag为1,处理题目跳转 | 
|---|
|  |  |  | if (a.branchFlag == 1) { | 
|---|
|  |  |  | if (selectedOptionObj.nextQuestion == 0) { | 
|---|
|  |  |  | // 结束问答 - 隐藏后面所有题目并标记 | 
|---|
|  |  |  | this.tableDatatop = this.tableDatatop.map((item, index) => ({ | 
|---|
|  |  |  | ...item, | 
|---|
|  |  |  | astrict: index > questionIndex, | 
|---|
|  |  |  | hiddenByEnd: index > questionIndex, // 标记这些题目是被结束问答隐藏的 | 
|---|
|  |  |  | })); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 正常跳转逻辑 | 
|---|
|  |  |  | const nextQuestionIndex = selectedOptionObj.nextQuestion - 1; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.tableDatatop = this.tableDatatop.map((item, index) => { | 
|---|
|  |  |  | // 保留当前题目之前的隐藏状态 | 
|---|
|  |  |  | if (index < questionIndex) { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | ...item, | 
|---|
|  |  |  | astrict: previouslyHiddenBeforeCurrent.includes(index), | 
|---|
|  |  |  | hiddenByEnd: false, // 清除结束标记 | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 当前题目总是可见 | 
|---|
|  |  |  | if (index === questionIndex) { | 
|---|
|  |  |  | return { ...item, astrict: 0, hiddenByEnd: false }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 显示目标下一题 | 
|---|
|  |  |  | if (index === nextQuestionIndex) { | 
|---|
|  |  |  | return { ...item, astrict: 0, hiddenByEnd: false }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 如果是之前被结束问答隐藏的题目,现在应该恢复显示 | 
|---|
|  |  |  | if (item.hiddenByEnd) { | 
|---|
|  |  |  | return { ...item, astrict: 0, hiddenByEnd: false }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 隐藏当前题和目标题之间的题目 | 
|---|
|  |  |  | if (index > questionIndex && index < nextQuestionIndex) { | 
|---|
|  |  |  | return { ...item, astrict: 1, hiddenByEnd: false }; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 其他情况保持原状 | 
|---|
|  |  |  | return item; | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | // 如果没有跳转,只需确保下一题可见 | 
|---|
|  |  |  | this.tableDatatop = this.tableDatatop.map((item, index) => ({ | 
|---|
|  |  |  | ...item, | 
|---|
|  |  |  | astrict: index === questionIndex + 1 ? 0 : item.astrict, | 
|---|
|  |  |  | hiddenByEnd: index === questionIndex + 1 ? false : item.hiddenByEnd, | 
|---|
|  |  |  | })); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | this.$forceUpdate(); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | overdata() { | 
|---|
|  |  |  | this.tableDatatop.forEach((item, index) => { | 
|---|
|  |  |  | var obj = item.svyLibTemplateTargetoptions.find( | 
|---|
|  |  |  | var obj = item.svyTaskTemplateTargetoptions.find( | 
|---|
|  |  |  | (items) => items.optioncontent == item.scriptResult | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | if (obj) { | 
|---|
|  |  |  | 
|---|
|  |  |  | setupsubtask() { | 
|---|
|  |  |  | this.$refs["zcform"].validate((valid) => { | 
|---|
|  |  |  | if (valid) { | 
|---|
|  |  |  | if (this.form.date1 && new Date(this.form.date1) < new Date()) { | 
|---|
|  |  |  | this.$message.error("随访时间不能小于当前时间"); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.form.remark = | 
|---|
|  |  |  | this.form.remark + "【" + this.getCurrentTime() + "】"; | 
|---|
|  |  |  | let form = structuredClone(this.form); | 
|---|
|  |  |  | form.longSendTime = this.formatTime(form.date1); | 
|---|
|  |  |  | form.finishtime = ""; | 
|---|
|  |  |  | if (form.resource) { | 
|---|
|  |  |  | if (form.resource == 2) { | 
|---|
|  |  |  | form.serviceType = 10; | 
|---|
|  |  |  | form.visitDeptCode = localStorage.getItem("deptCode"); | 
|---|
|  |  |  | form.visitDeptName = "随访中心"; | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | form.visitDeptCode = form.deptcode; | 
|---|
|  |  |  | form.visitDeptName = form.deptname; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$modal.msgError("未选择随访方式"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | form.id = null; | 
|---|
|  |  |  | // form.id = null; | 
|---|
|  |  |  | form.sendstate = 2; | 
|---|
|  |  |  | console.log(form.serviceType, "form.serviceType"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | addserviceSubtask(form).then((res) => { | 
|---|
|  |  |  | if (res.code == 200) { | 
|---|
|  |  |  | this.$modal.msgSuccess("创建成功"); | 
|---|
|  |  |  | if (form.serviceType == 13) { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/logisticsservice/zbAgain", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } else if (form.serviceType == 2) { | 
|---|
|  |  |  | this.$router.push({ | 
|---|
|  |  |  | path: "/logisticsservice/again", | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$modal.msgError("创建失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | updateScore(a, b, c) { | 
|---|
|  |  |  | console.log(a); | 
|---|
|  |  |  | console.log(b); | 
|---|
|  |  |  | console.log(c); | 
|---|
|  |  |  | 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}`; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | updateScore(a, b, c) {}, | 
|---|
|  |  |  | // 合并修改相关============================= | 
|---|
|  |  |  | toggleMergeMode() { | 
|---|
|  |  |  | this.isMergeMode = !this.isMergeMode; | 
|---|
|  |  |  | if (!this.isMergeMode) { | 
|---|
|  |  |  | this.selectedServices = []; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | handleSelectionChange(selection) { | 
|---|
|  |  |  | this.selectedServices = selection | 
|---|
|  |  |  | .filter( | 
|---|
|  |  |  | (item) => !item.preachformson || !item.preachformson.includes("3") | 
|---|
|  |  |  | ) | 
|---|
|  |  |  | .map((item) => ({ | 
|---|
|  |  |  | id: item.id, | 
|---|
|  |  |  | taskid: item.taskid, | 
|---|
|  |  |  | taskName: item.taskName, | 
|---|
|  |  |  | sendname: item.sendname, | 
|---|
|  |  |  | })); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | checkSelectable(row, index) { | 
|---|
|  |  |  | // 当 sendstate 为 6 时不可选 | 
|---|
|  |  |  | return row.sendstate !== 6; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | openMergeDialog() { | 
|---|
|  |  |  | if (this.selectedServices.length < 2) { | 
|---|
|  |  |  | this.$message.warning("请至少选择2个问卷服务进行合并"); | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | this.mergeDialogVisible = true; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | handleMergeSave(mergedData) { | 
|---|
|  |  |  | // 处理合并保存逻辑 | 
|---|
|  |  |  | this.mergeDialogVisible = false; | 
|---|
|  |  |  | this.isMergeMode = false; | 
|---|
|  |  |  | this.selectedServices = []; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 显示保存结果 | 
|---|
|  |  |  | if (mergedData.successCount == mergedData.totalCount) { | 
|---|
|  |  |  | this.$message.success(`成功保存 ${mergedData.successCount} 个问卷`); | 
|---|
|  |  |  | } else if (mergedData.successCount > 0) { | 
|---|
|  |  |  | this.$message.warning( | 
|---|
|  |  |  | `成功保存 ${mergedData.successCount} 个问卷,失败 ${ | 
|---|
|  |  |  | mergedData.totalCount - mergedData.successCount | 
|---|
|  |  |  | } 个` | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | this.$message.error("所有问卷保存失败"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 刷新数据 | 
|---|
|  |  |  | this.getTaskservelist(); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // deactivated() { | 
|---|
|  |  |  | //   console.log(11); | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | beforeRouteLeave(to, from, next) { | 
|---|
|  |  |  | this.$refs.callButton.cleanupResources(); | 
|---|
|  |  |  | next(); // 确保调用 nex | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | // beforeRouteUpdate() { | 
|---|
|  |  |  | //   console.log(33); | 
|---|
|  |  |  | // }, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | </script> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <style lang="scss" scoped> | 
|---|
|  |  |  | .Followupdetailspage { | 
|---|
|  |  |  | margin: 10px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | flex-direction: column; | 
|---|
|  |  |  | gap: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .action-container { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | gap: 20px; | 
|---|
|  |  |  | margin: 0 10px 20px 10px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .manual-action { | 
|---|
|  |  |  | flex: 1; | 
|---|
|  |  |  | min-width: 0; | 
|---|
|  |  |  | height: 100%; /* 确保高度继承 */ | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .call-action { | 
|---|
|  |  |  | width: 60%; | 
|---|
|  |  |  | min-width: 0; | 
|---|
|  |  |  | height: 100%; /* 确保高度继承 */ | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .numeric-input { | 
|---|
|  |  |  | position: relative; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .numeric-input::after { | 
|---|
|  |  |  | content: "只能输入数字"; | 
|---|
|  |  |  | position: absolute; | 
|---|
|  |  |  | right: 8px; | 
|---|
|  |  |  | top: 50%; | 
|---|
|  |  |  | transform: translateY(-50%); | 
|---|
|  |  |  | font-size: 12px; | 
|---|
|  |  |  | color: #999; | 
|---|
|  |  |  | background: #f5f5f5; | 
|---|
|  |  |  | padding: 2px 6px; | 
|---|
|  |  |  | border-radius: 4px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .call-container { | 
|---|
|  |  |  | padding: 20px; | 
|---|
|  |  |  | background: #fff; | 
|---|
|  |  |  | border: 1px solid #dcdfe6; | 
|---|
|  |  |  | box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), 0 0 6px 0 rgba(0, 0, 0, 0.04); | 
|---|
|  |  |  | border-radius: 4px; | 
|---|
|  |  |  | height: 100%; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .call-header { | 
|---|
|  |  |  | margin-bottom: 20px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | h2 { | 
|---|
|  |  |  | font-size: 20px; | 
|---|
|  |  |  | color: #333; | 
|---|
|  |  |  | margin: 0; | 
|---|
|  |  |  | padding-bottom: 10px; | 
|---|
|  |  |  | border-bottom: 1px solid #eee; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .call-status { | 
|---|
|  |  |  | margin-bottom: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .hangup-btn { | 
|---|
|  |  |  | text-align: center; | 
|---|
|  |  |  | margin-top: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .merge-controls { | 
|---|
|  |  |  | background: #f5f7fa; | 
|---|
|  |  |  | border-radius: 4px; | 
|---|
|  |  |  | margin-left: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .Followuserinfo { | 
|---|
|  |  |  | margin: 20px 10px; | 
|---|
|  |  |  | margin: 10px 10px 0 10px; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | padding: 30px; | 
|---|
|  |  |  | background: #ffff; | 
|---|
|  |  |  | border: 1px solid #dcdfe6; | 
|---|
|  |  |  | -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), | 
|---|
|  |  |  | 0 0 6px 0 rgba(0, 0, 0, 0.04); | 
|---|
|  |  |  | box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), 0 0 6px 0 rgba(0, 0, 0, 0.04); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .userinfo-text { | 
|---|
|  |  |  | font-size: 20px; | 
|---|
|  |  |  | margin-right: 20px; | 
|---|
|  |  |  | margin-bottom: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .userinfo-value { | 
|---|
|  |  |  | color: rgb(15, 139, 211); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | span { | 
|---|
|  |  |  | margin-right: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ::v-deep.el-table .warning-row { | 
|---|
|  |  |  | background: #c4e2ee; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .Followuserinfos { | 
|---|
|  |  |  | margin: 20px 10px; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | padding: 30px; | 
|---|
|  |  |  | background: #ffff; | 
|---|
|  |  |  | border: 1px solid #dcdfe6; | 
|---|
|  |  |  | -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), | 
|---|
|  |  |  | 0 0 6px 0 rgba(0, 0, 0, 0.04); | 
|---|
|  |  |  | box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), 0 0 6px 0 rgba(0, 0, 0, 0.04); | 
|---|
|  |  |  | height: 100%; /* 确保高度继承 */ | 
|---|
|  |  |  | min-height: 880px; /* 最小高度与随访内容一致 */ | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | flex-direction: column; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .userinfo-text { | 
|---|
|  |  |  | font-size: 20px; | 
|---|
|  |  |  | margin-right: 20px; | 
|---|
|  |  |  | margin-bottom: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .userinfo-value { | 
|---|
|  |  |  | color: rgb(15, 139, 211); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | span { | 
|---|
|  |  |  | margin-right: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-form { | 
|---|
|  |  |  | flex: 1; | 
|---|
|  |  |  | overflow-y: auto; /* 内容超过高度时显示滚动条 */ | 
|---|
|  |  |  | max-height: calc(880px - 60px); /* 减去padding */ | 
|---|
|  |  |  | padding-right: 10px; /* 防止滚动条遮挡内容 */ | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .append-input-container { | 
|---|
|  |  |  | margin-top: 15px; | 
|---|
|  |  |  | padding: 10px; | 
|---|
|  |  |  | background-color: #f5f7fa; | 
|---|
|  |  |  | border-radius: 4px; | 
|---|
|  |  |  | border: 1px solid #dcdfe6; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .borderdiv { | 
|---|
|  |  |  | min-height: 60vh; | 
|---|
|  |  |  | font-size: 20px; | 
|---|
|  |  |  | padding: 30px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .title { | 
|---|
|  |  |  | font-size: 22px; | 
|---|
|  |  |  | font-weight: bold; | 
|---|
|  |  |  | margin-bottom: 20px; | 
|---|
|  |  |  | text-align: center; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .leftside { | 
|---|
|  |  |  | margin: 30px 0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | span { | 
|---|
|  |  |  | width: 400px; | 
|---|
|  |  |  | margin-left: 20px; | 
|---|
|  |  |  | 
|---|
|  |  |  | border-radius: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .offside { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | flex-direction: row-reverse; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .offside-value { | 
|---|
|  |  |  | padding: 10px; | 
|---|
|  |  |  | background: rgb(217, 173, 253); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .topic-dev[inert] { | 
|---|
|  |  |  | opacity: 0.5; | 
|---|
|  |  |  | pointer-events: none; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .CONTENT { | 
|---|
|  |  |  | padding: 10px; | 
|---|
|  |  |  | height: 100%; | 
|---|
|  |  |  | min-height: 660px; /* 设置最小高度 */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .title { | 
|---|
|  |  |  | font-size: 22px; | 
|---|
|  |  |  | font-weight: bold; | 
|---|
|  |  |  | 
|---|
|  |  |  | text-align: center; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .preview-left { | 
|---|
|  |  |  | margin: 20px; | 
|---|
|  |  |  | //   margin: 20px; | 
|---|
|  |  |  | padding: 30px; | 
|---|
|  |  |  | // background: #ffff; | 
|---|
|  |  |  | border: 1px solid #dcdfe6; | 
|---|
|  |  |  | -webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), | 
|---|
|  |  |  | 0 0 6px 0 rgba(0, 0, 0, 0.04); | 
|---|
|  |  |  | box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.12), 0 0 6px 0 rgba(0, 0, 0, 0.04); | 
|---|
|  |  |  | max-height: 580px; /* 设置最大高度 */ | 
|---|
|  |  |  | overflow-y: auto; /* 内容超过高度时显示滚动条 */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .topic-dev { | 
|---|
|  |  |  | margin-bottom: 25px; | 
|---|
|  |  |  | font-size: 20px !important; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .dev-text { | 
|---|
|  |  |  | margin-bottom: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .scriptTopic-isabnormal { | 
|---|
|  |  |  | color: red; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .detailed { | 
|---|
|  |  |  | width: 88%; | 
|---|
|  |  |  | border-radius: 8px; | 
|---|
|  |  |  | padding: 30px; | 
|---|
|  |  |  | margin-bottom: 30px; | 
|---|
|  |  |  | background-color: #ddf0f8; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .bg-purple { | 
|---|
|  |  |  | margin-bottom: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .spanvalue { | 
|---|
|  |  |  | display: inline-block; | 
|---|
|  |  |  | min-width: 200px; | 
|---|
|  |  |  | border-bottom: 1px solid rgb(172, 172, 172); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .headline { | 
|---|
|  |  |  | font-size: 24px; | 
|---|
|  |  |  | height: 40px; | 
|---|
|  |  |  | 
|---|
|  |  |  | padding-left: 5px; | 
|---|
|  |  |  | margin-bottom: 10px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | // justify-content: space-between; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .Add-details { | 
|---|
|  |  |  | font-size: 18px; | 
|---|
|  |  |  | color: #02a7f0; | 
|---|
|  |  |  | cursor: pointer; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .red-star { | 
|---|
|  |  |  | ::v-deep.el-radio__label { | 
|---|
|  |  |  | position: relative; | 
|---|
|  |  |  | padding-right: 10px; /* 根据需要调整 */ | 
|---|
|  |  |  | padding-right: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ::v-deep.el-radio__label::after { | 
|---|
|  |  |  | content: "*"; | 
|---|
|  |  |  | color: red; | 
|---|
|  |  |  | position: absolute; | 
|---|
|  |  |  | right: -5px; /* 根据需要调整 */ | 
|---|
|  |  |  | right: -5px; | 
|---|
|  |  |  | top: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ::v-deep.el-input-group__textarea { | 
|---|
|  |  |  | white-space: pre-wrap; /* 保持空白符序列并正常换行 */ | 
|---|
|  |  |  | word-break: break-all; /* 在长单词或URL地址内部进行换行 */ | 
|---|
|  |  |  | white-space: pre-wrap; | 
|---|
|  |  |  | word-break: break-all; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ::v-deep.el-checkbox__label { | 
|---|
|  |  |  | position: relative; | 
|---|
|  |  |  | padding-right: 10px; /* 根据需要调整 */ | 
|---|
|  |  |  | padding-right: 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ::v-deep.el-checkbox__label::after { | 
|---|
|  |  |  | content: "*"; | 
|---|
|  |  |  | color: red; | 
|---|
|  |  |  | position: absolute; | 
|---|
|  |  |  | right: -5px; /* 根据需要调整 */ | 
|---|
|  |  |  | right: -5px; | 
|---|
|  |  |  | top: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .tag-selector-container { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | margin: 0 30px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .color-indicator { | 
|---|
|  |  |  | width: 16px; | 
|---|
|  |  |  | height: 16px; | 
|---|
|  |  |  | border-radius: 3px; | 
|---|
|  |  |  | margin-right: 8px; | 
|---|
|  |  |  | display: inline-block; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .selected-indicator { | 
|---|
|  |  |  | margin-left: 10px; | 
|---|
|  |  |  | width: 20px; | 
|---|
|  |  |  | height: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .tag-info-icon { | 
|---|
|  |  |  | margin-left: 10px; | 
|---|
|  |  |  | color: #909399; | 
|---|
|  |  |  | cursor: pointer; | 
|---|
|  |  |  | font-size: 16px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 确保选择器选项中也显示颜色块 */ | 
|---|
|  |  |  | .el-select-dropdown__item { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .tag-normal { | 
|---|
|  |  |  | background-color: #7ff5e1; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .tag-abnormal { | 
|---|
|  |  |  | background-color: #f75c5c; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | .tag-warning { | 
|---|
|  |  |  | background-color: #fbfb4a; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .tag-info { | 
|---|
|  |  |  | margin-left: 10px; | 
|---|
|  |  |  | color: #909399; | 
|---|
|  |  |  | cursor: pointer; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ::v-deep.offside-value .el-radio__label { | 
|---|
|  |  |  | color: #fff; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ::v-deep.el-link.el-link--default { | 
|---|
|  |  |  | color: #02a7f0 !important; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-message-box__btns button:nth-child(2) { | 
|---|
|  |  |  | margin-left: 10px; | 
|---|
|  |  |  | background-color: #f57676; | 
|---|
|  |  |  | border-color: #f57676; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-icon-phone { | 
|---|
|  |  |  | transition: all 0.3s; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-button[disabled] .el-icon-phone { | 
|---|
|  |  |  | color: #c0c4cc; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-button:not([disabled]) .el-icon-phone { | 
|---|
|  |  |  | color: #409eff; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-button:not([disabled]):hover .el-icon-phone { | 
|---|
|  |  |  | color: #66b1ff; | 
|---|
|  |  |  | transform: scale(1.1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .mulsz { | 
|---|
|  |  |  | font-size: 25px; | 
|---|
|  |  |  | margin-top: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-input.is-disabled .el-input__inner { | 
|---|
|  |  |  | background-color: #fff; | 
|---|
|  |  |  | border-color: #dcdfe6; | 
|---|
|  |  |  | color: #080808 !important; | 
|---|
|  |  |  | cursor: not-allowed; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-textarea.is-disabled .el-textarea__inner { | 
|---|
|  |  |  | background-color: #fff; | 
|---|
|  |  |  | border-color: #dcdfe6; | 
|---|
|  |  |  | color: #080808 !important; | 
|---|
|  |  |  | cursor: not-allowed; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /* 原有的样式保持不变,添加以下响应式代码 */ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .Followupdetailspage { | 
|---|
|  |  |  | margin: 10px; | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | flex-direction: column; | 
|---|
|  |  |  | gap: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .action-container { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | flex-direction: row; /* 默认横向排列 */ | 
|---|
|  |  |  | gap: 20px; | 
|---|
|  |  |  | margin: 0 10px 20px 10px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 当缩放比例大于100%或屏幕宽度较小时改为上下排列 */ | 
|---|
|  |  |  | @media screen and (max-width: 1200px), (min-resolution: 1dppx) { | 
|---|
|  |  |  | flex-direction: column; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .call-action, | 
|---|
|  |  |  | .manual-action { | 
|---|
|  |  |  | width: 100% !important; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .call-action { | 
|---|
|  |  |  | width: 65%; | 
|---|
|  |  |  | min-width: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .manual-action { | 
|---|
|  |  |  | flex: 1; | 
|---|
|  |  |  | min-width: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整内部元素的响应式布局 */ | 
|---|
|  |  |  | .Followuserinfos { | 
|---|
|  |  |  | .el-form { | 
|---|
|  |  |  | /* 表单响应式调整 */ | 
|---|
|  |  |  | .el-row { | 
|---|
|  |  |  | margin: 0 -10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-col { | 
|---|
|  |  |  | padding: 0 10px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @media screen and (max-width: 768px) { | 
|---|
|  |  |  | .el-col { | 
|---|
|  |  |  | width: 100%; | 
|---|
|  |  |  | margin-bottom: 15px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | &:last-child { | 
|---|
|  |  |  | margin-bottom: 0; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整表格的响应式表现 */ | 
|---|
|  |  |  | .el-table { | 
|---|
|  |  |  | ::v-deep .el-table__body-wrapper { | 
|---|
|  |  |  | overflow-x: auto; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 在小屏幕上调整表格列宽 */ | 
|---|
|  |  |  | @media screen and (max-width: 992px) { | 
|---|
|  |  |  | .el-table-column { | 
|---|
|  |  |  | min-width: 120px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整标签选择器的响应式布局 */ | 
|---|
|  |  |  | .tag-selector-container { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | align-items: center; | 
|---|
|  |  |  | flex-wrap: wrap; | 
|---|
|  |  |  | gap: 10px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @media screen and (max-width: 576px) { | 
|---|
|  |  |  | flex-direction: column; | 
|---|
|  |  |  | align-items: flex-start; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-select { | 
|---|
|  |  |  | width: 100%; | 
|---|
|  |  |  | margin-right: 0 !important; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整按钮组的响应式布局 */ | 
|---|
|  |  |  | .el-form-item.label-processing-opinion { | 
|---|
|  |  |  | .el-button-group { | 
|---|
|  |  |  | display: flex; | 
|---|
|  |  |  | flex-wrap: wrap; | 
|---|
|  |  |  | gap: 10px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-button { | 
|---|
|  |  |  | flex: 1; | 
|---|
|  |  |  | min-width: 120px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整选项卡的响应式表现 */ | 
|---|
|  |  |  | .el-tabs { | 
|---|
|  |  |  | ::v-deep .el-tabs__nav-wrap { | 
|---|
|  |  |  | overflow-x: auto; | 
|---|
|  |  |  | white-space: nowrap; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | &::after { | 
|---|
|  |  |  | display: none; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整预览区域的响应式表现 */ | 
|---|
|  |  |  | .preview-left { | 
|---|
|  |  |  | @media screen and (max-width: 768px) { | 
|---|
|  |  |  | margin: 10px; | 
|---|
|  |  |  | padding: 15px; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .topic-dev, | 
|---|
|  |  |  | .scriptTopic-dev { | 
|---|
|  |  |  | margin-bottom: 15px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整对话框的响应式表现 */ | 
|---|
|  |  |  | .el-dialog { | 
|---|
|  |  |  | @media screen and (max-width: 992px) { | 
|---|
|  |  |  | width: 90% !important; | 
|---|
|  |  |  | margin-top: 5vh !important; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-dialog__body { | 
|---|
|  |  |  | padding: 15px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @media screen and (max-width: 576px) { | 
|---|
|  |  |  | width: 95% !important; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .el-form-item { | 
|---|
|  |  |  | margin-bottom: 15px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 确保内容在缩放时保持可读性 */ | 
|---|
|  |  |  | .headline { | 
|---|
|  |  |  | font-size: clamp(18px, 2vw, 24px); /* 使用clamp函数确保字体大小在合理范围内 */ | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 为移动设备优化滚动体验 */ | 
|---|
|  |  |  | @media screen and (max-width: 768px) { | 
|---|
|  |  |  | .Followuserinfo, | 
|---|
|  |  |  | .Followuserinfos { | 
|---|
|  |  |  | padding: 15px; | 
|---|
|  |  |  | margin: 5px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .CONTENT { | 
|---|
|  |  |  | min-height: auto; | 
|---|
|  |  |  | padding: 5px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 缩放检测样式 */ | 
|---|
|  |  |  | @media screen and (min-resolution: 1.1dppx), | 
|---|
|  |  |  | screen and (-webkit-min-device-pixel-ratio: 1.1), | 
|---|
|  |  |  | screen and (max-width: 1200px) { | 
|---|
|  |  |  | .action-container { | 
|---|
|  |  |  | flex-direction: column; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | .call-action, | 
|---|
|  |  |  | .manual-action { | 
|---|
|  |  |  | width: 100%; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /* 调整内部元素间距 */ | 
|---|
|  |  |  | .call-container, | 
|---|
|  |  |  | .Followuserinfos { | 
|---|
|  |  |  | margin-bottom: 20px; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | </style> | 
|---|