You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
JiangningUrbanManagePc/src/views/bigScreen/components/mapRightContent.vue

179 lines
4.3 KiB

<!--
* @Descripttion:
* @version:
* @Author: JC9527
* @Date: 2023-08-15 11:09:57
* @LastEditors: JC9527
* @LastEditTime: 2024-01-22 13:03:42
-->
<template>
<div class="right-box">
<div class="item" :style="relativeHeight">
<title-box title="区域网格"></title-box>
<map-right :rightArray="wanggeArray" :height="getHeight" :id="1" v-on="$listeners"></map-right>
</div>
<div class="item" :style="relativeHeight">
<title-box title="重点区域"></title-box>
<map-right :rightArray="quyuArray" :height="getHeight" :id="2" v-on="$listeners"></map-right>
</div>
<div class="item" :style="relativeHeight">
<title-box title="重点路段"></title-box>
<map-right :rightArray="luduanArray" :height="getHeight" :id="3" v-on="$listeners"></map-right>
</div>
<div class="item" :style="relativeHeight">
<title-box title="考勤围栏"></title-box>
<map-right :rightArray="weilanArray" :height="getHeight" :id="4" v-on="$listeners"></map-right>
</div>
</div>
</template>
<script>
import titleBox from '../../components/title/index.vue'
import mapRight from '../../components/mapRight/index.vue'
export default {
name:'mapRightContent',
components:{titleBox,mapRight},
data() {
return {
griddingArray:[
{
name:'网格1',
event:60,
resolved:40,
unsolved:20
},{
name:'网格2',
event:60,
resolved:40,
unsolved:20
},{
name:'网格3',
event:60,
resolved:40,
unsolved:20
},{
name:'网格1',
event:60,
resolved:40,
unsolved:20
},{
name:'网格2',
event:60,
resolved:40,
unsolved:20
},
],
areaArray:[
{
name:'网格1',
event:60,
resolved:40,
unsolved:20
},{
name:'网格2',
event:60,
resolved:40,
unsolved:20
},{
name:'网格3',
event:60,
resolved:40,
unsolved:20
},{
name:'网格1',
event:60,
resolved:40,
unsolved:20
},{
name:'网格2',
event:60,
resolved:40,
unsolved:20
},
],
getHeight:0,
relativeHeight:{
height:'',
},
quyuArray:[],
weilanArray:[],
luduanArray:[],
wanggeArray:[],
$listeners: false,
}
},
props:['quyuData', 'weilanData', 'luduanData', 'wanggeData'],
watch:{
quyuData:{
handler(newQuyu){
// console.log(newQuyu,'区域');
if(newQuyu) {
this.quyuArray = newQuyu
}
},
immediate:true,
},
weilanData:{
handler(newWeilan){
// console.log(newWeilan,'围栏');
if(newWeilan) {
this.weilanArray = newWeilan
}
},
immediate:true,
},
luduanData:{
handler(newLuduan){
// console.log(newLuduan,'路段');
if(newLuduan) {
this.luduanArray = newLuduan
}
},
immediate:true,
},
wanggeData: {
handler(newWange){
// console.log(newWange,'网格');
if(newWange) {
this.wanggeArray = newWange
}
},
immediate:true,
}
},
methods:{
getDomHeight(){
this.$nextTick(()=>{
if(document.getElementsByClassName('right-box')) {
let dom = document.getElementsByClassName('right-box');
let height = dom[0].getBoundingClientRect();
let windowWidth = window.innerWidth;
let windowHeight = window.innerHeight;
let relativeHeight = (windowHeight - height.top) / 4 - 18;
this.relativeHeight.height = relativeHeight + 'px'
this.getHeight = Number(relativeHeight);
}
})
}
},
mounted(){
window.addEventListener("resize", () => {
this.screenHeight = document.body.clientHeight;
this.getDomHeight();
});
this.getDomHeight();
},
}
</script>
<style lang="scss" scoped>
.right-box {
display: grid;
grid-column: 1fr;
grid-row-gap: 15px;
height: 100%;
.item {
// background: rgba(222, 225, 230, 0.6);
// height: 161px;
}
}
</style>