# Conflicts:
#	src/views/dataService/remoteSensingData/components/searchCondition.vue
This commit is contained in:
yyhouc 2023-06-26 09:52:46 +08:00
commit 5de7ce79ae
3 changed files with 598 additions and 296 deletions

View File

@ -1,9 +1,10 @@
<template> <template>
<div ref="map" class="container"></div> <div ref="map"
class="container"></div>
</template> </template>
<script setup> <script setup>
import { ref, onMounted } from 'vue' import { ref, reactive, onMounted } from 'vue'
import WKT from 'terraformer-wkt-parser' import WKT from 'terraformer-wkt-parser'
import * as turf from '@turf/turf' import * as turf from '@turf/turf'
import L from 'leaflet' import L from 'leaflet'
@ -13,10 +14,11 @@ import 'leaflet-draw/dist/leaflet.draw.css'
import '@geoman-io/leaflet-geoman-free'; import '@geoman-io/leaflet-geoman-free';
import '@geoman-io/leaflet-geoman-free/dist/leaflet-geoman.css'; import '@geoman-io/leaflet-geoman-free/dist/leaflet-geoman.css';
import 'Leaflet-ImageOverlay-Rotated' import 'Leaflet-ImageOverlay-Rotated'
import 'leaflet-control-geocoder/dist/Control.Geocoder.css'; // import 'leaflet-control-geocoder/dist/Control.Geocoder.css';
import 'leaflet-control-geocoder'; // import 'leaflet-control-geocoder';
import { useVariableStore } from '/@/stores/index.ts' import { useVariableStore } from '/@/stores/index.ts'
import * as omnivore from '@mapbox/leaflet-omnivore' import * as omnivore from '@mapbox/leaflet-omnivore'
import axios from "axios";
const variableStore = useVariableStore() const variableStore = useVariableStore()
const map = ref() const map = ref()
let homeMap = null let homeMap = null
@ -24,6 +26,9 @@ let featureLayerG_area = null
let featureLayerG_point = null let featureLayerG_point = null
let layerRectangle = null let layerRectangle = null
const state = reactive({
markerLayer: null
})
onMounted(() => { onMounted(() => {
homeMap = L.map(map.value, { homeMap = L.map(map.value, {
@ -31,7 +36,7 @@ onMounted(() => {
crs: L.CRS.EPSG4326, crs: L.CRS.EPSG4326,
center: [29.563761, 106.550464], center: [29.563761, 106.550464],
zoom: 3, zoom: 3,
minZoom: 1, minZoom: 3,
maxZoom: 18, maxZoom: 18,
attributionControl: false, // leaflet attributionControl: false, // leaflet
zoomControl: false, zoomControl: false,
@ -49,32 +54,32 @@ onMounted(() => {
featureLayerG_area = L.layerGroup().addTo(homeMap) featureLayerG_area = L.layerGroup().addTo(homeMap)
featureLayerG_point = L.layerGroup().addTo(homeMap) featureLayerG_point = L.layerGroup().addTo(homeMap)
// 'http://t0.tianditu.com/img_c/wmts?layer=img&style=default&tilematrixset=c&Service=WMTS&Request=GetTile&Version=1.0.0&Format=tiles&TileMatrix={z}&TileCol={x}&TileRow={y}&tk=' 'http://t0.tianditu.com/img_c/wmts?layer=img&style=default&tilematrixset=c&Service=WMTS&Request=GetTile&Version=1.0.0&Format=tiles&TileMatrix={z}&TileCol={x}&TileRow={y}&tk='
// const CIA_C = "http://t0.tianditu.com/cia_c/wmts?layer=cia&style=default&tilematrixset=c&Service=WMTS&Request=GetTile&Version=1.0.0&Format=tiles&TileMatrix={z}&TileCol={x}&TileRow={y}&tk="; const CIA_C = "http://t0.tianditu.com/cia_c/wmts?layer=cia&style=default&tilematrixset=c&Service=WMTS&Request=GetTile&Version=1.0.0&Format=tiles&TileMatrix={z}&TileCol={x}&TileRow={y}&tk=";
// const nameLayer = L.tileLayer(CIA_C + TK_KEY, { const nameLayer = L.tileLayer(CIA_C + TK_KEY, {
// maxZoom: 20, maxZoom: 20,
// tileSize: 256, tileSize: 256,
// zoomOffset: 1 zoomOffset: 1
// }).addTo(homeMap);
// Geocoding
const geocoder = L.Control.geocoder({
defaultMarkGeocode: false,
placeholder: 'Enter address...',
collapsed: true,
}).addTo(homeMap); }).addTo(homeMap);
// Geocoding // // Geocoding
geocoder.on('markgeocode', function (event) { // const geocoder = L.Control.geocoder({
const result = event.geocode || {}; // defaultMarkGeocode: false,
onGeocodeResult(result); // placeholder: 'Enter address...',
}); // collapsed: true,
// }).addTo(homeMap);
// // Geocoding
// geocoder.on('markgeocode', function (event) {
// const result = event.geocode || {};
// onGeocodeResult(result);
// });
}) })
const onGeocodeResult = (result) => { // const onGeocodeResult = (result) => {
homeMap.setView(result.center, 5); // homeMap.setView(result.center, 5);
L.marker(result.center).addTo(homeMap); // L.marker(result.center).addTo(homeMap);
} // }
/** WKT /** WKT
* Object param 参数集合 * Object param 参数集合
@ -309,7 +314,6 @@ const mapOperations = {
featureLayerG_point.clearLayers() featureLayerG_point.clearLayers()
variableStore.layerGroupPoint = null variableStore.layerGroupPoint = null
variableStore.layerGroupPoly = null variableStore.layerGroupPoly = null
}, },
/** /**
* 清楚wkt添加的所有 * 清楚wkt添加的所有
@ -425,6 +429,25 @@ const mapOperations = {
}, },
removeEdit: () => { removeEdit: () => {
homeMap.pm.toggleGlobalRemovalMode(); homeMap.pm.toggleGlobalRemovalMode();
},
//
addressSelect: (keyWord) => {
if (state.markerLayer) {
homeMap.removeLayer(state.markerLayer)
}
let addressServer = 'http://api.tianditu.gov.cn/geocoder?ds={"keyWord":"' + keyWord + '"}&tk=dc8182ebeca998e22154d404aa3c0c17'
const service = axios.get(addressServer).then(res => {
homeMap.flyTo(L.latLng([res.data.location.lat, res.data.location.lon]), 6)
const markerParam = {
'x': res.data.location.lat,
'y': res.data.location.lon
}
state.markerLayer = L.marker(
new L.latLng(res.data.location.lat, res.data.location.lon),
).addTo(homeMap)
})
} }
} }
//omnivore.wkt.parse('POINT(-80 0)').addTo(homeMap); //omnivore.wkt.parse('POINT(-80 0)').addTo(homeMap);

View File

@ -19,16 +19,21 @@
</el-col> </el-col>
</el-row> </el-row>
</el-card> </el-card>
<el-card class="box-card" style="margin-top: 3%;"> <el-card class="box-card"
style="margin-top: 3%;">
<span>Select time range</span> <span>Select time range</span>
<el-row class="block"> <el-row class="block">
<el-col :span="5"> <el-col :span="5">
<span class="demonstration">Start time</span> <span class="demonstration">Start time</span>
</el-col> </el-col>
<el-col :span="19"> <el-col :span="19">
<el-date-picker style="width: 90%;" v-model="state.startTime" type="datetime" <el-date-picker style="width: 90%;"
placeholder="Select start time" value-format="YYYY-MM-DD HH:mm:ss" :shortcuts="state.shortcuts" v-model="state.startTime"
:disabled-date="disabledDate" /> type="datetime"
placeholder="Select start time"
value-format="YYYY-MM-DD HH:mm:ss"
:shortcuts="state.shortcuts"
:disabled-date="disabledDate" />
</el-col> </el-col>
</el-row> </el-row>
<el-row class="block"> <el-row class="block">
@ -36,20 +41,28 @@
<span class="demonstration">End time</span> <span class="demonstration">End time</span>
</el-col> </el-col>
<el-col :span="19"> <el-col :span="19">
<el-date-picker style="width: 90%;" v-model="state.endTime" type="datetime" placeholder="Select end time" <el-date-picker style="width: 90%;"
value-format="YYYY-MM-DD HH:mm:ss" :shortcuts="state.shortcuts" :disabled-date="disabledDate" /> v-model="state.endTime"
type="datetime"
placeholder="Select end time"
value-format="YYYY-MM-DD HH:mm:ss"
:shortcuts="state.shortcuts"
:disabled-date="disabledDate" />
</el-col> </el-col>
</el-row> </el-row>
</el-card> </el-card>
<el-card class="box-card" style="margin-top: 3%;"> <el-card class="box-card"
<span>Select a region <el-switch style="margin-top: 3%;">
v-model="state.switch" <span>Select a region
size="large" <el-switch v-model="state.switch"
active-text="Area" size="large"
inactive-text="Polygon" active-text="Area"
/></span> inactive-text="Polygon" />
<el-scrollbar wrap-class="list" view-class="view-box" :native="false"> </span>
<el-scrollbar wrap-class="list"
view-class="view-box"
:native="false">
<div v-for="(coordinate, i) in state.coordinateList "> <div v-for="(coordinate, i) in state.coordinateList ">
<el-row class="coordinateContainer"> <el-row class="coordinateContainer">
<el-col :span="1"></el-col> <el-col :span="1"></el-col>
@ -59,36 +72,53 @@
parseFloat(coordinate.Lng).toFixed(4) parseFloat(coordinate.Lng).toFixed(4)
}}</span> }}</span>
</el-col> </el-col>
<el-col :span="2"> <!-- <el-col :span="2">
<el-button class="el-icon" @click="editCoordinate" size="small"> <el-button class="el-icon"
@click="editCoordinate"
size="small">
<ele-Edit /> <ele-Edit />
</el-button> </el-button>
</el-col> </el-col> -->
<el-col :span="2"> <el-col :span="2">
<el-button class="el-icon" @click="state.coordinateList.splice(i, 1);" size="small"> <el-button class="el-icon"
@click="state.coordinateList.splice(i, 1);"
size="small">
<ele-Delete /> <ele-Delete />
</el-button> </el-button>
</el-col> </el-col>
</el-row> </el-row>
</div> </div>
<div v-if="state.switch==false"
style="margin-bottom: 10px;">
{{variableStore.layerGroupPoly}}
</div>
</el-scrollbar> </el-scrollbar>
<el-row> <el-row>
<el-col :span=" 1 "></el-col> <el-col :span=" 1 "></el-col>
<el-col :span=" 7 "> <el-col :span=" 7 ">
<el-button class="coordinateBtn" @click=" addCoordinate ">Add coordinates</el-button> <el-button class="coordinateBtn"
@click=" addCoordinate ">Add coordinates</el-button>
</el-col> </el-col>
<el-col :span=" 7 "> <el-col :span=" 7 ">
<el-button class="coordinateBtn" @click=" clearCoordinate ">Clear coordinates</el-button> <el-button class="coordinateBtn"
@click=" clearCoordinate ">Clear coordinates</el-button>
</el-col> </el-col>
</el-row> </el-row>
</el-card> </el-card>
<el-card class="box-card" style="margin-top: 3%;"> <el-card class="box-card"
style="margin-top: 3%;">
<span>Select satellite type</span> <span>Select satellite type</span>
<el-tree-select class="satelliteSelect" v-model=" state.satelliteSelected " :data=" state.sensor " multiple <el-tree-select class="satelliteSelect"
collapse-tags collapse-tags-tooltip :render-after-expand=" false " show-checkbox v-model=" state.satelliteSelected "
placeholder="Select satellite type" /> :data=" state.sensor "
multiple
collapse-tags
collapse-tags-tooltip
:render-after-expand=" false "
show-checkbox
placeholder="Select satellite type" />
</el-card> </el-card>
<!-- <el-card class="box-card" <!-- <el-card class="box-card"
@ -106,19 +136,34 @@
</el-card> --> </el-card> -->
<el-card style="margin-top:3%;"> <el-card style="margin-top:3%;">
<el-row> <el-row>
<el-button class="lowerBtn" @click=" startCrawl ">Start Crawl</el-button> <el-button class="lowerBtn"
@click=" startCrawl ">Start Crawl</el-button>
</el-row> </el-row>
<el-row> <el-row>
<el-button class="lowerBtn" @click=" ClearCondition ">Go Back</el-button> <el-button class="lowerBtn"
@click=" ClearCondition ">Go Back</el-button>
</el-row> </el-row>
</el-card> </el-card>
</div> </div>
</el-col> </el-col>
<el-col :span=" 16 "> <el-col :span=" 16 ">
<Map id="map" ref="map"> <Map id="map"
ref="map">
</Map> </Map>
</el-col> </el-col>
</el-row>
<el-row class="addressGroup">
<el-input v-model="state.address"
placeholder="Please input location"
class="input-with-select"
clearable>
<template #append>
<el-button :icon="Search"
@click="addressSelect" />
</template>
</el-input>
</el-row> </el-row>
<el-dialog title="status" v-model="state.statusShow" width="420px"> <el-dialog title="status" v-model="state.statusShow" width="420px">
<el-table :data="state.statusData"> <el-table :data="state.statusData">
@ -146,6 +191,7 @@ import { ref, reactive, watch, defineExpose, onMounted,defineEmits } from 'vue';
import { submit2 as submit ,rs2,getStatus } from '/@/api/crawl/index'; import { submit2 as submit ,rs2,getStatus } from '/@/api/crawl/index';
import { useUserInfo } from '/@/stores/userInfo'; import { useUserInfo } from '/@/stores/userInfo';
import { ElMessage, ElMessageBox } from "element-plus"; import { ElMessage, ElMessageBox } from "element-plus";
import { Search } from '@element-plus/icons-vue'
import { useVariableStore } from '/@/stores/index.ts'; import { useVariableStore } from '/@/stores/index.ts';
import { getList as BizDict } from "/@/api/system/dictbiz.js"; import { getList as BizDict } from "/@/api/system/dictbiz.js";
const variableStore = useVariableStore(); const variableStore = useVariableStore();
@ -156,6 +202,7 @@ const disabledDate = (time) => {
} }
// //
const map = ref() const map = ref()
const state = reactive({ const state = reactive({
statusData: [], statusData: [],
statusShow: false, statusShow: false,
@ -176,7 +223,7 @@ const state = reactive({
label: 'Sentinel', label: 'Sentinel',
}, },
], ],
dictData:[], dictData: [],
shortcuts: [ shortcuts: [
{ {
text: '1 month ago', text: '1 month ago',
@ -229,32 +276,32 @@ const state = reactive({
disLat: '', disLat: '',
disLon: '', disLon: '',
data: {}, data: {},
data2:[], data2: [],
geometry: null, geometry: null,
address: '',
}) })
// //
const openStatus = () => { const openStatus = () => {
getStatus(state.data.disasterId).then(res => { getStatus(state.data.disasterId).then(res => {
state.statusData = res; state.statusData = res;
console.log(res,state.statusData)
state.statusShow = true; state.statusShow = true;
}) })
} }
// //
onMounted(() => { onMounted(() => {
BizDict({ code: 'satelliteType' }).then(res => { BizDict({ code: 'satelliteType' }).then(res => {
let data = res.map(item=>{ let data = res.map(item => {
return {value:item.dictValue,label:item.dictValue} return { value: item.dictValue, label: item.dictValue }
}) })
state.data2=data; state.data2 = data;
//state.switchtrue landsatSentinel //state.switchtrue landsatSentinel
if(state.switch){ if (state.switch) {
state.sensor=state.data2.filter(item=>{ state.sensor = state.data2.filter(item => {
return item.value=='landsat'||item.value=='sentinel' return item.value == 'landsat' || item.value == 'sentinel'
}) })
}else{ } else {
state.sensor=state.data2.filter(item=>{ state.sensor = state.data2.filter(item => {
return item.value!='landsat'&&item.value!='sentinel' return item.value != 'landsat' && item.value != 'sentinel'
}) })
} }
state.dictData = res; state.dictData = res;
@ -324,14 +371,12 @@ const changeLatLon = (e) => {
state.disLon = String((360 - state.disLon).toFixed(3)) + "°W" state.disLon = String((360 - state.disLon).toFixed(3)) + "°W"
} }
} }
} }
// //
const addCoordinate = () => { const addCoordinate = () => {
state.addCoord = !state.addCoord; state.addCoord = !state.addCoord;
if(state.switch){ if (state.switch) {
if (state.addCoord && state.coordinateList.length <= 2) { if (state.addCoord && state.coordinateList.length <= 2) {
map.value.mapOperations.drawRectangle() map.value.mapOperations.drawRectangle()
map.value.mapOperations.on("click", onMapClick) map.value.mapOperations.on("click", onMapClick)
@ -341,13 +386,13 @@ const addCoordinate = () => {
map.value.mapOperations.off("click", onMapClick) map.value.mapOperations.off("click", onMapClick)
document.getElementsByClassName('coordinateBtn')[0].innerText = 'Add coordinates'; document.getElementsByClassName('coordinateBtn')[0].innerText = 'Add coordinates';
} }
}else{ } else {
map.value.mapOperations.drawCreated() map.value.mapOperations.drawCreated()
map.value.mapOperations.off("click", onMapClick) map.value.mapOperations.off("click", onMapClick)
map.value.mapOperations.drawPolygon() map.value.mapOperations.drawPolygon()
map.value.mapOperations.wktParseToMap(state.geometry) map.value.mapOperations.wktParseToMap(state.geometry)
} }
} }
@ -356,7 +401,7 @@ const mapClick = (res) => {
} }
// //
const clearCoordinate = () => { const clearCoordinate = () => {
if(!state.switch){ if (!state.switch) {
map.value.mapOperations.clearPolygon() map.value.mapOperations.clearPolygon()
return; return;
} }
@ -381,68 +426,68 @@ const startCrawl = () => {
ElMessage.error("Please select the search end time") ElMessage.error("Please select the search end time")
return; return;
} }
if ((state.coordinateList.length == 0 || !state.coordinateList[0].Lat || !state.coordinateList[0].Lng || !state.coordinateList[1].Lat || !state.coordinateList[1].Lng)&&state.switch) { if ((state.coordinateList.length == 0 || !state.coordinateList[0].Lat || !state.coordinateList[0].Lng || !state.coordinateList[1].Lat || !state.coordinateList[1].Lng) && state.switch) {
ElMessage.error("Please draw the area on the map") ElMessage.error("Please draw the area on the map")
return; return;
} }
if(!state.switch&&variableStore.layerGroupPoly==null){ if (!state.switch && variableStore.layerGroupPoly == null) {
ElMessage.error("Please draw the area on the map") ElMessage.error("Please draw the area on the map")
return; return;
} }
var ranges =state.switch? state.coordinateList[0].Lat + ' ' + state.coordinateList[0].Lng + ',' + state.coordinateList[1].Lat + ' ' + state.coordinateList[1].Lng:variableStore.layerGroupPoly; var ranges = state.switch ? state.coordinateList[0].Lat + ' ' + state.coordinateList[0].Lng + ',' + state.coordinateList[1].Lat + ' ' + state.coordinateList[1].Lng : variableStore.layerGroupPoly;
var param = [] var param = []
state.satelliteSelected.forEach(data=>{ state.satelliteSelected.forEach(data => {
// state.dictData.ma // state.dictData.ma
var obj = state.dictData.find(function(item) { var obj = state.dictData.find(function (item) {
return item.dictValue === data; return item.dictValue === data;
}); });
param.push( { param.push({
type: obj.dictKey, type: obj.dictKey,
startDate: state.startTime, startDate: state.startTime,
endDate: state.endTime, endDate: state.endTime,
manageId: userInfo.userInfos.id, manageId: userInfo.userInfos.id,
range:ranges, range: ranges,
status: 0, status: 0,
disasterId: state.data.disasterId, disasterId: state.data.disasterId,
}) })
}) })
// //
submit( param ).then(ret => { submit(param).then(ret => {
let arrParams=[]; let arrParams = [];
ret.forEach(res=>{ ret.forEach(res => {
var obj1 = state.dictData.find(function(item) { var obj1 = state.dictData.find(function (item) {
return item.dictKey == res.type; return item.dictKey == res.type;
}); });
arrParams.push({ arrParams.push({
type:obj1.dictValue, type: obj1.dictValue,
range:res.range, range: res.range,
id:res.id id: res.id
}) })
}) })
// //
rs2(state.data.disasterId,arrParams,state.startTime,state.endTime).then(res => { rs2(state.data.disasterId, arrParams, state.startTime, state.endTime).then(res => {
//arrParamstype 使 //arrParamstype 使
var typeArr=[]; var typeArr = [];
arrParams.forEach(item=>{ arrParams.forEach(item => {
typeArr.push(item.type) typeArr.push(item.type)
}) })
var typeStr=typeArr.join('、') var typeStr = typeArr.join('、')
// getData();
//使
ElMessageBox.confirm('The ' + typeStr + ' data has been crawled, do you want to stay on this page?', 'Prompt', {
confirmButtonText: 'Stay',
cancelButtonText: 'Return to the list',
type: 'warning'
}).then(() => {
}).catch(() => {
emit('response')
});
// getData();
//使
ElMessageBox.confirm('The '+typeStr+' data has been crawled, do you want to stay on this page?', 'Prompt', {
confirmButtonText: 'Stay',
cancelButtonText: 'Return to the list',
type: 'warning'
}).then(() => {
}).catch(() => {
emit('response')
});
}) })
}) })
} }
@ -458,6 +503,19 @@ const ClearCondition = () => {
emit('response') emit('response')
} }
//
const addressSelect = () => {
if (state.address) {
map.value.mapOperations.addressSelect(state.address)
}
else {
ElMessage({
message: 'Warning, please enter location !',
type: 'error',
})
}
}
// //
watch( watch(
() => state.coordinateList.length, () => state.coordinateList.length,
@ -472,13 +530,13 @@ watch(
watch( watch(
() => state.switch, () => state.switch,
(newValue, oldValue) => { (newValue, oldValue) => {
if(newValue){ if (newValue) {
state.sensor=state.data2.filter(item=>{ state.sensor = state.data2.filter(item => {
return item.value=='landsat'||item.value=='sentinel' return item.value == 'landsat' || item.value == 'sentinel'
}) })
}else{ } else {
state.sensor=state.data2.filter(item=>{ state.sensor = state.data2.filter(item => {
return item.value!='landsat'&&item.value!='sentinel'&&item.value!='obiter'&&item.value!='domestic' return item.value != 'landsat' && item.value != 'sentinel' && item.value != 'obiter' && item.value != 'domestic'
}) })
} }
}, },
@ -501,55 +559,62 @@ defineExpose({
<style scoped lang="scss"> <style scoped lang="scss">
.rsSelect { .rsSelect {
border: 1px solid #f7f7fa; border: 1px solid #f7f7fa;
height: 52rem; height: 52rem;
span {
display: block;
margin-bottom: 3%;
font-size: 18px;
}
span { .satelliteSelect,
display: block; .idSelect {
margin-bottom: 3%; width: 90%;
font-size: 18px; margin: 2% 3% 0 3%;
} }
.satelliteSelect, .block {
.idSelect { margin-top: 2%;
width: 90%; }
margin: 2% 3% 0 3%;
}
.block { .demonstration {
margin-top: 2%; font-size: 14px;
} float: left;
height: 20px;
line-height: 40px;
}
.demonstration { .coordinateContainer {
font-size: 14px; margin: 3%;
float: left; height: 15px;
height: 20px; }
line-height: 40px;
}
.coordinateContainer { .coordinateBtn {
margin: 3%; width: 90%;
height: 15px; word-break: keep-all;
} white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.coordinateBtn { .lowerBtn {
width: 90%; width: 100%;
word-break: keep-all; text-align: center;
white-space: nowrap; margin-top: 5px;
overflow: hidden; }
text-overflow: ellipsis;
}
.lowerBtn {
width: 100%;
text-align: center;
margin-top: 5px;
}
} }
#map { #map {
height: 58rem; height: 58rem;
margin-left: 5px; margin-left: 5px;
z-index: 1;
}
.addressGroup {
position: absolute;
top: 20px;
right: 30px;
z-index: 99;
} }
</style> </style>

View File

@ -1,182 +1,360 @@
<template> <template>
<div class="system-role-container layout-padding"> <div class="system-role-container layout-padding">
<el-config-provider :locale="en" style="position: relative;"> <el-config-provider :locale="en"
style="position: relative;">
<div class="system-role-padding layout-padding-auto layout-padding-view"> <div class="system-role-padding layout-padding-auto layout-padding-view">
<el-tabs v-model="activeName" class="demo-tabs" @tab-click="handleClick" style="margin-left: 20px"> <el-tabs v-model="activeName"
<el-tab-pane label="Unapproved" name="first"> class="demo-tabs"
<el-table :data="state.tableData.data" v-loading="state.tableData.loading" style="width: 100%"> @tab-click="handleClick"
<el-table-column prop="username" label="User name" show-overflow-tooltip sortable></el-table-column> style="margin-left: 20px">
<el-table-column prop="organization" label="Organization" show-overflow-tooltip sortable></el-table-column> <el-tab-pane label="Unapproved"
<el-table-column prop="disasterType" label="Disaster type" show-overflow-tooltip sortable> name="first">
<el-table :data="state.tableData.data"
v-loading="state.tableData.loading"
style="width: 100%">
<el-table-column prop="username"
label="User name"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="organization"
label="Organization"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterType"
label="Disaster type"
show-overflow-tooltip
sortable>
<!-- 在disasterType中获取dictKey 对应的dictValue --> <!-- 在disasterType中获取dictKey 对应的dictValue -->
<template #default="scope"> <template #default="scope">
<el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag> <el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="disasterKeyword" label="Disaster keyword" show-overflow-tooltip <el-table-column prop="disasterKeyword"
sortable></el-table-column> label="Disaster keyword"
<el-table-column prop="disasterTime" label="Disaster time" show-overflow-tooltip sortable> show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterTime"
label="Disaster time"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<!-- 格式化去除时分秒 --> <!-- 格式化去除时分秒 -->
{{ dateFormat(scope.row.disasterTime) }} {{ dateFormat(scope.row.disasterTime) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="respondStatus" label="Response status" show-overflow-tooltip sortable> <el-table-column prop="respondStatus"
label="Response status"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<el-tag type="info" v-if="scope.row.respondStatus === 0">Awaiting approval</el-tag> <el-tag type="info"
<el-tag type="info" v-if="scope.row.respondStatus === 1">Rejected</el-tag> v-if="scope.row.respondStatus === 0">Awaiting approval</el-tag>
<el-tag type="info"
v-if="scope.row.respondStatus === 1">Rejected</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="Operate" label="Operate" show-overflow-tooltip sortable> <el-table-column prop="Operate"
label="Operate"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<el-button size="small" text type="primary" <el-button size="small"
@click="onOpenEditRole('edit', scope.row)">Approve</el-button> text
type="primary"
@click="onOpenEditRole('edit', scope.row)">Approve</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-pagination @size-change="onHandleSizeChange" @current-change="onHandleCurrentChange" class="mt15" <el-pagination @size-change="onHandleSizeChange"
:pager-count="5" :page-sizes="[10, 20, 30]" v-model:current-page="state.tableData.param.current" background @current-change="onHandleCurrentChange"
v-model:page-size="state.tableData.param.size" layout="total, sizes, prev, pager, next, jumper" class="mt15"
:total="state.tableData.total"> :pager-count="5"
:page-sizes="[10, 20, 30]"
v-model:current-page="state.tableData.param.current"
background
v-model:page-size="state.tableData.param.size"
layout="total, sizes, prev, pager, next, jumper"
:total="state.tableData.total">
</el-pagination> </el-pagination>
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="Rejected" name="firstNew"> <el-tab-pane label="Rejected"
<el-table :data="state.tableData.data" v-loading="state.tableData.loading" style="width: 100%"> name="firstNew">
<el-table-column prop="username" label="User name" show-overflow-tooltip sortable></el-table-column> <el-table :data="state.tableData.data"
<el-table-column prop="organization" label="Organization" show-overflow-tooltip sortable></el-table-column> v-loading="state.tableData.loading"
<el-table-column prop="disasterType" label="Disaster type" show-overflow-tooltip sortable> style="width: 100%">
<el-table-column prop="username"
label="User name"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="organization"
label="Organization"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterType"
label="Disaster type"
show-overflow-tooltip
sortable>
<!-- 在disasterType中获取dictKey 对应的dictValue --> <!-- 在disasterType中获取dictKey 对应的dictValue -->
<template #default="scope"> <template #default="scope">
<el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag> <el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="disasterKeyword" label="Disaster keyword" show-overflow-tooltip <el-table-column prop="disasterKeyword"
sortable></el-table-column> label="Disaster keyword"
<el-table-column prop="disasterTime" label="Disaster time" show-overflow-tooltip sortable> show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterTime"
label="Disaster time"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<!-- 格式化去除时分秒 --> <!-- 格式化去除时分秒 -->
{{ dateFormat(scope.row.disasterTime) }} {{ dateFormat(scope.row.disasterTime) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column width="200" prop="Operate" label="Operate" show-overflow-tooltip sortable v-auth-role="'admin'"> <el-table-column width="200"
prop="Operate"
label="Operate"
show-overflow-tooltip
sortable
v-auth-role="'admin'">
<template #default="scope"> <template #default="scope">
<el-button size="small" text type="danger" @click="remove(scope.row)">Delete</el-button> <el-button size="small"
text
type="danger"
@click="remove(scope.row)">Delete</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-pagination @size-change="onHandleSizeChange" @current-change="onHandleCurrentChange" class="mt15" <el-pagination @size-change="onHandleSizeChange"
:pager-count="5" :page-sizes="[10, 20, 30]" v-model:current-page="state.tableData.param.current" background @current-change="onHandleCurrentChange"
v-model:page-size="state.tableData.param.size" layout="total, sizes, prev, pager, next, jumper" class="mt15"
:total="state.tableData.total"> :pager-count="5"
:page-sizes="[10, 20, 30]"
v-model:current-page="state.tableData.param.current"
background
v-model:page-size="state.tableData.param.size"
layout="total, sizes, prev, pager, next, jumper"
:total="state.tableData.total">
</el-pagination> </el-pagination>
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="Approved" name="second"> <el-tab-pane label="Approved"
<el-table :data="state.tableData.data" v-loading="state.tableData.loading" style="width: 100%"> name="second">
<el-table :data="state.tableData.data"
v-loading="state.tableData.loading"
style="width: 100%">
<el-table-column prop="username" label="User name" show-overflow-tooltip sortable width="150"></el-table-column> <el-table-column prop="username"
<el-table-column prop="organization" label="Organization" show-overflow-tooltip sortable width="160"></el-table-column> label="User name"
<el-table-column prop="email" label="Email" show-overflow-tooltip sortable></el-table-column> show-overflow-tooltip
<el-table-column prop="disasterType" label="Disaster type" show-overflow-tooltip sortable width="160"> sortable
width="150"></el-table-column>
<el-table-column prop="organization"
label="Organization"
show-overflow-tooltip
sortable
width="160"></el-table-column>
<el-table-column prop="email"
label="Email"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterType"
label="Disaster type"
show-overflow-tooltip
sortable
width="160">
<!-- 在disasterType中获取dictKey 对应的dictValue --> <!-- 在disasterType中获取dictKey 对应的dictValue -->
<template #default="scope"> <template #default="scope">
<el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag> <el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="disasterKeyword" label="Disaster keyword" width="190" show-overflow-tooltip <el-table-column prop="disasterKeyword"
sortable></el-table-column> label="Disaster keyword"
<el-table-column prop="disasterTime" label="Disaster time" show-overflow-tooltip sortable width="150"> width="190"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterTime"
label="Disaster time"
show-overflow-tooltip
sortable
width="150">
<template #default="scope"> <template #default="scope">
<!-- 格式化去除时分秒 --> <!-- 格式化去除时分秒 -->
{{ dateFormat(scope.row.disasterTime) }} {{ dateFormat(scope.row.disasterTime) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="chiefName" label="Answer" show-overflow-tooltip sortable></el-table-column> <el-table-column prop="chiefName"
<el-table-column prop="reviewTime" label="reviewTime" show-overflow-tooltip sortable width="140"/> label="Answer"
<el-table-column width="170" prop="respondStatus" label="Response status" show-overflow-tooltip sortable> show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="reviewTime"
label="reviewTime"
show-overflow-tooltip
sortable
width="140" />
<el-table-column width="170"
prop="respondStatus"
label="Response status"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<el-tag type="info" v-if="scope.row.respondStatus === 2">Approved</el-tag> <el-tag type="info"
<el-tag type="info" v-if="scope.row.respondStatus === 1">Rejected</el-tag> v-if="scope.row.respondStatus === 2">Approved</el-tag>
<el-tag type="success" v-if="scope.row.respondStatus === 3">Complete response</el-tag> <el-tag type="info"
v-if="scope.row.respondStatus === 1">Rejected</el-tag>
<el-tag type="success"
v-if="scope.row.respondStatus === 3">Complete response</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column width="240" prop="Operate" label="Operate" show-overflow-tooltip sortable> <el-table-column width="240"
prop="Operate"
label="Operate"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<el-button size="small" text type="primary" @click="onAllocation(scope.row)">Allocation</el-button> <el-button size="small"
<el-button size="small" text type="danger" @click="responseEnded(scope.row)">Response ended</el-button> text
<el-button size="small" text type="danger" @click="remove(scope.row)" v-auth-role="'admin'">Delete</el-button> type="primary"
@click="onAllocation(scope.row)">Allocation</el-button>
<el-button size="small"
text
type="danger"
@click="responseEnded(scope.row)">Response ended</el-button>
<el-button size="small"
text
type="danger"
@click="remove(scope.row)"
v-auth-role="'admin'">Delete</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-pagination @size-change="onHandleSizeChange" @current-change="onHandleCurrentChange" class="mt15" <el-pagination @size-change="onHandleSizeChange"
:pager-count="5" :page-sizes="[10, 20, 30]" v-model:current-page="state.tableData.param.current" background @current-change="onHandleCurrentChange"
v-model:page-size="state.tableData.param.size" layout="total, sizes, prev, pager, next, jumper" class="mt15"
:total="state.tableData.total"> :pager-count="5"
:page-sizes="[10, 20, 30]"
v-model:current-page="state.tableData.param.current"
background
v-model:page-size="state.tableData.param.size"
layout="total, sizes, prev, pager, next, jumper"
:total="state.tableData.total">
</el-pagination> </el-pagination>
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="Finish"
<el-tab-pane label="Finish" name="firstNewOne"> name="firstNewOne">
<el-table :data="state.tableData.data" v-loading="state.tableData.loading" style="width: 100%"> <el-table :data="state.tableData.data"
<el-table-column prop="username" label="User name" show-overflow-tooltip sortable></el-table-column> v-loading="state.tableData.loading"
<el-table-column prop="organization" label="Organization" show-overflow-tooltip sortable></el-table-column> style="width: 100%">
<el-table-column prop="disasterType" label="Disaster type" show-overflow-tooltip sortable> <el-table-column prop="username"
label="User name"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="organization"
label="Organization"
show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterType"
label="Disaster type"
show-overflow-tooltip
sortable>
<!-- 在disasterType中获取dictKey 对应的dictValue --> <!-- 在disasterType中获取dictKey 对应的dictValue -->
<template #default="scope"> <template #default="scope">
<el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag> <el-tag type="info">{{ getValue(scope.row.disasterType) }}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="disasterKeyword" label="Disaster keyword" show-overflow-tooltip <el-table-column prop="disasterKeyword"
sortable></el-table-column> label="Disaster keyword"
<el-table-column prop="disasterTime" label="Disaster time" show-overflow-tooltip sortable> show-overflow-tooltip
sortable></el-table-column>
<el-table-column prop="disasterTime"
label="Disaster time"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<!-- 格式化去除时分秒 --> <!-- 格式化去除时分秒 -->
{{ dateFormat(scope.row.disasterTime) }} {{ dateFormat(scope.row.disasterTime) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="respondedTime" label="Responded time" show-overflow-tooltip sortable> <el-table-column prop="respondedTime"
label="Responded time"
show-overflow-tooltip
sortable>
<template #default="scope"> <template #default="scope">
<!-- 格式化去除时分秒 --> <!-- 格式化去除时分秒 -->
{{ dateFormat(scope.row.respondedTime) }} {{ dateFormat(scope.row.respondedTime) }}
</template> </template>
</el-table-column> </el-table-column>
<el-table-column width="200" prop="Operate" label="Operate" show-overflow-tooltip sortable> <el-table-column width="200"
<template #default="scope" v-auth-role="'admin'"> prop="Operate"
<el-button size="small" text type="danger" @click="remove(scope.row)">Delete</el-button> label="Operate"
show-overflow-tooltip
sortable>
<template #default="scope"
v-auth-role="'admin'">
<el-button size="small"
text
type="danger"
@click="remove(scope.row)">Delete</el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-pagination @size-change="onHandleSizeChange" @current-change="onHandleCurrentChange" class="mt15" <el-pagination @size-change="onHandleSizeChange"
:pager-count="5" :page-sizes="[10, 20, 30]" v-model:current-page="state.tableData.param.current" background @current-change="onHandleCurrentChange"
v-model:page-size="state.tableData.param.size" layout="total, sizes, prev, pager, next, jumper" class="mt15"
:total="state.tableData.total"> :pager-count="5"
:page-sizes="[10, 20, 30]"
v-model:current-page="state.tableData.param.current"
background
v-model:page-size="state.tableData.param.size"
layout="total, sizes, prev, pager, next, jumper"
:total="state.tableData.total">
</el-pagination> </el-pagination>
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>
</div> </div>
<el-dialog v-model="state.dialogVisible" title="Approval" width="45%"> <el-dialog v-model="state.dialogVisible"
title="Approval"
width="45%">
<el-container style="margin-top: -2%;margin-bottom: 2%;"> <el-container style="margin-top: -2%;margin-bottom: 2%;">
<el-radio v-model="state.radio" label='1' @click="mapEvents('1')">Point</el-radio> <el-radio v-model="state.radio"
<el-radio v-model="state.radio" label='2' @click="mapEvents('2')">Area</el-radio> label='1'
<el-radio v-model="state.radio" label='3' @click="mapEvents('3')">Edit</el-radio> @click="mapEvents('1')">Point</el-radio>
<el-button type="primary" style="margin-left: 5%;" @click="ClearSubmit">Clear</el-button> <el-radio v-model="state.radio"
label='2'
@click="mapEvents('2')">Area</el-radio>
<el-radio v-model="state.radio"
label='3'
@click="mapEvents('3')">Edit</el-radio>
<el-button type="primary"
style="margin-left: 5%;"
@click="ClearSubmit">Clear</el-button>
</el-container> </el-container>
<el-container style="margin-top: 2%;margin-bottom: 2%;" v-if="state.radio === '1' ? true : false"> <el-container style="margin-top: 2%;margin-bottom: 2%;"
v-if="state.radio === '1' ? true : false">
<span style="line-height: 35px;"> Latitude</span> <span style="line-height: 35px;"> Latitude</span>
<el-input placeholder="wait……" style="height:35px;margin-right: 1%;" v-model="state.dislat"> <el-input placeholder="wait……"
style="height:35px;margin-right: 1%;"
v-model="state.dislat">
</el-input> </el-input>
<span style="line-height: 35px;">Longitude</span> <span style="line-height: 35px;">Longitude</span>
<el-input placeholder="wait……" style="height:35px;" v-model="state.dislon"></el-input> <el-input placeholder="wait……"
style="height:35px;"
v-model="state.dislon"></el-input>
</el-container> </el-container>
<el-container style="margin-top: 2%;margin-bottom: 2%;" v-if="state.radio === '3' ? true : false"> <el-container style="margin-top: 2%;margin-bottom: 2%;"
v-if="state.radio === '3' ? true : false">
<el-row> <el-row>
<el-col :span="3"> <el-col :span="3">
<span style="line-height: 35px;"> Latitude</span> <span style="line-height: 35px;"> Latitude</span>
</el-col> </el-col>
<el-col :span="7"> <el-col :span="7">
<el-input placeholder="wait……" style="height:35px;margin-right: 1%;" v-model="state.dislat" <el-input placeholder="wait……"
:onchange="manualLat"> style="height:35px;margin-right: 1%;"
v-model="state.dislat"
:onchange="manualLat">
</el-input> </el-input>
</el-col> </el-col>
<el-col :span="2"></el-col> <el-col :span="2"></el-col>
@ -184,53 +362,76 @@
<span style="line-height: 35px;">Longitude</span> <span style="line-height: 35px;">Longitude</span>
</el-col> </el-col>
<el-col :span="7"> <el-col :span="7">
<el-input placeholder="wait……" style="height:35px;" v-model="state.dislon" :onchange="manualLon"></el-input> <el-input placeholder="wait……"
style="height:35px;"
v-model="state.dislon"
:onchange="manualLon"></el-input>
</el-col> </el-col>
</el-row> </el-row>
</el-container> </el-container>
<MapPage style="height:350px ; width:100% ;margin-bottom: 10px;" ref="mapRef"> <MapPage style="height:350px ; width:100% ;margin-bottom: 10px;"
ref="mapRef">
</MapPage> </MapPage>
<div class="latLon-div"> {{ state.popupLat }} , {{ state.popupLon }} </div> <div class="latLon-div"> {{ state.popupLat }} , {{ state.popupLon }} </div>
<el-form :inline="true" label-width="auto" :label-position="labelPosition" :model="formInline" <el-form :inline="true"
class="demo-form-inline"> label-width="auto"
:label-position="labelPosition"
:model="formInline"
class="demo-form-inline">
<el-form-item label="Disaster Time"> <el-form-item label="Disaster Time">
<el-date-picker style="width: 200px;" v-model="state.edit.disasterTime" type="date" value-format="YYYY-MM-DD" <el-date-picker style="width: 200px;"
placeholder="Select date and time" /> v-model="state.edit.disasterTime"
type="date"
value-format="YYYY-MM-DD"
placeholder="Select date and time" />
</el-form-item> </el-form-item>
<el-form-item label="Disaster type"> <el-form-item label="Disaster type">
<el-select style="width: 200px; height: 40px;" class="form-select" size="default" clearable <el-select style="width: 200px; height: 40px;"
placeholder="Disaster Type" v-model="state.edit.disasterType"> class="form-select"
<el-option v-for="(item, index) in state.dictList" :value="item.dictKey" :key="index" size="default"
:label="item.dictValue" /> clearable
placeholder="Disaster Type"
v-model="state.edit.disasterType">
<el-option v-for="(item, index) in state.dictList"
:value="item.dictKey"
:key="index"
:label="item.dictValue" />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="Disaster country"> <el-form-item label="Disaster country">
<el-input style="width: 200px;" v-model="state.edit.disasterCountry" placeholder="please Disaster country" <el-input style="width: 200px;"
clearable></el-input> v-model="state.edit.disasterCountry"
placeholder="please Disaster country"
clearable></el-input>
</el-form-item> </el-form-item>
<el-form-item label="Theme keywords"> <el-form-item label="Theme keywords">
<el-input style="width: 200px;" v-model="state.edit.disasterKeyword" placeholder="please Theme keywords" <el-input style="width: 200px;"
clearable></el-input> v-model="state.edit.disasterKeyword"
placeholder="please Theme keywords"
clearable></el-input>
</el-form-item> </el-form-item>
</el-form> </el-form>
<template #footer> <template #footer>
<span class="dialog-footer"> <span class="dialog-footer">
<el-button @click="dialogVisible = false">Cancel</el-button> <el-button @click="dialogVisible = false">Cancel</el-button>
<el-button type="danger" @click="reviews(1)"> <el-button type="danger"
@click="reviews(1)">
Reject Reject
</el-button> </el-button>
<el-button type="primary" @click="reviews(2)"> <el-button type="primary"
@click="reviews(2)">
Approve Approve
</el-button> </el-button>
</span> </span>
</template> </template>
</el-dialog> </el-dialog>
<selectUser ref="select" @callback="getTableData"></selectUser> <selectUser ref="select"
@callback="getTableData"></selectUser>
</el-config-provider> </el-config-provider>
</div> </div>
</template> </template>
@ -239,7 +440,7 @@
import en from 'element-plus/dist/locale/en.mjs' import en from 'element-plus/dist/locale/en.mjs'
import { reactive, onMounted, ref, nextTick, watchEffect, defineAsyncComponent, h } from 'vue'; import { reactive, onMounted, ref, nextTick, watchEffect, defineAsyncComponent, h } from 'vue';
import { ElMessageBox, ElMessage } from 'element-plus'; import { ElMessageBox, ElMessage } from 'element-plus';
import { getList, review, responseEndedDisasterInfo,deleteByIds } from '/@/api/disasterInfo/index'; import { getList, review, responseEndedDisasterInfo, deleteByIds } from '/@/api/disasterInfo/index';
import { getDictionary, getList as getListNew } from '/@/api/system/dictbiz'; import { getDictionary, getList as getListNew } from '/@/api/system/dictbiz';
import { useVariableStore } from '/@/stores/index.ts' import { useVariableStore } from '/@/stores/index.ts'
// //
@ -258,7 +459,7 @@ const variableStore = useVariableStore();
const mapRef = ref(); const mapRef = ref();
const activeName = ref('first'); const activeName = ref('first');
const select = ref(); const select = ref();
const remove =(row) =>{ const remove = (row) => {
let arr = []; let arr = [];
arr.push(row.disasterId); arr.push(row.disasterId);
//使 //使
@ -363,35 +564,48 @@ const onHandleSizeChange = (val) => {
getTableData(); getTableData();
}; };
const onOpenEditRole = (type, row) => { const onOpenEditRole = (type, row) => {
if (state.wktPoint_Poly) {
mapRef.value.mapOperations.removeLayer(state.wktPoint_Poly)
}
// //
state.edit = JSON.parse(JSON.stringify(row)); state.edit = JSON.parse(JSON.stringify(row));
state.dialogVisible = true; state.dialogVisible = true;
if (row.geometry.indexOf("POINT")!=-1) { if (row.geometry.indexOf("POINT") != -1) {
setTimeout(() => { setTimeout(() => {
state.radio = "1" state.radio = "1"
state.dislon = row.geometry.substring(row.geometry.indexOf("(") + 1, row.geometry.lastIndexOf(" "))
state.dislat = row.geometry.substring(row.geometry.lastIndexOf(" ") + 1, row.geometry.indexOf(")"))
// mapRef.value.mapOperations.removeAll() // mapRef.value.mapOperations.removeAll()
// //
if (state.wktPoint_Poly) { // if (state.wktPoint_Poly) {
mapRef.value.mapOperations.removeLayer(state.wktPoint_Poly) // mapRef.value.mapOperations.removeLayer(state.wktPoint_Poly)
} // console.log('');
// }
state.wktPoint_Poly = mapRef.value.mapOperations.wktParseToMap(row.geometry) state.wktPoint_Poly = mapRef.value.mapOperations.wktParseToMap(row.geometry)
mapEvents('1') mapEvents('1')
}, 100); }, 100);
} }
else if (row.geometry.indexOf("POLYGON")!=-1 ) { else if (row.geometry.indexOf("POLYGON") != -1) {
setTimeout(() => { setTimeout(() => {
state.radio = "2" state.radio = "2"
// mapRef.value.mapOperations.removeAll() // mapRef.value.mapOperations.removeAll()
// //
// if (state.wktPoint_Poly) { // if (state.wktPoint_Poly) {
// mapRef.value.mapOperations.removeLayer(state.wktPoint_Poly) // mapRef.value.mapOperations.removeLayer(state.wktPoint_Poly)
// console.log('');
// } // }
mapRef.value.mapOperations.wktParseToMap(row.geometry) // mapRef.value.mapOperations.removeWktAll()
state.wktPoint_Poly = mapRef.value.mapOperations.wktParseToMap(row.geometry)
mapEvents('2') mapEvents('2')
}, 100); }, 100);
} }
}; };
const cancelApporval = () => {
state.dialogVisible = false;
if (state.wktPoint_Poly) {
mapRef.value.mapOperations.removeLayer(state.wktPoint_Poly)
}
}
// //
const manualLat = () => { const manualLat = () => {
@ -595,42 +809,42 @@ const getValue = (key) => {
}; };
</script> </script>
<style lang="scss"> <style lang="scss">
.demo-tabs>.el-tabs__content { .demo-tabs > .el-tabs__content {
padding: 0px; padding: 0px;
color: #6b778c; color: #6b778c;
font-size: 32px; font-size: 32px;
font-weight: 600; font-weight: 600;
} }
.system-role-container { .system-role-container {
.system-role-padding { .system-role-padding {
padding: 15px; padding: 15px;
.el-table { .el-table {
flex: 1; flex: 1;
} }
} }
} }
.mt15 { .mt15 {
display: flex; display: flex;
justify-content: end; justify-content: end;
float: right; float: right;
margin-bottom: 15px; margin-bottom: 15px;
} }
.latLon-div { .latLon-div {
position: absolute; position: absolute;
top: 60%; top: 60%;
right: 5%; right: 5%;
z-index: 1000; z-index: 1000;
color: white; color: white;
font-size: 15px; font-size: 15px;
} }
.form-select { .form-select {
.el-input__wrapper { .el-input__wrapper {
height: 40px; height: 40px;
} }
} }
</style> </style>