2023-07-26 09:49:30 +08:00

907 lines
38 KiB
Vue
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<div class="rightMenu-wrap">
<div class="left-border"></div>
<div class="content">
<div class="list-item" v-if="pageType == 1">
<div class="item-content">
<div class="item-title"><span></span>智能监测</div>
<div>
<ul class="monitor-list">
<li v-for="(item,index) in statisticsDevCount" :key="index">
<p><b>{{item.devOnline}}</b>/{{item.devNum}}</p>
<span>{{item.name}}</span>
</li>
</ul>
</div>
</div>
</div>
<div class="list-item" v-if="pageType == 1">
<div class="item-content">
<div class="item-title"><span></span>巡检情况</div>
<div class="item-detail">
<!-- 暂无数据 -->
<div class="condition-title">检查总数<span>208</span></div>
<div ref="echart1" style="width:100%; height:148px"></div>
</div>
</div>
</div>
<div class="list-item" v-if="pageType == 1">
<div class="item-content">
<div class="item-title"><span></span>累计预警工程排行</div>
<div class="item-detail">
<!-- 暂无数据 -->
<div ref="echart2" style="width:100%; height:177px"></div>
</div>
</div>
</div>
<div class="list-item" v-if="pageType == 1">
<div class="item-content">
<div class="item-title"><span></span>设备预警</div>
<div class="item-detail">
<ul class="warning-list">
<li :class="{'active': warningIndex == index}" v-for="(item,index) in warningData" :key="index" @click="selectEchartData(index)">
{{item.num}}
<span>{{item.name}}</span>
</li>
</ul>
<div ref="echart3" style="width:100%; height:151px"></div>
</div>
</div>
</div>
<div class="viedo-list" v-if="pageType == 2">
<div class="video-title">
<span>视频回放</span>
<el-select v-model="value" size="small" placeholder="请选择">
<el-option
v-for="item in dateList"
:key="item.value"
:label="item.label"
:value="item.value">
<span style="float: left">时间:</span>
<span style="float: right; font-size: 13px">{{ item.label.split("")[1] }}</span>
</el-option>
</el-select>
</div>
<div class="video-content">
<ul>
<li v-for="i in 20" :key="i">
<!-- <video src=""></video> -->
<img src="./../../../assets/images/bigScreen/demo.jpg" style="width: 90%; height: 130px; margin: 0 auto; display: block;"/>
<div class="video-message"><span>2020-06-13</span></div>
</li>
</ul>
</div>
</div>
</div>
<div class="right-border"></div>
</div>
</template>
<script>
import echarts from 'echarts4';;
import {
selectDevCountStatistics,
selectDevCurrentAlarmCount,
selectDischargingSevenDayAlarmList,
selectEnvironmentSevenDayAlarmList,
selectVideoSevenDayAlarmList,
selectLifterSevenDayAlarmList,
selectTowerSevenDayAlarmList,
} from './../../../assets/js/api/companyBigScreen.js'
export default {
name: "rightMenu",
props:{
pageType:{
type: Number,
default: 1
},
projectSn:{
type: String,
default: ""
}
},
data(){
return{
dateList: [
{
label: "时间2021-06-13",
value: "1"
}
],
value: "",
monitorData: [
{
name: '扬尘',
params: '4',
num: '103'
},
{
name: '塔吊',
params: '4',
num: '103'
},
{
name: '升降机',
params: '4',
num: '103'
},
{
name: '卸料',
params: '4',
num: '103'
},
{
name: '水表',
params: '4',
num: '103'
},
{
name: '烟感',
params: '4',
num: '103'
},
{
name: '电表',
params: '4',
num: '103'
},
{
name: '养护室',
params: '4',
num: '103'
}
],
warningData: [],
echart1: Object,
option1: {},
echart2: Object,
option2: {},
echart3: Object,
option3: {},
statisticsDevCount: [],
warningIndex: 0,
}
},
watch:{
pageType(val, oldval){
if(val == 1){
this.$nextTick(()=>{
this.createEchart1();
this.createEchart2();
this.getDevCurrentAlarmCount();
})
}
},
projectSn(val, oldval){
console.log(val)
this.getDevCountStatistics();
this.getDevCurrentAlarmCount();
}
},
created(){
// this.projectSn = JSON.parse(sessionStorage.getItem('vuex')).userInfo.sn;
this.getDevCountStatistics();
this.getDevCurrentAlarmCount();
},
mounted(){
if(this.pageType == 1){
this.createEchart1();
this.createEchart2();
this.createEchart3();
}
},
methods: {
createEchart1(){
let echart1 = echarts.init(this.$refs['echart1']);
this.echart1 = echart1
echart1.clear();
this.option1 = {
legend: {
show:false
},
grid: {
right: "5%",
top: "20%",
left: "5%",
bottom: "5%",
containLabel: true
},
xAxis: {
type: "category",
boundaryGap: true,
data: ["安全检查","综合检查",'质量检查'],
axisLabel: {
//坐标轴刻度标签的相关设置。
interval: 0, //设置为 1表示『隔一个标签显示一个标签』
// margin:15,
textStyle: {
color: "rgba(255,255,255,0.4)",
fontStyle: "normal",
fontSize: 12
}
},
axisTick: {
//坐标轴刻度相关设置。
show: false
},
splitLine: {
//坐标轴在 grid 区域中的分隔线。
show: false,
},
axisLine: {
show: false,
},
},
yAxis: [{
type: "value",
splitNumber: 6,
axisLabel: {
textStyle: {
color: "rgba(255,255,255,0.4)",
fontSize: 12
}
},
axisLine:{
show: true,
lineStyle:{
type: 'dashed',
color: 'rgba(255,255,255,0.2)'
},
},
axisTick: {
show: false
},
splitLine: {
show: true,
lineStyle: {
color: "rgba(255,255,255, 0.2)",
type: 'dashed'
}
}
}
],
series: [{
name: '巡检情况',
type: "pictorialBar",
barWidth: "60%",
label: {
show: true,
position: 'top',
color: "rgba(255,255,255, 0.8)"
},
symbol: "image://",
data: [23,84,101,74,87]
}],
};
echart1.setOption(this.option1);
},
createEchart2(){
let echart2 = echarts.init(this.$refs['echart2']);
this.echart2 = echart2
echart2.clear();
this.option2 = {
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
legend: {
show: false
},
grid: {
left: '0%',
right: '10%',
bottom: '0',
top: "0",
containLabel: true
},
xAxis: {
type: 'value',
show: false
},
yAxis: {
type: 'category',
data: ['御花园一期…', '御花园一期…', '御花园一期…', '御花园一期…', '御花园一期…',"御花园一期…"],
axisLabel: {
color: "rgba(255,255,255,0.8)",
formatter: function(value){
let valueTxt = ''
if (value.length > 5) {
valueTxt = value.substring(0,5) + '...'
} else {
valueTxt = value
}
return valueTxt
}
},
},
series: [
{
name: '累计预警次数',
type: 'bar',
data: [ 100, 50, 30, 5, 15, 85 ],
label : {
normal : {
show : true,//显示数字
position : 'right',
color: "#fff"
}
},
barHeight: '12',
symbol: 'circle',
itemStyle:{
color: new echarts.graphic.LinearGradient(0, 0, 1, 0,
[
{offset: 0, color: 'rgba(2,251,256,0.8)'},
{offset: 1, color: 'rgba(238,115,25,0.8)'}
])
},
barCategoryGap: 14,
// barWidth: "40%"
}
]
};
echart2.setOption(this.option2);
},
createEchart3(val1,val2){
let echart3 = echarts.init(this.$refs['echart3']);
this.echart3 = echart3
echart3.clear();
let data1 = val1 ? val1 : []
let data2 = val2 ? val2 : []
this.option3 = {
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'cross',
label: {
backgroundColor: '#6a7985'
}
}
},
legend: {
show: false
},
grid: {
left: '3%',
right: '20',
bottom: '3%',
top: '20',
containLabel: true
},
xAxis: [
{
type: 'category',
boundaryGap: false,
data: data1,
axisLine: {
show: false,
lineStyle: {
color: 'rgba(255,255,255,0.6)',
type: 'dashed',
show: false,
fontSize: 10
}
},
nameTextStyle: {
fontSize: 10
},
splitLine: {
show: false
},
axisTick: {
show: false
},
axisLabel: {
interval: 0,
},
boundaryGap: false
}
],
yAxis: [
{
type: 'value',
axisLine:{
show: false,
lineStyle:{
type: 'dashed',
color: 'rgba(255,255,255,0.3)'
},
},
axisTick: {
show: false
},
nameTextStyle:{
color: "#fff"
},
splitLine: {
lineStyle: {
color: 'rgba(255,255,255,0.3)',
type: 'dashed'
}
},
}
],
series: [
{
name: '设备预警',
type: 'line',
areaStyle: {
color: new echarts.graphic.LinearGradient(0, 0, 1, 0,
[
{offset: 0, color: 'rgba(252,201,16,0.3)'},
{offset: 1, color: 'rgba(238,115,25,0.3)'}
])
},
emphasis: {
focus: 'series'
},
data: data2,
symbol: 'circle',
symbolSize: 5,
itemStyle: {
        normal: {
           color: "#FCC710",//折线点的颜色
          lineStyle: {
            color: new echarts.graphic.LinearGradient(0, 0, 1, 0,
[
{offset: 0, color: 'rgba(252,201,16,1)'},
{offset: 1, color: 'rgba(238,115,25,1)'}
])//折线的颜色
          }
    }
    }
}
]
}
echart3.setOption(this.option3);
},
// 获取智能检测数据
getDevCountStatistics(){
let data = {
sn: this.projectSn
}
selectDevCountStatistics(data).then(res=>{
// console.log(res)
if(res.code == 200){
let arr = []
for(let key in res.result){
arr.push(res.result[key])
}
this.statisticsDevCount = arr
// console.log(this.statisticsDevCount)
}
})
},
// 获取每日设备预警数
getDevCurrentAlarmCount(){
let data = {
sn: this.projectSn
}
selectDevCurrentAlarmCount(data).then(res=>{
// console.log(res)
if(res.code == 200){
let arr = []
for(let i in res.result){
var obj = {}
if(i == 'dischargingAlarmNum'){
obj.name = "卸料"
obj.num = res.result[i]
arr.push(obj)
} else if(i == 'environmentAlarmNum'){
obj.name = "扬尘"
obj.num = res.result[i]
arr.push(obj)
}else if(i == 'lifterAlarmNum'){
obj.name = "升降机"
obj.num = res.result[i]
arr.push(obj)
}else if(i == 'towerAlarmNum'){
obj.name = "塔吊"
obj.num = res.result[i]
arr.push(obj)
}else if(i == 'videoAlarmCount'){
obj.name = "视频"
obj.num = res.result[i]
arr.push(obj)
}
}
this.warningData = arr
this.selectEchartData(this.warningIndex)
}
})
},
// 切换预警展示数据
selectEchartData(index){
this.warningIndex = index
if(this.warningData[index].name == '卸料'){
this.getDischargingSevenDayAlarmList()
} else if(this.warningData[index].name == '扬尘'){
this.getEnvironmentSevenDayAlarmList()
} else if(this.warningData[index].name == '视频'){
this.getVideoSevenDayAlarmList()
} else if(this.warningData[index].name == '升降机'){
this.getLifterSevenDayAlarmList()
} else if(this.warningData[index].name == '塔吊'){
this.getTowerSevenDayAlarmList()
}
// console.log(this.warningData[index])
},
// 获取卸料七日内数据
getDischargingSevenDayAlarmList(){
let data = {
sn: this.projectSn
}
selectDischargingSevenDayAlarmList(data).then(res=>{
// console.log(res)
if(res.code == 200){
let arr1 = [],
arr2 = [];
res.result.forEach(item=>{
let str = item.titleName.split('-')[1]+"/"+item.titleName.split('-')[2]
arr1.push(str)
arr2.push(item.num)
})
this.createEchart3(arr1,arr2)
}
})
},
// 获取扬尘七日内数据
getEnvironmentSevenDayAlarmList(){
let data = {
sn: this.projectSn
}
selectEnvironmentSevenDayAlarmList(data).then(res=>{
// console.log(res)
if(res.code == 200){
let arr1 = [],
arr2 = [];
res.result.forEach(item=>{
let str = item.titleName.split('-')[1]+"/"+item.titleName.split('-')[2]
arr1.push(str)
arr2.push(item.num)
})
this.createEchart3(arr1,arr2)
}
})
},
// 获取视频预警七日内数据
getVideoSevenDayAlarmList(){
let data = {
sn: this.projectSn
}
selectVideoSevenDayAlarmList(data).then(res=>{
// console.log(res)
if(res.code == 200){
let arr1 = [],
arr2 = [];
res.result.forEach(item=>{
let str = item.titleName.split('-')[1]+"/"+item.titleName.split('-')[2]
arr1.push(str)
arr2.push(item.num)
})
this.createEchart3(arr1,arr2)
}
})
},
// 获取升降机七日内数据
getLifterSevenDayAlarmList(){
let data = {
sn: this.projectSn
}
selectLifterSevenDayAlarmList(data).then(res=>{
// console.log(res)
if(res.code == 200){
let arr1 = [],
arr2 = [];
res.result.forEach(item=>{
let str = item.titleName.split('-')[1]+"/"+item.titleName.split('-')[2]
arr1.push(str)
arr2.push(item.num)
})
this.createEchart3(arr1,arr2)
}
})
},
// 获取塔吊七日内数据
getTowerSevenDayAlarmList(){
let data = {
sn: this.projectSn
}
selectTowerSevenDayAlarmList(data).then(res=>{
// console.log(res)
if(res.code == 200){
let arr1 = [],
arr2 = [];
res.result.forEach(item=>{
let str = item.titleName.split('-')[1]+"/"+item.titleName.split('-')[2]
arr1.push(str)
arr2.push(item.num)
})
this.createEchart3(arr1,arr2)
}
})
},
}
}
</script>
<style lang="less" scoped>
.rightMenu-wrap{
position: absolute;
right: 0;
top: 50px;
width: 24%;
bottom: 0;
height:calc(100% - 50px);
z-index: 10;
display: flex;
}
.left-border{
width: 34px;
height: 100%;
background: url("./../../../assets/images/bigScreen/right-border.png") center no-repeat;
background-size: contain;
}
.right-border{
width: 34px;
height: 100%;
background: url("./../../../assets/images/bigScreen/body-right.png") center no-repeat;
background-size: contain;
}
.content{
flex: 1;
width: calc(100% - 68px);
height: 100%;
background-color: rgba(18, 65, 68, .2);
}
.list-item{
position: relative;
width: 100%;
margin-bottom: 12px;
padding: 13px 0;
.item-content{
background-color: rgba(18, 65, 68,0.3);
.item-title{
height: 22px;
color: #02FBE2;
font-size: 14px;
position: relative;
padding-left: 19px;
display: flex;
align-items: center;
margin-bottom: 18px;
span{
width: 3px;
height: 13px;
background: #02FBE2;
margin-right: 6px;
}
}
.item-title::before{
content: "";
position: absolute;
left: 0;
top: 0;
width: 40px;
height: 100%;
background: linear-gradient(to right, rgba(2, 251, 226, 0.5),rgba(0,0,0,0));
}
}
}
.list-item::before{
content: "";
display: block;
background: url("./../../../assets/images/bigScreen/top-border.png") center no-repeat;
background-size: 100%;
width: 100%;
height: 10px;
position: absolute;
top: 0;
left: 0;
}
.list-item::after{
content: "";
display: block;
background: url("./../../../assets/images/bigScreen/bottom-border.png") center no-repeat;
background-size: 100%;
width: 100%;
height: 10px;
position: absolute;
bottom: 0;
left: 0;
}
.item-detail{
padding: 0 20px;
box-sizing: border-box;
padding-bottom: 6px;
}
.item-detail:nth-child(2){
line-height: 180px;
text-align: center;
width: 100%;
height:180px;
}
.item-detail:nth-child(3){
line-height: 180px;
text-align: center;
width: 100%;
height:180px;
}
.monitor-list{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
li{
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
flex: 25%;
height: 74px;
background: url('./../../../assets/images/bigScreen/num-border.png') no-repeat center;
margin-bottom: 9px;
color: #02FBE2;
b{
font-weight: normal;
color: #FFDF10;
}
span{
color: rgba(255, 255, 255, 0.8);
margin-top: 2px;
}
}
}
.condition-title{
display: flex;
color: rgba(255, 255, 255, 0.8);
align-items: center;
justify-content: flex-end;
margin-top: -30px;
span{
width: 65px;
height: 35px;
display: block;
background: url('./../../../assets/images/bigScreen/inspect-border.png') no-repeat center;
font-size: 20px;
font-weight: 600;
color: #02FBE2;
text-align: center;
line-height: 35px;
margin-left: 15px;
position: relative;
}
}
.warning-list{
display: flex;
justify-content: space-between;
align-items: center;
li{
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
color: #02FBE2;
font-size: 16px;
margin: 0 2px;
width: 69px;
opacity: 0.5;
cursor: pointer;
height: 58px;
background: url('./../../../assets/images/bigScreen/item-border.png') no-repeat center;
span{
color: rgba(255, 255, 255, 0.8);
font-size: 12px;
padding-bottom: 6px;
}
}
.active{
opacity: 1;
}
}
.viedo-list{
height: calc(100% - 10px);
.video-title{
display: flex;
justify-content: space-between;
align-items: center;
padding-left: 10px;
box-sizing: border-box;
color: rgba(255, 255, 255, 0.8);
margin-bottom: 10px;
/deep/ .el-input{
display: flex;
align-items: center;
margin-right: 18px;
}
/deep/ .el-input__inner{
height: 34px;
background: rgba(5, 12, 17, 0.5);
color: rgba(255, 255, 255, 0.8);
border-radius: 16px;
border: 1px solid rgba(4, 134, 123, 0.28);
}
/deep/ .el-input__icon{
color: #02FBE2;
line-height: 34px;
}
/deep/ .el-input__inner:focus {
outline: none;
border: 1px solid rgba(4, 134, 123, 0.8);
}
}
.video-content{
height: calc(100% - 40px);
overflow: auto;
ul{
li{
border-bottom: 1px solid rgba(255, 255, 255, 0.1);
padding: 10px 0;
.video-message{
margin-left: 5%;
margin-top: 10px;
color: rgba(255, 255, 255, 0.8);
}
}
}
}
}
/*滚动条整体部分,必须要设置*/
::-webkit-scrollbar{
width: 4px;
height: 26px;
background-color: transparent;
}
/*滚动条的轨道*/
::-webkit-scrollbar-track{
background-color: transparent;
}
/*滚动条的滑块按钮*/
::-webkit-scrollbar-thumb{
border-radius: 10px;
background-color: rgba(4, 106, 169,0.3);
box-shadow: inset 0 0 5px rgba(4, 186, 169,0.3);
}
/*滚动条的上下两端的按钮*/
::-webkit-scrollbar-button{
height: 0;
background-color: rgba(4, 186, 169,0.3);
}
// 两个滚动条的交汇处
::-webkit-scrollbar-corner{
background-color: transparent;
}
div{
/*三角箭头的颜色*/
scrollbar-arrow-color: rgba(4, 186, 169,0.3);
/*滚动条滑块按钮的颜色*/
scrollbar-face-color: rgba(4, 186, 169,0.3);
/*滚动条整体颜色*/
scrollbar-highlight-color: rgb(12,23,35);
/*滚动条阴影*/
scrollbar-shadow-color: transparent;
/*滚动条轨道颜色*/
scrollbar-track-color: transparent;
/*滚动条3d亮色阴影边框的外观颜色——左边和上边的阴影色*/
scrollbar-3dlight-color:rgba(4, 186, 169,0.3);
/*滚动条3d暗色阴影边框的外观颜色——右边和下边的阴影色*/
scrollbar-darkshadow-color: rgba(4, 186, 169,0.3);
/*滚动条基准颜色*/
scrollbar-base-color: rgba(4, 186, 169,0.3);
}
</style>