186 lines
5.7 KiB
Vue
186 lines
5.7 KiB
Vue
|
|
<template>
|
|||
|
|
<div
|
|||
|
|
class="default-main device-control"
|
|||
|
|
:style="{ height: pageHeight.height }"
|
|||
|
|
v-loading="loading"
|
|||
|
|
style="position: relative"
|
|||
|
|
>
|
|||
|
|
<!-- @init="nodeClick" -->
|
|||
|
|
<PointTree @node-click="nodeClick" @pointTypeChange="pointTypeChange" @checkChange="handleCheckedNodesChange"></PointTree>
|
|||
|
|
<div class="device-control-right" >
|
|||
|
|
<el-tabs type="border-card" class="mb10" @tab-click="handleClick" v-model="activeTab">
|
|||
|
|
<el-tab-pane label="稳态补召" name="deviceInfo1">
|
|||
|
|
<div style="height: calc(100vh - 205px)">
|
|||
|
|
<SteadyRecall ref="steadyRef" :checked-nodes="checkedNodes"></SteadyRecall>
|
|||
|
|
</div>
|
|||
|
|
</el-tab-pane>
|
|||
|
|
<el-tab-pane label="暂态补召" name="deviceInfo2">
|
|||
|
|
<div style="height: calc(100vh - 205px)">
|
|||
|
|
<Event ref="eventRef" :checked-nodes="checkedNodes"></Event>
|
|||
|
|
</div>
|
|||
|
|
</el-tab-pane>
|
|||
|
|
</el-tabs>
|
|||
|
|
</div>
|
|||
|
|
</div>
|
|||
|
|
</template>
|
|||
|
|
|
|||
|
|
<script setup lang="ts">
|
|||
|
|
import PointTree from '@/components/tree/govern/selectTree.vue'
|
|||
|
|
import { ref, reactive, onMounted, onUnmounted, inject, nextTick, onBeforeUnmount } from 'vue'
|
|||
|
|
import DatePicker from '@/components/form/datePicker/index.vue'
|
|||
|
|
import TableHeader from '@/components/table/header/index.vue'
|
|||
|
|
import { mainHeight } from '@/utils/layout'
|
|||
|
|
import Event from './eventRecall.vue'
|
|||
|
|
import SteadyRecall from './steadyRecall.vue'
|
|||
|
|
|
|||
|
|
const pageHeight = mainHeight(20)
|
|||
|
|
const steadyRef = ref()
|
|||
|
|
const eventRef = ref()
|
|||
|
|
const loading = ref(false)
|
|||
|
|
const activeTab = ref('deviceInfo1')
|
|||
|
|
const checkedNodes = ref<any[]>([]) // 存储左侧树勾选的节点
|
|||
|
|
|
|||
|
|
defineOptions({
|
|||
|
|
name: 'govern/monitorRecall/index'
|
|||
|
|
})
|
|||
|
|
|
|||
|
|
// 处理子组件传递的勾选节点变化
|
|||
|
|
const handleCheckedNodesChange = (nodes: any[]) => {
|
|||
|
|
|
|||
|
|
checkedNodes.value = nodes
|
|||
|
|
|
|||
|
|
// 将勾选的节点传递给当前激活的tab组件
|
|||
|
|
if (activeTab.value === 'deviceInfo1' && steadyRef.value) {
|
|||
|
|
// 如果steadyRecall组件有接收勾选节点的方法,可以调用
|
|||
|
|
if (steadyRef.value.setCheckedNodes) {
|
|||
|
|
steadyRef.value.setCheckedNodes(nodes)
|
|||
|
|
}
|
|||
|
|
} else if (activeTab.value === 'deviceInfo2' && eventRef.value) {
|
|||
|
|
// 如果eventRecall组件有接收勾选节点的方法,可以调用
|
|||
|
|
if (eventRef.value.setCheckedNodes) {
|
|||
|
|
eventRef.value.setCheckedNodes(nodes)
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// tab切换时的处理
|
|||
|
|
const handleClick = (tab: any) => {
|
|||
|
|
activeTab.value = tab.props.name
|
|||
|
|
|
|||
|
|
// tab切换时刷新对应组件的数据
|
|||
|
|
nextTick(() => {
|
|||
|
|
if (tab.props.name === 'deviceInfo1' && steadyRef.value) {
|
|||
|
|
// 刷新稳态补召数据
|
|||
|
|
if (steadyRef.value.refreshData) {
|
|||
|
|
steadyRef.value.refreshData(checkedNodes.value)
|
|||
|
|
} else if (steadyRef.value.getTableParams) {
|
|||
|
|
// 如果有getTableParams方法,调用它
|
|||
|
|
steadyRef.value.getTableParams({ nodes: checkedNodes.value })
|
|||
|
|
}
|
|||
|
|
} else if (tab.props.name === 'deviceInfo2' && eventRef.value) {
|
|||
|
|
// 刷新暂态补召数据
|
|||
|
|
if (eventRef.value.refreshData) {
|
|||
|
|
eventRef.value.refreshData(checkedNodes.value)
|
|||
|
|
} else if (eventRef.value.getTableParams) {
|
|||
|
|
// 如果有getTableParams方法,调用它
|
|||
|
|
eventRef.value.getTableParams({ nodes: checkedNodes.value })
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
})
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
const nodeClick = (node: any) => {
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
const pointTypeChange = (type: any, node: any) => {
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
</script>
|
|||
|
|
|
|||
|
|
<style lang="scss">
|
|||
|
|
.device-control {
|
|||
|
|
display: flex;
|
|||
|
|
height: 100%;
|
|||
|
|
|
|||
|
|
&-left {
|
|||
|
|
// width: 280px;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
&-right {
|
|||
|
|
overflow: hidden;
|
|||
|
|
flex: 1;
|
|||
|
|
padding: 10px 10px 10px 0;
|
|||
|
|
height: 100%;
|
|||
|
|
|
|||
|
|
.el-tabs {
|
|||
|
|
height: 100%;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
.el-tabs__content {
|
|||
|
|
height: calc(100% - 55px);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
.el-tab-pane {
|
|||
|
|
height: 100%;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
.el-descriptions__header {
|
|||
|
|
height: 36px;
|
|||
|
|
margin-bottom: 7px;
|
|||
|
|
display: flex;
|
|||
|
|
align-items: center;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
.content {
|
|||
|
|
box-sizing: border-box;
|
|||
|
|
overflow: auto;
|
|||
|
|
display: grid;
|
|||
|
|
grid-template-columns: repeat(auto-fit, minmax(310px, 1fr));
|
|||
|
|
grid-gap: 10px;
|
|||
|
|
justify-content: center;
|
|||
|
|
|
|||
|
|
.box-card {
|
|||
|
|
display: flex;
|
|||
|
|
flex-direction: column;
|
|||
|
|
justify-content: space-between;
|
|||
|
|
color: var(--el-color-white);
|
|||
|
|
min-height: 80px;
|
|||
|
|
font-size: 13px;
|
|||
|
|
|
|||
|
|
.el-card__header {
|
|||
|
|
padding: 0;
|
|||
|
|
|
|||
|
|
.clearfix {
|
|||
|
|
box-sizing: border-box;
|
|||
|
|
display: flex;
|
|||
|
|
align-items: center;
|
|||
|
|
justify-content: space-between;
|
|||
|
|
height: 35px;
|
|||
|
|
padding: 0 10px;
|
|||
|
|
background: var(--el-color-primary);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
.el-card__body {
|
|||
|
|
flex: 1;
|
|||
|
|
padding: 10px;
|
|||
|
|
margin-bottom: 0;
|
|||
|
|
background-image: linear-gradient(var(--el-color-primary), var(--el-color-primary-light-3));
|
|||
|
|
|
|||
|
|
.box-card-content {
|
|||
|
|
height: 100%;
|
|||
|
|
display: flex;
|
|||
|
|
flex-direction: column;
|
|||
|
|
justify-content: space-between;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
.device-control-right > div {
|
|||
|
|
height: 100%;
|
|||
|
|
}
|
|||
|
|
</style>
|