| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | <!-- | 
					
						
							|  |  |  |  |  * @Author: error: error: git config user.name & please set dead value or install git && error: git config user.email & please set dead value or install git & please set dead value or install git | 
					
						
							|  |  |  |  |  * @Date: 2024-10-08 10:58:25 | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |  * @LastEditors: SunTao 328867980@qq.com | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |  * @LastEditTime: 2025-01-14 11:50:15 | 
					
						
							| 
									
										
										
										
											2024-12-05 10:05:41 +08:00
										 |  |  |  |  * @FilePath: \znxjxt-ui\src\views\xj\inspection\disease-management\index.vue | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |  * @Description: 巡检信息管理-病害管理 | 
					
						
							|  |  |  |  | --> | 
					
						
							|  |  |  |  | <template> | 
					
						
							|  |  |  |  |   <div class="app-container"> | 
					
						
							|  |  |  |  |     <!-- 搜索表单 --> | 
					
						
							|  |  |  |  |     <el-form | 
					
						
							|  |  |  |  |       :model="queryParams" | 
					
						
							|  |  |  |  |       ref="queryForm" | 
					
						
							|  |  |  |  |       size="small" | 
					
						
							|  |  |  |  |       :inline="true" | 
					
						
							|  |  |  |  |       v-show="showSearch" | 
					
						
							|  |  |  |  |       label-width="100px" | 
					
						
							|  |  |  |  |     > | 
					
						
							|  |  |  |  |       <el-form-item label="道路名称" prop="segmentName"> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         <el-select | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           v-model="queryParams.segmentName" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           placeholder="请选择路段" | 
					
						
							| 
									
										
										
										
											2024-12-09 15:35:13 +08:00
										 |  |  |  |           filterable | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           clearable | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         > | 
					
						
							|  |  |  |  |           <el-option | 
					
						
							|  |  |  |  |             v-for="item in segmentList" | 
					
						
							|  |  |  |  |             :key="item.value" | 
					
						
							|  |  |  |  |             :label="item.label" | 
					
						
							|  |  |  |  |             :value="item.value" | 
					
						
							|  |  |  |  |           /> | 
					
						
							|  |  |  |  |         </el-select> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       </el-form-item> | 
					
						
							|  |  |  |  |       <el-form-item label="采集时间" prop="dateTime"> | 
					
						
							|  |  |  |  |         <el-date-picker | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |           v-model="dateTime" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           type="daterange" | 
					
						
							|  |  |  |  |           start-placeholder="开始日期" | 
					
						
							|  |  |  |  |           end-placeholder="结束日期" | 
					
						
							|  |  |  |  |           format="yyyy-MM-dd" | 
					
						
							|  |  |  |  |           value-format="yyyy-MM-dd" | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         /> | 
					
						
							|  |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |       <el-form-item label="病害类型" prop="paramsDefectType"> | 
					
						
							|  |  |  |  |         <el-cascader | 
					
						
							|  |  |  |  |           v-model="paramsDefectType" | 
					
						
							|  |  |  |  |           :options="tableDefect" | 
					
						
							|  |  |  |  |           :props="{ | 
					
						
							|  |  |  |  |             checkStrictly: true, | 
					
						
							|  |  |  |  |             emitPath: true, | 
					
						
							|  |  |  |  |             children: 'subTypes', | 
					
						
							|  |  |  |  |           }" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           clearable | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |         ></el-cascader> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |       <!-- <el-form-item label="病害状态" prop="state"> | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |         <el-select | 
					
						
							|  |  |  |  |           v-model="queryParams.state" | 
					
						
							|  |  |  |  |           placeholder="请选择病害状态" | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         > | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           <el-option | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |             v-for="item in defectStatus" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |             :key="item.value" | 
					
						
							|  |  |  |  |             :label="item.label" | 
					
						
							|  |  |  |  |             :value="item.value" | 
					
						
							|  |  |  |  |           /> | 
					
						
							|  |  |  |  |         </el-select> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |       </el-form-item> --> | 
					
						
							| 
									
										
										
										
											2024-12-05 10:05:41 +08:00
										 |  |  |  |       <el-form-item label="上下行" prop="inspectDirection"> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         <el-select | 
					
						
							|  |  |  |  |           v-model="queryParams.inspectDirection" | 
					
						
							|  |  |  |  |           placeholder="请选择" | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         > | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           <el-option label="上行" value="0" /> | 
					
						
							|  |  |  |  |           <el-option label="下行" value="1" /> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         </el-select> | 
					
						
							| 
									
										
										
										
											2024-12-05 10:05:41 +08:00
										 |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       <el-form-item label="公里桩" prop="stakeRange"> | 
					
						
							|  |  |  |  |         <el-input | 
					
						
							|  |  |  |  |           v-model="queryParams.stakeStart" | 
					
						
							|  |  |  |  |           placeholder="起始公里桩" | 
					
						
							|  |  |  |  |           style="width: 10rem" | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         /> | 
					
						
							|  |  |  |  |         <span style="margin: 0 5px">-</span> | 
					
						
							|  |  |  |  |         <el-input | 
					
						
							|  |  |  |  |           v-model="queryParams.stakeEnd" | 
					
						
							|  |  |  |  |           placeholder="终止公里桩" | 
					
						
							|  |  |  |  |           style="width: 10rem" | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         /> | 
					
						
							|  |  |  |  |         <el-tooltip | 
					
						
							|  |  |  |  |           class="item" | 
					
						
							|  |  |  |  |           effect="dark" | 
					
						
							|  |  |  |  |           content="格式为K0000+000" | 
					
						
							|  |  |  |  |           placement="top" | 
					
						
							|  |  |  |  |         > | 
					
						
							|  |  |  |  |           <i class="el-icon-info"></i> | 
					
						
							|  |  |  |  |         </el-tooltip> | 
					
						
							|  |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |       <el-form-item label="病害id" prop="id"> | 
					
						
							|  |  |  |  |         <el-input | 
					
						
							|  |  |  |  |           v-model="queryParams.id" | 
					
						
							|  |  |  |  |           placeholder="请填写病害id" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           clearable | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |         /> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       </el-form-item> | 
					
						
							|  |  |  |  |       <el-form-item label="病害长度" prop="lengthRange"> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         <el-input-number | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           v-model="queryParams.minLen" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           controls-position="right" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           placeholder="最小长度" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           :min="0" | 
					
						
							|  |  |  |  |         ></el-input-number> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         <span style="margin: 0 5px">-</span> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         <el-input-number | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           v-model="queryParams.maxLen" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           controls-position="right" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           placeholder="最大长度" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           :min="0" | 
					
						
							|  |  |  |  |         ></el-input-number> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-12-05 10:05:41 +08:00
										 |  |  |  |       <el-form-item label="快照id" prop="snapshotId"> | 
					
						
							|  |  |  |  |         <el-input | 
					
						
							|  |  |  |  |           v-model="queryParams.snapshotId" | 
					
						
							|  |  |  |  |           placeholder="请填写快照id" | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         /> | 
					
						
							|  |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       <el-form-item label="病害面积" prop="areaRange"> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         <el-input-number | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           v-model="queryParams.minArea" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           controls-position="right" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           placeholder="最小面积" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           :min="0" | 
					
						
							|  |  |  |  |         ></el-input-number> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         <span style="margin: 0 5px">-</span> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         <el-input-number | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           v-model="queryParams.maxArea" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           controls-position="right" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           placeholder="最大面积" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           :min="0" | 
					
						
							|  |  |  |  |         ></el-input-number> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-11-25 15:40:46 +08:00
										 |  |  |  |       <el-form-item label="巡检任务" prop="taskId"> | 
					
						
							|  |  |  |  |         <el-select | 
					
						
							|  |  |  |  |           v-model="queryParams.taskId" | 
					
						
							|  |  |  |  |           placeholder="请选择巡检任务" | 
					
						
							|  |  |  |  |           filterable | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         > | 
					
						
							|  |  |  |  |           <el-option | 
					
						
							|  |  |  |  |             v-for="item in taskList" | 
					
						
							|  |  |  |  |             :key="item.value" | 
					
						
							|  |  |  |  |             :label="item.label" | 
					
						
							|  |  |  |  |             :value="item.value" | 
					
						
							|  |  |  |  |           /> | 
					
						
							|  |  |  |  |         </el-select> | 
					
						
							|  |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2025-01-15 15:09:36 +08:00
										 |  |  |  |       <el-form-item label="是否已确认" prop="dataStatus"> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |         <el-select | 
					
						
							| 
									
										
										
										
											2025-01-15 15:09:36 +08:00
										 |  |  |  |           v-model="queryParams.dataStatus" | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |           placeholder="请选择" | 
					
						
							|  |  |  |  |           clearable | 
					
						
							|  |  |  |  |         > | 
					
						
							| 
									
										
										
										
											2025-01-15 15:09:36 +08:00
										 |  |  |  |           <el-option label="确认" value="2" /> | 
					
						
							|  |  |  |  |           <el-option label="未确认" value="1" /> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |         </el-select> | 
					
						
							|  |  |  |  |       </el-form-item> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       <el-form-item> | 
					
						
							|  |  |  |  |         <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 | 
					
						
							|  |  |  |  |         > | 
					
						
							|  |  |  |  |       </el-form-item> | 
					
						
							|  |  |  |  |     </el-form> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 操作按钮 --> | 
					
						
							|  |  |  |  |     <el-row :gutter="10" class="mb8"> | 
					
						
							|  |  |  |  |       <el-col :span="1.5"> | 
					
						
							|  |  |  |  |         <el-button | 
					
						
							|  |  |  |  |           type="primary" | 
					
						
							|  |  |  |  |           plain | 
					
						
							|  |  |  |  |           icon="el-icon-plus" | 
					
						
							|  |  |  |  |           size="mini" | 
					
						
							|  |  |  |  |           @click="handleAdd" | 
					
						
							|  |  |  |  |           >新增 | 
					
						
							|  |  |  |  |         </el-button> | 
					
						
							|  |  |  |  |       </el-col> | 
					
						
							|  |  |  |  |       <el-col :span="1.5"> | 
					
						
							|  |  |  |  |         <el-button | 
					
						
							|  |  |  |  |           type="danger" | 
					
						
							|  |  |  |  |           plain | 
					
						
							|  |  |  |  |           icon="el-icon-delete" | 
					
						
							|  |  |  |  |           size="mini" | 
					
						
							|  |  |  |  |           :disabled="multiple" | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |           @click="handleDelete('')" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           >删除 | 
					
						
							|  |  |  |  |         </el-button> | 
					
						
							|  |  |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |       <el-col :span="1.5"> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         <el-button | 
					
						
							|  |  |  |  |           type="success" | 
					
						
							|  |  |  |  |           plain | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |           icon="el-icon-top-right" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           size="mini" | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |           @click="handleExport" | 
					
						
							|  |  |  |  |           >导出 | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         </el-button> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |       </el-col> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     </el-row> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 数据表格 --> | 
					
						
							|  |  |  |  |     <el-table | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       ref="defectTable" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       v-loading="loading" | 
					
						
							|  |  |  |  |       :data="defectList" | 
					
						
							|  |  |  |  |       @selection-change="handleSelectionChange" | 
					
						
							|  |  |  |  |       style="width: 100%" | 
					
						
							|  |  |  |  |     > | 
					
						
							|  |  |  |  |       <el-table-column type="selection" width="55" align="center" /> | 
					
						
							|  |  |  |  |       <el-table-column label="路段名称" align="center" prop="segmentName" /> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       <el-table-column label="采集时间" align="center" prop="createdTime"> | 
					
						
							|  |  |  |  |         <template slot-scope="scope"> | 
					
						
							|  |  |  |  |           <span>{{ new Date(scope.row.createdTime).toLocaleString() }}</span> | 
					
						
							|  |  |  |  |         </template> | 
					
						
							|  |  |  |  |       </el-table-column> | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |       <el-table-column label="病害类型" align="center" prop="defectTypeName"> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       </el-table-column> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |       <!-- <el-table-column label="病害状态" align="center" prop="state"> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         <template slot-scope="scope"> | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |           <span>{{ filterState(scope.row.state) }}</span> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         </template> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |       </el-table-column> --> | 
					
						
							| 
									
										
										
										
											2024-10-12 17:25:56 +08:00
										 |  |  |  |       <el-table-column label="校验状态" align="center" prop="dataStatus"> | 
					
						
							|  |  |  |  |         <template slot-scope="scope"> | 
					
						
							|  |  |  |  |           <span>{{ | 
					
						
							|  |  |  |  |             scope.row.dataStatus | 
					
						
							|  |  |  |  |               ? scope.row.dataStatus === 1 | 
					
						
							|  |  |  |  |                 ? "未校验" | 
					
						
							|  |  |  |  |                 : "已校验" | 
					
						
							|  |  |  |  |               : "" | 
					
						
							|  |  |  |  |           }}</span> | 
					
						
							|  |  |  |  |         </template> | 
					
						
							|  |  |  |  |       </el-table-column> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       <el-table-column label="开始桩号" align="center" prop="stakeStart" /> | 
					
						
							|  |  |  |  |       <el-table-column label="结束桩号" align="center" prop="stakeEnd" /> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       <el-table-column label="病害图片" align="center" prop="media"> | 
					
						
							|  |  |  |  |         <template slot-scope="scope"> | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |           <img | 
					
						
							|  |  |  |  |             @click="showScreenImg(scope.row)" | 
					
						
							|  |  |  |  |             height="50" | 
					
						
							|  |  |  |  |             :src="scope.row.mediaUrl" | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |           /> | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         </template> | 
					
						
							|  |  |  |  |       </el-table-column> | 
					
						
							| 
									
										
										
										
											2024-11-28 11:12:21 +08:00
										 |  |  |  |       <el-table-column label="病害长度" align="center" prop="targetLen"> | 
					
						
							|  |  |  |  |         <template slot-scope="scope"> | 
					
						
							|  |  |  |  |           {{ scope.row.targetLen * 1 <= 0 ? "" : `${scope.row.targetLen}米` }} | 
					
						
							|  |  |  |  |         </template> | 
					
						
							|  |  |  |  |       </el-table-column> | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |       <el-table-column label="病害面积" align="center" prop="targetArea" /> | 
					
						
							| 
									
										
										
										
											2024-12-05 10:05:41 +08:00
										 |  |  |  |       <el-table-column label="道路方向" align="center" prop="inspectDirection"> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         <template slot-scope="scope"> | 
					
						
							| 
									
										
										
										
											2024-12-05 10:05:41 +08:00
										 |  |  |  |           <span>{{ | 
					
						
							|  |  |  |  |             scope.row.inspectDirection === "0" ? "上行" : "下行" | 
					
						
							|  |  |  |  |           }}</span> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         </template> | 
					
						
							|  |  |  |  |       </el-table-column> | 
					
						
							|  |  |  |  |       <el-table-column | 
					
						
							|  |  |  |  |         label="操作" | 
					
						
							|  |  |  |  |         align="center" | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |         width="180" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         class-name="small-padding fixed-width" | 
					
						
							|  |  |  |  |       > | 
					
						
							|  |  |  |  |         <template slot-scope="scope"> | 
					
						
							|  |  |  |  |           <el-button | 
					
						
							|  |  |  |  |             size="mini" | 
					
						
							|  |  |  |  |             type="text" | 
					
						
							|  |  |  |  |             icon="el-icon-edit" | 
					
						
							|  |  |  |  |             @click="viewDefect(scope.row)" | 
					
						
							|  |  |  |  |             >查看 | 
					
						
							|  |  |  |  |           </el-button> | 
					
						
							|  |  |  |  |           <el-button | 
					
						
							|  |  |  |  |             size="mini" | 
					
						
							|  |  |  |  |             type="text" | 
					
						
							|  |  |  |  |             icon="el-icon-edit" | 
					
						
							|  |  |  |  |             @click="handleUpdate(scope.row)" | 
					
						
							|  |  |  |  |             >修改 | 
					
						
							|  |  |  |  |           </el-button> | 
					
						
							|  |  |  |  |           <el-button | 
					
						
							|  |  |  |  |             size="mini" | 
					
						
							|  |  |  |  |             type="text" | 
					
						
							|  |  |  |  |             icon="el-icon-delete" | 
					
						
							|  |  |  |  |             @click="handleDelete(scope.row)" | 
					
						
							|  |  |  |  |             >删除 | 
					
						
							|  |  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |           <el-button | 
					
						
							|  |  |  |  |             size="mini" | 
					
						
							|  |  |  |  |             type="text" | 
					
						
							|  |  |  |  |             icon="el-icon-bangzhu" | 
					
						
							|  |  |  |  |             @click="mergeDefect(scope.row)" | 
					
						
							|  |  |  |  |             >合并 | 
					
						
							|  |  |  |  |           </el-button> | 
					
						
							|  |  |  |  |           <el-button | 
					
						
							|  |  |  |  |             size="mini" | 
					
						
							|  |  |  |  |             type="text" | 
					
						
							|  |  |  |  |             icon="el-icon-copy-document" | 
					
						
							| 
									
										
										
										
											2024-11-05 11:22:23 +08:00
										 |  |  |  |             v-if="scope.row.id !== scope.row.snapshotId" | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |             @click="splitDefect(scope.row)" | 
					
						
							|  |  |  |  |             >拆分 | 
					
						
							|  |  |  |  |           </el-button> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         </template> | 
					
						
							|  |  |  |  |       </el-table-column> | 
					
						
							|  |  |  |  |     </el-table> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 分页组件 --> | 
					
						
							|  |  |  |  |     <pagination | 
					
						
							|  |  |  |  |       v-show="total > 0" | 
					
						
							|  |  |  |  |       :total="total" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       :page.sync="queryParams.page" | 
					
						
							|  |  |  |  |       :limit.sync="queryParams.size" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       @pagination="getList" | 
					
						
							|  |  |  |  |     /> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 添加或修改缺陷对话框 --> | 
					
						
							|  |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       :title="dialogTitle" | 
					
						
							|  |  |  |  |       :visible.sync="dialogVisible" | 
					
						
							|  |  |  |  |       width="60rem" | 
					
						
							|  |  |  |  |       append-to-body | 
					
						
							|  |  |  |  |       :close-on-click-modal="false" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       destroy-on-close | 
					
						
							|  |  |  |  |       @close="cancel" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     > | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |       <template v-if="dialogVisible"> | 
					
						
							|  |  |  |  |         <el-form | 
					
						
							|  |  |  |  |           class="addForm" | 
					
						
							|  |  |  |  |           ref="defectForm" | 
					
						
							|  |  |  |  |           :model="form" | 
					
						
							|  |  |  |  |           :rules="rules" | 
					
						
							|  |  |  |  |           label-width="100px" | 
					
						
							|  |  |  |  |         > | 
					
						
							|  |  |  |  |           <el-row :gutter="24"> | 
					
						
							|  |  |  |  |             <el-col :span="dialogTitle === '添加缺陷' ? 12 : 24"> | 
					
						
							|  |  |  |  |               <el-form-item label="路段" prop="segmentId"> | 
					
						
							|  |  |  |  |                 <el-select | 
					
						
							|  |  |  |  |                   v-model="form.segmentId" | 
					
						
							|  |  |  |  |                   placeholder="请选择路段" | 
					
						
							|  |  |  |  |                   clearable | 
					
						
							|  |  |  |  |                 > | 
					
						
							|  |  |  |  |                   <el-option | 
					
						
							|  |  |  |  |                     v-for="item in segmentList" | 
					
						
							|  |  |  |  |                     :key="item.value" | 
					
						
							|  |  |  |  |                     :label="item.label" | 
					
						
							|  |  |  |  |                     :value="item.value" | 
					
						
							|  |  |  |  |                   /> | 
					
						
							|  |  |  |  |                 </el-select> | 
					
						
							|  |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							|  |  |  |  |             <el-col :span="12" v-if="dialogTitle === '添加缺陷'"> | 
					
						
							|  |  |  |  |               <el-form-item label="病害类型" prop="defectType"> | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |                 <el-cascader | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |                   v-model="form.defectType" | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |                   :options="tableDefect" | 
					
						
							|  |  |  |  |                   :props="{ | 
					
						
							|  |  |  |  |                     checkStrictly: false, | 
					
						
							|  |  |  |  |                     emitPath: false, | 
					
						
							|  |  |  |  |                     children: 'subTypes', | 
					
						
							|  |  |  |  |                   }" | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |                   clearable | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |                 ></el-cascader> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							|  |  |  |  |           </el-row> | 
					
						
							|  |  |  |  |           <el-row :gutter="24"> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |             <el-col :span="24" v-if="dialogTitle != '添加缺陷'"> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               <el-form-item label="校验状态" prop="dataStatus"> | 
					
						
							|  |  |  |  |                 <el-select | 
					
						
							|  |  |  |  |                   v-model="form.dataStatus" | 
					
						
							|  |  |  |  |                   placeholder="请选择校验状态" | 
					
						
							|  |  |  |  |                   clearable | 
					
						
							|  |  |  |  |                 > | 
					
						
							|  |  |  |  |                   <el-option | 
					
						
							|  |  |  |  |                     v-for="item in states" | 
					
						
							|  |  |  |  |                     :key="item.value" | 
					
						
							|  |  |  |  |                     :label="item.label" | 
					
						
							|  |  |  |  |                     :value="item.value" | 
					
						
							|  |  |  |  |                   /> | 
					
						
							|  |  |  |  |                 </el-select> | 
					
						
							|  |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |             <!-- <el-col :span="dialogTitle === '添加缺陷' ? 24 : 12"> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               <el-form-item label="病害状态" prop="state"> | 
					
						
							|  |  |  |  |                 <el-select | 
					
						
							|  |  |  |  |                   v-model="form.state" | 
					
						
							|  |  |  |  |                   placeholder="请选择病害状态" | 
					
						
							|  |  |  |  |                   clearable | 
					
						
							|  |  |  |  |                 > | 
					
						
							|  |  |  |  |                   <el-option | 
					
						
							|  |  |  |  |                     v-for="item in defectStatus" | 
					
						
							|  |  |  |  |                     :key="item.value" | 
					
						
							|  |  |  |  |                     :label="item.label" | 
					
						
							|  |  |  |  |                     :value="item.value" | 
					
						
							|  |  |  |  |                   /> | 
					
						
							|  |  |  |  |                 </el-select> | 
					
						
							|  |  |  |  |               </el-form-item> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |             </el-col> --> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |           </el-row> | 
					
						
							|  |  |  |  |           <el-row :gutter="24"> | 
					
						
							|  |  |  |  |             <el-col :span="12"> | 
					
						
							|  |  |  |  |               <el-form-item label="开始桩号" prop="stakeStart"> | 
					
						
							|  |  |  |  |                 <el-input | 
					
						
							|  |  |  |  |                   v-model="form.stakeStart" | 
					
						
							|  |  |  |  |                   placeholder="请输入开始桩号" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |                 /> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							|  |  |  |  |             <el-col :span="12"> | 
					
						
							|  |  |  |  |               <el-form-item label="结束桩号" prop="stakeEnd"> | 
					
						
							|  |  |  |  |                 <el-input | 
					
						
							|  |  |  |  |                   v-model="form.stakeEnd" | 
					
						
							|  |  |  |  |                   placeholder="请输入结束桩号" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |                 /> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							|  |  |  |  |           </el-row> | 
					
						
							|  |  |  |  |           <el-row :gutter="24"> | 
					
						
							|  |  |  |  |             <el-col :span="12"> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |               <el-form-item label="病害长度"> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |                 <el-input-number | 
					
						
							|  |  |  |  |                   v-model="form.targetLen" | 
					
						
							|  |  |  |  |                   :min="0" | 
					
						
							|  |  |  |  |                   placeholder="请输入病害长度" | 
					
						
							|  |  |  |  |                   style="width: 100%" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |                 /> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							|  |  |  |  |             <el-col :span="12"> | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |               <el-form-item label="病害面积"> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |                 <el-input-number | 
					
						
							|  |  |  |  |                   v-model="form.targetArea" | 
					
						
							|  |  |  |  |                   :min="0" | 
					
						
							|  |  |  |  |                   placeholder="请输入病害面积" | 
					
						
							|  |  |  |  |                   style="width: 100%" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |                 /> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							|  |  |  |  |           </el-row> | 
					
						
							|  |  |  |  |           <el-row :gutter="24"> | 
					
						
							|  |  |  |  |             <el-col :span="12"> | 
					
						
							|  |  |  |  |               <el-form-item label="上下行" prop="inspectDirection"> | 
					
						
							|  |  |  |  |                 <el-select | 
					
						
							|  |  |  |  |                   v-model="form.inspectDirection" | 
					
						
							|  |  |  |  |                   placeholder="请选择上下行" | 
					
						
							|  |  |  |  |                   clearable | 
					
						
							|  |  |  |  |                 > | 
					
						
							|  |  |  |  |                   <el-option label="上行" value="0" /> | 
					
						
							|  |  |  |  |                   <el-option label="下行" value="1" /> | 
					
						
							|  |  |  |  |                 </el-select> | 
					
						
							|  |  |  |  |               </el-form-item> | 
					
						
							|  |  |  |  |             </el-col> | 
					
						
							|  |  |  |  |           </el-row> | 
					
						
							|  |  |  |  |           <el-form-item label="病害位置"> | 
					
						
							|  |  |  |  |             <fssm-map | 
					
						
							|  |  |  |  |               ref="diseaseMap" | 
					
						
							|  |  |  |  |               @map-click="getMapClick" | 
					
						
							|  |  |  |  |               class="no-hand-cursor" | 
					
						
							|  |  |  |  |             ></fssm-map> | 
					
						
							|  |  |  |  |           </el-form-item> | 
					
						
							|  |  |  |  |           <el-form-item label="上传病害图片"> | 
					
						
							|  |  |  |  |             <el-upload | 
					
						
							|  |  |  |  |               ref="upload" | 
					
						
							|  |  |  |  |               accept=".jpg, .png" | 
					
						
							|  |  |  |  |               :action="upload.url" | 
					
						
							|  |  |  |  |               :headers="upload.headers" | 
					
						
							|  |  |  |  |               :file-list="upload.fileList" | 
					
						
							|  |  |  |  |               :on-progress="handleFileUploadProgress" | 
					
						
							|  |  |  |  |               :on-success="handleFileSuccess" | 
					
						
							|  |  |  |  |               :auto-upload="false" | 
					
						
							|  |  |  |  |               list-type="picture" | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |             > | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               <el-button slot="trigger" size="small" type="primary" | 
					
						
							|  |  |  |  |                 >选取文件</el-button | 
					
						
							|  |  |  |  |               > | 
					
						
							|  |  |  |  |               <el-button | 
					
						
							|  |  |  |  |                 style="margin-left: 1rem" | 
					
						
							|  |  |  |  |                 size="small" | 
					
						
							|  |  |  |  |                 type="success" | 
					
						
							|  |  |  |  |                 :loading="upload.isUploading" | 
					
						
							|  |  |  |  |                 @click="submitUpload" | 
					
						
							|  |  |  |  |                 >上传到服务器</el-button | 
					
						
							|  |  |  |  |               > | 
					
						
							|  |  |  |  |               <div slot="tip" class="el-upload__tip"> | 
					
						
							|  |  |  |  |                 只能上传jpg/png文件,且不超过500kb | 
					
						
							|  |  |  |  |               </div> | 
					
						
							|  |  |  |  |             </el-upload> | 
					
						
							|  |  |  |  |           </el-form-item> | 
					
						
							|  |  |  |  |         </el-form> | 
					
						
							|  |  |  |  |         <div slot="footer" class="dialog-footer"> | 
					
						
							|  |  |  |  |           <el-button type="primary" @click="submitForm">确 定</el-button> | 
					
						
							|  |  |  |  |           <el-button @click="cancel">取 消</el-button> | 
					
						
							|  |  |  |  |         </div> | 
					
						
							|  |  |  |  |       </template> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     </el-dialog> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     <!-- 查看病害详细信息对话框 --> | 
					
						
							|  |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       title="查看病害详细信息" | 
					
						
							|  |  |  |  |       :visible.sync="openViewDialog" | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |       width="55rem" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       append-to-body | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       destroy-on-close | 
					
						
							|  |  |  |  |       @close="cancel" | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     > | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |       <template v-if="openViewDialog"> | 
					
						
							|  |  |  |  |         <div> | 
					
						
							|  |  |  |  |           <!-- 上半部分 --> | 
					
						
							|  |  |  |  |           <div style="display: flex; flex-direction: column; height: 50%"> | 
					
						
							|  |  |  |  |             <!-- 下拉选择框 --> | 
					
						
							|  |  |  |  |             <div> | 
					
						
							|  |  |  |  |               <el-select | 
					
						
							|  |  |  |  |                 v-model="viewCheck" | 
					
						
							|  |  |  |  |                 @change="changeView" | 
					
						
							|  |  |  |  |                 placeholder="请选择" | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |               > | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |                 <el-option | 
					
						
							|  |  |  |  |                   v-for="item in viewOptions" | 
					
						
							|  |  |  |  |                   :key="item.value" | 
					
						
							|  |  |  |  |                   :label="item.label" | 
					
						
							|  |  |  |  |                   :value="item.value" | 
					
						
							|  |  |  |  |                 > | 
					
						
							|  |  |  |  |                 </el-option> | 
					
						
							|  |  |  |  |               </el-select> | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |             </div> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |             <div style="display: flex"> | 
					
						
							|  |  |  |  |               <!-- 左侧病害信息 --> | 
					
						
							|  |  |  |  |               <div style="width: 50%; padding: 10px"> | 
					
						
							|  |  |  |  |                 <p> | 
					
						
							|  |  |  |  |                   上报日期:{{ | 
					
						
							|  |  |  |  |                     new Date(viewForm.createdTime).toLocaleString() | 
					
						
							|  |  |  |  |                   }} | 
					
						
							|  |  |  |  |                 </p> | 
					
						
							|  |  |  |  |                 <p>路段名称:{{ viewForm.segmentName }}</p> | 
					
						
							|  |  |  |  |                 <!-- <p>病害坐标:{{ viewForm.geometry.coordinates }}</p> --> | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |                 <p>病害类型:{{ viewForm.defectTypeName }}</p> | 
					
						
							| 
									
										
										
										
											2024-12-06 15:49:58 +08:00
										 |  |  |  |                 <p> | 
					
						
							|  |  |  |  |                   病害长度:{{ | 
					
						
							| 
									
										
										
										
											2024-12-24 16:18:30 +08:00
										 |  |  |  |                     viewForm.targetLen * 1 < 0 ? "" : `${viewForm.targetLen}米` | 
					
						
							| 
									
										
										
										
											2024-12-06 15:49:58 +08:00
										 |  |  |  |                   }} | 
					
						
							|  |  |  |  |                 </p> | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |                 <p>病害id:{{ viewForm.id }}</p> | 
					
						
							|  |  |  |  |                 <p>快照id:{{ viewForm.snapshotId }}</p> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               <!-- 右侧图片展示 --> | 
					
						
							|  |  |  |  |               <div style="width: 50%; padding: 10px"> | 
					
						
							|  |  |  |  |                 <el-carousel class="view-carousel" height="15rem"> | 
					
						
							|  |  |  |  |                   <el-carousel-item | 
					
						
							|  |  |  |  |                     v-for="(img, index) in viewForm.media" | 
					
						
							|  |  |  |  |                     :key="index" | 
					
						
							|  |  |  |  |                   > | 
					
						
							|  |  |  |  |                     <img :src="img.img" alt="病害图片" /> | 
					
						
							|  |  |  |  |                   </el-carousel-item> | 
					
						
							|  |  |  |  |                 </el-carousel> | 
					
						
							|  |  |  |  |               </div> | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |             </div> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           </div> | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |           <!-- 下半部分显示天地图 --> | 
					
						
							|  |  |  |  |           <!-- <div id="viewMap" style="height: 300px; margin-top: 20px"></div> --> | 
					
						
							|  |  |  |  |           <fssm-map | 
					
						
							|  |  |  |  |             style="height: 300px; margin-top: 20px" | 
					
						
							|  |  |  |  |             ref="diseaseMap" | 
					
						
							|  |  |  |  |           ></fssm-map> | 
					
						
							|  |  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |         <div slot="footer" class="dialog-footer"> | 
					
						
							|  |  |  |  |           <el-button @click="closeDialog">关闭</el-button> | 
					
						
							|  |  |  |  |         </div> | 
					
						
							|  |  |  |  |       </template> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |     <!-- 合并病害弹窗 --> | 
					
						
							|  |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       title="合并病害" | 
					
						
							|  |  |  |  |       :visible.sync="mergeVisibleDialog" | 
					
						
							|  |  |  |  |       width="75rem" | 
					
						
							|  |  |  |  |       append-to-body | 
					
						
							|  |  |  |  |       destroy-on-close | 
					
						
							|  |  |  |  |       @close="mergeCancel" | 
					
						
							|  |  |  |  |     > | 
					
						
							|  |  |  |  |       <merge-dialog | 
					
						
							|  |  |  |  |         :segmentList="segmentList" | 
					
						
							|  |  |  |  |         :tableDefect="tableDefect" | 
					
						
							|  |  |  |  |         :defectStatus="defectStatus" | 
					
						
							|  |  |  |  |         :mergeItem="mergeItem" | 
					
						
							|  |  |  |  |         @mergeCancel="mergeCancel" | 
					
						
							|  |  |  |  |       ></merge-dialog> | 
					
						
							|  |  |  |  |     </el-dialog> | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |     <!-- 查看图片大图 --> | 
					
						
							|  |  |  |  |     <el-dialog | 
					
						
							|  |  |  |  |       title="查看图片" | 
					
						
							|  |  |  |  |       :visible.sync="showImageDialog" | 
					
						
							| 
									
										
										
										
											2024-12-24 16:18:30 +08:00
										 |  |  |  |       width="85rem" | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |       append-to-body | 
					
						
							|  |  |  |  |       destroy-on-close | 
					
						
							|  |  |  |  |       @close="imgCancel" | 
					
						
							|  |  |  |  |     > | 
					
						
							|  |  |  |  |       <div class="image-container" ref="imageContainer"> | 
					
						
							|  |  |  |  |         <img | 
					
						
							|  |  |  |  |           :src="currentImageItem.mediaUrl" | 
					
						
							|  |  |  |  |           alt="Main Image" | 
					
						
							|  |  |  |  |           ref="mainImage" | 
					
						
							|  |  |  |  |           @load="updateRects" | 
					
						
							|  |  |  |  |         /> | 
					
						
							|  |  |  |  |         <div | 
					
						
							|  |  |  |  |           v-for="(rect, index) in rects" | 
					
						
							|  |  |  |  |           :key="index" | 
					
						
							|  |  |  |  |           class="rect-overlay" | 
					
						
							|  |  |  |  |           :style="getRectStyle(rect)" | 
					
						
							|  |  |  |  |         ></div> | 
					
						
							| 
									
										
										
										
											2024-12-24 16:18:30 +08:00
										 |  |  |  |         <div class="rect-image"> | 
					
						
							|  |  |  |  |           采集时间: | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |           {{ new Date(currentImageItem.createdTime).toLocaleString() }} | 
					
						
							|  |  |  |  |           起始桩号: {{ currentImageItem.stakeStart || "暂无数据" }} 终止桩号: | 
					
						
							| 
									
										
										
										
											2024-12-24 16:18:30 +08:00
										 |  |  |  |           {{ currentImageItem.stakeEnd || "暂无数据" }} | 
					
						
							|  |  |  |  |           病害类型: | 
					
						
							|  |  |  |  |           {{ currentImageItem.defectTypeName || "暂无数据" }} | 
					
						
							|  |  |  |  |           病害面积:{{ currentImageItem.targetArea }}平方米 病害长度:{{ | 
					
						
							|  |  |  |  |             currentImageItem.targetLen * 1 <= 0 | 
					
						
							|  |  |  |  |               ? "暂无数据" | 
					
						
							|  |  |  |  |               : `${currentImageItem.targetLen}米` | 
					
						
							|  |  |  |  |           }} | 
					
						
							|  |  |  |  |         </div> | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |       </div> | 
					
						
							|  |  |  |  |     </el-dialog> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |   </div> | 
					
						
							|  |  |  |  | </template> | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | <script> | 
					
						
							|  |  |  |  | import { | 
					
						
							|  |  |  |  |   listDefect, | 
					
						
							|  |  |  |  |   delDefect, | 
					
						
							|  |  |  |  |   addDefect, | 
					
						
							|  |  |  |  |   updateDefect, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |   getSegment, | 
					
						
							|  |  |  |  |   getDefectList, | 
					
						
							|  |  |  |  |   getStatesList, | 
					
						
							|  |  |  |  |   getDefectStatus, | 
					
						
							|  |  |  |  |   changeDefectStatus, | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |   splitDefect, | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |   getDefectById, | 
					
						
							|  |  |  |  |   getDetailsBySnapShotId, | 
					
						
							| 
									
										
										
										
											2024-11-25 15:40:46 +08:00
										 |  |  |  |   getTaskList, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | } from "@/api/xj/disease"; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  | import { getToken } from "@/utils/auth"; | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  | import MergeDialog from "./components/merge-dialog.vue"; | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  | // 地图
 | 
					
						
							|  |  |  |  | import FssmMap from "@/components/map/fssm-map.vue"; | 
					
						
							|  |  |  |  | import { Feature } from "ol"; | 
					
						
							|  |  |  |  | import { Point } from "ol/geom"; | 
					
						
							|  |  |  |  | import { Style } from "ol/style"; | 
					
						
							|  |  |  |  | import * as styleExports from "ol/style"; | 
					
						
							|  |  |  |  | import VectorLayer from "ol/layer/Vector"; | 
					
						
							|  |  |  |  | import { Vector as VectorSource } from "ol/source"; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | export default { | 
					
						
							|  |  |  |  |   name: "Defect", | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |   components: { | 
					
						
							|  |  |  |  |     MergeDialog, | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     FssmMap, | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |   }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |   data() { | 
					
						
							|  |  |  |  |     return { | 
					
						
							|  |  |  |  |       typeInfo: [], | 
					
						
							|  |  |  |  |       // 查看弹窗显隐控制
 | 
					
						
							|  |  |  |  |       openViewDialog: false, | 
					
						
							|  |  |  |  |       // 遮罩层
 | 
					
						
							|  |  |  |  |       loading: false, | 
					
						
							|  |  |  |  |       // 选中数组
 | 
					
						
							|  |  |  |  |       ids: [], | 
					
						
							|  |  |  |  |       // 非单个禁用
 | 
					
						
							|  |  |  |  |       single: true, | 
					
						
							|  |  |  |  |       // 非多个禁用
 | 
					
						
							|  |  |  |  |       multiple: true, | 
					
						
							|  |  |  |  |       // 显示搜索条件
 | 
					
						
							|  |  |  |  |       showSearch: true, | 
					
						
							|  |  |  |  |       // 总条数
 | 
					
						
							|  |  |  |  |       total: 0, | 
					
						
							|  |  |  |  |       // 缺陷表格数据
 | 
					
						
							|  |  |  |  |       defectList: [], | 
					
						
							|  |  |  |  |       // 弹出层标题
 | 
					
						
							|  |  |  |  |       dialogTitle: "", | 
					
						
							|  |  |  |  |       // 是否显示弹出层
 | 
					
						
							|  |  |  |  |       dialogVisible: false, | 
					
						
							|  |  |  |  |       // 查询表单参数
 | 
					
						
							|  |  |  |  |       queryParams: { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         page: 1, | 
					
						
							|  |  |  |  |         size: 10, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         segmentName: "", | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         defectType: "", | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |         classType: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         taskId: "", | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         state: "", | 
					
						
							|  |  |  |  |         inspectDirection: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         stakeStart: "", | 
					
						
							|  |  |  |  |         stakeEnd: "", | 
					
						
							|  |  |  |  |         warningFlag: null, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         minLen: undefined, | 
					
						
							|  |  |  |  |         maxLen: undefined, | 
					
						
							|  |  |  |  |         minArea: undefined, | 
					
						
							|  |  |  |  |         maxArea: undefined, | 
					
						
							| 
									
										
										
										
											2025-01-15 15:09:36 +08:00
										 |  |  |  |         dataStatus: "", | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |         id: "", | 
					
						
							|  |  |  |  |         snapshotId: "", | 
					
						
							| 
									
										
										
										
											2024-11-25 15:40:46 +08:00
										 |  |  |  |         taskId: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |       // 日期范围
 | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |       dateTime: [], | 
					
						
							| 
									
										
										
										
											2024-11-25 15:40:46 +08:00
										 |  |  |  |       // 巡检任务下拉数据
 | 
					
						
							|  |  |  |  |       taskList: [], | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |       // 病害类型级联下拉绑定
 | 
					
						
							|  |  |  |  |       paramsDefectType: [], | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       // 新增/编辑表单参数
 | 
					
						
							|  |  |  |  |       form: { | 
					
						
							|  |  |  |  |         id: null, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         segmentId: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         defectType: "", | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         dataStatus: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         state: "", | 
					
						
							|  |  |  |  |         stakeStart: "", | 
					
						
							|  |  |  |  |         stakeEnd: "", | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         targetLen: undefined, | 
					
						
							|  |  |  |  |         targetArea: undefined, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         inspectDirection: "", | 
					
						
							|  |  |  |  |         media: [], | 
					
						
							|  |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       // 上传参数设置
 | 
					
						
							|  |  |  |  |       upload: { | 
					
						
							|  |  |  |  |         // 是否禁用上传
 | 
					
						
							|  |  |  |  |         isUploading: false, | 
					
						
							|  |  |  |  |         // 设置上传的请求头部
 | 
					
						
							|  |  |  |  |         headers: { Authorization: "Bearer " + getToken() }, | 
					
						
							|  |  |  |  |         // 上传的地址
 | 
					
						
							|  |  |  |  |         url: process.env.VUE_APP_BASE_API + "/common/upload", | 
					
						
							|  |  |  |  |         // 上传的文件列表
 | 
					
						
							|  |  |  |  |         fileList: [], | 
					
						
							|  |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       // 表单校验规则
 | 
					
						
							|  |  |  |  |       rules: { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         segmentId: [ | 
					
						
							|  |  |  |  |           { required: true, message: "请选择路段", trigger: "change" }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         ], | 
					
						
							|  |  |  |  |         defectType: [ | 
					
						
							|  |  |  |  |           { required: true, message: "请选择病害类型", trigger: "change" }, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         state: [ | 
					
						
							|  |  |  |  |           { required: true, message: "请选择病害状态", trigger: "change" }, | 
					
						
							|  |  |  |  |         ], | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         dataStatus: [ | 
					
						
							|  |  |  |  |           { required: true, message: "请选择校验状态", trigger: "change" }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         ], | 
					
						
							|  |  |  |  |         stakeStart: [ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           { required: true, message: "请输入开始桩号", trigger: "blur" }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           { | 
					
						
							|  |  |  |  |             pattern: /^K\d{4}\+\d{3}$/, | 
					
						
							|  |  |  |  |             message: "请按照K0000+000格式进行填写", | 
					
						
							|  |  |  |  |           }, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         stakeEnd: [ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           { required: true, message: "请输入结束桩号", trigger: "blur" }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           { | 
					
						
							|  |  |  |  |             pattern: /^K\d{4}\+\d{3}$/, | 
					
						
							|  |  |  |  |             message: "请按照K0000+000格式进行填写", | 
					
						
							|  |  |  |  |           }, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         targetLen: [ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           { required: true, message: "请填写病害长度", trigger: "blur" }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           { | 
					
						
							|  |  |  |  |             type: "number", | 
					
						
							|  |  |  |  |             min: 0, | 
					
						
							|  |  |  |  |             message: "病害长度必须为正数", | 
					
						
							|  |  |  |  |             trigger: "change", | 
					
						
							|  |  |  |  |           }, | 
					
						
							|  |  |  |  |         ], | 
					
						
							|  |  |  |  |         targetArea: [ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           { required: true, message: "请填写病害面积", trigger: "blur" }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           { | 
					
						
							|  |  |  |  |             type: "number", | 
					
						
							|  |  |  |  |             min: 0, | 
					
						
							|  |  |  |  |             message: "病害面积必须为正数", | 
					
						
							|  |  |  |  |             trigger: "change", | 
					
						
							|  |  |  |  |           }, | 
					
						
							|  |  |  |  |         ], | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         inspectDirection: [ | 
					
						
							|  |  |  |  |           { required: true, message: "请选择上下行", trigger: "change" }, | 
					
						
							|  |  |  |  |         ], | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       }, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       // 路段下拉选项
 | 
					
						
							|  |  |  |  |       segmentList: [], | 
					
						
							|  |  |  |  |       // 列表病害状态数据
 | 
					
						
							|  |  |  |  |       tableDefect: [], | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       defectTypes: [], | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       // 校验状态下拉选项
 | 
					
						
							|  |  |  |  |       states: [], | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       // 病害状态下拉选项
 | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       defectStatus: [], | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       // 新增/编辑打点数组
 | 
					
						
							|  |  |  |  |       markers: [], | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |       // 查看弹窗选择绑定
 | 
					
						
							|  |  |  |  |       viewCheck: "", | 
					
						
							|  |  |  |  |       // 查看弹窗下拉数据绑定
 | 
					
						
							|  |  |  |  |       viewOptions: [], | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       // 查看弹窗信息绑定
 | 
					
						
							|  |  |  |  |       viewForm: {}, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |       // 查看图片大图弹窗显隐控制
 | 
					
						
							|  |  |  |  |       showImageDialog: false, | 
					
						
							|  |  |  |  |       // 查看大图片路径
 | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |       currentImageItem: {}, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |       // 图片病害位置信息
 | 
					
						
							|  |  |  |  |       rects: [], | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |       // 合并病害弹窗显隐控制
 | 
					
						
							|  |  |  |  |       mergeVisibleDialog: false, | 
					
						
							|  |  |  |  |       // 传合并病害弹窗数据
 | 
					
						
							|  |  |  |  |       mergeItem: {}, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     }; | 
					
						
							|  |  |  |  |   }, | 
					
						
							|  |  |  |  |   created() { | 
					
						
							|  |  |  |  |     this.getList(); | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |     this.getSegmentList(); | 
					
						
							|  |  |  |  |     this.getTableDefect(); | 
					
						
							|  |  |  |  |     this.getStates(); | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |     // this.getDefectStatusList();
 | 
					
						
							| 
									
										
										
										
											2024-11-25 15:40:46 +08:00
										 |  |  |  |     this.getTaskSelectList(); | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  |   methods: { | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取路段下拉数据 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |     getSegmentList() { | 
					
						
							|  |  |  |  |       getSegment().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.segmentList = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 获取列表病害类型对应数据 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |     getTableDefect() { | 
					
						
							|  |  |  |  |       getDefectList().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.tableDefect = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 过滤列表病害状态 | 
					
						
							|  |  |  |  |      * @param {*} value | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |     // filterState(value) {
 | 
					
						
							|  |  |  |  |     //   let a = null;
 | 
					
						
							|  |  |  |  |     //   [a] = this.defectStatus.filter((item) => {
 | 
					
						
							|  |  |  |  |     //     return item.value === value;
 | 
					
						
							|  |  |  |  |     //   });
 | 
					
						
							|  |  |  |  |     //   if (a) {
 | 
					
						
							|  |  |  |  |     //     return a.label;
 | 
					
						
							|  |  |  |  |     //   }
 | 
					
						
							|  |  |  |  |     // },
 | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 查询校验状态下拉数据 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |     getStates() { | 
					
						
							|  |  |  |  |       getStatesList().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.states = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 查询病害状态下拉数据 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |     // getDefectStatusList() {
 | 
					
						
							|  |  |  |  |     //   getDefectStatus().then(({ data, code }) => {
 | 
					
						
							|  |  |  |  |     //     if (code === 200) {
 | 
					
						
							|  |  |  |  |     //       this.defectStatus = data;
 | 
					
						
							|  |  |  |  |     //     }
 | 
					
						
							|  |  |  |  |     //   });
 | 
					
						
							|  |  |  |  |     // },
 | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-25 15:40:46 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 查询巡检任务下拉数据 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     getTaskSelectList() { | 
					
						
							|  |  |  |  |       getTaskList().then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.taskList = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 查询缺陷列表 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     getList() { | 
					
						
							|  |  |  |  |       // 处理日期范围
 | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |       this.loading = true; | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |       const params = { | 
					
						
							|  |  |  |  |         ...this.queryParams, | 
					
						
							|  |  |  |  |         startTime: this.dateTime ? this.dateTime[0] : "", | 
					
						
							|  |  |  |  |         endTime: this.dateTime ? this.dateTime[1] : "", | 
					
						
							|  |  |  |  |       }; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       listDefect(params) | 
					
						
							|  |  |  |  |         .then((response) => { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           this.defectList = response.rows; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           this.total = response.total; | 
					
						
							|  |  |  |  |           this.loading = false; | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |         .catch(() => { | 
					
						
							|  |  |  |  |           this.loading = false; | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 新增/编辑弹窗取消按钮 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     cancel() { | 
					
						
							|  |  |  |  |       this.dialogVisible = false; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       this.upload.fileList = []; | 
					
						
							|  |  |  |  |       this.markers = []; | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |       this.form = { | 
					
						
							|  |  |  |  |         id: null, | 
					
						
							|  |  |  |  |         segmentId: "", | 
					
						
							|  |  |  |  |         defectType: "", | 
					
						
							|  |  |  |  |         dataStatus: "", | 
					
						
							|  |  |  |  |         state: "", | 
					
						
							|  |  |  |  |         stakeStart: "", | 
					
						
							|  |  |  |  |         stakeEnd: "", | 
					
						
							|  |  |  |  |         targetLen: undefined, | 
					
						
							|  |  |  |  |         targetArea: undefined, | 
					
						
							|  |  |  |  |         inspectDirection: "", | 
					
						
							|  |  |  |  |         media: [], | 
					
						
							|  |  |  |  |       }; | 
					
						
							|  |  |  |  |       // this.resetFormData();
 | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 重置表单方法 | 
					
						
							|  |  |  |  |      * @param {*} formName | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     resetForm(formName) { | 
					
						
							|  |  |  |  |       this.$refs[formName].resetFields(); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 表单重置事件 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     resetQuery() { | 
					
						
							|  |  |  |  |       this.resetForm("queryForm"); | 
					
						
							|  |  |  |  |       this.queryParams = { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         page: 1, | 
					
						
							|  |  |  |  |         size: 10, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         segmentName: "", | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |         defectType: "", | 
					
						
							|  |  |  |  |         classType: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         taskId: "", | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         state: "", | 
					
						
							|  |  |  |  |         inspectDirection: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         stakeStart: "", | 
					
						
							|  |  |  |  |         stakeEnd: "", | 
					
						
							|  |  |  |  |         warningFlag: null, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         minLen: undefined, | 
					
						
							|  |  |  |  |         maxLen: undefined, | 
					
						
							|  |  |  |  |         minArea: undefined, | 
					
						
							|  |  |  |  |         maxArea: undefined, | 
					
						
							| 
									
										
										
										
											2025-01-15 15:09:36 +08:00
										 |  |  |  |         dataStatus: "", | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |         id: "", | 
					
						
							|  |  |  |  |         snapshotId: "", | 
					
						
							| 
									
										
										
										
											2024-11-25 15:40:46 +08:00
										 |  |  |  |         taskId: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       }; | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |       this.paramsDefectType = []; | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |       this.dateTime = []; | 
					
						
							|  |  |  |  |       this.getList(); | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 点击搜索按钮操作 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     handleQuery() { | 
					
						
							|  |  |  |  |       const phonereg = /^K\d{4}\+\d{3}$/; | 
					
						
							|  |  |  |  |       if (this.queryParams.stakeStart) { | 
					
						
							|  |  |  |  |         if (phonereg.test(this.queryParams.stakeStart)) { | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |           this.queryParams.classType = this.paramsDefectType | 
					
						
							|  |  |  |  |             ? this.paramsDefectType[0] | 
					
						
							|  |  |  |  |             : ""; | 
					
						
							|  |  |  |  |           this.queryParams.defectType = this.paramsDefectType | 
					
						
							|  |  |  |  |             ? this.paramsDefectType.length > 1 | 
					
						
							|  |  |  |  |               ? this.paramsDefectType[1] | 
					
						
							|  |  |  |  |               : "" | 
					
						
							|  |  |  |  |             : ""; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           this.queryParams.page = 1; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           this.getList(); | 
					
						
							|  |  |  |  |         } else { | 
					
						
							|  |  |  |  |           this.$modal.msgWarning("请按照格式填写公里桩进行修改"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } else if (this.queryParams.stakeEnd) { | 
					
						
							|  |  |  |  |         if (phonereg.test(this.queryParams.stakeEnd)) { | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |           this.queryParams.classType = this.paramsDefectType | 
					
						
							|  |  |  |  |             ? this.paramsDefectType[0] | 
					
						
							|  |  |  |  |             : ""; | 
					
						
							|  |  |  |  |           this.queryParams.defectType = this.paramsDefectType | 
					
						
							|  |  |  |  |             ? this.paramsDefectType.length > 1 | 
					
						
							|  |  |  |  |               ? this.paramsDefectType[1] | 
					
						
							|  |  |  |  |               : "" | 
					
						
							|  |  |  |  |             : ""; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           this.queryParams.page = 1; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           this.getList(); | 
					
						
							|  |  |  |  |         } else { | 
					
						
							|  |  |  |  |           this.$modal.msgWarning("请按照格式填写公里桩进行修改"); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |         this.queryParams.classType = this.paramsDefectType | 
					
						
							|  |  |  |  |           ? this.paramsDefectType[0] | 
					
						
							|  |  |  |  |           : ""; | 
					
						
							|  |  |  |  |         this.queryParams.defectType = this.paramsDefectType | 
					
						
							|  |  |  |  |           ? this.paramsDefectType.length > 1 | 
					
						
							|  |  |  |  |             ? this.paramsDefectType[1] | 
					
						
							|  |  |  |  |             : "" | 
					
						
							|  |  |  |  |           : ""; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         this.queryParams.page = 1; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         this.getList(); | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 多选框选中数据 | 
					
						
							|  |  |  |  |      * @param {*} selection | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     handleSelectionChange(selection) { | 
					
						
							|  |  |  |  |       this.ids = selection.map((item) => item.id); | 
					
						
							|  |  |  |  |       this.single = selection.length !== 1; | 
					
						
							|  |  |  |  |       this.multiple = !selection.length; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 新增按钮操作 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     handleAdd() { | 
					
						
							|  |  |  |  |       this.dialogVisible = true; | 
					
						
							|  |  |  |  |       this.dialogTitle = "添加缺陷"; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 修改按钮操作 | 
					
						
							|  |  |  |  |      * @param {*} row | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     handleUpdate(row) { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       this.dialogVisible = true; | 
					
						
							|  |  |  |  |       this.dialogTitle = "修改缺陷"; | 
					
						
							|  |  |  |  |       this.$nextTick(() => { | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |         const map = this.$refs.diseaseMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.getView().setCenter(row.geometry.coordinates); | 
					
						
							|  |  |  |  |         this.markers = row.geometry.coordinates; | 
					
						
							|  |  |  |  |         this.drawMapPoint(); | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |       this.form = { ...row, dataStatus: row?.dataStatus?.toString() }; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       this.upload.fileList = row.media.map((item) => { | 
					
						
							|  |  |  |  |         return { | 
					
						
							|  |  |  |  |           ...item, | 
					
						
							|  |  |  |  |           url: item.img, | 
					
						
							|  |  |  |  |         }; | 
					
						
							|  |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 批量确认操作 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     handleUpdateBatch() { | 
					
						
							|  |  |  |  |       if (this.ids.length > 0) { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         changeDefectStatus(this.ids).then(({ code, data }) => { | 
					
						
							|  |  |  |  |           if (code === 200) { | 
					
						
							|  |  |  |  |             this.$modal.msgSuccess(`修改${data}`); | 
					
						
							|  |  |  |  |             this.$refs.defectTable.clearSelection(); | 
					
						
							|  |  |  |  |             this.ids = []; | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       } else { | 
					
						
							|  |  |  |  |         this.$modal.msgWarning("请选择一条记录进行修改"); | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 传回来的地图点击事件获取点位数据 | 
					
						
							|  |  |  |  |      * @param {*} e | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     getMapClick(e) { | 
					
						
							|  |  |  |  |       const map = this.$refs.diseaseMap.instance.get("map"); | 
					
						
							|  |  |  |  |       map.removeLayer(this.markLayerPoints); | 
					
						
							|  |  |  |  |       const { coordinate } = e; | 
					
						
							|  |  |  |  |       this.markers = coordinate; | 
					
						
							|  |  |  |  |       this.drawMapPoint(); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 绘制地图点位 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     drawMapPoint() { | 
					
						
							|  |  |  |  |       const features = []; | 
					
						
							|  |  |  |  |       const point = new Point(this.markers); // 修改坐标格式
 | 
					
						
							|  |  |  |  |       const feature = new Feature({ | 
					
						
							|  |  |  |  |         geometry: point, | 
					
						
							|  |  |  |  |         type: "icon", //  自己设置一个标识
 | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       feature.setStyle([ | 
					
						
							|  |  |  |  |         new Style({ | 
					
						
							|  |  |  |  |           image: new styleExports.Circle({ | 
					
						
							|  |  |  |  |             //点样式
 | 
					
						
							|  |  |  |  |             radius: 6, | 
					
						
							|  |  |  |  |             stroke: new styleExports.Stroke({ | 
					
						
							|  |  |  |  |               color: "#9a9c9e", | 
					
						
							|  |  |  |  |               width: 4, | 
					
						
							|  |  |  |  |             }), | 
					
						
							|  |  |  |  |             fill: new styleExports.Fill({ | 
					
						
							|  |  |  |  |               color: "blue", | 
					
						
							|  |  |  |  |             }), | 
					
						
							|  |  |  |  |           }), | 
					
						
							|  |  |  |  |         }), | 
					
						
							|  |  |  |  |       ]); | 
					
						
							|  |  |  |  |       features.push(feature); | 
					
						
							|  |  |  |  |       //设置地图的数据源
 | 
					
						
							|  |  |  |  |       const pointSource = new VectorSource({ | 
					
						
							|  |  |  |  |         features, | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.markLayerPoints = new VectorLayer({ | 
					
						
							|  |  |  |  |         source: pointSource, | 
					
						
							|  |  |  |  |         properties: { | 
					
						
							|  |  |  |  |           type: "point", | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.$nextTick(() => { | 
					
						
							|  |  |  |  |         const map = this.$refs.diseaseMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.addLayer(this.markLayerPoints); | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 文件提交处理 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |     submitUpload() { | 
					
						
							|  |  |  |  |       this.$refs.upload.submit(); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 文件上传中处理 | 
					
						
							|  |  |  |  |      * @param {*} event | 
					
						
							|  |  |  |  |      * @param {*} file | 
					
						
							|  |  |  |  |      * @param {*} fileList | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |     handleFileUploadProgress(event, file, fileList) { | 
					
						
							|  |  |  |  |       this.upload.isUploading = true; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 文件上传成功处理 | 
					
						
							|  |  |  |  |      * @param {*} response | 
					
						
							|  |  |  |  |      * @param {*} file | 
					
						
							|  |  |  |  |      * @param {*} fileList | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |     handleFileSuccess(response, file, fileList) { | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |       this.upload.fileList = fileList.map((item) => { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         if (item.response) { | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |           return { ...item, img: item.response.url }; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         } | 
					
						
							|  |  |  |  |         return item; | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |       this.upload.isUploading = false; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 提交按钮 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     submitForm() { | 
					
						
							|  |  |  |  |       this.$refs["defectForm"].validate((valid) => { | 
					
						
							|  |  |  |  |         if (valid) { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           // 验证点位
 | 
					
						
							|  |  |  |  |           if (this.markers.length < 1) { | 
					
						
							|  |  |  |  |             this.$modal.msgWarning("请选择病害位置"); | 
					
						
							|  |  |  |  |             return false; | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |           // 验证文件上传列表
 | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |           if (this.upload.fileList.length < 1) { | 
					
						
							| 
									
										
										
										
											2024-10-12 14:35:31 +08:00
										 |  |  |  |             this.$modal.msgWarning("请上传图片"); | 
					
						
							|  |  |  |  |             return false; | 
					
						
							|  |  |  |  |           } | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |           const data = { | 
					
						
							|  |  |  |  |             ...this.form, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |             media: this.upload.fileList.map((item) => { | 
					
						
							|  |  |  |  |               return { ...item, img: item.img }; | 
					
						
							|  |  |  |  |             }), | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |             geometry: { | 
					
						
							|  |  |  |  |               type: "Point", | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |               coordinates: this.markers, | 
					
						
							| 
									
										
										
										
											2024-10-25 17:29:08 +08:00
										 |  |  |  |               id: this.form?.geometry?.id, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |             }, | 
					
						
							|  |  |  |  |           }; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |           if (this.form.id) { | 
					
						
							|  |  |  |  |             // 更新缺陷
 | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |             updateDefect(data) | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |               .then(() => { | 
					
						
							|  |  |  |  |                 this.$modal.msgSuccess("修改成功"); | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |                 this.$refs["defectForm"].resetFields(); | 
					
						
							|  |  |  |  |                 this.upload.fileList = []; | 
					
						
							|  |  |  |  |                 this.markers = []; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |                 this.dialogVisible = false; | 
					
						
							|  |  |  |  |                 this.getList(); | 
					
						
							|  |  |  |  |               }) | 
					
						
							|  |  |  |  |               .catch(() => { | 
					
						
							|  |  |  |  |                 this.$modal.msgError("修改失败"); | 
					
						
							|  |  |  |  |               }); | 
					
						
							|  |  |  |  |           } else { | 
					
						
							|  |  |  |  |             // 添加缺陷
 | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |             addDefect(data) | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |               .then(() => { | 
					
						
							|  |  |  |  |                 this.$modal.msgSuccess("新增成功"); | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |                 this.$refs["defectForm"].resetFields(); | 
					
						
							|  |  |  |  |                 this.upload.fileList = []; | 
					
						
							|  |  |  |  |                 this.markers = []; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |                 this.dialogVisible = false; | 
					
						
							|  |  |  |  |                 this.getList(); | 
					
						
							|  |  |  |  |               }) | 
					
						
							|  |  |  |  |               .catch(() => { | 
					
						
							|  |  |  |  |                 this.$modal.msgError("新增失败"); | 
					
						
							|  |  |  |  |               }); | 
					
						
							|  |  |  |  |           } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 删除按钮操作 | 
					
						
							|  |  |  |  |      * @param {*} row | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     handleDelete(row) { | 
					
						
							|  |  |  |  |       const ids = row ? [row.id] : this.ids; | 
					
						
							|  |  |  |  |       if (!ids.length) { | 
					
						
							|  |  |  |  |         this.$modal.msgWarning("请选择要删除的记录"); | 
					
						
							|  |  |  |  |         return; | 
					
						
							|  |  |  |  |       } | 
					
						
							|  |  |  |  |       this.$modal | 
					
						
							|  |  |  |  |         .confirm(`是否确认删除选中的${ids.length}条记录?`) | 
					
						
							|  |  |  |  |         .then(() => { | 
					
						
							|  |  |  |  |           return delDefect(ids); | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |         .then(() => { | 
					
						
							|  |  |  |  |           this.getList(); | 
					
						
							|  |  |  |  |           this.$modal.msgSuccess("删除成功"); | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |         .catch(() => {}); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-14 16:42:10 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 导出按钮事件 | 
					
						
							|  |  |  |  |      * @param {*} | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							|  |  |  |  |     handleExport() { | 
					
						
							|  |  |  |  |       const params = { | 
					
						
							|  |  |  |  |         ...this.queryParams, | 
					
						
							|  |  |  |  |         startTime: this.dateTime ? this.dateTime[0] : "", | 
					
						
							|  |  |  |  |         endTime: this.dateTime ? this.dateTime[1] : "", | 
					
						
							|  |  |  |  |       }; | 
					
						
							|  |  |  |  |       exportDefectData(params) | 
					
						
							|  |  |  |  |         .then((res) => { | 
					
						
							|  |  |  |  |           const link = document.createElement("a"); | 
					
						
							|  |  |  |  |           const blob = new Blob([res], { | 
					
						
							|  |  |  |  |             // type: "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
 | 
					
						
							|  |  |  |  |             // type: "application/zip",
 | 
					
						
							|  |  |  |  |             type: "application/vnd.ms-excel", | 
					
						
							|  |  |  |  |           }); | 
					
						
							|  |  |  |  |           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.getList(); | 
					
						
							|  |  |  |  |         }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 合并按钮事件 | 
					
						
							|  |  |  |  |      * @param {*} row | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |     mergeDefect(row) { | 
					
						
							|  |  |  |  |       this.mergeItem = row; | 
					
						
							|  |  |  |  |       this.mergeVisibleDialog = true; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 拆分按钮事件 | 
					
						
							|  |  |  |  |      * @param {*} row | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |     splitDefect(row) { | 
					
						
							|  |  |  |  |       const snapshotId = row.snapshotId; | 
					
						
							|  |  |  |  |       this.$modal | 
					
						
							|  |  |  |  |         .confirm(`是否确认拆分该条记录?`) | 
					
						
							|  |  |  |  |         .then(() => { | 
					
						
							|  |  |  |  |           return splitDefect({ snapshotId: snapshotId }); | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |         .then(() => { | 
					
						
							|  |  |  |  |           this.getList(); | 
					
						
							|  |  |  |  |           this.$modal.msgSuccess("拆分成功"); | 
					
						
							|  |  |  |  |         }) | 
					
						
							|  |  |  |  |         .catch(() => {}); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 重置表单数据 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     resetFormData() { | 
					
						
							|  |  |  |  |       this.form = { | 
					
						
							|  |  |  |  |         id: null, | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         segmentId: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         defectType: "", | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         dataStatus: "", | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         state: "", | 
					
						
							|  |  |  |  |         stakeStart: "", | 
					
						
							|  |  |  |  |         stakeEnd: "", | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |         targetLen: undefined, | 
					
						
							|  |  |  |  |         targetArea: undefined, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |         inspectDirection: "", | 
					
						
							|  |  |  |  |         media: [], | 
					
						
							|  |  |  |  |       }; | 
					
						
							|  |  |  |  |       this.resetForm("defectForm"); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 点击行列表查看事件 | 
					
						
							|  |  |  |  |      * @param {*} defect | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     viewDefect(defect) { | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       // this.loadDefect(defect.id);
 | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |       this.getSnapShotIdList(defect.id); | 
					
						
							|  |  |  |  |       this.viewCheck = defect.snapshotId; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       this.openViewDialog = true; | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  |       this.viewForm = defect; | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       this.$nextTick(() => { | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |         const map = this.$refs.diseaseMap.instance.get("map"); | 
					
						
							|  |  |  |  |         map.getView().setCenter(defect.geometry.coordinates); | 
					
						
							|  |  |  |  |         this.markers = defect.geometry.coordinates; | 
					
						
							|  |  |  |  |         this.drawMapPoint(); | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 根据病害id获取所有下拉快照数据 | 
					
						
							|  |  |  |  |      * @param {*} id | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |     getSnapShotIdList(id) { | 
					
						
							|  |  |  |  |       getDefectById(id).then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							|  |  |  |  |           this.viewOptions = data; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       }); | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 查看弹窗选择改变触发事件 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |     changeView(val) { | 
					
						
							| 
									
										
										
										
											2024-11-18 17:50:06 +08:00
										 |  |  |  |       getDetailsBySnapShotId(val).then(({ code, data }) => { | 
					
						
							|  |  |  |  |         if (code === 200) { | 
					
						
							| 
									
										
										
										
											2024-11-25 14:27:01 +08:00
										 |  |  |  |           this.viewForm = data; | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |           console.log(data, "查看弹窗选择改变触发事件"); | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-11-18 17:50:06 +08:00
										 |  |  |  |       }); | 
					
						
							| 
									
										
										
										
											2024-11-06 11:07:52 +08:00
										 |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 关闭查看对话框 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |     closeDialog() { | 
					
						
							|  |  |  |  |       this.openViewDialog = false; | 
					
						
							|  |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 打开查看图片弹窗 | 
					
						
							|  |  |  |  |      * @param {*} item | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |     showScreenImg(item) { | 
					
						
							|  |  |  |  |       this.currentImageItem = item; | 
					
						
							| 
									
										
										
										
											2024-12-24 16:18:30 +08:00
										 |  |  |  |       console.log(item, "ddddd"); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |       this.showImageDialog = true; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 图片位置信息获取 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |     updateRects() { | 
					
						
							|  |  |  |  |       this.rects = []; | 
					
						
							|  |  |  |  |       this.rectsItem = {}; | 
					
						
							|  |  |  |  |       const rects = this.currentImageItem?.rect?.split(",").map(Number) || []; | 
					
						
							|  |  |  |  |       this.rects = [ | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           left: rects[0], | 
					
						
							|  |  |  |  |           top: rects[1], | 
					
						
							|  |  |  |  |           width: rects[2], | 
					
						
							|  |  |  |  |           height: rects[3], | 
					
						
							|  |  |  |  |         }, | 
					
						
							|  |  |  |  |       ]; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 图片红框位置 | 
					
						
							|  |  |  |  |      * @param {*} left | 
					
						
							|  |  |  |  |      * @param {*} top | 
					
						
							|  |  |  |  |      * @param {*} width | 
					
						
							|  |  |  |  |      * @param {*} height | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |     getRectStyle({ left, top, width, height }) { | 
					
						
							|  |  |  |  |       const image = this.$refs.mainImage; | 
					
						
							|  |  |  |  |       const container = this.$refs.imageContainer; | 
					
						
							|  |  |  |  |       if (!image || !container) return {}; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       const scaleX = container.clientWidth / image.naturalWidth; | 
					
						
							|  |  |  |  |       const scaleY = container.clientHeight / image.naturalHeight; | 
					
						
							|  |  |  |  |       const scale = Math.min(scaleX, scaleY); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       const renderedWidth = image.naturalWidth * scale; | 
					
						
							|  |  |  |  |       const renderedHeight = image.naturalHeight * scale; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       const offsetX = (container.clientWidth - renderedWidth) / 2; | 
					
						
							|  |  |  |  |       const offsetY = (container.clientHeight - renderedHeight) / 2; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       return { | 
					
						
							|  |  |  |  |         position: "absolute", | 
					
						
							|  |  |  |  |         left: `${left * scale + offsetX}px`, | 
					
						
							|  |  |  |  |         top: `${top * scale + offsetY}px`, | 
					
						
							|  |  |  |  |         width: `${width * scale}px`, | 
					
						
							|  |  |  |  |         height: `${height * scale}px`, | 
					
						
							|  |  |  |  |         border: "2px solid #FF0000", | 
					
						
							|  |  |  |  |         boxSizing: "border-box", | 
					
						
							|  |  |  |  |       }; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 关闭查看图片弹窗 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |     imgCancel() { | 
					
						
							|  |  |  |  |       this.showImageDialog = false; | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |       this.currentImageItem = {}; | 
					
						
							|  |  |  |  |       this.rects = []; | 
					
						
							|  |  |  |  |     }, | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-21 15:38:45 +08:00
										 |  |  |  |     /** | 
					
						
							|  |  |  |  |      * @description: 关闭合并病害弹窗 | 
					
						
							|  |  |  |  |      * @param {*} val | 
					
						
							|  |  |  |  |      * @return {*} | 
					
						
							|  |  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2024-11-05 09:25:16 +08:00
										 |  |  |  |     mergeCancel() { | 
					
						
							|  |  |  |  |       this.mergeVisibleDialog = false; | 
					
						
							|  |  |  |  |       this.getList(); | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |     }, | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  |   }, | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | </script> | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  | <style lang="scss" scoped> | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | .app-container { | 
					
						
							|  |  |  |  |   padding: 20px; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .mb8 { | 
					
						
							|  |  |  |  |   margin-bottom: 8px; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .small-padding { | 
					
						
							|  |  |  |  |   padding: 0 5px; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .fixed-width { | 
					
						
							|  |  |  |  |   width: 120px; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  | /* 新增弹窗/编辑弹窗 */ | 
					
						
							|  |  |  |  | .addForm { | 
					
						
							|  |  |  |  |   .el-select, | 
					
						
							|  |  |  |  |   .el-cascader { | 
					
						
							|  |  |  |  |     width: 100%; | 
					
						
							|  |  |  |  |   } | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | /* 新增地图框样式 */ | 
					
						
							|  |  |  |  | .no-hand-cursor { | 
					
						
							|  |  |  |  |   cursor: default !important; | 
					
						
							|  |  |  |  |   width: 100%; | 
					
						
							|  |  |  |  |   height: 20rem; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-11 15:04:14 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /* 上传文件列表样式 */ | 
					
						
							|  |  |  |  | ::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-11-04 10:38:06 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /* 查看大图弹窗 */ | 
					
						
							|  |  |  |  | .image-container { | 
					
						
							|  |  |  |  |   position: relative; | 
					
						
							|  |  |  |  |   width: 100%; | 
					
						
							|  |  |  |  |   height: 80%; | 
					
						
							|  |  |  |  |   display: flex; | 
					
						
							| 
									
										
										
										
											2024-12-24 16:18:30 +08:00
										 |  |  |  |   flex-direction: column; | 
					
						
							| 
									
										
										
										
											2024-11-04 10:38:06 +08:00
										 |  |  |  |   align-items: center; | 
					
						
							|  |  |  |  |   justify-content: center; | 
					
						
							|  |  |  |  |   overflow: hidden; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .image-container img { | 
					
						
							|  |  |  |  |   max-width: 100%; | 
					
						
							|  |  |  |  |   max-height: 100%; | 
					
						
							|  |  |  |  |   object-fit: contain; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | .rect-overlay { | 
					
						
							|  |  |  |  |   position: absolute; | 
					
						
							|  |  |  |  |   pointer-events: none; | 
					
						
							|  |  |  |  |   border: 2px solid red; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-12-24 16:18:30 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | // 图片信息
 | 
					
						
							|  |  |  |  | .rect-image { | 
					
						
							|  |  |  |  |   width: 90%; | 
					
						
							|  |  |  |  |   position: absolute; | 
					
						
							|  |  |  |  |   top: 0; | 
					
						
							|  |  |  |  |   font-size: 1.2rem; | 
					
						
							|  |  |  |  |   color: #ffffff; | 
					
						
							|  |  |  |  |   background-color: rgba(0, 0, 0, 0.5); | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2024-10-09 11:55:13 +08:00
										 |  |  |  | </style> |