feat: 智能治理页面
This commit is contained in:
parent
3cf1e45762
commit
da3136ecc6
|
@ -43,7 +43,7 @@
|
|||
{{ scope.row.equipment_envdata.humidity ? scope.row.equipment_envdata.humidity : '-' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="流量(m3/h)">
|
||||
<el-table-column label="流量(m3/h)" width="130">
|
||||
<template #default="scope">
|
||||
{{ scope.row.equipment_envdata.flux ? scope.row.equipment_envdata.flux : '-' }}
|
||||
</template>
|
||||
|
|
|
@ -0,0 +1,183 @@
|
|||
<template>
|
||||
<el-container>
|
||||
<el-header style="height: 40%">
|
||||
<el-container>
|
||||
<el-header>
|
||||
<div class="panel_title">污染源监测清单</div>
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<scTable :data="tableData" style="width: 100%;" size="large" :apiObj="apiObj" row-key="id"
|
||||
:params="params" hidePagination hideDo @row-click="rowClick">
|
||||
<el-table-column type="index" width="50" />
|
||||
<el-table-column prop="equipment_number" label="设备编号" width="120" />
|
||||
<el-table-column prop="equipment_name" label="设备名称" width="180" />
|
||||
<el-table-column prop="mgroup_name" label="所属工段" width="120">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="监测状态" />
|
||||
<el-table-column label="TSP(mg/m3)">
|
||||
<template #default="scope">
|
||||
{{ scope.row.equipment_envdata.tsp ? scope.row.equipment_envdata.tsp : '-' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="温度(℃)">
|
||||
<template #default="scope">
|
||||
{{ scope.row.equipment_envdata.temperature ? scope.row.equipment_envdata.temperature : '-'
|
||||
}}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="湿度(%)">
|
||||
<template #default="scope">
|
||||
{{ scope.row.equipment_envdata.humidity ? scope.row.equipment_envdata.humidity : '-' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
</scTable>
|
||||
</el-main>
|
||||
</el-container>
|
||||
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<el-container>
|
||||
<el-main class="nopadding">
|
||||
<el-container>
|
||||
<el-header>
|
||||
<div class="left-panel">
|
||||
<div class="panel_title">污染源监测详情</div>
|
||||
</div>
|
||||
<div class="right-panel">
|
||||
<el-date-picker v-model="timeRange" type="datetimerange" range-separator="至"
|
||||
start-placeholder="开始时间" end-placeholder="结束时间" @change="handleQuery"
|
||||
style="width: 100%" />
|
||||
<el-select v-model="query.time_bucket" placeholder="周期" style="margin-left:4px"
|
||||
@change="handleQuery">
|
||||
<el-option v-for="item in timeOptions" :key="item.value" :label="item.label"
|
||||
:value="item.value" />
|
||||
</el-select>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="nppadding">
|
||||
<div v-show="currentEquipmentId != ''" id="cChart" style="width: 100%; height:100%;"></div>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</template>
|
||||
<script>
|
||||
import * as echarts from "echarts";
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
apiObj: this.$API.enp.drain_equip.list,
|
||||
params: { drain__type: 20, equipment__type: 20, has_envdata: 'yes' },
|
||||
currentEquipmentId: '',
|
||||
currentEquipmentName: '',
|
||||
timeRange: [],
|
||||
timeOptions: [
|
||||
{ label: '分钟', value: '1 minute' },
|
||||
{ label: '小时', value: '1 hour' },
|
||||
{ label: '天', value: '1 day' },
|
||||
],
|
||||
basicOption: {
|
||||
title: {
|
||||
text: '设备名称'
|
||||
},
|
||||
tooltip: {
|
||||
trigger: 'axis'
|
||||
},
|
||||
grid: {
|
||||
left: '3%',
|
||||
right: '4%',
|
||||
bottom: '3%',
|
||||
containLabel: true
|
||||
},
|
||||
toolbox: {
|
||||
feature: {
|
||||
saveAsImage: {}
|
||||
}
|
||||
},
|
||||
dataset: {
|
||||
source: []
|
||||
},
|
||||
xAxis: { type: 'category' },
|
||||
yAxis: {},
|
||||
// series: [{ type: 'line' }, { type: 'line' }, { type: 'line' }, { type: 'line' }, { type: 'line' }, { type: 'line' }],
|
||||
series: [
|
||||
{ type: 'line', encode: { y: 'tsp', seriesName: ["tsp"] } },
|
||||
{ type: 'line', encode: { y: '温度', seriesName: ["温度"] } },
|
||||
{ type: 'line', encode: { y: '压力', seriesName: ["压力"] } }]
|
||||
},
|
||||
query: {
|
||||
"end_time": "",
|
||||
"start_time": "",
|
||||
"time_bucket": "1 hour",
|
||||
"equipment_id": ''
|
||||
}
|
||||
}
|
||||
},
|
||||
mounted() {
|
||||
this.initTimeRange()
|
||||
},
|
||||
methods: {
|
||||
initTimeRange() {
|
||||
var now = new Date();
|
||||
var start = new Date();
|
||||
start.setTime(start.getTime() - 3600 * 1000 * 24 * 3);
|
||||
this.timeRange = [start, now]
|
||||
},
|
||||
rowClick(row) {
|
||||
this.currentEquipmentId = row.equipment;
|
||||
this.currentEquipmentName = row.equipment_name;
|
||||
this.query.equipment_id = row.equipment;
|
||||
this.$nextTick(() => { this.handleQuery() })
|
||||
|
||||
},
|
||||
initChart() {
|
||||
var that = this;
|
||||
var myChart = echarts.getInstanceByDom(document.getElementById('cChart'));
|
||||
if (myChart == undefined) {
|
||||
myChart = echarts.init(document.getElementById('cChart'), 'dark');
|
||||
}
|
||||
myChart.showLoading();
|
||||
this.$API.bi.dataset.exec.req('enp_edata2', {
|
||||
query: this.query,
|
||||
raise_exception: true
|
||||
}).then(res => {
|
||||
let newOption = Object.assign({}, this.basicOption);
|
||||
let ds0 = res.data.ds0
|
||||
ds0.pop()
|
||||
newOption.dataset.source = res.data.ds0;
|
||||
newOption.title.text = this.currentEquipmentName;
|
||||
myChart.setOption(newOption);
|
||||
}).then(() => { myChart.hideLoading() })
|
||||
|
||||
},
|
||||
handleQuery() {
|
||||
let that = this;
|
||||
let timeRange = Object.assign([], that.timeRange);;
|
||||
let time1 = timeRange[0]
|
||||
let time2 = timeRange[1];
|
||||
let formatstr = 'yyyy-MM-dd hh:mm:ss'
|
||||
if (this.query.time_bucket == '1 minute') {
|
||||
time2 = new Date(time2.getTime() + 1000 * 60);
|
||||
formatstr = 'yyyy-MM-dd hh:mm:00'
|
||||
}
|
||||
else if (this.query.time_bucket == '1 hour') {
|
||||
time2 = new Date(time2.getTime() + 1000 * 60 * 60);
|
||||
formatstr = 'yyyy-MM-dd hh:00:00'
|
||||
}
|
||||
else if (this.query.time_bucket == '1 day') {
|
||||
time2 = new Date(time2.getTime() + 1000 * 60 * 60 * 24);
|
||||
formatstr = 'yyyy-MM-dd'
|
||||
}
|
||||
this.query.start_time = this.$TOOL.dateFormat(time1, formatstr)
|
||||
this.query.end_time = this.$TOOL.dateFormat(time2, formatstr)
|
||||
this.initChart()
|
||||
}
|
||||
},
|
||||
|
||||
}
|
||||
</script>
|
|
@ -0,0 +1,114 @@
|
|||
<template>
|
||||
<el-container>
|
||||
<el-header>
|
||||
<div class="left-panel">
|
||||
<el-select></el-select>
|
||||
<span style="width: 4px;"></span>
|
||||
<el-button type="primary">查询</el-button>
|
||||
</div>
|
||||
<div class="right-panel">
|
||||
<div class="typebox">
|
||||
<span style="color:red;">
|
||||
<img style="height: 16px; weight: 16px;"
|
||||
src="" />
|
||||
产治未同步</span>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="greenb radio"></div>
|
||||
<div class="green">设备正常</div>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="orangeb radio"></div>
|
||||
<div class="orange">设备待机</div>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="grayb radio"></div>
|
||||
<div class="gray">设备离线</div>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="redb radio"></div>
|
||||
<div class="red">设备故障</div>
|
||||
</div>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<scTable style="width: 100%;" size="large" :apiObj="apiObj" row-key="id" :params="params" hidePagination hideDo>
|
||||
<el-table-column prop="name" label="污染源编号" />
|
||||
<el-table-column prop="type" label="污染源名称" />
|
||||
<el-table-column label="生产设备名称">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="生产设备名称">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="type" label="待机时间" />
|
||||
<el-table-column label="治理设备名称">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="type" label="待机时间" />
|
||||
<el-table-column prop="type" label="污染浓度" />
|
||||
</scTable>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</template>
|
||||
<script>
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
apiObj: null,
|
||||
params: {}
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped>
|
||||
.typebox {
|
||||
font-size: 14px;
|
||||
font-weight: 400;
|
||||
margin-right: 10px;
|
||||
display: flex
|
||||
}
|
||||
|
||||
.radio {
|
||||
width: 14px;
|
||||
height: 14px;
|
||||
border-radius: 50%;
|
||||
}
|
||||
|
||||
.red {
|
||||
color: red;
|
||||
}
|
||||
|
||||
.redb {
|
||||
background: red;
|
||||
}
|
||||
|
||||
.green {
|
||||
color: #00d614;
|
||||
}
|
||||
|
||||
.greenb {
|
||||
background: #00d614;
|
||||
}
|
||||
|
||||
.orange {
|
||||
color: #ff9600
|
||||
}
|
||||
|
||||
.orangeb {
|
||||
background: #ff9600
|
||||
}
|
||||
|
||||
.gray {
|
||||
color: #cbcbcb;
|
||||
}
|
||||
|
||||
.grayb {
|
||||
background: #cbcbcb
|
||||
}</style>
|
|
@ -0,0 +1,45 @@
|
|||
<template>
|
||||
<el-container>
|
||||
<el-header>
|
||||
<el-menu mode="horizontal" :default-active="activeIndex" :ellipsis="false" @select="handleSelect">
|
||||
<el-menu-item index="1">厂区环境治理</el-menu-item>
|
||||
<el-menu-item index="2">生产过程治理</el-menu-item>
|
||||
<el-menu-item index="3">物料输送治理</el-menu-item>
|
||||
</el-menu>
|
||||
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<smartg_carwash v-if="activeIndex == '1'"></smartg_carwash>
|
||||
<smartg_prod v-if="activeIndex == '2'"></smartg_prod>
|
||||
<smartg_trans v-if="activeIndex == '3'"></smartg_trans>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</template>
|
||||
<script>
|
||||
import smartg_carwash from "./smartg_carwash.vue";
|
||||
import smartg_prod from "./smartg_prod.vue";
|
||||
import smartg_trans from "./smarg_trans.vue";
|
||||
export default {
|
||||
components: {
|
||||
smartg_carwash,
|
||||
smartg_prod,
|
||||
smartg_trans
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
activeIndex: "1",
|
||||
tableData: [],
|
||||
}
|
||||
},
|
||||
methods: {
|
||||
handleSelect(key, keyPath) {
|
||||
this.activeIndex = key;
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style>
|
||||
.el-tabs {
|
||||
height: 100%;
|
||||
}
|
||||
</style>
|
|
@ -0,0 +1,79 @@
|
|||
<template>
|
||||
<el-container>
|
||||
<el-aside width="70%">
|
||||
<el-container>
|
||||
<el-header>
|
||||
<div class="left-panel">
|
||||
<div class="left-panel">洗车行为统计</div>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<scTable style="width: 100%;" size="large" :apiObj="apiObj" row-key="id" :params="params" hidePagination
|
||||
hideDo>
|
||||
<el-table-column type="index" width="50" />
|
||||
<el-table-column prop="start_time" label="开始时间" width="120" />
|
||||
<el-table-column prop="end_time" label="结束时间" width="120" />
|
||||
<el-table-column label="洗车时长">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="压力" />
|
||||
<el-table-column label="流量">
|
||||
<template #default="scope">
|
||||
{{ scope.row.equipment_envdata.tsp ? scope.row.equipment_envdata.tsp :
|
||||
'-' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
</scTable>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</el-aside>
|
||||
<el-main class="nopadding">
|
||||
<el-container>
|
||||
<el-header>
|
||||
<div class="left-panel">环卫车智能调度</div>
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<el-container>
|
||||
<el-header>
|
||||
<div class="left-panel">
|
||||
<span>厂区环境(PM10):</span>
|
||||
<span style="color: green"> 36ug/m3</span>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<scTable style="width: 100%;" size="large" :apiObj="apiObj2" row-key="id" :params="params2"
|
||||
hidePagination hideDo>
|
||||
<el-table-column type="index" width="50" />
|
||||
<el-table-column prop="name" label="环卫车名称" />
|
||||
<el-table-column prop="type" label="环卫车类型" />
|
||||
<el-table-column label="今日工作时长">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</scTable>
|
||||
</el-main>
|
||||
<el-footer height="400px">
|
||||
xx
|
||||
</el-footer>
|
||||
</el-container>
|
||||
</el-main>
|
||||
</el-container>
|
||||
|
||||
</el-main>
|
||||
</el-container>
|
||||
</template>
|
||||
<script>
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
apiObj: null,
|
||||
params: {},
|
||||
apiObj2: null,
|
||||
params2: {},
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
|
@ -0,0 +1,114 @@
|
|||
<template>
|
||||
<el-container>
|
||||
<el-header>
|
||||
<div class="left-panel">
|
||||
<el-select></el-select>
|
||||
<span style="width: 4px;"></span>
|
||||
<el-button type="primary">查询</el-button>
|
||||
</div>
|
||||
<div class="right-panel">
|
||||
<div class="typebox">
|
||||
<span style="color:red;">
|
||||
<img style="height: 16px; weight: 16px;"
|
||||
src="" />
|
||||
产治未同步</span>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="greenb radio"></div>
|
||||
<div class="green">设备正常</div>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="orangeb radio"></div>
|
||||
<div class="orange">设备待机</div>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="grayb radio"></div>
|
||||
<div class="gray">设备离线</div>
|
||||
</div>
|
||||
<div class="typebox">
|
||||
<div class="redb radio"></div>
|
||||
<div class="red">设备故障</div>
|
||||
</div>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="nopadding">
|
||||
<scTable style="width: 100%;" size="large" :apiObj="apiObj" row-key="id" :params="params" hidePagination hideDo>
|
||||
<el-table-column prop="name" label="污染源编号" />
|
||||
<el-table-column prop="type" label="污染源名称" />
|
||||
<el-table-column label="生产设备名称">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="生产设备名称">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="type" label="待机时间" />
|
||||
<el-table-column label="治理设备名称">
|
||||
<template #default="scope">
|
||||
<span v-if="scope.row.drain_">{{ scope.row.drain_.mgroup_name }}</span>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="type" label="待机时间" />
|
||||
<el-table-column prop="type" label="污染浓度" />
|
||||
</scTable>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</template>
|
||||
<script>
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
apiObj: null,
|
||||
params: {}
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style scoped>
|
||||
.typebox {
|
||||
font-size: 14px;
|
||||
font-weight: 400;
|
||||
margin-right: 10px;
|
||||
display: flex
|
||||
}
|
||||
|
||||
.radio {
|
||||
width: 14px;
|
||||
height: 14px;
|
||||
border-radius: 50%;
|
||||
}
|
||||
|
||||
.red {
|
||||
color: red;
|
||||
}
|
||||
|
||||
.redb {
|
||||
background: red;
|
||||
}
|
||||
|
||||
.green {
|
||||
color: #00d614;
|
||||
}
|
||||
|
||||
.greenb {
|
||||
background: #00d614;
|
||||
}
|
||||
|
||||
.orange {
|
||||
color: #ff9600
|
||||
}
|
||||
|
||||
.orangeb {
|
||||
background: #ff9600
|
||||
}
|
||||
|
||||
.gray {
|
||||
color: #cbcbcb;
|
||||
}
|
||||
|
||||
.grayb {
|
||||
background: #cbcbcb
|
||||
}</style>
|
|
@ -43,7 +43,7 @@
|
|||
<el-dropdown-menu class="enpMenu">
|
||||
<el-dropdown-item command="pollutant">污染源清单</el-dropdown-item>
|
||||
<el-dropdown-item command="pollutant2">污染源监测</el-dropdown-item>
|
||||
<el-dropdown-item>智能治理</el-dropdown-item>
|
||||
<el-dropdown-item command="smartg">智能治理</el-dropdown-item>
|
||||
<el-dropdown-item>设备清单</el-dropdown-item>
|
||||
<el-dropdown-item>环境质量</el-dropdown-item>
|
||||
<el-dropdown-item>台账管理</el-dropdown-item>
|
||||
|
@ -293,6 +293,8 @@
|
|||
<cems2-drawer v-else-if="activeDrawerName == 'cems2'" @close="closeDialog"></cems2-drawer>
|
||||
<cems-export v-else-if="activeDrawerName == 'cemsExport'" @close="closeDialog"></cems-export>
|
||||
<pollutant v-else-if="activeDrawerName == 'pollutant'" @close="closeDialog"></pollutant>
|
||||
<pollutant2 v-else-if="activeDrawerName == 'pollutant2'" @close="closeDialog"></pollutant2>
|
||||
<smartg v-else-if="activeDrawerName == 'smartg'" @close="closeDialog"></smartg>
|
||||
</el-drawer>
|
||||
</div>
|
||||
</el-main>
|
||||
|
@ -309,6 +311,8 @@ import cemsDrawer from './enpComponents/cems.vue'
|
|||
import cems2Drawer from './enpComponents/cems2.vue'
|
||||
import cemsExport from './enpComponents/cemsExport.vue'
|
||||
import pollutant from "./enpComponents/pollutant.vue"
|
||||
import pollutant2 from "./enpComponents/pollutant2.vue"
|
||||
import smartg from "./enpComponents/smartg.vue"
|
||||
import 'babylonjs-loaders';
|
||||
import 'animate.css';
|
||||
export default {
|
||||
|
@ -317,7 +321,9 @@ export default {
|
|||
cemsDrawer,
|
||||
cems2Drawer,
|
||||
cemsExport,
|
||||
pollutant
|
||||
pollutant,
|
||||
pollutant2,
|
||||
smartg
|
||||
},
|
||||
data() {
|
||||
return {
|
||||
|
|
Loading…
Reference in New Issue