Files
emsfront/src/views/ems/dzjk/sbjk/dh/index.vue

121 lines
3.4 KiB
Vue
Raw Normal View History

<template>
2025-12-12 17:38:26 +08:00
<div v-loading="loading">
<el-card
v-for="(item,index) in list"
:key="index+'ylLise'"
class="sbjk-card-container running-card-container"
shadow="always">
<div slot="header">
<span class="large-title">{{ item.deviceName }}</span>
<div class="info">
<div>数据更新时间{{ item.dataUpdateTime || '-' }}</div>
</div>
<div class="alarm">
<el-button type="primary" round size="small" style="margin-right:20px;" @click="pointDetail(item,'point')">
详细
</el-button>
<el-badge :hidden="!item.alarmNum" :value="item.alarmNum || 0" class="item">
2025-12-12 17:38:26 +08:00
<i
class="el-icon-message-solid alarm-icon"
@click="pointDetail(item,'alarmPoint')"
></i>
</el-badge>
</div>
2025-12-12 17:38:26 +08:00
</div>
<el-row class="device-info-row">
<el-col v-for="(tempDataItem,tempDataIndex) in tempData" :key="tempDataIndex+'hdTempData'" :span="12"
class="device-info-col">
<span class="pointer" @click="showChart(tempDataItem.title,item.deviceId)">
2026-01-13 16:38:21 +08:00
<span class="left">{{ tempDataItem.title }}</span> <span
class="right">{{ item[tempDataItem.attr] || '-' }}<span
2025-12-12 17:38:26 +08:00
v-html="tempDataItem.unit"></span></span>
</span>
2025-12-12 17:38:26 +08:00
</el-col>
</el-row>
</el-card>
<el-empty v-show="list.length<=0" :image-size="200"></el-empty>
<point-chart ref="pointChart" :site-id="siteId"/>
<point-table ref="pointTable"/>
</div>
</template>
<script>
import getQuerySiteId from "@/mixins/ems/getQuerySiteId";
import {getDhDataList} from '@/api/ems/dzjk'
import intervalUpdate from "@/mixins/ems/intervalUpdate";
import pointChart from "./../PointChart.vue";
import PointTable from "@/views/ems/site/sblb/PointTable.vue";
2025-12-12 17:38:26 +08:00
export default {
2025-12-12 17:38:26 +08:00
name: 'DzjkSbjkDh',
mixins: [getQuerySiteId, intervalUpdate],
components: {pointChart, PointTable},
data() {
return {
2025-12-12 17:38:26 +08:00
loading: false,
list: [],
tempData: [
{title: '湿度', attr: 'humidity', unit: ''},
{title: '温度', attr: 'temperature', unit: '&#8451;'},
]
}
},
2025-12-12 17:38:26 +08:00
methods: {
// 查看设备电位表格
2025-12-12 17:38:26 +08:00
pointDetail(row, dataType) {
const {deviceId} = row
2025-12-12 17:38:26 +08:00
this.$refs.pointTable.showTable({siteId: this.siteId, deviceId, deviceCategory: 'DH'}, dataType)
},
2025-12-12 17:38:26 +08:00
showChart(pointName, deviceId) {
pointName && this.$refs.pointChart.showChart({pointName, deviceCategory: 'DH', deviceId})
},
2025-12-12 17:38:26 +08:00
updateData() {
this.loading = true
getDhDataList(this.siteId).then(response => {
2025-12-12 17:38:26 +08:00
this.list = JSON.parse(JSON.stringify(response?.data || []));
}).finally(() => {
this.loading = false
})
},
2025-12-12 17:38:26 +08:00
init() {
this.updateData()
this.updateInterval(this.updateData)
}
},
2025-12-12 17:38:26 +08:00
mounted() {
}
}
</script>
<style scoped lang="scss">
2025-12-12 17:38:26 +08:00
.sbjk-card-container {
&:not(:last-child) {
margin-bottom: 25px;
}
2025-12-12 17:38:26 +08:00
.el-row {
background-color: #ffffff;
2025-12-12 17:38:26 +08:00
border: 1px solid #eeeeee;
font-size: 14px;
line-height: 16px;
color: #333333;
2025-12-12 17:38:26 +08:00
.el-col {
padding: 12px 0;
text-align: center;
position: relative;
}
2025-12-12 17:38:26 +08:00
.el-col {
border-bottom: 1px solid #eeeeee;
}
2025-12-12 17:38:26 +08:00
.el-col:not(:nth-child(3n)) {
border-right: 1px solid #eeeeee;
}
}
}
</style>