| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  | <!-- | 
					
						
							|  |  |  |  * @Author: SunTao 328867980@qq.com | 
					
						
							|  |  |  |  * @Date: 2024-10-14 09:48:43 | 
					
						
							|  |  |  |  * @LastEditors: SunTao 328867980@qq.com | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |  * @LastEditTime: 2024-12-05 16:27:28 | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |  * @FilePath: \znxjxt-ui\src\views\xj\inspection\task-management\index.vue | 
					
						
							|  |  |  |  * @Description: 巡检管理-巡检任务 | 
					
						
							|  |  |  | --> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <template> | 
					
						
							|  |  |  |   <div class="app-container"> | 
					
						
							|  |  |  |     <!-- 搜索表单 --> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" label-width="100px"> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       <el-form-item label="任务id" prop="taskId"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |         <el-autocomplete v-model="queryParams.taskId" :fetch-suggestions="querySearchAsync" placeholder="请输入任务id"
 | 
					
						
							|  |  |  |           @select="handleSelect"></el-autocomplete> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       <el-form-item label="车牌号码" prop="plateNo"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |         <el-input v-model="queryParams.plateNo" placeholder="请输入车牌号码" clearable=""></el-input> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       <el-form-item label="巡检路段" prop="segmentId"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |         <el-select v-model="queryParams.segmentId" placeholder="请选择巡检路段" clearable> | 
					
						
							|  |  |  |           <el-option v-for="item in segmentList" :key="item.value" :label="item.label" :value="item.value" /> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |         </el-select> | 
					
						
							|  |  |  |       </el-form-item> | 
					
						
							|  |  |  |       <el-form-item label="巡检时间" prop="dateTime"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |         <el-date-picker v-model="dateTime" type="daterange" start-placeholder="开始日期" end-placeholder="结束日期"
 | 
					
						
							|  |  |  |           format="yyyy-MM-dd" value-format="yyyy-MM-dd" clearable /> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       </el-form-item> | 
					
						
							|  |  |  |       <el-form-item> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |         <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> | 
					
						
							|  |  |  |         <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       </el-form-item> | 
					
						
							|  |  |  |     </el-form> | 
					
						
							|  |  |  |     <!-- 列表 --> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |     <el-table ref="roadTable" :data="roadList" @selection-change="handleSelectionChange" | 
					
						
							|  |  |  |       style="width: 100%"> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       <el-table-column type="selection" width="55" align="center" /> | 
					
						
							|  |  |  |       <el-table-column label="巡检路段" align="center" prop="segmentName" /> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       <el-table-column label="巡检路段编码" align="center" prop="segmentCode"> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       </el-table-column> | 
					
						
							|  |  |  |       <el-table-column label="巡检开始时间" align="center" prop="startTime"> | 
					
						
							|  |  |  |         <template slot-scope="scope"> | 
					
						
							|  |  |  |           <span>{{ | 
					
						
							|  |  |  |             scope.row.startTime | 
					
						
							|  |  |  |               ? new Date(scope.row.startTime).toLocaleString() | 
					
						
							|  |  |  |               : "" | 
					
						
							|  |  |  |           }}</span> | 
					
						
							|  |  |  |         </template> | 
					
						
							|  |  |  |       </el-table-column> | 
					
						
							|  |  |  |       <el-table-column label="巡检起点" align="center" prop="stakeStart" /> | 
					
						
							|  |  |  |       <el-table-column label="巡检终点" align="center" prop="stakeEnd" /> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       <el-table-column label="车牌号码" align="center" prop="plateNo"> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       </el-table-column> | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       <el-table-column label="任务id" align="center" prop="extId" /> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |       <el-table-column label="操作" align="center" class-name="small-padding fixed-width"> | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |         <template slot-scope="scope"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |           <el-button size="mini" type="text" icon="el-icon-view" @click="viewDefect(scope.row)">查看 | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |           <el-button size="mini" type="text" icon="el-icon-refresh-right" @click="handleRetrace(scope.row)">回顾 | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |           <el-button style="margin-left: 0.5rem;" size="mini" type="text" icon="el-icon-download" | 
					
						
							|  |  |  |             @click="handelExpport(scope.row)">导出</el-button> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |         </template> | 
					
						
							|  |  |  |       </el-table-column> | 
					
						
							|  |  |  |     </el-table> | 
					
						
							|  |  |  |     <!-- 分页组件 --> | 
					
						
							|  |  |  |     <div class="pagination-part"> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |       <el-pagination background :current-page.sync="pagination.page" @current-change="handleCurrentChange" | 
					
						
							|  |  |  |         :page-sizes="[10, 20, 30, 40]" :page-size.sync="pagination.size" @size-change="handleSizeChange" | 
					
						
							|  |  |  |         layout="total, sizes, prev, pager, next, jumper" :total="tableTotal"> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       </el-pagination> | 
					
						
							|  |  |  |     </div> | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |     <!-- 查看新增病害弹窗 --> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |     <el-dialog title="查看新增病害" :visible.sync="viewVisible" width="80rem" append-to-body :close-on-click-modal="false" | 
					
						
							|  |  |  |       destroy-on-close @close="viewCancel"> | 
					
						
							|  |  |  |       <task-view v-if="viewVisible" @cancel="viewCancel" :dialogItem="dialogItem"
 | 
					
						
							|  |  |  |         :defectCascaderList="defectCascaderList"></task-view> | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |       <!-- <task-retrace | 
					
						
							|  |  |  |         v-if="viewVisible" | 
					
						
							|  |  |  |         @cancel="viewCancel" | 
					
						
							|  |  |  |         :dialogItem="dialogItem" | 
					
						
							|  |  |  |       ></task-retrace> --> | 
					
						
							|  |  |  |     </el-dialog> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <!-- 回顾巡检任务弹窗 --> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |     <el-dialog title="回顾任务" fullscreen :visible.sync="retraceVisible" width="80rem" append-to-body | 
					
						
							|  |  |  |       :close-on-click-modal="false" destroy-on-close @close="retraceCancel" class="retrace-dialog"> | 
					
						
							|  |  |  |       <task-retrace v-if="retraceVisible" @cancel="retraceCancel" :dialogItem="dialogItem"></task-retrace> | 
					
						
							|  |  |  |     </el-dialog> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     <!-- 导出数据弹窗 --> | 
					
						
							|  |  |  |     <el-dialog title="导出" :visible.sync="exportVisible" width="30rem" append-to-body :close-on-click-modal="false" | 
					
						
							|  |  |  |       destroy-on-close @close="exportCancel"> | 
					
						
							|  |  |  |       <template> | 
					
						
							|  |  |  |         <div style="font-size: 1.5rem;"> | 
					
						
							|  |  |  |           导出是否附带图片 | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |         <div class="dialog-footer"> | 
					
						
							|  |  |  |           <el-button type="primary" @click="submitForm(true)">确 定</el-button> | 
					
						
							|  |  |  |           <el-button @click="submitForm(false)">取 消</el-button> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  |       </template> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     </el-dialog> | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  | <script> | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  | import { Loading } from "element-ui"; | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | import TaskRetrace from "./components/task-retrace.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  | import TaskView from "./components/task-view.vue"; | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  | import { | 
					
						
							|  |  |  |   getTaskTable, | 
					
						
							|  |  |  |   getSegment, | 
					
						
							|  |  |  |   getRoadType, | 
					
						
							|  |  |  |   getTaskIdList, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |   getDefectList, | 
					
						
							| 
									
										
										
										
											2024-12-03 13:42:21 +08:00
										 |  |  |   exportDefectData, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  | } from "@/api/xj/task"; | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |   components: { TaskRetrace, TaskView }, | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |   data() { | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       // 查询表单
 | 
					
						
							|  |  |  |       queryParams: { | 
					
						
							|  |  |  |         // 任务id
 | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |         taskId: "", | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |         // 车牌号码
 | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |         plateNo: "", | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |         // 巡检路段
 | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |         segmentId: "", | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       }, | 
					
						
							|  |  |  |       // 巡检时间
 | 
					
						
							|  |  |  |       dateTime: [], | 
					
						
							|  |  |  |       // 传查询接口表单
 | 
					
						
							|  |  |  |       searchForm: {}, | 
					
						
							|  |  |  |       // 巡检路段下拉
 | 
					
						
							|  |  |  |       segmentList: [], | 
					
						
							|  |  |  |       // 路产类型下拉
 | 
					
						
							|  |  |  |       roadType: [], | 
					
						
							|  |  |  |       // 列表数据绑定
 | 
					
						
							|  |  |  |       roadList: [], | 
					
						
							|  |  |  |       // 列表已选数组
 | 
					
						
							|  |  |  |       checkIds: [], | 
					
						
							|  |  |  |       // 非单个禁用
 | 
					
						
							|  |  |  |       single: true, | 
					
						
							|  |  |  |       // 非多个禁用
 | 
					
						
							|  |  |  |       multiple: true, | 
					
						
							|  |  |  |       // 分页-列表总数
 | 
					
						
							|  |  |  |       tableTotal: 0, | 
					
						
							|  |  |  |       // 分页-页数页码
 | 
					
						
							|  |  |  |       pagination: { | 
					
						
							|  |  |  |         page: 1, | 
					
						
							|  |  |  |         size: 10, | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       // 传弹窗的数据
 | 
					
						
							|  |  |  |       dialogItem: {}, | 
					
						
							|  |  |  |       // 查看弹窗显隐控制
 | 
					
						
							|  |  |  |       viewVisible: false, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |       // 回顾弹窗显隐控制
 | 
					
						
							|  |  |  |       retraceVisible: false, | 
					
						
							|  |  |  |       // 病害类型下拉
 | 
					
						
							|  |  |  |       defectCascaderList: [], | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |       // 导出弹窗显隐控制
 | 
					
						
							|  |  |  |       exportVisible: false, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     }; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   created() { | 
					
						
							|  |  |  |     this.getTaskList(); | 
					
						
							|  |  |  |     this.getSegmentList(); | 
					
						
							|  |  |  |     this.getRoadTypeList(); | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |     this.getDefectCascaderList(); | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @description: 获取病害类型下拉数据 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							| 
									
										
										
										
											2024-12-03 13:42:21 +08:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |     getDefectCascaderList() { | 
					
						
							|  |  |  |       getDefectList().then(({ code, data }) => { | 
					
						
							|  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |           this.defectCascaderList = data; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 任务id远程搜索 结果 | 
					
						
							|  |  |  |      * @param {*} item | 
					
						
							|  |  |  |      * @param {*} cb | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |     querySearchAsync(item, cb) { | 
					
						
							|  |  |  |       getTaskIdList({ name: item }).then(({ data, code }) => { | 
					
						
							|  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |           let list = []; | 
					
						
							|  |  |  |           data.map((item) => { | 
					
						
							|  |  |  |             list.push({ | 
					
						
							|  |  |  |               value: item.label, | 
					
						
							|  |  |  |               id: item.value, | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  |           }); | 
					
						
							|  |  |  |           cb(list); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 任务id选择事件 | 
					
						
							|  |  |  |      * @param {*} | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |     handleSelect() { }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 获取巡检路段下拉数据 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     getSegmentList() { | 
					
						
							|  |  |  |       getSegment().then(({ code, data }) => { | 
					
						
							|  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |           this.segmentList = data; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 获取路产类型下拉数据 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     getRoadTypeList() { | 
					
						
							|  |  |  |       getRoadType().then(({ code, data }) => { | 
					
						
							|  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |           this.roadType = data; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 点击搜索事件 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     handleQuery() { | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       this.pagination.page = 1; | 
					
						
							|  |  |  |       this.searchForm = JSON.parse(JSON.stringify(this.queryParams)); | 
					
						
							|  |  |  |       this.getTaskList(); | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 点击重置事件 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     resetQuery() { | 
					
						
							|  |  |  |       this.searchForm = {}; | 
					
						
							|  |  |  |       this.queryParams = { | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |         taskId: "", | 
					
						
							|  |  |  |         plateNo: "", | 
					
						
							|  |  |  |         segmentId: "", | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       }; | 
					
						
							|  |  |  |       this.dateTime = []; | 
					
						
							|  |  |  |       this.getTaskList(); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 获取列表数据 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     getTaskList() { | 
					
						
							|  |  |  |       const params = { | 
					
						
							|  |  |  |         ...this.pagination, | 
					
						
							|  |  |  |         ...this.searchForm, | 
					
						
							|  |  |  |         startTime: this.dateTime ? this.dateTime[0] : "", | 
					
						
							|  |  |  |         endTime: this.dateTime ? this.dateTime[1] : "", | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       getTaskTable(params).then(({ code, rows, total }) => { | 
					
						
							|  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |           this.roadList = rows; | 
					
						
							|  |  |  |           this.tableTotal = total; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 列表选择改变事件 | 
					
						
							|  |  |  |      * @param {*} selection | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     handleSelectionChange(selection) { | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |       this.checkIds = selection.map((item) => item.taskId); | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |       this.single = selection.length !== 1; | 
					
						
							|  |  |  |       this.multiple = !selection.length; | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 点击查看新增病害事件 | 
					
						
							|  |  |  |      * @param {*} item | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     viewDefect(item) { | 
					
						
							|  |  |  |       this.viewVisible = true; | 
					
						
							|  |  |  |       this.dialogItem = item; | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 点击回顾事件 | 
					
						
							|  |  |  |      * @param {*} item | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     handleRetrace(item) { | 
					
						
							|  |  |  |       this.retraceVisible = true; | 
					
						
							|  |  |  |       this.dialogItem = item; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 点击导出事件 | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     handelExpport(item) { | 
					
						
							|  |  |  |       this.exportVisible = true; | 
					
						
							|  |  |  |       this.dialogItem = item; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 导出文件 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     submitForm(type) { | 
					
						
							|  |  |  |       this.wordExport(this.dialogItem, type) | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 导出文件的方法 | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  |      * @param {*} item | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |     wordExport(item, type) { | 
					
						
							|  |  |  |       Loading.service({ fullscreen: true }); | 
					
						
							|  |  |  |       let loadingInstance = Loading.service({ fullscreen: true }); | 
					
						
							|  |  |  |       exportDefectData({ taskId: item.extId, media: type }).then((res) => { | 
					
						
							|  |  |  |         const link = document.createElement("a"); | 
					
						
							|  |  |  |         const blob = new Blob([res], { | 
					
						
							|  |  |  |           type: "application/vnd.openxmlformats-officedocument.wordprocessingml.document", | 
					
						
							| 
									
										
										
										
											2024-12-03 13:42:21 +08:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  |         link.style.display = "none"; | 
					
						
							|  |  |  |         link.href = URL.createObjectURL(blob); | 
					
						
							|  |  |  |         // TODO 源文件名问题
 | 
					
						
							|  |  |  |         link.download = item.extId; | 
					
						
							|  |  |  |         document.body.appendChild(link); | 
					
						
							|  |  |  |         link.click(); | 
					
						
							|  |  |  |         document.body.removeChild(link); | 
					
						
							|  |  |  |       }).finally(() => { | 
					
						
							|  |  |  |         this.exportCancel() | 
					
						
							|  |  |  |         loadingInstance.close(); | 
					
						
							|  |  |  |       }) | 
					
						
							| 
									
										
										
										
											2024-12-03 13:42:21 +08:00
										 |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 切换分页 | 
					
						
							|  |  |  |      * @param {*} arg | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     handleCurrentChange(arg) { | 
					
						
							|  |  |  |       this.pagination.page = arg; | 
					
						
							|  |  |  |       this.getTaskList(); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 切换每条/页 | 
					
						
							|  |  |  |      * @param {*} arg | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     handleSizeChange(arg) { | 
					
						
							|  |  |  |       this.pagination.size = arg; | 
					
						
							|  |  |  |       this.getTaskList(); | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 关闭查看弹窗 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |     viewCancel() { | 
					
						
							|  |  |  |       this.viewVisible = false; | 
					
						
							|  |  |  |       this.dialogItem = {}; | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @description: 关闭回顾弹窗 | 
					
						
							|  |  |  |      * @return {*} | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     retraceCancel() { | 
					
						
							|  |  |  |       this.retraceVisible = false; | 
					
						
							|  |  |  |       this.dialogItem = {}; | 
					
						
							|  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |  * @description: 关闭导出弹窗 | 
					
						
							|  |  |  |  * @return {*} | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  |     exportCancel() { | 
					
						
							|  |  |  |       this.exportVisible = false; | 
					
						
							|  |  |  |       this.dialogItem = {}; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |   }, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | </script> | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  | .app-container { | 
					
						
							|  |  |  |   padding: 20px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .mb8 { | 
					
						
							|  |  |  |   margin-bottom: 8px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .small-padding { | 
					
						
							|  |  |  |   padding: 0 5px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .fixed-width { | 
					
						
							|  |  |  |   width: 120px; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 分页样式 */ | 
					
						
							|  |  |  | .pagination-part { | 
					
						
							|  |  |  |   width: 100%; | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   padding-top: 1rem; | 
					
						
							|  |  |  |   justify-content: flex-end; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 新增弹窗/编辑弹窗 */ | 
					
						
							|  |  |  | .addForm { | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  |   .el-select, | 
					
						
							|  |  |  |   .el-cascader { | 
					
						
							|  |  |  |     width: 100%; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-15 13:14:38 +08:00
										 |  |  | /* 新增地图框样式 */ | 
					
						
							|  |  |  | .no-hand-cursor { | 
					
						
							|  |  |  |   cursor: default !important; | 
					
						
							|  |  |  |   width: 100%; | 
					
						
							|  |  |  |   height: 20rem; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 上传文件列表样式 */ | 
					
						
							|  |  |  | ::v-deep .el-upload-list { | 
					
						
							|  |  |  |   img { | 
					
						
							|  |  |  |     width: auto; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 查看弹窗-图片框样式 */ | 
					
						
							|  |  |  | .view-carousel { | 
					
						
							|  |  |  |   height: 15rem; | 
					
						
							|  |  |  |   // .el-carousel__item{
 | 
					
						
							|  |  |  |   //   height: 12rem;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   img { | 
					
						
							|  |  |  |     max-height: 15rem; | 
					
						
							|  |  |  |     max-width: 25rem; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-12-03 09:47:20 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | .retrace-dialog { | 
					
						
							|  |  |  |   ::v-deep .el-dialog__header { | 
					
						
							|  |  |  |     padding: 10px; | 
					
						
							|  |  |  |     background-color: #113463; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     span, | 
					
						
							|  |  |  |     i { | 
					
						
							|  |  |  |       color: #ffffff; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ::v-deep .el-dialog__body { | 
					
						
							|  |  |  |     padding: 0; | 
					
						
							|  |  |  |     background-color: #2e3a46; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-12-05 17:25:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* 页脚 */ | 
					
						
							|  |  |  | .dialog-footer { | 
					
						
							|  |  |  |   display: flex; | 
					
						
							|  |  |  |   justify-content: flex-end; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | </style> |