540 lines
22 KiB
Vue
540 lines
22 KiB
Vue
|
<template>
|
|||
|
<div class="renyuan">
|
|||
|
<div class="block1">
|
|||
|
<div class="options">
|
|||
|
<div v-for="(item,index) in block1OptionsList" :key="index" class="option">
|
|||
|
{{ item.title }}:<count-to :start-val="0" :end-val="+item.count" :duration="3600"/>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="block2">
|
|||
|
<layout-title title="重大危险源统计"/>
|
|||
|
<div class="content">
|
|||
|
<div id="main2"/>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="block3">
|
|||
|
<layout-title title="危险源列表"/>
|
|||
|
<div class="content">
|
|||
|
<div class="table">
|
|||
|
<div class="tr">
|
|||
|
<div class="td">危险源名称</div>
|
|||
|
<div class="td">液位</div>
|
|||
|
<div class="td">温度</div>
|
|||
|
<div class="td">状态</div>
|
|||
|
</div>
|
|||
|
<div v-infinite-scroll="false" :infinite-scroll-disabled="false" class="scroll">
|
|||
|
<div v-for="(item,index) in block3List" :key="index" class="tr">
|
|||
|
<div class="td">{{ item.MAJORDANGERSOURCE_NAME }}</div>
|
|||
|
<div class="td">{{ item.STORAGETANK_LIQUIDLEVEL }}</div>
|
|||
|
<div class="td">{{ item.STORAGETANK_TEMPERATURE }}</div>
|
|||
|
<div class="td">
|
|||
|
<span v-if="item.MAJORDANGERSOURCE_STATUS == 1">正常</span>
|
|||
|
<span v-if="item.MAJORDANGERSOURCE_STATUS == 2">停用</span>
|
|||
|
<span v-if="item.MAJORDANGERSOURCE_STATUS == 3">检修</span>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="block4">
|
|||
|
<layout-title title="报警处置情况"/>
|
|||
|
<div class="content">
|
|||
|
<div id="main3"/>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
<div class="block5">
|
|||
|
<layout-title title="报警信息"/>
|
|||
|
<div class="content">
|
|||
|
<div class="table">
|
|||
|
<div class="tr">
|
|||
|
<div class="td">设备名称</div>
|
|||
|
<div class="td">报警时间</div>
|
|||
|
<div class="td">处置状态</div>
|
|||
|
</div>
|
|||
|
<div v-infinite-scroll="false" :infinite-scroll-disabled="false" class="scroll">
|
|||
|
<div v-for="(item,index) in block5List" :key="index" class="tr">
|
|||
|
<div class="td">{{ item.MAJORDANGERSOURCE_NAME }}</div>
|
|||
|
<div class="td">{{ item.CREATTIME }}</div>
|
|||
|
<div class="td">
|
|||
|
<span v-if="item.DISPOSAL_STATUS == -1">未处置</span>
|
|||
|
<span v-if="item.DISPOSAL_STATUS == 0">报警升级</span>
|
|||
|
<span v-if="item.DISPOSAL_STATUS == 1">完成处置</span>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</template>
|
|||
|
|
|||
|
<script>
|
|||
|
import layoutTitle from './title.vue'
|
|||
|
import CountTo from 'vue-count-to'
|
|||
|
import * as echarts from 'echarts'
|
|||
|
import { requestFN } from '@/utils/request'
|
|||
|
|
|||
|
let myChart2 = null
|
|||
|
let myChart3 = null
|
|||
|
export default {
|
|||
|
components: {
|
|||
|
CountTo,
|
|||
|
layoutTitle
|
|||
|
},
|
|||
|
data() {
|
|||
|
return {
|
|||
|
block1OptionsList: [],
|
|||
|
block3List: [],
|
|||
|
block5List: [],
|
|||
|
loading: false,
|
|||
|
currentPage: 1,
|
|||
|
count: 0,
|
|||
|
totalPage: 0
|
|||
|
}
|
|||
|
},
|
|||
|
mounted() {
|
|||
|
window.onresize = function() {
|
|||
|
myChart2 && myChart2.resize()
|
|||
|
myChart3 && myChart3.resize()
|
|||
|
}
|
|||
|
// this.initEcharts2()
|
|||
|
this.getFindDeclarationLevelChartData()
|
|||
|
this.getFindAlarmDisposalChartData()
|
|||
|
},
|
|||
|
beforeDestroy() {
|
|||
|
myChart2 = null
|
|||
|
myChart3 = null
|
|||
|
},
|
|||
|
created() {
|
|||
|
this.getFindMajorDangerSourceListAll()
|
|||
|
this.getListDisposal()
|
|||
|
this.getFindMajorDangerSourceCount()
|
|||
|
},
|
|||
|
methods: {
|
|||
|
initEcharts1(o) {
|
|||
|
myChart2 = echarts.init(document.querySelector('#main2'))
|
|||
|
const img = '
|
|||
|
const trafficWay = o.seriesData
|
|||
|
const data = []
|
|||
|
const color = ['#ee0e44', '#fc5600', '#9628a3', '#fedc00']
|
|||
|
for (let i = 0; i < trafficWay.length; i++) {
|
|||
|
data.push(
|
|||
|
{
|
|||
|
value: trafficWay[i].value,
|
|||
|
name: trafficWay[i].name,
|
|||
|
itemStyle: {
|
|||
|
normal: {
|
|||
|
borderWidth: 5,
|
|||
|
shadowBlur: 20,
|
|||
|
borderColor: color[i],
|
|||
|
shadowColor: color[i]
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
{
|
|||
|
value: 2,
|
|||
|
name: '',
|
|||
|
itemStyle: {
|
|||
|
normal: {
|
|||
|
label: {
|
|||
|
show: false
|
|||
|
},
|
|||
|
labelLine: {
|
|||
|
show: false
|
|||
|
},
|
|||
|
color: 'rgba(0, 0, 0, 0)',
|
|||
|
borderColor: 'rgba(0, 0, 0, 0)',
|
|||
|
borderWidth: 0
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
)
|
|||
|
}
|
|||
|
const seriesOption = [
|
|||
|
{
|
|||
|
name: '',
|
|||
|
type: 'pie',
|
|||
|
clockWise: false,
|
|||
|
radius: [55, 59],
|
|||
|
hoverAnimation: false,
|
|||
|
itemStyle: {
|
|||
|
normal: {
|
|||
|
label: {
|
|||
|
show: false
|
|||
|
},
|
|||
|
labelLine: {
|
|||
|
show: false
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
data: data
|
|||
|
}
|
|||
|
]
|
|||
|
const option = {
|
|||
|
color: color,
|
|||
|
graphic: {
|
|||
|
elements: [
|
|||
|
{
|
|||
|
type: 'image',
|
|||
|
z: 3,
|
|||
|
style: {
|
|||
|
image: img,
|
|||
|
width: 88,
|
|||
|
height: 88
|
|||
|
},
|
|||
|
left: 'center',
|
|||
|
top: 'center'
|
|||
|
}
|
|||
|
]
|
|||
|
},
|
|||
|
tooltip: {
|
|||
|
trigger: 'item'
|
|||
|
},
|
|||
|
legend: {
|
|||
|
icon: 'circle',
|
|||
|
orient: 'vertical',
|
|||
|
data: ['一级', '二级', '三级', '四级'],
|
|||
|
right: '30px',
|
|||
|
top: 'center',
|
|||
|
textStyle: {
|
|||
|
color: '#fff'
|
|||
|
},
|
|||
|
itemGap: 10
|
|||
|
},
|
|||
|
series: seriesOption
|
|||
|
}
|
|||
|
myChart2.setOption(option)
|
|||
|
},
|
|||
|
initEcharts2(o) {
|
|||
|
myChart3 = echarts.init(document.querySelector('#main3'))
|
|||
|
const data = o
|
|||
|
const series = []
|
|||
|
for (let i = 0; i < data.seriesData.length; i++) {
|
|||
|
series.push({
|
|||
|
name: data.legendData[i],
|
|||
|
type: 'bar',
|
|||
|
data: data.seriesData[i]
|
|||
|
})
|
|||
|
}
|
|||
|
const option = {
|
|||
|
color: ['#3db1ee', '#0def67', '#fc5008'],
|
|||
|
tooltip: {
|
|||
|
trigger: 'axis',
|
|||
|
axisPointer: {
|
|||
|
type: 'shadow'
|
|||
|
}
|
|||
|
},
|
|||
|
grid: {
|
|||
|
left: '2%',
|
|||
|
right: '5%',
|
|||
|
bottom: '12%',
|
|||
|
top: '16%',
|
|||
|
containLabel: true
|
|||
|
},
|
|||
|
legend: {
|
|||
|
top: 0,
|
|||
|
data: data.legendData,
|
|||
|
textStyle: {
|
|||
|
color: '#fff'
|
|||
|
}
|
|||
|
},
|
|||
|
dataZoom: [
|
|||
|
{
|
|||
|
show: true,
|
|||
|
height: 5,
|
|||
|
xAxisIndex: [0],
|
|||
|
bottom: '5%',
|
|||
|
right: '5%',
|
|||
|
start: 0,
|
|||
|
end: 50,
|
|||
|
moveHandleSize: '3',
|
|||
|
moveHandleStyle: {
|
|||
|
color: '#2a569e'
|
|||
|
},
|
|||
|
fillerColor: '#2a569e',
|
|||
|
textStyle: {
|
|||
|
color: 'transparent'
|
|||
|
},
|
|||
|
borderColor: '#3a7a95'
|
|||
|
},
|
|||
|
{
|
|||
|
type: 'inside',
|
|||
|
show: true,
|
|||
|
start: 0,
|
|||
|
end: 25
|
|||
|
}
|
|||
|
],
|
|||
|
xAxis: {
|
|||
|
type: 'category',
|
|||
|
data: data.xAxisData,
|
|||
|
axisLabel: {
|
|||
|
rotate: 45,
|
|||
|
textStyle: {
|
|||
|
color: 'rgba(255,255,255,0.5)'
|
|||
|
}
|
|||
|
},
|
|||
|
axisLine: {
|
|||
|
show: true,
|
|||
|
lineStyle: {
|
|||
|
color: 'rgba(255,255,255,0.5)'
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
yAxis: {
|
|||
|
type: 'value',
|
|||
|
axisLine: {
|
|||
|
show: true,
|
|||
|
lineStyle: {
|
|||
|
color: 'rgba(255,255,255,0.5)'
|
|||
|
}
|
|||
|
},
|
|||
|
splitLine: {
|
|||
|
show: false
|
|||
|
}
|
|||
|
},
|
|||
|
series
|
|||
|
}
|
|||
|
myChart3.setOption(option)
|
|||
|
},
|
|||
|
|
|||
|
// 重大危险源统计
|
|||
|
getFindDeclarationLevelChartData() {
|
|||
|
requestFN('/api/homemajor/findDeclarationLevelChartData').then(res => {
|
|||
|
this.$nextTick(() => {
|
|||
|
this.initEcharts1(res.chartData)
|
|||
|
})
|
|||
|
})
|
|||
|
},
|
|||
|
// 危险源列表
|
|||
|
getFindMajorDangerSourceListAll() {
|
|||
|
requestFN('/api/homemajor/findMajorDangerSourceListAll').then(res => {
|
|||
|
if (res.varList) {
|
|||
|
// created by liuJiaNan description:数据展示多条可能出现滚动调,所以只展示3条
|
|||
|
this.block3List = []
|
|||
|
this.block3List = res.varList
|
|||
|
}
|
|||
|
})
|
|||
|
},
|
|||
|
// 报警信息
|
|||
|
getListDisposal() {
|
|||
|
requestFN('/api/homemajor/listDisposal').then(res => {
|
|||
|
if (res.varList) {
|
|||
|
// created by liuJiaNan description:数据展示多条可能出现滚动调,所以只展示3条
|
|||
|
this.block5List = []
|
|||
|
this.block5List = res.varList
|
|||
|
}
|
|||
|
})
|
|||
|
},
|
|||
|
getFindMajorDangerSourceCount() {
|
|||
|
requestFN('/api/homemajor/findMajorDangerSourceCount').then(res => {
|
|||
|
this.block1OptionsList = [
|
|||
|
{ title: '重大危险源', count: res.pd.COUNTSOURCE },
|
|||
|
{ title: '监测点数', count: res.pd.COUNTSOURCE * 2 },
|
|||
|
{ title: '监测天数', count: res.pd.COUNTDAYS }
|
|||
|
]
|
|||
|
})
|
|||
|
},
|
|||
|
getFindDisposalCount() {
|
|||
|
requestFN('/api/homemajor/findDisposalCount').then(res => {
|
|||
|
this.top_risk_list1 = [
|
|||
|
{ title: '报警数', value: res.pd.COUNTALARM },
|
|||
|
{ title: '已处置', value: res.pd.COUNTDISPOSED },
|
|||
|
{ title: '处置中', value: res.pd.COUNTDISPOSAL }
|
|||
|
]
|
|||
|
})
|
|||
|
},
|
|||
|
getFindAlarmChartData() {
|
|||
|
requestFN('/api/homemajor/findAlarmChartData').then(res => {
|
|||
|
this.$nextTick(() => {
|
|||
|
this.initEcharts3(res.chartData)
|
|||
|
})
|
|||
|
})
|
|||
|
},
|
|||
|
getVideoInfo(id) {
|
|||
|
requestFN('/api/homemajor/getVideoInfo', { VIDOMANAGER_ID: id }).then(res => {
|
|||
|
this.$nextTick(() => {
|
|||
|
this.videoForm = res.pd
|
|||
|
this.dialogVideo = true
|
|||
|
})
|
|||
|
})
|
|||
|
},
|
|||
|
getFindAlarmDisposalChartData() {
|
|||
|
requestFN('/api/homemajor/findAlarmDisposalChartData').then(res => {
|
|||
|
this.$nextTick(() => {
|
|||
|
this.initEcharts2(res.chartData)
|
|||
|
})
|
|||
|
})
|
|||
|
},
|
|||
|
initMap() {
|
|||
|
this.iframeSrc = config.weburl + 'static/mapshowimage.html?t=' + Math.random()
|
|||
|
requestFN('/api/homemajor/listMajordangersourceLocation').then(res => {
|
|||
|
this.$nextTick(() => {
|
|||
|
const boxList = this.initMapData()
|
|||
|
// eslint-disable-next-line no-new-object
|
|||
|
var wallMap = new Object() // 一公司外墙
|
|||
|
const iframe = document.querySelector('#iframe')
|
|||
|
// 处理兼容行问题
|
|||
|
if (iframe.attachEvent) {
|
|||
|
iframe.attachEvent('onload', function() {
|
|||
|
this.contentWindow.postMessage(
|
|||
|
{
|
|||
|
'varList': res.varList,
|
|||
|
'boxList': boxList,
|
|||
|
'wallMap': wallMap,
|
|||
|
'LONGITUDE': 119.65138731427636,
|
|||
|
'LATITUDE': 39.93429609044706,
|
|||
|
'distance': 800, // 距屏幕中心点距离(单位m)
|
|||
|
'rotate': 60, // 旋转角(单位°)
|
|||
|
'tilt': 45 // 倾斜角(单位°)
|
|||
|
}, '*')
|
|||
|
})
|
|||
|
} else {
|
|||
|
iframe.onload = function() {
|
|||
|
this.contentWindow.postMessage(
|
|||
|
{
|
|||
|
'varList': res.varList,
|
|||
|
'boxList': boxList,
|
|||
|
'wallMap': wallMap,
|
|||
|
'LONGITUDE': 119.65138731427636,
|
|||
|
'LATITUDE': 39.93429609044706,
|
|||
|
'distance': 800, // 距屏幕中心点距离(单位m)
|
|||
|
'rotate': 60, // 旋转角(单位°)
|
|||
|
'tilt': 45 // 倾斜角(单位°)
|
|||
|
}, '*')
|
|||
|
}
|
|||
|
}
|
|||
|
})
|
|||
|
})
|
|||
|
},
|
|||
|
load() {
|
|||
|
this.loading = true
|
|||
|
this.currentPage += 1
|
|||
|
this.getUnitPersonnel('1')
|
|||
|
},
|
|||
|
getUnitPersonnel(index) {
|
|||
|
requestFN(
|
|||
|
'/map/getUnitPersonnel?showCount=20' + '¤tPage=' + this.currentPage,
|
|||
|
{
|
|||
|
CORPINFO_ID: this.corpInfoId,
|
|||
|
AREA: this.area,
|
|||
|
GANGKOU: this.gangkou,
|
|||
|
INDEX: index
|
|||
|
}
|
|||
|
).then((data) => {
|
|||
|
this.block3List = this.block3List.concat(data.varList)
|
|||
|
this.totalPage = data.page.totalPage
|
|||
|
this.currentPage = data.page.currentPage
|
|||
|
this.loading = false
|
|||
|
})
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
</script>
|
|||
|
|
|||
|
<style lang="scss" scoped>
|
|||
|
.renyuan {
|
|||
|
|
|||
|
.block1 {
|
|||
|
width: 410px;
|
|||
|
background-color: rgba(0, 0, 0, 0.3);
|
|||
|
|
|||
|
.options {
|
|||
|
padding: 10px;
|
|||
|
border: 1px solid;
|
|||
|
border-image: linear-gradient(to bottom, rgba(58, 122, 149, 0.4), rgba(58, 122, 149, 1)) 1;
|
|||
|
display: flex;
|
|||
|
flex-wrap: wrap;
|
|||
|
|
|||
|
.option {
|
|||
|
flex:1;
|
|||
|
background-image: url("../../../assets/map/anquan/label.png");
|
|||
|
background-size: 100% 100%;
|
|||
|
background-repeat: no-repeat;
|
|||
|
width: 125px;
|
|||
|
height: 25px;
|
|||
|
font-size: 12px;
|
|||
|
line-height: 25px;
|
|||
|
text-align: center;
|
|||
|
color: #fff;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.block2,.block4 {
|
|||
|
margin-top: 10px;
|
|||
|
width: 410px;
|
|||
|
background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.8));
|
|||
|
|
|||
|
.content {
|
|||
|
border: 1px solid;
|
|||
|
border-image: linear-gradient(to bottom, rgba(58, 122, 149, 0), rgba(58, 122, 149, 1)) 1;
|
|||
|
border-top: none;
|
|||
|
padding: 5px 10px;
|
|||
|
|
|||
|
#main2,#main3 {
|
|||
|
width: 405px;
|
|||
|
height: 150px;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
.block3,.block5 {
|
|||
|
margin-top: 10px;
|
|||
|
width: 410px;
|
|||
|
background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.8));
|
|||
|
|
|||
|
.content {
|
|||
|
border: 1px solid;
|
|||
|
border-image: linear-gradient(to bottom, rgba(58, 122, 149, 0), rgba(58, 122, 149, 1)) 1;
|
|||
|
border-top: none;
|
|||
|
padding: 10px;
|
|||
|
|
|||
|
.table {
|
|||
|
margin-top: 10px;
|
|||
|
.scroll {
|
|||
|
max-height: 100px;
|
|||
|
overflow-y: auto;
|
|||
|
|
|||
|
&::-webkit-scrollbar {
|
|||
|
width: 5px;
|
|||
|
}
|
|||
|
|
|||
|
&::-webkit-scrollbar-thumb {
|
|||
|
border-radius: 5px;
|
|||
|
background: rgba(2, 30, 81, 0.851);
|
|||
|
}
|
|||
|
|
|||
|
&::-webkit-scrollbar-track {
|
|||
|
border-radius: 5px;
|
|||
|
background: rgba(255, 255, 255, 0.1);
|
|||
|
}
|
|||
|
|
|||
|
.tr {
|
|||
|
&:nth-child(odd) {
|
|||
|
background-color: transparent;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
.tr {
|
|||
|
display: flex;
|
|||
|
|
|||
|
&:nth-child(odd) {
|
|||
|
background-color: rgba(42, 86, 158, 0.53);
|
|||
|
}
|
|||
|
|
|||
|
.td {
|
|||
|
flex: 1;
|
|||
|
text-align: center;
|
|||
|
font-size: 12px;
|
|||
|
color: #fff;
|
|||
|
padding: 5px;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
</style>
|