增加元数据接口,
This commit is contained in:
parent
95fe3563cb
commit
26686e62e4
@ -1,7 +1,7 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<script src="https://api.tianditu.gov.cn/api?v=4.0&tk=c691040443c68cda625755c5c3e2acc3" type="text/javascript"></script>
|
||||
<script src="https://api.tianditu.gov.cn/api?v=4.0&tk=1eb44fae5b9dc454442b322e9a41d233" type="text/javascript"></script>
|
||||
|
||||
<meta charset="utf-8">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||
|
||||
@ -1,44 +1,44 @@
|
||||
import request from '@/utils/request'
|
||||
|
||||
// 查询病害列表
|
||||
// 查询病害日志列表
|
||||
export function listDefect(query) {
|
||||
return request({
|
||||
url: '/api/defect/list',
|
||||
url: '/xj/defect/list',
|
||||
method: 'get',
|
||||
params: query
|
||||
})
|
||||
}
|
||||
|
||||
// 查询病害详细
|
||||
// 查询病害日志详细
|
||||
export function getDefect(id) {
|
||||
return request({
|
||||
url: '/api/defect/' + id,
|
||||
url: '/xj/defect/' + id,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
|
||||
// 新增病害
|
||||
// 新增病害日志
|
||||
export function addDefect(data) {
|
||||
return request({
|
||||
url: '/api/defect',
|
||||
url: '/xj/defect',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 修改病害
|
||||
// 修改病害日志
|
||||
export function updateDefect(data) {
|
||||
return request({
|
||||
url: '/api/defect',
|
||||
url: '/xj/defect',
|
||||
method: 'put',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 删除病害
|
||||
// 删除病害日志
|
||||
export function delDefect(id) {
|
||||
return request({
|
||||
url: '/api/defect/' + id,
|
||||
url: '/xj/defect/' + id,
|
||||
method: 'delete'
|
||||
})
|
||||
}
|
||||
16
src/api/xj/metadata.js
Normal file
16
src/api/xj/metadata.js
Normal file
@ -0,0 +1,16 @@
|
||||
import request from "@/utils/request";
|
||||
|
||||
// 查询病害日志列表
|
||||
export function listMetadata(query) {
|
||||
return request({
|
||||
url: '/metadata/list',
|
||||
method: 'get',
|
||||
params: query
|
||||
})
|
||||
}
|
||||
export function refreshCache () {
|
||||
return request({
|
||||
url: '/metadata/',
|
||||
method: 'delete',
|
||||
})
|
||||
}
|
||||
44
src/api/xj/route.js
Normal file
44
src/api/xj/route.js
Normal file
@ -0,0 +1,44 @@
|
||||
import request from '@/utils/request'
|
||||
|
||||
// 查询道路线列表
|
||||
export function listRoute(query) {
|
||||
return request({
|
||||
url: '/xj/route/list',
|
||||
method: 'get',
|
||||
params: query
|
||||
})
|
||||
}
|
||||
|
||||
// 查询道路线详细
|
||||
export function getRoute(id) {
|
||||
return request({
|
||||
url: '/xj/route/' + id,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
|
||||
// 新增道路线
|
||||
export function addRoute(data) {
|
||||
return request({
|
||||
url: '/xj/route',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 修改道路线
|
||||
export function updateRoute(data) {
|
||||
return request({
|
||||
url: '/xj/route',
|
||||
method: 'put',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 删除道路线
|
||||
export function delRoute(id) {
|
||||
return request({
|
||||
url: '/xj/route/' + id,
|
||||
method: 'delete'
|
||||
})
|
||||
}
|
||||
44
src/api/xj/segment.js
Normal file
44
src/api/xj/segment.js
Normal file
@ -0,0 +1,44 @@
|
||||
import request from '@/utils/request'
|
||||
|
||||
// 查询道路线列表
|
||||
export function listSegment(query) {
|
||||
return request({
|
||||
url: '/xj/segment/list',
|
||||
method: 'get',
|
||||
params: query
|
||||
})
|
||||
}
|
||||
|
||||
// 查询道路线详细
|
||||
export function getSegment(id) {
|
||||
return request({
|
||||
url: '/xj/segment/' + id,
|
||||
method: 'get'
|
||||
})
|
||||
}
|
||||
|
||||
// 新增道路线
|
||||
export function addSegment(data) {
|
||||
return request({
|
||||
url: '/xj/segment',
|
||||
method: 'post',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 修改道路线
|
||||
export function updateSegment(data) {
|
||||
return request({
|
||||
url: '/xj/segment',
|
||||
method: 'put',
|
||||
data: data
|
||||
})
|
||||
}
|
||||
|
||||
// 删除道路线
|
||||
export function delSegment(id) {
|
||||
return request({
|
||||
url: '/xj/segment/' + id,
|
||||
method: 'delete'
|
||||
})
|
||||
}
|
||||
@ -1,5 +1,5 @@
|
||||
<template>
|
||||
<div id="mapContainer" style="width: 100%; height: 100%;"></div>
|
||||
<div id="mapContainer" style="width: 100%; height: 100%;background-color:rgba(0,211,0,0.6)"></div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
@ -11,15 +11,28 @@ export default {
|
||||
},
|
||||
methods: {
|
||||
initializeMap() {
|
||||
var imageURL = "http://t0.tianditu.gov.cn/img_w/wmts?" +
|
||||
"SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=img&STYLE=default&TILEMATRIXSET=w&FORMAT=tiles" +
|
||||
"&TILEMATRIX={z}&TILEROW={y}&TILECOL={x}&tk=1eb44fae5b9dc454442b322e9a41d233";
|
||||
//创建自定义图层对象
|
||||
var lay = new T.TileLayer(imageURL, {minZoom: 1, maxZoom: 18});
|
||||
var config = {layers: [lay]};
|
||||
// 创建地图对象
|
||||
const map = new T.Map('mapContainer');
|
||||
const map = new T.Map('mapContainer', config);
|
||||
|
||||
// 设置地图中心点和缩放级别
|
||||
map.centerAndZoom(new T.LngLat(116.404, 39.915), 12);
|
||||
|
||||
map.setStyle("indigo")
|
||||
// 添加图层(例如:底图层)
|
||||
// map.addLayer(new T.TileLayer());
|
||||
|
||||
const options = new T.Control.OverviewMapOptions();
|
||||
options.anchor = "T_ANCHOR_TOP_RIGHT";
|
||||
options.size = new T.Point(100, 100)
|
||||
options.isOpen = true;
|
||||
|
||||
let a = T.Control.OverviewMap(options)
|
||||
map.addControl(a);
|
||||
let points = [];
|
||||
points.push(new T.LngLat(116.41136, 39.97569));
|
||||
points.push(new T.LngLat(116.411794, 39.9068));
|
||||
@ -28,7 +41,6 @@ export default {
|
||||
var line = new T.Polyline(points);
|
||||
line.addEventListener('mouseover', this.handleMouseOver);
|
||||
line.addEventListener('mouseout', this.handleMouseOut);
|
||||
|
||||
//向地图上添加线
|
||||
map.addOverLay(line);
|
||||
|
||||
|
||||
@ -1,595 +0,0 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||||
<el-form-item label="病害类型" prop="defectType">
|
||||
<el-select v-model="queryParams.defectType" placeholder="请选择病害类型(0,1,2,1000等)" clearable>
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="路产类型" prop="equipmentType">
|
||||
<el-select v-model="queryParams.equipmentType" placeholder="请选择路产类型" clearable>
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害状态" prop="bhStatus">
|
||||
<el-select v-model="queryParams.bhStatus" placeholder="请选择病害状态" clearable>
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="开始桩号" prop="stakeStart">
|
||||
<el-input
|
||||
v-model="queryParams.stakeStart"
|
||||
placeholder="请输入开始桩号"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="结束桩号" prop="stakeEnd">
|
||||
<el-input
|
||||
v-model="queryParams.stakeEnd"
|
||||
placeholder="请输入结束桩号"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害位置" prop="geometry">
|
||||
<el-input
|
||||
v-model="queryParams.geometry"
|
||||
placeholder="请输入病害位置"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害面积" prop="targetArea">
|
||||
<el-input
|
||||
v-model="queryParams.targetArea"
|
||||
placeholder="请输入病害面积"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害长度" prop="targetLen">
|
||||
<el-input
|
||||
v-model="queryParams.targetLen"
|
||||
placeholder="请输入病害长度"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害快照id" prop="snapshotId">
|
||||
<el-input
|
||||
v-model="queryParams.snapshotId"
|
||||
placeholder="请输入病害快照id"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="任务id" prop="taskId">
|
||||
<el-input
|
||||
v-model="queryParams.taskId"
|
||||
placeholder="请输入任务id"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="路段id" prop="segmentId">
|
||||
<el-input
|
||||
v-model="queryParams.segmentId"
|
||||
placeholder="请输入路段id"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="路段名称" prop="segmentName">
|
||||
<el-input
|
||||
v-model="queryParams.segmentName"
|
||||
placeholder="请输入路段名称"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="上下行信息" prop="inspectDirection">
|
||||
<el-input
|
||||
v-model="queryParams.inspectDirection"
|
||||
placeholder="请输入上下行信息"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="数据来源" prop="datafrom">
|
||||
<el-input
|
||||
v-model="queryParams.datafrom"
|
||||
placeholder="请输入数据来源,离线上传:offline,实时上传:Inspect"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="是否报警" prop="warningflag">
|
||||
<el-input
|
||||
v-model="queryParams.warningflag"
|
||||
placeholder="请输入是否报警"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="图片资源" prop="media">
|
||||
<el-input
|
||||
v-model="queryParams.media"
|
||||
placeholder="请输入图片资源"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="关联路产实体id" prop="equipmentId">
|
||||
<el-input
|
||||
v-model="queryParams.equipmentId"
|
||||
placeholder="请输入关联路产实体id"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="相比上次的变化状态" prop="transformation">
|
||||
<el-input
|
||||
v-model="queryParams.transformation"
|
||||
placeholder="请输入相比上次的变化状态"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="数据状态" prop="dataStatus">
|
||||
<el-select v-model="queryParams.dataStatus" placeholder="请选择数据状态" clearable>
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害与车顶天线距离" prop="objDistance">
|
||||
<el-input
|
||||
v-model="queryParams.objDistance"
|
||||
placeholder="请输入病害与车顶天线距离"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="公里桩是否校准" prop="calibrated">
|
||||
<el-input
|
||||
v-model="queryParams.calibrated"
|
||||
placeholder="请输入公里桩是否校准0:未校准,1:已校准"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<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"
|
||||
v-hasPermi="['api:defect:add']"
|
||||
>新增</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['api:defect:edit']"
|
||||
>修改</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['api:defect:remove']"
|
||||
>删除</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['api:defect:export']"
|
||||
>导出</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<el-table v-loading="loading" :data="defectList" @selection-change="handleSelectionChange">
|
||||
<el-table-column type="selection" width="55" align="center" />
|
||||
<el-table-column label="病害唯一id" align="center" prop="id" />
|
||||
<el-table-column label="病害类型(0,1,2,1000等)" align="center" prop="defectType">
|
||||
<template slot-scope="scope">
|
||||
<dict-tag :options="dict.type.bh_type" :value="scope.row.defectType"/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="路产类型" align="center" prop="equipmentType">
|
||||
<template slot-scope="scope">
|
||||
<dict-tag :options="dict.type.bh_type" :value="scope.row.equipmentType"/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="病害状态" align="center" prop="bhStatus">
|
||||
<template slot-scope="scope">
|
||||
<dict-tag :options="dict.type.bh_type" :value="scope.row.bhStatus"/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="开始桩号" align="center" prop="stakeStart" />
|
||||
<el-table-column label="结束桩号" align="center" prop="stakeEnd" />
|
||||
<el-table-column label="病害位置" align="center" prop="geometry" />
|
||||
<el-table-column label="病害面积" align="center" prop="targetArea" />
|
||||
<el-table-column label="病害长度" align="center" prop="targetLen" />
|
||||
<el-table-column label="病害快照id" align="center" prop="snapshotId" />
|
||||
<el-table-column label="任务id" align="center" prop="taskId" />
|
||||
<el-table-column label="路段id" align="center" prop="segmentId" />
|
||||
<el-table-column label="路段名称" align="center" prop="segmentName" />
|
||||
<el-table-column label="上下行信息" align="center" prop="inspectDirection" />
|
||||
<el-table-column label="数据来源,离线上传:offline,实时上传:Inspect" align="center" prop="datafrom" />
|
||||
<el-table-column label="是否报警" align="center" prop="warningflag" />
|
||||
<el-table-column label="病害图片" width="150">
|
||||
<template slot-scope="scope">
|
||||
<el-popover
|
||||
placement="top-start"
|
||||
trigger="hover">
|
||||
<img :src="scope.row.diseaseImage" />
|
||||
|
||||
<img :src="scope.row.diseaseImage" height="40px" slot="reference" />
|
||||
</el-popover>
|
||||
</template>
|
||||
</el-table-column> <el-table-column label="关联路产实体id" align="center" prop="equipmentId" />
|
||||
<el-table-column label="相比上次的变化状态" align="center" prop="transformation" />
|
||||
<el-table-column label="数据状态" align="center" prop="dataStatus">
|
||||
<template slot-scope="scope">
|
||||
<dict-tag :options="dict.type.bh_type" :value="scope.row.dataStatus"/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="病害与车顶天线距离" align="center" prop="objDistance" />
|
||||
<el-table-column label="公里桩是否校准0:未校准,1:已校准" align="center" prop="calibrated" />
|
||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-edit"
|
||||
@click="handleUpdate(scope.row)"
|
||||
v-hasPermi="['api:defect:edit']"
|
||||
>修改</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['api:defect:remove']"
|
||||
>删除</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"
|
||||
/>
|
||||
|
||||
<!-- 添加或修改病害对话框 -->
|
||||
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
|
||||
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
||||
<el-form-item label="病害类型" prop="defectType">
|
||||
<el-select v-model="form.defectType" placeholder="请选择病害类型(0,1,2,1000等)">
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="路产类型" prop="equipmentType">
|
||||
<el-select v-model="form.equipmentType" placeholder="请选择路产类型">
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害状态" prop="bhStatus">
|
||||
<el-select v-model="form.bhStatus" placeholder="请选择病害状态">
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="开始桩号" prop="stakeStart">
|
||||
<el-input v-model="form.stakeStart" placeholder="请输入开始桩号" />
|
||||
</el-form-item>
|
||||
<el-form-item label="结束桩号" prop="stakeEnd">
|
||||
<el-input v-model="form.stakeEnd" placeholder="请输入结束桩号" />
|
||||
</el-form-item>
|
||||
<el-form-item label="病害位置" prop="geometry">
|
||||
<el-input v-model="form.geometry" placeholder="请输入病害位置" />
|
||||
</el-form-item>
|
||||
<el-form-item label="病害面积" prop="targetArea">
|
||||
<el-input v-model="form.targetArea" placeholder="请输入病害面积" />
|
||||
</el-form-item>
|
||||
<el-form-item label="病害长度" prop="targetLen">
|
||||
<el-input v-model="form.targetLen" placeholder="请输入病害长度" />
|
||||
</el-form-item>
|
||||
<el-form-item label="路段名称" prop="segmentName">
|
||||
<el-input v-model="form.segmentName" placeholder="请输入路段名称" />
|
||||
</el-form-item>
|
||||
<el-form-item label="上下行信息" prop="inspectDirection">
|
||||
<el-input v-model="form.inspectDirection" placeholder="请输入上下行信息" />
|
||||
</el-form-item>
|
||||
<el-form-item label="数据来源" prop="datafrom">
|
||||
<el-input v-model="form.datafrom" placeholder="请输入数据来源,离线上传:offline,实时上传:Inspect" />
|
||||
</el-form-item>
|
||||
<el-form-item label="是否报警" prop="warningflag">
|
||||
<el-input v-model="form.warningflag" placeholder="请输入是否报警" />
|
||||
</el-form-item>
|
||||
<el-form-item label="图片资源" prop="media">
|
||||
<el-input v-model="form.media" placeholder="请输入图片资源" />
|
||||
</el-form-item>
|
||||
<el-form-item label="关联路产实体id" prop="equipmentId">
|
||||
<el-input v-model="form.equipmentId" placeholder="请输入关联路产实体id" />
|
||||
</el-form-item>
|
||||
<el-form-item label="相比上次的变化状态" prop="transformation">
|
||||
<el-input v-model="form.transformation" placeholder="请输入相比上次的变化状态" />
|
||||
</el-form-item>
|
||||
<el-form-item label="数据状态" prop="dataStatus">
|
||||
<el-select v-model="form.dataStatus" placeholder="请选择数据状态">
|
||||
<el-option
|
||||
v-for="dict in dict.type.bh_type"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="parseInt(dict.value)"
|
||||
></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害与车顶天线距离" prop="objDistance">
|
||||
<el-input v-model="form.objDistance" placeholder="请输入病害与车顶天线距离" />
|
||||
</el-form-item>
|
||||
<el-form-item label="公里桩是否校准" prop="calibrated">
|
||||
<el-input v-model="form.calibrated" placeholder="请输入公里桩是否校准0:未校准,1:已校准" />
|
||||
</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>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { listDefect, getDefect, delDefect, addDefect, updateDefect } from "@/api/api/defect";
|
||||
|
||||
export default {
|
||||
name: "Defect",
|
||||
dicts: ['bh_type'],
|
||||
data() {
|
||||
return {
|
||||
// 遮罩层
|
||||
loading: true,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
single: true,
|
||||
// 非多个禁用
|
||||
multiple: true,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 病害表格数据
|
||||
defectList: [],
|
||||
// 弹出层标题
|
||||
title: "",
|
||||
// 是否显示弹出层
|
||||
open: false,
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
defectType: null,
|
||||
equipmentType: null,
|
||||
bhStatus: null,
|
||||
stakeStart: null,
|
||||
stakeEnd: null,
|
||||
geometry: null,
|
||||
targetArea: null,
|
||||
targetLen: null,
|
||||
snapshotId: null,
|
||||
taskId: null,
|
||||
segmentId: null,
|
||||
segmentName: null,
|
||||
inspectDirection: null,
|
||||
datafrom: null,
|
||||
warningflag: null,
|
||||
media: null,
|
||||
equipmentId: null,
|
||||
transformation: null,
|
||||
dataStatus: null,
|
||||
objDistance: null,
|
||||
calibrated: null
|
||||
},
|
||||
// 表单参数
|
||||
form: {},
|
||||
// 表单校验
|
||||
rules: {
|
||||
stakeStart: [
|
||||
{ required: true, message: "开始桩号不能为空", trigger: "blur" }
|
||||
],
|
||||
stakeEnd: [
|
||||
{ required: true, message: "结束桩号不能为空", trigger: "blur" }
|
||||
],
|
||||
geometry: [
|
||||
{ required: true, message: "病害位置不能为空", trigger: "blur" }
|
||||
],
|
||||
targetArea: [
|
||||
{ required: true, message: "病害面积不能为空", trigger: "blur" }
|
||||
],
|
||||
targetLen: [
|
||||
{ required: true, message: "病害长度不能为空", trigger: "blur" }
|
||||
],
|
||||
}
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.getList();
|
||||
},
|
||||
methods: {
|
||||
/** 查询病害列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
listDefect(this.queryParams).then(response => {
|
||||
this.defectList = response.rows;
|
||||
this.total = response.total;
|
||||
this.loading = false;
|
||||
});
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
this.open = false;
|
||||
this.reset();
|
||||
},
|
||||
// 表单重置
|
||||
reset() {
|
||||
this.form = {
|
||||
id: null,
|
||||
defectType: null,
|
||||
equipmentType: null,
|
||||
createTime: null,
|
||||
updateTime: null,
|
||||
bhStatus: null,
|
||||
stakeStart: null,
|
||||
stakeEnd: null,
|
||||
geometry: null,
|
||||
targetArea: null,
|
||||
targetLen: null,
|
||||
snapshotId: null,
|
||||
taskId: null,
|
||||
segmentId: null,
|
||||
segmentName: null,
|
||||
inspectDirection: null,
|
||||
datafrom: null,
|
||||
warningflag: null,
|
||||
media: null,
|
||||
equipmentId: null,
|
||||
transformation: null,
|
||||
dataStatus: null,
|
||||
objDistance: null,
|
||||
calibrated: null
|
||||
};
|
||||
this.resetForm("form");
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNum = 1;
|
||||
this.getList();
|
||||
},
|
||||
/** 重置按钮操作 */
|
||||
resetQuery() {
|
||||
this.resetForm("queryForm");
|
||||
this.handleQuery();
|
||||
},
|
||||
// 多选框选中数据
|
||||
handleSelectionChange(selection) {
|
||||
this.ids = selection.map(item => item.id)
|
||||
this.single = selection.length!==1
|
||||
this.multiple = !selection.length
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.reset();
|
||||
this.open = true;
|
||||
this.title = "添加病害";
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
this.reset();
|
||||
const id = row.id || this.ids
|
||||
getDefect(id).then(response => {
|
||||
this.form = response.data;
|
||||
this.open = true;
|
||||
this.title = "修改病害";
|
||||
});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm() {
|
||||
this.$refs["form"].validate(valid => {
|
||||
if (valid) {
|
||||
if (this.form.id != null) {
|
||||
updateDefect(this.form).then(response => {
|
||||
this.$modal.msgSuccess("修改成功");
|
||||
this.open = false;
|
||||
this.getList();
|
||||
});
|
||||
} else {
|
||||
addDefect(this.form).then(response => {
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.open = false;
|
||||
this.getList();
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
handleDelete(row) {
|
||||
const ids = row.id || this.ids;
|
||||
this.$modal.confirm('是否确认删除病害编号为"' + ids + '"的数据项?').then(function() {
|
||||
return delDefect(ids);
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("删除成功");
|
||||
}).catch(() => {});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
this.download('api/defect/export', {
|
||||
...this.queryParams
|
||||
}, `defect_${new Date().getTime()}.xlsx`)
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
@ -39,8 +39,8 @@ export default {
|
||||
|
||||
<style scoped lang="scss">
|
||||
.map{
|
||||
width: 2000px;
|
||||
height: 1800px;
|
||||
width: 1000px;
|
||||
height: 800px;
|
||||
}
|
||||
</style>
|
||||
|
||||
|
||||
682
src/views/system/depect/index.vue
Normal file
682
src/views/system/depect/index.vue
Normal file
@ -0,0 +1,682 @@
|
||||
<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">
|
||||
<el-input
|
||||
v-model="queryParams.segmentName"
|
||||
placeholder="请输入道路名称"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="采集时间" prop="dateTime">
|
||||
<el-date-picker
|
||||
v-model="queryParams.dateTime"
|
||||
type="daterange"
|
||||
start-placeholder="开始日期"
|
||||
end-placeholder="结束日期"
|
||||
format="yyyy-MM-dd"
|
||||
value-format="yyyy-MM-dd"
|
||||
clearable
|
||||
@change="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害类型" prop="defectType">
|
||||
<el-select v-model="queryParams.defectType" placeholder="请选择" clearable multiple>
|
||||
<el-option v-for="item in defectTypes" :key="item.value" :label="item.label" :value="item.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="任务ID" prop="taskId">
|
||||
<el-input
|
||||
v-model="queryParams.taskId"
|
||||
placeholder="请输入任务ID"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害状态" prop="state">
|
||||
<el-select v-model="queryParams.state" placeholder="请选择" clearable multiple>
|
||||
<el-option v-for="item in states" :key="item.value" :label="item.label" :value="item.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="上下行" prop="inspectDirection">
|
||||
<el-select v-model="queryParams.inspectDirection" placeholder="请选择" clearable multiple>
|
||||
<el-option label="上行" value="upstream" />
|
||||
<el-option label="下行" value="downstream" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="公里桩" prop="stakeRange">
|
||||
<el-input
|
||||
v-model="queryParams.stakeStart"
|
||||
placeholder="起始公里桩"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.stakeEnd"
|
||||
placeholder="终止公里桩"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="预警标识" prop="warningFlag">
|
||||
<el-select v-model="queryParams.warningFlag" placeholder="请选择" clearable>
|
||||
<el-option label="是" :value="1" />
|
||||
<el-option label="否" :value="0" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害长度" prop="lengthRange">
|
||||
<el-input
|
||||
v-model="queryParams.minLen"
|
||||
placeholder="最小长度"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.maxLen"
|
||||
placeholder="最大长度"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害面积" prop="areaRange">
|
||||
<el-input
|
||||
v-model="queryParams.minArea"
|
||||
placeholder="最小面积"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.maxArea"
|
||||
placeholder="最大面积"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="距离车顶天线" prop="distanceRange">
|
||||
<el-input
|
||||
v-model="queryParams.minDistance"
|
||||
placeholder="最小距离"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.maxDistance"
|
||||
placeholder="最大距离"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<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="2">
|
||||
<el-button
|
||||
type="primary"
|
||||
plain
|
||||
icon="el-icon-plus"
|
||||
size="mini"
|
||||
@click="handleAdd"
|
||||
v-hasPermi="['system:defect:add']"
|
||||
>新增</el-button>
|
||||
</el-col>
|
||||
<el-col :span="2">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['system:defect:edit']"
|
||||
>修改</el-button>
|
||||
</el-col>
|
||||
<el-col :span="2">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['system:defect:remove']"
|
||||
>删除</el-button>
|
||||
</el-col>
|
||||
<el-col :span="2">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['system:defect:export']"
|
||||
>导出</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<!-- 数据表格 -->
|
||||
<el-table 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" />
|
||||
<el-table-column label="采集时间" align="center" prop="createdTime" />
|
||||
<el-table-column label="病害类型" align="center" prop="defectType" />
|
||||
<el-table-column label="病害状态" align="center" prop="state" />
|
||||
<el-table-column label="开始桩号" align="center" prop="stakeStart" />
|
||||
<el-table-column label="结束桩号" align="center" prop="stakeEnd" />
|
||||
<el-table-column label="病害长度" align="center" prop="targetLen" />
|
||||
<el-table-column label="病害面积" align="center" prop="targetArea" />
|
||||
<el-table-column label="预警标识" align="center" prop="warningFlag">
|
||||
<template slot-scope="scope">
|
||||
<el-tag :type="scope.row.warningFlag === 1 ? 'danger' : 'success'">
|
||||
{{ scope.row.warningFlag === 1 ? '是' : '否' }}
|
||||
</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-edit"
|
||||
@click="handleUpdate(scope.row)"
|
||||
v-hasPermi="['system:defect:edit']"
|
||||
>修改</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['system:defect:remove']"
|
||||
>删除</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<!-- 分页组件 -->
|
||||
<pagination
|
||||
v-show="total > 0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"
|
||||
/>
|
||||
|
||||
<!-- 添加或修改缺陷对话框 -->
|
||||
<el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="600px" append-to-body>
|
||||
<el-form ref="defectForm" :model="form" :rules="rules" label-width="100px">
|
||||
<el-form-item label="道路名称" prop="segmentName">
|
||||
<el-input v-model="form.segmentName" placeholder="请输入道路名称" />
|
||||
</el-form-item>
|
||||
<el-form-item label="病害类型" prop="defectType">
|
||||
<el-select v-model="form.defectType" placeholder="请选择病害类型" clearable>
|
||||
<el-option v-for="item in defectTypes" :key="item.value" :label="item.label" :value="item.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害状态" prop="state">
|
||||
<el-select v-model="form.state" placeholder="请选择病害状态" clearable>
|
||||
<el-option v-for="item in states" :key="item.value" :label="item.label" :value="item.value" />
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="采集时间" prop="createdTime">
|
||||
<el-date-picker
|
||||
v-model="form.createdTime"
|
||||
type="datetime"
|
||||
placeholder="选择采集时间"
|
||||
format="yyyy-MM-dd HH:mm:ss"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="开始桩号" prop="stakeStart">
|
||||
<el-input v-model="form.stakeStart" placeholder="请输入开始桩号" />
|
||||
</el-form-item>
|
||||
<el-form-item label="结束桩号" prop="stakeEnd">
|
||||
<el-input v-model="form.stakeEnd" placeholder="请输入结束桩号" />
|
||||
</el-form-item>
|
||||
<el-form-item label="病害长度" prop="targetLen">
|
||||
<el-input-number v-model="form.targetLen" :min="0" placeholder="请输入病害长度" style="width: 100%" />
|
||||
</el-form-item>
|
||||
<el-form-item label="病害面积" prop="targetArea">
|
||||
<el-input-number v-model="form.targetArea" :min="0" placeholder="请输入病害面积" style="width: 100%" />
|
||||
</el-form-item>
|
||||
<el-form-item label="预警标识" prop="warningFlag">
|
||||
<el-switch v-model="form.warningFlag" active-value="1" inactive-value="0" active-text="是" inactive-text="否" />
|
||||
</el-form-item>
|
||||
<el-form-item label="病害位置" prop="geometry">
|
||||
<el-input v-model="form.geometry.coordinates" placeholder="请输入坐标 (e.g., [lng, lat])" />
|
||||
</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>
|
||||
</el-dialog>
|
||||
|
||||
|
||||
<!-- 查看病害详细信息对话框 -->
|
||||
<el-dialog title="查看病害详细信息" :visible.sync="openViewDialog" width="800px" append-to-body>
|
||||
<div>
|
||||
<!-- 上半部分 -->
|
||||
<div style="display: flex; height: 50%;">
|
||||
<!-- 左侧病害信息 -->
|
||||
<div style="flex: 1; padding: 10px;">
|
||||
<p>上报日期:{{ form.createdTime }}</p>
|
||||
<p>路段名称:{{ form.segmentName }}</p>
|
||||
<p>病害坐标:{{ form.geometry.coordinates }}</p>
|
||||
<p>病害类型:{{ form.defectType }}</p>
|
||||
<p>病害长度:{{ form.targetLen }} 米</p>
|
||||
</div>
|
||||
|
||||
<!-- 右侧图片展示 -->
|
||||
<div style="flex: 1; padding: 10px;">
|
||||
<el-carousel height="150px">
|
||||
<el-carousel-item v-for="(img, index) in form.media" :key="index">
|
||||
<img :src="img.img" alt="病害图片" style="width: 100%;" />
|
||||
</el-carousel-item>
|
||||
</el-carousel>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 下半部分显示天地图 -->
|
||||
<div id="mapContainer" style="height: 300px; margin-top: 20px;"></div>
|
||||
</div>
|
||||
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button @click="closeDialog">关闭</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import {
|
||||
listDefect,
|
||||
getDefect,
|
||||
delDefect,
|
||||
addDefect,
|
||||
updateDefect,
|
||||
exportDefect
|
||||
} from "@/api/xj/defect";
|
||||
|
||||
export default {
|
||||
name: "Defect",
|
||||
data() {
|
||||
return {
|
||||
openViewDialog: false,
|
||||
|
||||
// 遮罩层
|
||||
loading: false,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
single: true,
|
||||
// 非多个禁用
|
||||
multiple: true,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 缺陷表格数据
|
||||
defectList: [],
|
||||
// 弹出层标题
|
||||
dialogTitle: "",
|
||||
// 是否显示弹出层
|
||||
dialogVisible: false,
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
segmentName: "",
|
||||
dateTime: [],
|
||||
defectType: [],
|
||||
taskId: "",
|
||||
state: [],
|
||||
inspectDirection: [],
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
warningFlag: null,
|
||||
minLen: null,
|
||||
maxLen: null,
|
||||
minArea: null,
|
||||
maxArea: null,
|
||||
minDistance: null,
|
||||
maxDistance: null
|
||||
},
|
||||
// 表单参数
|
||||
form: {
|
||||
id: null,
|
||||
segmentName: "",
|
||||
defectType: "",
|
||||
equipmentType: "",
|
||||
createdTime: "",
|
||||
updatedTime: "",
|
||||
state: "",
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
geometry: {
|
||||
type: "Point",
|
||||
coordinates: []
|
||||
},
|
||||
targetArea: null,
|
||||
targetLen: null,
|
||||
snapshotId: "",
|
||||
taskId: "",
|
||||
segmentId: "",
|
||||
inspectDirection: "",
|
||||
dataFrom: "",
|
||||
warningFlag: 0,
|
||||
equipmentId: "",
|
||||
transformation: 0,
|
||||
dataStatus: 0,
|
||||
objDistance: null,
|
||||
isCalibrated: 0,
|
||||
count: 0,
|
||||
media: []
|
||||
},
|
||||
// 表单校验规则
|
||||
rules: {
|
||||
segmentName: [
|
||||
{ required: true, message: "请输入道路名称", trigger: "blur" }
|
||||
],
|
||||
defectType: [
|
||||
{ required: true, message: "请选择病害类型", trigger: "change" }
|
||||
],
|
||||
state: [
|
||||
{ required: true, message: "请选择病害状态", trigger: "change" }
|
||||
],
|
||||
createdTime: [
|
||||
{ type: "array", required: false, message: "请选择采集时间", trigger: "change" }
|
||||
],
|
||||
stakeStart: [
|
||||
{ required: false, message: "请输入开始桩号", trigger: "blur" }
|
||||
],
|
||||
stakeEnd: [
|
||||
{ required: false, message: "请输入结束桩号", trigger: "blur" }
|
||||
],
|
||||
targetLen: [
|
||||
{ type: "number", min: 0, message: "病害长度必须为正数", trigger: "change" }
|
||||
],
|
||||
targetArea: [
|
||||
{ type: "number", min: 0, message: "病害面积必须为正数", trigger: "change" }
|
||||
]
|
||||
// 可以根据需要添加更多校验规则
|
||||
},
|
||||
// 下拉选项
|
||||
defectTypes: [
|
||||
{ label: "裂缝", value: "crack" },
|
||||
{ label: "坑槽", value: "pothole" },
|
||||
{ label: "脱皮", value: "peeling" }
|
||||
// 添加更多病害类型
|
||||
],
|
||||
states: [
|
||||
{ label: "未处理", value: "untreated" },
|
||||
{ label: "处理中", value: "in_process" },
|
||||
{ label: "已处理", value: "processed" }
|
||||
// 添加更多病害状态
|
||||
]
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.getList();
|
||||
},
|
||||
methods: {
|
||||
/** 查询缺陷列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
// 处理日期范围
|
||||
const params = { ...this.queryParams };
|
||||
if (params.dateTime && params.dateTime.length === 2) {
|
||||
params.startDate = params.dateTime[0];
|
||||
params.endDate = params.dateTime[1];
|
||||
}
|
||||
delete params.dateTime;
|
||||
delete params.lengthRange;
|
||||
delete params.areaRange;
|
||||
delete params.distanceRange;
|
||||
|
||||
listDefect(params)
|
||||
.then(response => {
|
||||
this.defectList = response.rows;
|
||||
this.total = response.total;
|
||||
this.loading = false;
|
||||
})
|
||||
.catch(() => {
|
||||
this.loading = false;
|
||||
});
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
this.dialogVisible = false;
|
||||
this.resetFormData();
|
||||
},
|
||||
// 表单重置
|
||||
resetForm(formName) {
|
||||
this.$refs[formName].resetFields();
|
||||
},
|
||||
resetQuery() {
|
||||
this.resetForm("queryForm");
|
||||
this.queryParams = {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
segmentName: "",
|
||||
dateTime: [],
|
||||
defectType: [],
|
||||
taskId: "",
|
||||
state: [],
|
||||
inspectDirection: [],
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
warningFlag: null,
|
||||
minLen: null,
|
||||
maxLen: null,
|
||||
minArea: null,
|
||||
maxArea: null,
|
||||
minDistance: null,
|
||||
maxDistance: null
|
||||
};
|
||||
this.handleQuery();
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNum = 1;
|
||||
this.getList();
|
||||
},
|
||||
// 多选框选中数据
|
||||
handleSelectionChange(selection) {
|
||||
this.ids = selection.map(item => item.id);
|
||||
this.single = selection.length !== 1;
|
||||
this.multiple = !selection.length;
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.resetFormData();
|
||||
this.dialogVisible = true;
|
||||
this.dialogTitle = "添加缺陷";
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
if (row) {
|
||||
// 通过行数据修改
|
||||
this.loadDefect(row.id);
|
||||
} else if (this.ids.length === 1) {
|
||||
// 通过选中项修改
|
||||
this.loadDefect(this.ids[0]);
|
||||
} else {
|
||||
this.$modal.msgWarning("请选择一条记录进行修改");
|
||||
}
|
||||
},
|
||||
/** 加载缺陷数据 */
|
||||
loadDefect(id) {
|
||||
getDefect(id)
|
||||
.then(response => {
|
||||
this.form = { ...response.data };
|
||||
// 处理日期格式
|
||||
if (this.form.createdTime) {
|
||||
this.form.createdTime = new Date(this.form.createdTime);
|
||||
}
|
||||
this.dialogVisible = true;
|
||||
this.dialogTitle = "修改缺陷";
|
||||
})
|
||||
.catch(() => {
|
||||
this.$modal.msgError("加载缺陷数据失败");
|
||||
});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm() {
|
||||
this.$refs["defectForm"].validate(valid => {
|
||||
if (valid) {
|
||||
if (this.form.id) {
|
||||
// 更新缺陷
|
||||
updateDefect(this.form)
|
||||
.then(() => {
|
||||
this.$modal.msgSuccess("修改成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
})
|
||||
.catch(() => {
|
||||
this.$modal.msgError("修改失败");
|
||||
});
|
||||
} else {
|
||||
// 添加缺陷
|
||||
addDefect(this.form)
|
||||
.then(() => {
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
})
|
||||
.catch(() => {
|
||||
this.$modal.msgError("新增失败");
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
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(() => {});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
this.download('xj/defect/export', {
|
||||
...this.queryParams
|
||||
}, `defect_${new Date().getTime()}.xlsx`)
|
||||
},
|
||||
/** 重置表单数据 */
|
||||
resetFormData() {
|
||||
this.form = {
|
||||
id: null,
|
||||
segmentName: "",
|
||||
defectType: "",
|
||||
equipmentType: "",
|
||||
createdTime: "",
|
||||
updatedTime: "",
|
||||
state: "",
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
geometry: {
|
||||
type: "Point",
|
||||
coordinates: []
|
||||
},
|
||||
targetArea: null,
|
||||
targetLen: null,
|
||||
snapshotId: "",
|
||||
taskId: "",
|
||||
segmentId: "",
|
||||
inspectDirection: "",
|
||||
dataFrom: "",
|
||||
warningFlag: 0,
|
||||
equipmentId: "",
|
||||
transformation: 0,
|
||||
dataStatus: 0,
|
||||
objDistance: null,
|
||||
isCalibrated: 0,
|
||||
count: 0,
|
||||
media: []
|
||||
};
|
||||
this.resetForm("defectForm");
|
||||
},
|
||||
|
||||
// 打开查看详情弹出框
|
||||
viewDefect(defect) {
|
||||
this.form = defect;
|
||||
this.openViewDialog = true;
|
||||
this.$nextTick(() => {
|
||||
this.initMap();
|
||||
});
|
||||
},
|
||||
|
||||
// 初始化天地图并标注病害位置
|
||||
initMap() {
|
||||
if (this.map) {
|
||||
this.map.remove(); // 如果已经有地图实例,先移除再重新加载
|
||||
}
|
||||
|
||||
// 初始化天地图
|
||||
this.map = new T.Map("mapContainer");
|
||||
|
||||
// 设置中心点为病害的坐标
|
||||
const coordinates = this.form.geometry.coordinates;
|
||||
if (coordinates && coordinates.length === 2) {
|
||||
const lon = coordinates[0];
|
||||
const lat = coordinates[1];
|
||||
|
||||
// 设置地图中心点
|
||||
const center = new T.LngLat(lon, lat);
|
||||
this.map.centerAndZoom(center, 15);
|
||||
|
||||
// 添加病害位置标注
|
||||
const marker = new T.Marker(center);
|
||||
this.map.addOverLay(marker);
|
||||
} else {
|
||||
console.error("无效的病害坐标");
|
||||
}
|
||||
},
|
||||
|
||||
// 关闭对话框
|
||||
closeDialog() {
|
||||
this.openViewDialog = false;
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.app-container {
|
||||
padding: 20px;
|
||||
}
|
||||
.mb8 {
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
.small-padding {
|
||||
padding: 0 5px;
|
||||
}
|
||||
.fixed-width {
|
||||
width: 120px;
|
||||
}
|
||||
</style>
|
||||
@ -1,99 +1,7 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||||
<el-form-item label="字典名称" prop="dictName">
|
||||
<el-input
|
||||
v-model="queryParams.dictName"
|
||||
placeholder="请输入字典名称"
|
||||
clearable
|
||||
style="width: 240px"
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="字典类型" prop="dictType">
|
||||
<el-input
|
||||
v-model="queryParams.dictType"
|
||||
placeholder="请输入字典类型"
|
||||
clearable
|
||||
style="width: 240px"
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-select
|
||||
v-model="queryParams.status"
|
||||
placeholder="字典状态"
|
||||
clearable
|
||||
style="width: 240px"
|
||||
>
|
||||
<el-option
|
||||
v-for="dict in dict.type.sys_normal_disable"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="创建时间">
|
||||
<el-date-picker
|
||||
v-model="dateRange"
|
||||
style="width: 240px"
|
||||
value-format="yyyy-MM-dd"
|
||||
type="daterange"
|
||||
range-separator="-"
|
||||
start-placeholder="开始日期"
|
||||
end-placeholder="结束日期"
|
||||
></el-date-picker>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<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"
|
||||
v-hasPermi="['system:dict:add']"
|
||||
>新增</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['system:dict:edit']"
|
||||
>修改</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>删除</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['system:dict:export']"
|
||||
>导出</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
@ -102,33 +10,19 @@
|
||||
size="mini"
|
||||
@click="handleRefreshCache"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>刷新缓存</el-button>
|
||||
>刷新缓存
|
||||
</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<el-table v-loading="loading" :data="typeList" @selection-change="handleSelectionChange">
|
||||
<el-table-column type="selection" width="55" align="center"/>
|
||||
<el-table-column label="字典编号" align="center" prop="dictId" />
|
||||
<el-table-column label="字典名称" align="center" prop="dictName" :show-overflow-tooltip="true" />
|
||||
<el-table-column label="字典类型" align="center" :show-overflow-tooltip="true">
|
||||
<template slot-scope="scope">
|
||||
<router-link :to="'/system/dict-data/index/' + scope.row.dictId" class="link-type">
|
||||
<span>{{ scope.row.dictType }}</span>
|
||||
</router-link>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="状态" align="center" prop="status">
|
||||
<template slot-scope="scope">
|
||||
<dict-tag :options="dict.type.sys_normal_disable" :value="scope.row.status"/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
|
||||
<el-table-column label="字典类型" align="center" prop="key" :show-overflow-tooltip="true"/>
|
||||
|
||||
<el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true"/>
|
||||
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
|
||||
<template slot-scope="scope">
|
||||
<span>{{ parseTime(scope.row.createTime) }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
|
||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
@ -137,14 +31,9 @@
|
||||
icon="el-icon-edit"
|
||||
@click="handleUpdate(scope.row)"
|
||||
v-hasPermi="['system:dict:edit']"
|
||||
>修改</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>删除</el-button>
|
||||
>查看
|
||||
</el-button>
|
||||
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
@ -159,44 +48,35 @@
|
||||
|
||||
<!-- 添加或修改参数配置对话框 -->
|
||||
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
|
||||
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
||||
<el-form-item label="字典名称" prop="dictName">
|
||||
<el-input v-model="form.dictName" placeholder="请输入字典名称" />
|
||||
</el-form-item>
|
||||
<el-form-item label="字典类型" prop="dictType">
|
||||
<el-input v-model="form.dictType" placeholder="请输入字典类型" />
|
||||
</el-form-item>
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-radio-group v-model="form.status">
|
||||
<el-radio
|
||||
v-for="dict in dict.type.sys_normal_disable"
|
||||
:key="dict.value"
|
||||
:label="dict.value"
|
||||
>{{dict.label}}</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="备注" prop="remark">
|
||||
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
<el-table v-loading="loading" :data="formList" @selection-change="handleSelectionChange">
|
||||
<el-table-column type="selection" width="55" align="center"/>
|
||||
|
||||
<el-table-column label="名称" align="center" prop="label" :show-overflow-tooltip="true"/>
|
||||
|
||||
<el-table-column label="编码" align="center" prop="value" :show-overflow-tooltip="true"/>
|
||||
|
||||
</el-table>
|
||||
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="primary" @click="submitForm">确 定</el-button>
|
||||
<el-button @click="cancel">取 消</el-button>
|
||||
|
||||
<el-button @click="cancel">关 闭</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { listType, getType, delType, addType, updateType, refreshCache } from "@/api/system/dict/type";
|
||||
import {listType, getType, delType, addType, updateType} from "@/api/system/dict/type";
|
||||
import {listMetadata,refreshCache} from "@/api/xj/metadata";
|
||||
|
||||
export default {
|
||||
name: "Dict",
|
||||
dicts: ['sys_normal_disable'],
|
||||
data() {
|
||||
return {
|
||||
formList:[],
|
||||
// 遮罩层
|
||||
loading: true,
|
||||
loading: false,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
@ -240,15 +120,105 @@ export default {
|
||||
this.getList();
|
||||
},
|
||||
methods: {
|
||||
|
||||
transformToDeepCategorizedLabelValue(data) {
|
||||
const result = {};
|
||||
|
||||
data.items.forEach(item => {
|
||||
Object.entries(item).forEach(([categoryKey, categoryValue]) => {
|
||||
if (!result[categoryKey]) {
|
||||
result[categoryKey] = {};
|
||||
}
|
||||
categoryValue.forEach(subCategory => {
|
||||
Object.entries(subCategory).forEach(([subCategoryKey, subCategoryValue]) => {
|
||||
if (!result[categoryKey][subCategoryKey]) {
|
||||
result[categoryKey][subCategoryKey] = [];
|
||||
}
|
||||
// 处理嵌套的对象,将其转换为 label 和 value
|
||||
if (typeof subCategoryValue === 'object') {
|
||||
Object.entries(subCategoryValue).forEach(([key, value]) => {
|
||||
result[categoryKey][subCategoryKey].push({
|
||||
label: value,
|
||||
value: key
|
||||
});
|
||||
});
|
||||
} else {
|
||||
result[categoryKey][subCategoryKey].push({
|
||||
label: subCategoryValue,
|
||||
value: subCategoryKey
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
return result;
|
||||
},
|
||||
transformToDeepCategorizedListLabelValue(data) {
|
||||
const temp = {};
|
||||
const result = [];
|
||||
|
||||
data.items.forEach(item => {
|
||||
Object.entries(item).forEach(([categoryKey, categoryValue]) => {
|
||||
|
||||
categoryValue.forEach(subCategory => {
|
||||
Object.entries(subCategory).forEach(([subCategoryKey, subCategoryValue]) => {
|
||||
|
||||
// 处理嵌套的对象,将其转换为 label 和 value
|
||||
if (typeof subCategoryValue === 'object') {
|
||||
if (!temp[categoryKey + ":" + subCategoryKey]) {
|
||||
temp[categoryKey + ":" + subCategoryKey] = [];
|
||||
}
|
||||
|
||||
Object.entries(subCategoryValue).forEach(([key, value]) => {
|
||||
temp[categoryKey + ":" + subCategoryKey].push({
|
||||
label: value,
|
||||
value: key
|
||||
});
|
||||
});
|
||||
} else {
|
||||
temp[categoryKey + ":" + subCategoryKey].push({
|
||||
label: subCategoryValue,
|
||||
value: subCategoryKey
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
Object.entries(temp).forEach(([categoryKey, categoryValue]) => {
|
||||
result.push({key: categoryKey, value: categoryValue});
|
||||
})
|
||||
|
||||
this.total = result.length;
|
||||
|
||||
if (this.queryParams.pageNum *this.queryParams.pageSize > result.length) {
|
||||
return result.slice((this.queryParams.pageNum -1)*this.queryParams.pageSize, result.length);
|
||||
}else{
|
||||
return result.slice((this.queryParams.pageNum -1)*this.queryParams.pageSize,this.queryParams.pageSize*this.queryParams.pageNum);
|
||||
}
|
||||
|
||||
return result;
|
||||
},
|
||||
|
||||
getTypeInfo() {
|
||||
|
||||
|
||||
},
|
||||
/** 查询字典类型列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
listType(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
|
||||
this.typeList = response.rows;
|
||||
this.total = response.total;
|
||||
|
||||
|
||||
listMetadata().then(response => {
|
||||
|
||||
this.typeList = this.transformToDeepCategorizedListLabelValue(JSON.parse(response.data))
|
||||
console.log(this.typeList)
|
||||
this.loading = false;
|
||||
}
|
||||
);
|
||||
|
||||
})
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
@ -291,13 +261,16 @@ export default {
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
this.reset();
|
||||
/* this.reset();
|
||||
const dictId = row.dictId || this.ids
|
||||
getType(dictId).then(response => {
|
||||
this.form = response.data;
|
||||
this.open = true;
|
||||
this.title = "修改字典类型";
|
||||
});
|
||||
});*/
|
||||
|
||||
this.formList = row.value;
|
||||
this.open = true;
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm: function () {
|
||||
@ -327,7 +300,8 @@ export default {
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("删除成功");
|
||||
}).catch(() => {});
|
||||
}).catch(() => {
|
||||
});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
|
||||
402
src/views/system/dict2/data.vue
Normal file
402
src/views/system/dict2/data.vue
Normal file
@ -0,0 +1,402 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||||
<el-form-item label="字典名称" prop="dictType">
|
||||
<el-select v-model="queryParams.dictType">
|
||||
<el-option
|
||||
v-for="item in typeOptions"
|
||||
:key="item.dictId"
|
||||
:label="item.dictName"
|
||||
:value="item.dictType"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="字典标签" prop="dictLabel">
|
||||
<el-input
|
||||
v-model="queryParams.dictLabel"
|
||||
placeholder="请输入字典标签"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-select v-model="queryParams.status" placeholder="数据状态" clearable>
|
||||
<el-option
|
||||
v-for="dict in dict.type.sys_normal_disable"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<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"
|
||||
v-hasPermi="['system:dict:add']"
|
||||
>新增</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['system:dict:edit']"
|
||||
>修改</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>删除</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['system:dict:export']"
|
||||
>导出</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-close"
|
||||
size="mini"
|
||||
@click="handleClose"
|
||||
>关闭</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<el-table v-loading="loading" :data="dataList" @selection-change="handleSelectionChange">
|
||||
<el-table-column type="selection" width="55" align="center" />
|
||||
<el-table-column label="字典编码" align="center" prop="dictCode" />
|
||||
<el-table-column label="字典标签" align="center" prop="dictLabel">
|
||||
<template slot-scope="scope">
|
||||
<span v-if="(scope.row.listClass == '' || scope.row.listClass == 'default') && (scope.row.cssClass == '' || scope.row.cssClass == null)">{{ scope.row.dictLabel }}</span>
|
||||
<el-tag v-else :type="scope.row.listClass == 'primary' ? '' : scope.row.listClass" :class="scope.row.cssClass">{{ scope.row.dictLabel }}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="字典键值" align="center" prop="dictValue" />
|
||||
<el-table-column label="字典排序" align="center" prop="dictSort" />
|
||||
<el-table-column label="状态" align="center" prop="status">
|
||||
<template slot-scope="scope">
|
||||
<dict-tag :options="dict.type.sys_normal_disable" :value="scope.row.status"/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true" />
|
||||
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
|
||||
<template slot-scope="scope">
|
||||
<span>{{ parseTime(scope.row.createTime) }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-edit"
|
||||
@click="handleUpdate(scope.row)"
|
||||
v-hasPermi="['system:dict:edit']"
|
||||
>修改</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>删除</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"
|
||||
/>
|
||||
|
||||
<!-- 添加或修改参数配置对话框 -->
|
||||
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
|
||||
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
||||
<el-form-item label="字典类型">
|
||||
<el-input v-model="form.dictType" :disabled="true" />
|
||||
</el-form-item>
|
||||
<el-form-item label="数据标签" prop="dictLabel">
|
||||
<el-input v-model="form.dictLabel" placeholder="请输入数据标签" />
|
||||
</el-form-item>
|
||||
<el-form-item label="数据键值" prop="dictValue">
|
||||
<el-input v-model="form.dictValue" placeholder="请输入数据键值" />
|
||||
</el-form-item>
|
||||
<el-form-item label="样式属性" prop="cssClass">
|
||||
<el-input v-model="form.cssClass" placeholder="请输入样式属性" />
|
||||
</el-form-item>
|
||||
<el-form-item label="显示排序" prop="dictSort">
|
||||
<el-input-number v-model="form.dictSort" controls-position="right" :min="0" />
|
||||
</el-form-item>
|
||||
<el-form-item label="回显样式" prop="listClass">
|
||||
<el-select v-model="form.listClass">
|
||||
<el-option
|
||||
v-for="item in listClassOptions"
|
||||
:key="item.value"
|
||||
:label="item.label + '(' + item.value + ')'"
|
||||
:value="item.value"
|
||||
></el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-radio-group v-model="form.status">
|
||||
<el-radio
|
||||
v-for="dict in dict.type.sys_normal_disable"
|
||||
:key="dict.value"
|
||||
:label="dict.value"
|
||||
>{{dict.label}}</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="备注" prop="remark">
|
||||
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
|
||||
</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>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { listData, getData, delData, addData, updateData } from "@/api/system/dict/data";
|
||||
import { optionselect as getDictOptionselect, getType } from "@/api/system/dict/type";
|
||||
|
||||
export default {
|
||||
name: "Data",
|
||||
dicts: ['sys_normal_disable'],
|
||||
data() {
|
||||
return {
|
||||
// 遮罩层
|
||||
loading: true,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
single: true,
|
||||
// 非多个禁用
|
||||
multiple: true,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 字典表格数据
|
||||
dataList: [],
|
||||
// 默认字典类型
|
||||
defaultDictType: "",
|
||||
// 弹出层标题
|
||||
title: "",
|
||||
// 是否显示弹出层
|
||||
open: false,
|
||||
// 数据标签回显样式
|
||||
listClassOptions: [
|
||||
{
|
||||
value: "default",
|
||||
label: "默认"
|
||||
},
|
||||
{
|
||||
value: "primary",
|
||||
label: "主要"
|
||||
},
|
||||
{
|
||||
value: "success",
|
||||
label: "成功"
|
||||
},
|
||||
{
|
||||
value: "info",
|
||||
label: "信息"
|
||||
},
|
||||
{
|
||||
value: "warning",
|
||||
label: "警告"
|
||||
},
|
||||
{
|
||||
value: "danger",
|
||||
label: "危险"
|
||||
}
|
||||
],
|
||||
// 类型数据字典
|
||||
typeOptions: [],
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
dictType: undefined,
|
||||
dictLabel: undefined,
|
||||
status: undefined
|
||||
},
|
||||
// 表单参数
|
||||
form: {},
|
||||
// 表单校验
|
||||
rules: {
|
||||
dictLabel: [
|
||||
{ required: true, message: "数据标签不能为空", trigger: "blur" }
|
||||
],
|
||||
dictValue: [
|
||||
{ required: true, message: "数据键值不能为空", trigger: "blur" }
|
||||
],
|
||||
dictSort: [
|
||||
{ required: true, message: "数据顺序不能为空", trigger: "blur" }
|
||||
]
|
||||
}
|
||||
};
|
||||
},
|
||||
created() {
|
||||
const dictId = this.$route.params && this.$route.params.dictId;
|
||||
this.getType(dictId);
|
||||
this.getTypeList();
|
||||
},
|
||||
methods: {
|
||||
/** 查询字典类型详细 */
|
||||
getType(dictId) {
|
||||
getType(dictId).then(response => {
|
||||
this.queryParams.dictType = response.data.dictType;
|
||||
this.defaultDictType = response.data.dictType;
|
||||
this.getList();
|
||||
});
|
||||
},
|
||||
/** 查询字典类型列表 */
|
||||
getTypeList() {
|
||||
getDictOptionselect().then(response => {
|
||||
this.typeOptions = response.data;
|
||||
});
|
||||
},
|
||||
/** 查询字典数据列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
listData(this.queryParams).then(response => {
|
||||
this.dataList = response.rows;
|
||||
this.total = response.total;
|
||||
this.loading = false;
|
||||
});
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
this.open = false;
|
||||
this.reset();
|
||||
},
|
||||
// 表单重置
|
||||
reset() {
|
||||
this.form = {
|
||||
dictCode: undefined,
|
||||
dictLabel: undefined,
|
||||
dictValue: undefined,
|
||||
cssClass: undefined,
|
||||
listClass: 'default',
|
||||
dictSort: 0,
|
||||
status: "0",
|
||||
remark: undefined
|
||||
};
|
||||
this.resetForm("form");
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNum = 1;
|
||||
this.getList();
|
||||
},
|
||||
/** 返回按钮操作 */
|
||||
handleClose() {
|
||||
const obj = { path: "/system/dict" };
|
||||
this.$tab.closeOpenPage(obj);
|
||||
},
|
||||
/** 重置按钮操作 */
|
||||
resetQuery() {
|
||||
this.resetForm("queryForm");
|
||||
this.queryParams.dictType = this.defaultDictType;
|
||||
this.handleQuery();
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.reset();
|
||||
this.open = true;
|
||||
this.title = "添加字典数据";
|
||||
this.form.dictType = this.queryParams.dictType;
|
||||
},
|
||||
// 多选框选中数据
|
||||
handleSelectionChange(selection) {
|
||||
this.ids = selection.map(item => item.dictCode)
|
||||
this.single = selection.length!=1
|
||||
this.multiple = !selection.length
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
this.reset();
|
||||
const dictCode = row.dictCode || this.ids
|
||||
getData(dictCode).then(response => {
|
||||
this.form = response.data;
|
||||
this.open = true;
|
||||
this.title = "修改字典数据";
|
||||
});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm: function() {
|
||||
this.$refs["form"].validate(valid => {
|
||||
if (valid) {
|
||||
if (this.form.dictCode != undefined) {
|
||||
updateData(this.form).then(response => {
|
||||
this.$store.dispatch('dict/removeDict', this.queryParams.dictType);
|
||||
this.$modal.msgSuccess("修改成功");
|
||||
this.open = false;
|
||||
this.getList();
|
||||
});
|
||||
} else {
|
||||
addData(this.form).then(response => {
|
||||
this.$store.dispatch('dict/removeDict', this.queryParams.dictType);
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.open = false;
|
||||
this.getList();
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
handleDelete(row) {
|
||||
const dictCodes = row.dictCode || this.ids;
|
||||
this.$modal.confirm('是否确认删除字典编码为"' + dictCodes + '"的数据项?').then(function() {
|
||||
return delData(dictCodes);
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("删除成功");
|
||||
this.$store.dispatch('dict/removeDict', this.queryParams.dictType);
|
||||
}).catch(() => {});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
this.download('system/dict/data/export', {
|
||||
...this.queryParams
|
||||
}, `data_${new Date().getTime()}.xlsx`)
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
347
src/views/system/dict2/index.vue
Normal file
347
src/views/system/dict2/index.vue
Normal file
@ -0,0 +1,347 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||||
<el-form-item label="字典名称" prop="dictName">
|
||||
<el-input
|
||||
v-model="queryParams.dictName"
|
||||
placeholder="请输入字典名称"
|
||||
clearable
|
||||
style="width: 240px"
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="字典类型" prop="dictType">
|
||||
<el-input
|
||||
v-model="queryParams.dictType"
|
||||
placeholder="请输入字典类型"
|
||||
clearable
|
||||
style="width: 240px"
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-select
|
||||
v-model="queryParams.status"
|
||||
placeholder="字典状态"
|
||||
clearable
|
||||
style="width: 240px"
|
||||
>
|
||||
<el-option
|
||||
v-for="dict in dict.type.sys_normal_disable"
|
||||
:key="dict.value"
|
||||
:label="dict.label"
|
||||
:value="dict.value"
|
||||
/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="创建时间">
|
||||
<el-date-picker
|
||||
v-model="dateRange"
|
||||
style="width: 240px"
|
||||
value-format="yyyy-MM-dd"
|
||||
type="daterange"
|
||||
range-separator="-"
|
||||
start-placeholder="开始日期"
|
||||
end-placeholder="结束日期"
|
||||
></el-date-picker>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<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"
|
||||
v-hasPermi="['system:dict:add']"
|
||||
>新增</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['system:dict:edit']"
|
||||
>修改</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>删除</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['system:dict:export']"
|
||||
>导出</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-refresh"
|
||||
size="mini"
|
||||
@click="handleRefreshCache"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>刷新缓存</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<el-table v-loading="loading" :data="typeList" @selection-change="handleSelectionChange">
|
||||
<el-table-column type="selection" width="55" align="center" />
|
||||
<el-table-column label="字典编号" align="center" prop="dictId" />
|
||||
<el-table-column label="字典名称" align="center" prop="dictName" :show-overflow-tooltip="true" />
|
||||
<el-table-column label="字典类型" align="center" :show-overflow-tooltip="true">
|
||||
<template slot-scope="scope">
|
||||
<router-link :to="'/system/dict-data/index/' + scope.row.dictId" class="link-type">
|
||||
<span>{{ scope.row.dictType }}</span>
|
||||
</router-link>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="状态" align="center" prop="status">
|
||||
<template slot-scope="scope">
|
||||
<dict-tag :options="dict.type.sys_normal_disable" :value="scope.row.status"/>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="备注" align="center" prop="remark" :show-overflow-tooltip="true" />
|
||||
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
|
||||
<template slot-scope="scope">
|
||||
<span>{{ parseTime(scope.row.createTime) }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-edit"
|
||||
@click="handleUpdate(scope.row)"
|
||||
v-hasPermi="['system:dict:edit']"
|
||||
>修改</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['system:dict:remove']"
|
||||
>删除</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"
|
||||
/>
|
||||
|
||||
<!-- 添加或修改参数配置对话框 -->
|
||||
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
|
||||
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
||||
<el-form-item label="字典名称" prop="dictName">
|
||||
<el-input v-model="form.dictName" placeholder="请输入字典名称" />
|
||||
</el-form-item>
|
||||
<el-form-item label="字典类型" prop="dictType">
|
||||
<el-input v-model="form.dictType" placeholder="请输入字典类型" />
|
||||
</el-form-item>
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-radio-group v-model="form.status">
|
||||
<el-radio
|
||||
v-for="dict in dict.type.sys_normal_disable"
|
||||
:key="dict.value"
|
||||
:label="dict.value"
|
||||
>{{dict.label}}</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
<el-form-item label="备注" prop="remark">
|
||||
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容"></el-input>
|
||||
</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>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import { listType, getType, delType, addType, updateType, refreshCache } from "@/api/system/dict/type";
|
||||
|
||||
export default {
|
||||
name: "Dict",
|
||||
dicts: ['sys_normal_disable'],
|
||||
data() {
|
||||
return {
|
||||
// 遮罩层
|
||||
loading: true,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
single: true,
|
||||
// 非多个禁用
|
||||
multiple: true,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 字典表格数据
|
||||
typeList: [],
|
||||
// 弹出层标题
|
||||
title: "",
|
||||
// 是否显示弹出层
|
||||
open: false,
|
||||
// 日期范围
|
||||
dateRange: [],
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
dictName: undefined,
|
||||
dictType: undefined,
|
||||
status: undefined
|
||||
},
|
||||
// 表单参数
|
||||
form: {},
|
||||
// 表单校验
|
||||
rules: {
|
||||
dictName: [
|
||||
{ required: true, message: "字典名称不能为空", trigger: "blur" }
|
||||
],
|
||||
dictType: [
|
||||
{ required: true, message: "字典类型不能为空", trigger: "blur" }
|
||||
]
|
||||
}
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.getList();
|
||||
},
|
||||
methods: {
|
||||
/** 查询字典类型列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
listType(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
|
||||
this.typeList = response.rows;
|
||||
this.total = response.total;
|
||||
this.loading = false;
|
||||
}
|
||||
);
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
this.open = false;
|
||||
this.reset();
|
||||
},
|
||||
// 表单重置
|
||||
reset() {
|
||||
this.form = {
|
||||
dictId: undefined,
|
||||
dictName: undefined,
|
||||
dictType: undefined,
|
||||
status: "0",
|
||||
remark: undefined
|
||||
};
|
||||
this.resetForm("form");
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNum = 1;
|
||||
this.getList();
|
||||
},
|
||||
/** 重置按钮操作 */
|
||||
resetQuery() {
|
||||
this.dateRange = [];
|
||||
this.resetForm("queryForm");
|
||||
this.handleQuery();
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.reset();
|
||||
this.open = true;
|
||||
this.title = "添加字典类型";
|
||||
},
|
||||
// 多选框选中数据
|
||||
handleSelectionChange(selection) {
|
||||
this.ids = selection.map(item => item.dictId)
|
||||
this.single = selection.length!=1
|
||||
this.multiple = !selection.length
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
this.reset();
|
||||
const dictId = row.dictId || this.ids
|
||||
getType(dictId).then(response => {
|
||||
this.form = response.data;
|
||||
this.open = true;
|
||||
this.title = "修改字典类型";
|
||||
});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm: function() {
|
||||
this.$refs["form"].validate(valid => {
|
||||
if (valid) {
|
||||
if (this.form.dictId != undefined) {
|
||||
updateType(this.form).then(response => {
|
||||
this.$modal.msgSuccess("修改成功");
|
||||
this.open = false;
|
||||
this.getList();
|
||||
});
|
||||
} else {
|
||||
addType(this.form).then(response => {
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.open = false;
|
||||
this.getList();
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
handleDelete(row) {
|
||||
const dictIds = row.dictId || this.ids;
|
||||
this.$modal.confirm('是否确认删除字典编号为"' + dictIds + '"的数据项?').then(function() {
|
||||
return delType(dictIds);
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("删除成功");
|
||||
}).catch(() => {});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
this.download('system/dict/type/export', {
|
||||
...this.queryParams
|
||||
}, `type_${new Date().getTime()}.xlsx`)
|
||||
},
|
||||
/** 刷新缓存按钮操作 */
|
||||
handleRefreshCache() {
|
||||
refreshCache().then(() => {
|
||||
this.$modal.msgSuccess("刷新成功");
|
||||
this.$store.dispatch('dict/cleanDict');
|
||||
});
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
784
src/views/xj/defect/index.vue
Normal file
784
src/views/xj/defect/index.vue
Normal file
@ -0,0 +1,784 @@
|
||||
<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">
|
||||
<el-input
|
||||
v-model="queryParams.segmentName"
|
||||
placeholder="请输入道路名称"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="采集时间" prop="dateTime">
|
||||
<el-date-picker
|
||||
v-model="queryParams.dateTime"
|
||||
type="daterange"
|
||||
start-placeholder="开始日期"
|
||||
end-placeholder="结束日期"
|
||||
format="yyyy-MM-dd"
|
||||
value-format="yyyy-MM-dd"
|
||||
clearable
|
||||
@change="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害类型" prop="defectType">
|
||||
<el-select v-model="queryParams.defectType" placeholder="请选择" clearable multiple>
|
||||
<el-option v-for="item in defectTypes" :key="item.value" :label="item.label" :value="item.value"/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="任务ID" prop="taskId">
|
||||
<el-input
|
||||
v-model="queryParams.taskId"
|
||||
placeholder="请输入任务ID"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害状态" prop="state">
|
||||
<el-select v-model="queryParams.state" placeholder="请选择" clearable multiple>
|
||||
<el-option v-for="item in states" :key="item.value" :label="item.label" :value="item.value"/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="上下行" prop="inspectDirection">
|
||||
<el-select v-model="queryParams.inspectDirection" placeholder="请选择" clearable multiple>
|
||||
<el-option label="上行" value="upstream"/>
|
||||
<el-option label="下行" value="downstream"/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="公里桩" prop="stakeRange">
|
||||
<el-input
|
||||
v-model="queryParams.stakeStart"
|
||||
placeholder="起始公里桩"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.stakeEnd"
|
||||
placeholder="终止公里桩"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="预警标识" prop="warningFlag">
|
||||
<el-select v-model="queryParams.warningFlag" placeholder="请选择" clearable>
|
||||
<el-option label="是" :value="1"/>
|
||||
<el-option label="否" :value="0"/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害长度" prop="lengthRange">
|
||||
<el-input
|
||||
v-model="queryParams.minLen"
|
||||
placeholder="最小长度"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.maxLen"
|
||||
placeholder="最大长度"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害面积" prop="areaRange">
|
||||
<el-input
|
||||
v-model="queryParams.minArea"
|
||||
placeholder="最小面积"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.maxArea"
|
||||
placeholder="最大面积"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="距离车顶天线" prop="distanceRange">
|
||||
<el-input
|
||||
v-model="queryParams.minDistance"
|
||||
placeholder="最小距离"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
<span style="margin: 0 5px;">-</span>
|
||||
<el-input
|
||||
v-model="queryParams.maxDistance"
|
||||
placeholder="最大距离"
|
||||
style="width: 100px;"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<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"
|
||||
v-hasPermi="['system:defect:add']"
|
||||
>新增
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['system:defect:edit']"
|
||||
>修改
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['system:defect:remove']"
|
||||
>删除
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['system:defect:export']"
|
||||
>导出
|
||||
</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<!-- 数据表格 -->
|
||||
<el-table 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"/>
|
||||
<el-table-column label="采集时间" align="center" prop="createdTime"/>
|
||||
<el-table-column label="病害类型" align="center" prop="defectType"/>
|
||||
<el-table-column label="病害状态" align="center" prop="state"/>
|
||||
<el-table-column label="开始桩号" align="center" prop="stakeStart"/>
|
||||
<el-table-column label="结束桩号" align="center" prop="stakeEnd"/>
|
||||
<el-table-column label="病害长度" align="center" prop="targetLen"/>
|
||||
<el-table-column label="病害面积" align="center" prop="targetArea"/>
|
||||
<el-table-column label="预警标识" align="center" prop="warningFlag">
|
||||
<template slot-scope="scope">
|
||||
<el-tag :type="scope.row.warningFlag === 1 ? 'danger' : 'success'">
|
||||
{{ scope.row.warningFlag === 1 ? '是' : '否' }}
|
||||
</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="操作" align="center" 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)"
|
||||
v-hasPermi="['system:defect:edit']"
|
||||
>修改
|
||||
</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['system:defect:remove']"
|
||||
>删除
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<!-- 分页组件 -->
|
||||
<pagination
|
||||
v-show="total > 0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"
|
||||
/>
|
||||
|
||||
<!-- 添加或修改缺陷对话框 -->
|
||||
<el-dialog :title="dialogTitle" :visible.sync="dialogVisible" width="600px" append-to-body>
|
||||
<el-form ref="defectForm" :model="form" :rules="rules" label-width="100px">
|
||||
<el-form-item label="道路名称" prop="segmentName">
|
||||
<el-input v-model="form.segmentName" placeholder="请输入道路名称"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害类型" prop="defectType">
|
||||
<el-select v-model="form.defectType" placeholder="请选择病害类型" clearable>
|
||||
<el-option v-for="item in defectTypes" :key="item.value" :label="item.label" :value="item.value"/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害状态" prop="state">
|
||||
<el-select v-model="form.state" placeholder="请选择病害状态" clearable>
|
||||
<el-option v-for="item in states" :key="item.value" :label="item.label" :value="item.value"/>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
<el-form-item label="采集时间" prop="createdTime">
|
||||
<el-date-picker
|
||||
v-model="form.createdTime"
|
||||
type="datetime"
|
||||
placeholder="选择采集时间"
|
||||
format="yyyy-MM-dd HH:mm:ss"
|
||||
value-format="yyyy-MM-dd HH:mm:ss"
|
||||
clearable
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="开始桩号" prop="stakeStart">
|
||||
<el-input v-model="form.stakeStart" placeholder="请输入开始桩号"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="结束桩号" prop="stakeEnd">
|
||||
<el-input v-model="form.stakeEnd" placeholder="请输入结束桩号"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害长度" prop="targetLen">
|
||||
<el-input-number v-model="form.targetLen" :min="0" placeholder="请输入病害长度" style="width: 100%"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害面积" prop="targetArea">
|
||||
<el-input-number v-model="form.targetArea" :min="0" placeholder="请输入病害面积" style="width: 100%"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="预警标识" prop="warningFlag">
|
||||
<el-switch v-model="form.warningFlag" active-value="1" inactive-value="0" active-text="是"
|
||||
inactive-text="否"/>
|
||||
</el-form-item>
|
||||
<el-form-item label="病害位置" prop="geometry">
|
||||
<el-input v-model="form.geometry.coordinates" placeholder="请输入坐标 (e.g., [lng, lat])"/>
|
||||
</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>
|
||||
</el-dialog>
|
||||
|
||||
|
||||
<!-- 查看病害详细信息对话框 -->
|
||||
<el-dialog title="查看病害详细信息" :visible.sync="openViewDialog" width="800px" append-to-body>
|
||||
<div>
|
||||
<!-- 上半部分 -->
|
||||
<div style="display: flex; height: 50%;">
|
||||
<!-- 左侧病害信息 -->
|
||||
<div style="flex: 1; padding: 10px;">
|
||||
<p>上报日期:{{ form.createdTime }}</p>
|
||||
<p>路段名称:{{ form.segmentName }}</p>
|
||||
<p>病害坐标:{{ form.geometry.coordinates }}</p>
|
||||
<p>病害类型:{{ form.defectType }}</p>
|
||||
<p>病害长度:{{ form.targetLen }} 米</p>
|
||||
</div>
|
||||
|
||||
<!-- 右侧图片展示 -->
|
||||
<div style="flex: 1; padding: 10px;">
|
||||
<el-carousel height="150px">
|
||||
<el-carousel-item v-for="(img, index) in form.media" :key="index">
|
||||
<img :src="img.img" alt="病害图片" style="width: 100%;"/>
|
||||
</el-carousel-item>
|
||||
</el-carousel>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- 下半部分显示天地图 -->
|
||||
<div id="mapContainer" style="height: 300px; margin-top: 20px;"></div>
|
||||
</div>
|
||||
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button @click="closeDialog">关闭</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import {
|
||||
listDefect,
|
||||
getDefect,
|
||||
delDefect,
|
||||
addDefect,
|
||||
updateDefect,
|
||||
} from "@/api/xj/defect";
|
||||
|
||||
import {listMetadata} from "@/api/xj/metadata"
|
||||
|
||||
export default {
|
||||
name: "Defect",
|
||||
data() {
|
||||
return {
|
||||
|
||||
typeInfo: [],
|
||||
openViewDialog: false,
|
||||
|
||||
// 遮罩层
|
||||
loading: false,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
single: true,
|
||||
// 非多个禁用
|
||||
multiple: true,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 缺陷表格数据
|
||||
defectList: [],
|
||||
// 弹出层标题
|
||||
dialogTitle: "",
|
||||
// 是否显示弹出层
|
||||
dialogVisible: false,
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
segmentName: "",
|
||||
dateTime: [],
|
||||
defectType: [],
|
||||
taskId: "",
|
||||
state: [],
|
||||
inspectDirection: [],
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
warningFlag: null,
|
||||
minLen: null,
|
||||
maxLen: null,
|
||||
minArea: null,
|
||||
maxArea: null,
|
||||
minDistance: null,
|
||||
maxDistance: null
|
||||
},
|
||||
// 表单参数
|
||||
form: {
|
||||
id: null,
|
||||
segmentName: "",
|
||||
defectType: "",
|
||||
equipmentType: "",
|
||||
createdTime: "",
|
||||
updatedTime: "",
|
||||
state: "",
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
geometry: {
|
||||
type: "Point",
|
||||
coordinates: []
|
||||
},
|
||||
targetArea: null,
|
||||
targetLen: null,
|
||||
snapshotId: "",
|
||||
taskId: "",
|
||||
segmentId: "",
|
||||
inspectDirection: "",
|
||||
dataFrom: "",
|
||||
warningFlag: 0,
|
||||
equipmentId: "",
|
||||
transformation: 0,
|
||||
dataStatus: 0,
|
||||
objDistance: null,
|
||||
isCalibrated: 0,
|
||||
count: 0,
|
||||
media: []
|
||||
},
|
||||
// 表单校验规则
|
||||
rules: {
|
||||
segmentName: [
|
||||
{required: true, message: "请输入道路名称", trigger: "blur"}
|
||||
],
|
||||
defectType: [
|
||||
{required: true, message: "请选择病害类型", trigger: "change"}
|
||||
],
|
||||
state: [
|
||||
{required: true, message: "请选择病害状态", trigger: "change"}
|
||||
],
|
||||
createdTime: [
|
||||
{type: "array", required: false, message: "请选择采集时间", trigger: "change"}
|
||||
],
|
||||
stakeStart: [
|
||||
{required: false, message: "请输入开始桩号", trigger: "blur"}
|
||||
],
|
||||
stakeEnd: [
|
||||
{required: false, message: "请输入结束桩号", trigger: "blur"}
|
||||
],
|
||||
targetLen: [
|
||||
{type: "number", min: 0, message: "病害长度必须为正数", trigger: "change"}
|
||||
],
|
||||
targetArea: [
|
||||
{type: "number", min: 0, message: "病害面积必须为正数", trigger: "change"}
|
||||
]
|
||||
// 可以根据需要添加更多校验规则
|
||||
},
|
||||
// 下拉选项
|
||||
defectTypes: [
|
||||
{label: "裂缝", value: "crack"},
|
||||
{label: "坑槽", value: "pothole"},
|
||||
{label: "脱皮", value: "peeling"}
|
||||
// 添加更多病害类型
|
||||
],
|
||||
states: [
|
||||
{label: "未处理", value: "untreated"},
|
||||
{label: "处理中", value: "in_process"},
|
||||
{label: "已处理", value: "processed"}
|
||||
// 添加更多病害状态
|
||||
]
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.getList();
|
||||
this.getTypeInfo();
|
||||
},
|
||||
methods: {
|
||||
// 转换为按分类、子分类的label和value格式
|
||||
transformToDeepCategorizedLabelValue(data) {
|
||||
const result = {};
|
||||
|
||||
data.items.forEach(item => {
|
||||
Object.entries(item).forEach(([categoryKey, categoryValue]) => {
|
||||
if (!result[categoryKey]) {
|
||||
result[categoryKey] = {};
|
||||
}
|
||||
categoryValue.forEach(subCategory => {
|
||||
Object.entries(subCategory).forEach(([subCategoryKey, subCategoryValue]) => {
|
||||
if (!result[categoryKey][subCategoryKey]) {
|
||||
result[categoryKey][subCategoryKey] = [];
|
||||
}
|
||||
// 处理嵌套的对象,将其转换为 label 和 value
|
||||
if (typeof subCategoryValue === 'object') {
|
||||
Object.entries(subCategoryValue).forEach(([key, value]) => {
|
||||
result[categoryKey][subCategoryKey].push({
|
||||
label: value,
|
||||
value: key
|
||||
});
|
||||
});
|
||||
} else {
|
||||
result[categoryKey][subCategoryKey].push({
|
||||
label: subCategoryValue,
|
||||
value: subCategoryKey
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
return result;
|
||||
},
|
||||
getTypeInfo() {
|
||||
listMetadata().then(response => {
|
||||
console.log(response)
|
||||
console.log(this.transformToDeepCategorizedLabelValue(JSON.parse(response.data)));
|
||||
})
|
||||
|
||||
},
|
||||
/** 查询缺陷列表 */
|
||||
getList() {
|
||||
|
||||
let list = {
|
||||
rows: [
|
||||
{
|
||||
"state": "1",
|
||||
"media": [],
|
||||
"segmentId": "7064484787674677248",
|
||||
"segmentName": "testroad",
|
||||
"createdTime": "2023-05-17T06:34:12.000Z",
|
||||
"updatedTime": "2023-05-17T06:34:12.000Z",
|
||||
"defectType": "0",
|
||||
"stakeStart": "K000+000",
|
||||
"stakeEnd": "K000+123",
|
||||
"targetArea": 1,
|
||||
"targetLen": 1,
|
||||
"warningFlag": "0",
|
||||
"inspectDirection": "0",
|
||||
"geometry": {
|
||||
"type": "Point",
|
||||
"coordinates": [
|
||||
120,
|
||||
30
|
||||
]
|
||||
},
|
||||
"id": "7064488256724795392",
|
||||
"snapshotId": "7064488256724795392",
|
||||
"equipmentId": "123",
|
||||
"transformation": "0",
|
||||
"taskid": "123456"
|
||||
}
|
||||
],
|
||||
total: 1420,
|
||||
}
|
||||
|
||||
this.defectList = list.rows;
|
||||
this.total = list.total;
|
||||
this.loading = false;
|
||||
return;
|
||||
this.loading = true;
|
||||
// 处理日期范围
|
||||
const params = {...this.queryParams};
|
||||
if (params.dateTime && params.dateTime.length === 2) {
|
||||
params.startDate = params.dateTime[0];
|
||||
params.endDate = params.dateTime[1];
|
||||
}
|
||||
delete params.dateTime;
|
||||
delete params.lengthRange;
|
||||
delete params.areaRange;
|
||||
delete params.distanceRange;
|
||||
|
||||
listDefect(params)
|
||||
.then(response => {
|
||||
this.defectList = response.rows;
|
||||
this.total = response.total;
|
||||
this.loading = false;
|
||||
})
|
||||
.catch(() => {
|
||||
this.loading = false;
|
||||
});
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
this.dialogVisible = false;
|
||||
this.resetFormData();
|
||||
},
|
||||
// 表单重置
|
||||
resetForm(formName) {
|
||||
this.$refs[formName].resetFields();
|
||||
},
|
||||
resetQuery() {
|
||||
this.resetForm("queryForm");
|
||||
this.queryParams = {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
segmentName: "",
|
||||
dateTime: [],
|
||||
defectType: [],
|
||||
taskId: "",
|
||||
state: [],
|
||||
inspectDirection: [],
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
warningFlag: null,
|
||||
minLen: null,
|
||||
maxLen: null,
|
||||
minArea: null,
|
||||
maxArea: null,
|
||||
minDistance: null,
|
||||
maxDistance: null
|
||||
};
|
||||
this.handleQuery();
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNum = 1;
|
||||
this.getList();
|
||||
},
|
||||
// 多选框选中数据
|
||||
handleSelectionChange(selection) {
|
||||
this.ids = selection.map(item => item.id);
|
||||
this.single = selection.length !== 1;
|
||||
this.multiple = !selection.length;
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.resetFormData();
|
||||
this.dialogVisible = true;
|
||||
this.dialogTitle = "添加缺陷";
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
if (row) {
|
||||
// 通过行数据修改
|
||||
this.loadDefect(row.id);
|
||||
} else if (this.ids.length === 1) {
|
||||
// 通过选中项修改
|
||||
this.loadDefect(this.ids[0]);
|
||||
} else {
|
||||
this.$modal.msgWarning("请选择一条记录进行修改");
|
||||
}
|
||||
},
|
||||
/** 加载缺陷数据 */
|
||||
loadDefect(id) {
|
||||
getDefect(id)
|
||||
.then(response => {
|
||||
this.form = {...response.data};
|
||||
// 处理日期格式
|
||||
if (this.form.createdTime) {
|
||||
this.form.createdTime = new Date(this.form.createdTime);
|
||||
}
|
||||
this.dialogVisible = true;
|
||||
this.dialogTitle = "修改缺陷";
|
||||
})
|
||||
.catch(() => {
|
||||
this.$modal.msgError("加载缺陷数据失败");
|
||||
});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm() {
|
||||
this.$refs["defectForm"].validate(valid => {
|
||||
if (valid) {
|
||||
if (this.form.id) {
|
||||
// 更新缺陷
|
||||
updateDefect(this.form)
|
||||
.then(() => {
|
||||
this.$modal.msgSuccess("修改成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
})
|
||||
.catch(() => {
|
||||
this.$modal.msgError("修改失败");
|
||||
});
|
||||
} else {
|
||||
// 添加缺陷
|
||||
addDefect(this.form)
|
||||
.then(() => {
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
})
|
||||
.catch(() => {
|
||||
this.$modal.msgError("新增失败");
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
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(() => {
|
||||
});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
this.download('xj/defect/export', {
|
||||
...this.queryParams
|
||||
}, `defect_${new Date().getTime()}.xlsx`)
|
||||
},
|
||||
/** 重置表单数据 */
|
||||
resetFormData() {
|
||||
this.form = {
|
||||
id: null,
|
||||
segmentName: "",
|
||||
defectType: "",
|
||||
equipmentType: "",
|
||||
createdTime: "",
|
||||
updatedTime: "",
|
||||
state: "",
|
||||
stakeStart: "",
|
||||
stakeEnd: "",
|
||||
geometry: {
|
||||
type: "Point",
|
||||
coordinates: []
|
||||
},
|
||||
targetArea: null,
|
||||
targetLen: null,
|
||||
snapshotId: "",
|
||||
taskId: "",
|
||||
segmentId: "",
|
||||
inspectDirection: "",
|
||||
dataFrom: "",
|
||||
warningFlag: 0,
|
||||
equipmentId: "",
|
||||
transformation: 0,
|
||||
dataStatus: 0,
|
||||
objDistance: null,
|
||||
isCalibrated: 0,
|
||||
count: 0,
|
||||
media: []
|
||||
};
|
||||
this.resetForm("defectForm");
|
||||
},
|
||||
|
||||
// 打开查看详情弹出框
|
||||
viewDefect(defect) {
|
||||
this.form = defect;
|
||||
this.openViewDialog = true;
|
||||
this.$nextTick(() => {
|
||||
this.initMap();
|
||||
});
|
||||
},
|
||||
|
||||
// 初始化天地图并标注病害位置
|
||||
initMap() {
|
||||
if (this.map) {
|
||||
this.map.remove(); // 如果已经有地图实例,先移除再重新加载
|
||||
}
|
||||
|
||||
// 初始化天地图
|
||||
this.map = new T.Map("mapContainer");
|
||||
|
||||
// 设置中心点为病害的坐标
|
||||
const coordinates = this.form.geometry.coordinates;
|
||||
if (coordinates && coordinates.length === 2) {
|
||||
const lon = coordinates[0];
|
||||
const lat = coordinates[1];
|
||||
|
||||
// 设置地图中心点
|
||||
const center = new T.LngLat(lon, lat);
|
||||
this.map.centerAndZoom(center, 15);
|
||||
|
||||
// 添加病害位置标注
|
||||
const marker = new T.Marker(center);
|
||||
this.map.addOverLay(marker);
|
||||
} else {
|
||||
console.error("无效的病害坐标");
|
||||
}
|
||||
},
|
||||
|
||||
// 关闭对话框
|
||||
closeDialog() {
|
||||
this.openViewDialog = false;
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.app-container {
|
||||
padding: 20px;
|
||||
}
|
||||
|
||||
.mb8 {
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
|
||||
.small-padding {
|
||||
padding: 0 5px;
|
||||
}
|
||||
|
||||
.fixed-width {
|
||||
width: 120px;
|
||||
}
|
||||
</style>
|
||||
569
src/views/xj/route/index.vue
Normal file
569
src/views/xj/route/index.vue
Normal file
@ -0,0 +1,569 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||||
<el-form-item label="路线编码" prop="routeCode">
|
||||
<el-input
|
||||
v-model="queryParams.routeCode"
|
||||
placeholder="请输入路线编码,唯一"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="路线名称" prop="routeName">
|
||||
<el-input
|
||||
v-model="queryParams.routeName"
|
||||
placeholder="请输入路线名称"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<el-form-item label="路线全称" prop="fullName">
|
||||
<el-input
|
||||
v-model="queryParams.fullName"
|
||||
placeholder="请输入路线全称"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<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"
|
||||
v-hasPermi="['xj:route:add']"
|
||||
>新增
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['xj:route:edit']"
|
||||
>修改
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['xj:route:remove']"
|
||||
>删除
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['xj:route:export']"
|
||||
>导出
|
||||
</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<el-table v-loading="loading" :data="routeList" @selection-change="handleSelectionChange">
|
||||
<el-table-column type="selection" width="55" align="center"/>
|
||||
<el-table-column label="路线编码" align="center" prop="routeCode"/>
|
||||
<el-table-column label="路线名称" align="center" prop="routeName"/>
|
||||
<el-table-column label="路线全称" align="center" prop="fullName"/>
|
||||
<el-table-column label="方向" align="center" prop="direction"/>
|
||||
<el-table-column label="起点" align="center" prop="startPoint"/>
|
||||
<el-table-column label="终点" align="center" prop="endPoint"/>
|
||||
<el-table-column label="起点桩号" align="center" prop="startMilepost"/>
|
||||
<el-table-column label="止点桩号" align="center" prop="endMilepost"/>
|
||||
<el-table-column label="创建人" align="center" prop="createdBy"/>
|
||||
<el-table-column label="创建时间" align="center" prop="createdAt" width="180">
|
||||
<template slot-scope="scope">
|
||||
<span>{{ parseTime(scope.row.createdAt, '{y}-{m}-{d}') }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="修改人" align="center" prop="updatedBy"/>
|
||||
<el-table-column label="修改时间" align="center" prop="updatedAt" width="180">
|
||||
<template slot-scope="scope">
|
||||
<span>{{ parseTime(scope.row.updatedAt, '{y}-{m}-{d}') }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
|
||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-edit"
|
||||
@click="handleUpdate(scope.row)"
|
||||
v-hasPermi="['xj:route:edit']"
|
||||
>修改
|
||||
</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['xj:route:remove']"
|
||||
>删除
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"
|
||||
/>
|
||||
|
||||
<!-- 添加或修改道路线对话框 -->
|
||||
<el-dialog :title="title" :visible.sync="dialogVisible" width="80%" append-to-body>
|
||||
<div style="display: flex;">
|
||||
<!-- 左侧表单部分 -->
|
||||
<div style="flex: 1; padding-right: 20px;">
|
||||
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
|
||||
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="路线编码">
|
||||
<el-input v-model="form.routeCode"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="路线名称">
|
||||
<el-input v-model="form.routeName"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item label="路线类型">
|
||||
<el-input v-model="form.routeType"></el-input>
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="路线全称">
|
||||
<el-input v-model="form.fullName"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="方向">
|
||||
<el-input v-model="form.direction"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="起点">
|
||||
<el-input v-model="form.startPoint"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="终点">
|
||||
<el-input v-model="form.endPoint"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="起点桩号">
|
||||
<el-input v-model="form.startMilepost"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="止点桩号">
|
||||
<el-input v-model="form.endMilepost"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
<el-form-item label="坐标点">
|
||||
<el-input type="textarea" :disabled="true" v-model="form.coordinates" rows="4"></el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="备注">
|
||||
<el-input v-model="form.remarks"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</div>
|
||||
|
||||
<!-- 右侧地图部分 -->
|
||||
<div style="flex: 1; position: relative;">
|
||||
<div id="add_map" ref="mapContainer" class="no-hand-cursor"></div>
|
||||
</div>
|
||||
</div>
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="primary" @click="submitForm">确 定</el-button>
|
||||
<el-button @click="cancel">取 消</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import {listRoute, getRoute, delRoute, addRoute, updateRoute} from "@/api/xj/route";
|
||||
|
||||
export default {
|
||||
name: "Route",
|
||||
data() {
|
||||
return {
|
||||
menuOpen: false,
|
||||
markers: [],
|
||||
dialogVisible: false, // 控制dialog显示
|
||||
routeForm: {
|
||||
routeCode: '',
|
||||
routeName: '',
|
||||
routeFullName: '',
|
||||
direction: '',
|
||||
startPoint: '',
|
||||
endPoint: '',
|
||||
startStake: '',
|
||||
endStake: '',
|
||||
coordinates: '',
|
||||
remark: ''
|
||||
},
|
||||
lines: [], // 保存所有添加的连线
|
||||
map: null,
|
||||
markerLayer: null,
|
||||
previousPoint: null,
|
||||
// 遮罩层
|
||||
loading: true,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
single: true,
|
||||
// 非多个禁用
|
||||
multiple: true,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 道路线表格数据
|
||||
routeList: [],
|
||||
// 弹出层标题
|
||||
title: "",
|
||||
// 是否显示弹出层
|
||||
open: false,
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
routeCode: null,
|
||||
routeName: null,
|
||||
fullName: null,
|
||||
routeType: null,
|
||||
},
|
||||
// 表单参数
|
||||
form: {
|
||||
coordinates: '',
|
||||
|
||||
},
|
||||
// 表单校验
|
||||
rules: {
|
||||
routeCode: [
|
||||
{required: true, message: "路线编码,唯一不能为空", trigger: "blur"}
|
||||
],
|
||||
routeName: [
|
||||
{required: true, message: "路线名称不能为空", trigger: "blur"}
|
||||
],
|
||||
routeType: [
|
||||
{required: true, message: "路线类型不能为空", trigger: "change"}
|
||||
],
|
||||
}
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.getList();
|
||||
this.dialogVisible = true;
|
||||
this.dialogVisible = false;
|
||||
},
|
||||
methods: {
|
||||
undoLastAction() {
|
||||
// 撤销最后一次添加的点和连线
|
||||
if (this.lines.length > 0) {
|
||||
const lastLine = this.lines.pop();
|
||||
this.map.removeOverLay(lastLine);// 从地图中移除最后一条线
|
||||
}
|
||||
|
||||
if (this.lines.length == 0) {
|
||||
this.resetMap();
|
||||
return;
|
||||
}
|
||||
this.markers.pop();
|
||||
// 更新上一个点为撤销后的点
|
||||
this.previousPoint = this.markers.length > 0 ? this.markers[this.markers.length - 1].getLngLat() : null;
|
||||
|
||||
// 更新坐标点 textarea
|
||||
const coordArr = this.form.coordinates.split(';');
|
||||
coordArr.pop(); // 移除最后一个坐标
|
||||
this.form.coordinates = coordArr.join(';');
|
||||
},
|
||||
|
||||
resetMap() {
|
||||
// 清空坐标点、地图上的所有覆盖物
|
||||
this.form.coordinates = '';
|
||||
this.previousPoint = null;
|
||||
this.map.clearOverLays();
|
||||
this.markers = [];
|
||||
this.lines = [];
|
||||
},
|
||||
initMap() {
|
||||
if (!this.map){
|
||||
// 初始化天地图
|
||||
|
||||
this.map = new T.Map('add_map');
|
||||
this.map.centerAndZoom(new T.LngLat(116.40769, 39.89945), 12); // 设置中心点和缩放级别
|
||||
|
||||
// 添加双击事件
|
||||
this.map.on("click", this.onMapClick);
|
||||
|
||||
// 添加右键菜单
|
||||
this.map.on("contextmenu", this.onMapRightClick);
|
||||
}else{
|
||||
this.resetMap()
|
||||
}
|
||||
|
||||
|
||||
},
|
||||
onMapClick(e) {
|
||||
if (this.menuOpen) {
|
||||
this.menuOpen = false;
|
||||
return;
|
||||
}
|
||||
const latLng = e.lnglat;
|
||||
const point = `${latLng.lng},${latLng.lat}`;
|
||||
|
||||
// 追加经纬度到textarea
|
||||
if(this.form.coordinates == null){
|
||||
this.form.coordinates = '';
|
||||
}
|
||||
this.form.coordinates += this.form.coordinates ? `;${point}` : point;
|
||||
|
||||
// 绘制点和连线
|
||||
|
||||
const marker = new T.Marker(latLng);
|
||||
|
||||
|
||||
this.markers.push(marker); // 保存点
|
||||
// 连线
|
||||
if (this.previousPoint) {
|
||||
const line = new T.Polyline([this.previousPoint, latLng], {
|
||||
strokeColor: "blue",
|
||||
strokeWeight: 3,
|
||||
strokeOpacity: 0.7
|
||||
});
|
||||
this.map.addOverLay(line);
|
||||
this.lines.push(line)
|
||||
}
|
||||
if (this.lines.length == 0 ){
|
||||
this.map.addOverLay(marker)
|
||||
}
|
||||
this.previousPoint = latLng; // 记录上一个点
|
||||
},
|
||||
drawExistingCoordinates() {
|
||||
// 如果有保存的坐标点数据
|
||||
if (this.form.coordinates) {
|
||||
const coordArr = this.form.coordinates.split(';');
|
||||
let previousLatLng = null;
|
||||
|
||||
coordArr.forEach((coord, index) => {
|
||||
const [lng, lat] = coord.split(',').map(Number);
|
||||
const latLng = new T.LngLat(lng, lat);
|
||||
|
||||
// 绘制点
|
||||
const marker = new T.Marker(latLng);
|
||||
this.markers.push(marker);
|
||||
|
||||
// 如果有上一个点,绘制连线
|
||||
if (previousLatLng) {
|
||||
const line = new T.Polyline([previousLatLng, latLng], {
|
||||
strokeColor: "blue",
|
||||
strokeWeight: 3,
|
||||
strokeOpacity: 0.7
|
||||
});
|
||||
this.map.addOverLay(line);
|
||||
this.lines.push(line);
|
||||
}
|
||||
|
||||
// 将当前点设置为 previousPoint,最后一个点会被设置为最后的 previousPoint
|
||||
previousLatLng = latLng;
|
||||
});
|
||||
|
||||
// 设置最后一个点为当前的 previousPoint,方便继续绘制
|
||||
this.previousPoint = previousLatLng;
|
||||
}
|
||||
},
|
||||
onMapRightClick(e) {
|
||||
this.menuOpen = true;
|
||||
var menu = new T.ContextMenu({
|
||||
width: 50
|
||||
});
|
||||
var _MenuItem1 = new T.MenuItem("撤销", this.undoLastAction);
|
||||
|
||||
var _MenuItem2 = new T.MenuItem("重绘", this.resetMap);
|
||||
|
||||
menu.addItem(_MenuItem1);
|
||||
|
||||
menu.addItem(_MenuItem2);
|
||||
this.map.addContextMenu(menu);
|
||||
},
|
||||
|
||||
/** 查询道路线列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
listRoute(this.queryParams).then(response => {
|
||||
this.routeList = response.rows;
|
||||
this.total = response.total;
|
||||
this.loading = false;
|
||||
});
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
this.open = false;
|
||||
this.dialogVisible = false;
|
||||
this.reset();
|
||||
},
|
||||
// 表单重置
|
||||
reset() {
|
||||
this.form = {
|
||||
id: null,
|
||||
routeCode: null,
|
||||
routeName: null,
|
||||
fullName: null,
|
||||
routeType: null,
|
||||
direction: null,
|
||||
startPoint: null,
|
||||
endPoint: null,
|
||||
coordinates: null,
|
||||
startMilepost: null,
|
||||
endMilepost: null,
|
||||
remarks: null,
|
||||
createdBy: null,
|
||||
createdAt: null,
|
||||
updatedBy: null,
|
||||
updatedAt: null,
|
||||
deletedBy: null,
|
||||
deletedAt: null,
|
||||
isDeleted: null,
|
||||
companyId: null
|
||||
};
|
||||
this.resetForm("form");
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNum = 1;
|
||||
this.getList();
|
||||
},
|
||||
/** 重置按钮操作 */
|
||||
resetQuery() {
|
||||
this.resetForm("queryForm");
|
||||
this.handleQuery();
|
||||
},
|
||||
// 多选框选中数据
|
||||
handleSelectionChange(selection) {
|
||||
this.ids = selection.map(item => item.id)
|
||||
this.single = selection.length !== 1
|
||||
this.multiple = !selection.length
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.reset();
|
||||
this.dialogVisible = true;
|
||||
|
||||
this.title = "添加道路线";
|
||||
let that = this;
|
||||
setTimeout(function () {
|
||||
that.initMap();
|
||||
}, 100)
|
||||
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
this.reset();
|
||||
const id = row.id || this.ids
|
||||
getRoute(id).then(response => {
|
||||
this.form = response.data;
|
||||
this.dialogVisible = true;
|
||||
this.title = "修改道路线";
|
||||
let that = this;
|
||||
|
||||
setTimeout(function () {
|
||||
that.initMap();
|
||||
that.drawExistingCoordinates()
|
||||
},200)
|
||||
|
||||
});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm() {
|
||||
this.$refs["form"].validate(valid => {
|
||||
if (valid) {
|
||||
if (this.form.id != null) {
|
||||
updateRoute(this.form).then(response => {
|
||||
this.$modal.msgSuccess("修改成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
});
|
||||
} else {
|
||||
addRoute(this.form).then(response => {
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
handleDelete(row) {
|
||||
const ids = row.id || this.ids;
|
||||
this.$modal.confirm('是否确认删除道路线编号为"' + ids + '"的数据项?').then(function () {
|
||||
return delRoute(ids);
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("删除成功");
|
||||
}).catch(() => {
|
||||
});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
this.download('xj/route/export', {
|
||||
...this.queryParams
|
||||
}, `route_${new Date().getTime()}.xlsx`)
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
<style scoped>
|
||||
|
||||
|
||||
.no-hand-cursor {
|
||||
cursor: default !important;
|
||||
width: 100%;
|
||||
height: 500px;
|
||||
}
|
||||
</style>
|
||||
543
src/views/xj/segment/index.vue
Normal file
543
src/views/xj/segment/index.vue
Normal file
@ -0,0 +1,543 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||||
|
||||
<el-form-item label="路段名称" prop="routeName">
|
||||
<el-input
|
||||
v-model="queryParams.segname"
|
||||
placeholder="请输入路线名称"
|
||||
clearable
|
||||
@keyup.enter.native="handleQuery"
|
||||
/>
|
||||
</el-form-item>
|
||||
<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"
|
||||
v-hasPermi="['xj:route:add']"
|
||||
>新增
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="success"
|
||||
plain
|
||||
icon="el-icon-edit"
|
||||
size="mini"
|
||||
:disabled="single"
|
||||
@click="handleUpdate"
|
||||
v-hasPermi="['xj:route:edit']"
|
||||
>修改
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="danger"
|
||||
plain
|
||||
icon="el-icon-delete"
|
||||
size="mini"
|
||||
:disabled="multiple"
|
||||
@click="handleDelete"
|
||||
v-hasPermi="['xj:route:remove']"
|
||||
>删除
|
||||
</el-button>
|
||||
</el-col>
|
||||
<el-col :span="1.5">
|
||||
<el-button
|
||||
type="warning"
|
||||
plain
|
||||
icon="el-icon-download"
|
||||
size="mini"
|
||||
@click="handleExport"
|
||||
v-hasPermi="['xj:route:export']"
|
||||
>导出
|
||||
</el-button>
|
||||
</el-col>
|
||||
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||
</el-row>
|
||||
|
||||
<el-table v-loading="loading" :data="routeList" @selection-change="handleSelectionChange">
|
||||
<el-table-column type="selection" width="55" align="center"/>
|
||||
<el-table-column label="路段名称" align="center" prop="segname"/>
|
||||
<el-table-column label="路段编码" align="center" prop="segcode"/>
|
||||
<el-table-column label="起始桩" align="center" prop="stakestart"/>
|
||||
<el-table-column label="终止桩" align="center" prop="stakeend"/>
|
||||
<el-table-column label="道路类型" align="center" prop="roadtype"/>
|
||||
<el-table-column label="里程" align="center" prop="mileage"/>
|
||||
<el-table-column label="车道数量" align="center" prop="lanecount"/>
|
||||
<el-table-column label="城市" align="center" prop="city"/>
|
||||
<el-table-column label="区县" align="center" prop="district"/>
|
||||
<el-table-column label="最大限速" align="center" prop="maxspeedlimit"/>
|
||||
|
||||
|
||||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||
<template slot-scope="scope">
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-edit"
|
||||
@click="handleUpdate(scope.row)"
|
||||
v-hasPermi="['xj:route:edit']"
|
||||
>修改
|
||||
</el-button>
|
||||
<el-button
|
||||
size="mini"
|
||||
type="text"
|
||||
icon="el-icon-delete"
|
||||
@click="handleDelete(scope.row)"
|
||||
v-hasPermi="['xj:route:remove']"
|
||||
>删除
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="queryParams.pageNum"
|
||||
:limit.sync="queryParams.pageSize"
|
||||
@pagination="getList"
|
||||
/>
|
||||
|
||||
<!-- 添加或修改道路线对话框 -->
|
||||
<el-dialog :title="title" :visible.sync="dialogVisible" width="80%" append-to-body>
|
||||
<div style="display: flex;">
|
||||
<!-- 左侧表单部分 -->
|
||||
<div style="flex: 1; padding-right: 20px;">
|
||||
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
|
||||
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="路段编码">
|
||||
<el-input v-model="form.segcode"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="路段名称">
|
||||
<el-input v-model="form.segname"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item label="道路类型">
|
||||
<el-input v-model="form.roadtype"></el-input>
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="里程">
|
||||
<el-input v-model="form.mileage"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="车道数量">
|
||||
<el-input v-model="form.lanecount"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="城市">
|
||||
<el-input v-model="form.city"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="区县">
|
||||
<el-input v-model="form.district"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
<el-form-item>
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="12">
|
||||
<el-form-item label="养护级别">
|
||||
<el-input v-model="form.curinglevel"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="12">
|
||||
<el-form-item label="最大限速">
|
||||
<el-input v-model="form.maxspeedlimit"></el-input>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form-item>
|
||||
|
||||
<el-form-item label="备注">
|
||||
<el-input v-model="form.mark"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</div>
|
||||
|
||||
<!-- 右侧地图部分 -->
|
||||
<div style="flex: 1; position: relative;">
|
||||
<div id="add_map" ref="mapContainer" class="no-hand-cursor"></div>
|
||||
</div>
|
||||
</div>
|
||||
<div slot="footer" class="dialog-footer">
|
||||
<el-button type="primary" @click="submitForm">确 定</el-button>
|
||||
<el-button @click="cancel">取 消</el-button>
|
||||
</div>
|
||||
</el-dialog>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import {listRoute, getRoute, delRoute, addRoute, updateRoute} from "@/api/xj/route";
|
||||
|
||||
export default {
|
||||
name: "Route",
|
||||
data() {
|
||||
return {
|
||||
menuOpen: false,
|
||||
markers: [],
|
||||
dialogVisible: false, // 控制dialog显示
|
||||
routeForm: {
|
||||
routeCode: '',
|
||||
routeName: '',
|
||||
routeFullName: '',
|
||||
direction: '',
|
||||
startPoint: '',
|
||||
endPoint: '',
|
||||
startStake: '',
|
||||
endStake: '',
|
||||
coordinates: '',
|
||||
remark: ''
|
||||
},
|
||||
lines: [], // 保存所有添加的连线
|
||||
map: null,
|
||||
markerLayer: null,
|
||||
previousPoint: null,
|
||||
// 遮罩层
|
||||
loading: true,
|
||||
// 选中数组
|
||||
ids: [],
|
||||
// 非单个禁用
|
||||
single: true,
|
||||
// 非多个禁用
|
||||
multiple: true,
|
||||
// 显示搜索条件
|
||||
showSearch: true,
|
||||
// 总条数
|
||||
total: 0,
|
||||
// 道路线表格数据
|
||||
routeList: [],
|
||||
// 弹出层标题
|
||||
title: "",
|
||||
// 是否显示弹出层
|
||||
open: false,
|
||||
// 查询参数
|
||||
queryParams: {
|
||||
pageNum: 1,
|
||||
pageSize: 10,
|
||||
routeCode: null,
|
||||
routeName: null,
|
||||
fullName: null,
|
||||
routeType: null,
|
||||
},
|
||||
// 表单参数
|
||||
form: {
|
||||
coordinates: '',
|
||||
|
||||
},
|
||||
// 表单校验
|
||||
rules: {
|
||||
routeCode: [
|
||||
{required: true, message: "路线编码,唯一不能为空", trigger: "blur"}
|
||||
],
|
||||
routeName: [
|
||||
{required: true, message: "路线名称不能为空", trigger: "blur"}
|
||||
],
|
||||
routeType: [
|
||||
{required: true, message: "路线类型不能为空", trigger: "change"}
|
||||
],
|
||||
}
|
||||
};
|
||||
},
|
||||
created() {
|
||||
this.getList();
|
||||
this.dialogVisible = true;
|
||||
this.dialogVisible = false;
|
||||
},
|
||||
methods: {
|
||||
undoLastAction() {
|
||||
// 撤销最后一次添加的点和连线
|
||||
if (this.lines.length > 0) {
|
||||
const lastLine = this.lines.pop();
|
||||
this.map.removeOverLay(lastLine);// 从地图中移除最后一条线
|
||||
}
|
||||
|
||||
if (this.lines.length == 0) {
|
||||
this.resetMap();
|
||||
return;
|
||||
}
|
||||
this.markers.pop();
|
||||
// 更新上一个点为撤销后的点
|
||||
this.previousPoint = this.markers.length > 0 ? this.markers[this.markers.length - 1].getLngLat() : null;
|
||||
|
||||
// 更新坐标点 textarea
|
||||
const coordArr = this.form.coordinates.split(';');
|
||||
coordArr.pop(); // 移除最后一个坐标
|
||||
this.form.coordinates = coordArr.join(';');
|
||||
},
|
||||
|
||||
resetMap() {
|
||||
// 清空坐标点、地图上的所有覆盖物
|
||||
this.form.coordinates = '';
|
||||
this.previousPoint = null;
|
||||
this.map.clearOverLays();
|
||||
this.markers = [];
|
||||
this.lines = [];
|
||||
},
|
||||
initMap() {
|
||||
if (!this.map){
|
||||
// 初始化天地图
|
||||
|
||||
this.map = new T.Map('add_map');
|
||||
this.map.centerAndZoom(new T.LngLat(116.40769, 39.89945), 12); // 设置中心点和缩放级别
|
||||
|
||||
// 添加双击事件
|
||||
this.map.on("click", this.onMapClick);
|
||||
|
||||
// 添加右键菜单
|
||||
this.map.on("contextmenu", this.onMapRightClick);
|
||||
}else{
|
||||
this.resetMap()
|
||||
}
|
||||
|
||||
|
||||
},
|
||||
onMapClick(e) {
|
||||
if (this.menuOpen) {
|
||||
this.menuOpen = false;
|
||||
return;
|
||||
}
|
||||
const latLng = e.lnglat;
|
||||
const point = `${latLng.lng},${latLng.lat}`;
|
||||
|
||||
// 追加经纬度到textarea
|
||||
if(this.form.coordinates == null){
|
||||
this.form.coordinates = '';
|
||||
}
|
||||
this.form.coordinates += this.form.coordinates ? `;${point}` : point;
|
||||
|
||||
// 绘制点和连线
|
||||
|
||||
const marker = new T.Marker(latLng);
|
||||
|
||||
|
||||
this.markers.push(marker); // 保存点
|
||||
// 连线
|
||||
if (this.previousPoint) {
|
||||
const line = new T.Polyline([this.previousPoint, latLng], {
|
||||
strokeColor: "blue",
|
||||
strokeWeight: 3,
|
||||
strokeOpacity: 0.7
|
||||
});
|
||||
this.map.addOverLay(line);
|
||||
this.lines.push(line)
|
||||
}
|
||||
if (this.lines.length == 0 ){
|
||||
this.map.addOverLay(marker)
|
||||
}
|
||||
this.previousPoint = latLng; // 记录上一个点
|
||||
},
|
||||
drawExistingCoordinates() {
|
||||
// 如果有保存的坐标点数据
|
||||
if (this.form.coordinates) {
|
||||
const coordArr = this.form.coordinates.split(';');
|
||||
let previousLatLng = null;
|
||||
|
||||
coordArr.forEach((coord, index) => {
|
||||
const [lng, lat] = coord.split(',').map(Number);
|
||||
const latLng = new T.LngLat(lng, lat);
|
||||
|
||||
// 绘制点
|
||||
const marker = new T.Marker(latLng);
|
||||
this.markers.push(marker);
|
||||
|
||||
// 如果有上一个点,绘制连线
|
||||
if (previousLatLng) {
|
||||
const line = new T.Polyline([previousLatLng, latLng], {
|
||||
strokeColor: "blue",
|
||||
strokeWeight: 3,
|
||||
strokeOpacity: 0.7
|
||||
});
|
||||
this.map.addOverLay(line);
|
||||
this.lines.push(line);
|
||||
}
|
||||
|
||||
// 将当前点设置为 previousPoint,最后一个点会被设置为最后的 previousPoint
|
||||
previousLatLng = latLng;
|
||||
});
|
||||
|
||||
// 设置最后一个点为当前的 previousPoint,方便继续绘制
|
||||
this.previousPoint = previousLatLng;
|
||||
}
|
||||
},
|
||||
onMapRightClick(e) {
|
||||
this.menuOpen = true;
|
||||
var menu = new T.ContextMenu({
|
||||
width: 50
|
||||
});
|
||||
var _MenuItem1 = new T.MenuItem("撤销", this.undoLastAction);
|
||||
|
||||
var _MenuItem2 = new T.MenuItem("重绘", this.resetMap);
|
||||
|
||||
menu.addItem(_MenuItem1);
|
||||
|
||||
menu.addItem(_MenuItem2);
|
||||
this.map.addContextMenu(menu);
|
||||
},
|
||||
|
||||
/** 查询道路线列表 */
|
||||
getList() {
|
||||
this.loading = true;
|
||||
listRoute(this.queryParams).then(response => {
|
||||
this.routeList = response.rows;
|
||||
this.total = response.total;
|
||||
this.loading = false;
|
||||
});
|
||||
},
|
||||
// 取消按钮
|
||||
cancel() {
|
||||
this.open = false;
|
||||
this.dialogVisible = false;
|
||||
this.reset();
|
||||
},
|
||||
// 表单重置
|
||||
reset() {
|
||||
this.form = {
|
||||
id: null,
|
||||
routeCode: null,
|
||||
routeName: null,
|
||||
fullName: null,
|
||||
routeType: null,
|
||||
direction: null,
|
||||
startPoint: null,
|
||||
endPoint: null,
|
||||
coordinates: null,
|
||||
startMilepost: null,
|
||||
endMilepost: null,
|
||||
remarks: null,
|
||||
createdBy: null,
|
||||
createdAt: null,
|
||||
updatedBy: null,
|
||||
updatedAt: null,
|
||||
deletedBy: null,
|
||||
deletedAt: null,
|
||||
isDeleted: null,
|
||||
companyId: null
|
||||
};
|
||||
this.resetForm("form");
|
||||
},
|
||||
/** 搜索按钮操作 */
|
||||
handleQuery() {
|
||||
this.queryParams.pageNum = 1;
|
||||
this.getList();
|
||||
},
|
||||
/** 重置按钮操作 */
|
||||
resetQuery() {
|
||||
this.resetForm("queryForm");
|
||||
this.handleQuery();
|
||||
},
|
||||
// 多选框选中数据
|
||||
handleSelectionChange(selection) {
|
||||
this.ids = selection.map(item => item.id)
|
||||
this.single = selection.length !== 1
|
||||
this.multiple = !selection.length
|
||||
},
|
||||
/** 新增按钮操作 */
|
||||
handleAdd() {
|
||||
this.reset();
|
||||
this.dialogVisible = true;
|
||||
|
||||
this.title = "添加道路线";
|
||||
let that = this;
|
||||
setTimeout(function () {
|
||||
that.initMap();
|
||||
}, 100)
|
||||
|
||||
},
|
||||
/** 修改按钮操作 */
|
||||
handleUpdate(row) {
|
||||
this.reset();
|
||||
const id = row.id || this.ids
|
||||
getRoute(id).then(response => {
|
||||
this.form = response.data;
|
||||
this.dialogVisible = true;
|
||||
this.title = "修改道路线";
|
||||
let that = this;
|
||||
|
||||
setTimeout(function () {
|
||||
that.initMap();
|
||||
that.drawExistingCoordinates()
|
||||
},200)
|
||||
|
||||
});
|
||||
},
|
||||
/** 提交按钮 */
|
||||
submitForm() {
|
||||
this.$refs["form"].validate(valid => {
|
||||
if (valid) {
|
||||
if (this.form.id != null) {
|
||||
updateRoute(this.form).then(response => {
|
||||
this.$modal.msgSuccess("修改成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
});
|
||||
} else {
|
||||
addRoute(this.form).then(response => {
|
||||
this.$modal.msgSuccess("新增成功");
|
||||
this.dialogVisible = false;
|
||||
this.getList();
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
},
|
||||
/** 删除按钮操作 */
|
||||
handleDelete(row) {
|
||||
const ids = row.id || this.ids;
|
||||
this.$modal.confirm('是否确认删除道路线编号为"' + ids + '"的数据项?').then(function () {
|
||||
return delRoute(ids);
|
||||
}).then(() => {
|
||||
this.getList();
|
||||
this.$modal.msgSuccess("删除成功");
|
||||
}).catch(() => {
|
||||
});
|
||||
},
|
||||
/** 导出按钮操作 */
|
||||
handleExport() {
|
||||
this.download('xj/route/export', {
|
||||
...this.queryParams
|
||||
}, `route_${new Date().getTime()}.xlsx`)
|
||||
}
|
||||
}
|
||||
};
|
||||
</script>
|
||||
<style scoped>
|
||||
|
||||
|
||||
.no-hand-cursor {
|
||||
cursor: default !important;
|
||||
width: 100%;
|
||||
height: 500px;
|
||||
}
|
||||
</style>
|
||||
Loading…
x
Reference in New Issue
Block a user