|
@@ -1,73 +1,77 @@
|
|
|
<template>
|
|
|
- <div class="home-container">
|
|
|
- <div class="header">
|
|
|
- <div class="head-time">
|
|
|
- <span>2022/03/28</span>
|
|
|
- <span>星期一</span>
|
|
|
- <span>13:46:37</span>
|
|
|
- </div>
|
|
|
- <div class="main-title">通防智能管控系统</div>
|
|
|
- </div>
|
|
|
- <div class="home-contents">
|
|
|
- <div class="left-content">
|
|
|
- <!-- 局部通风机 -->
|
|
|
- <div class="monitor-box">
|
|
|
- <fanMonitor :fandata="fanLocalList" />
|
|
|
- </div>
|
|
|
- <!-- 主通风机 -->
|
|
|
- <div class="monitor-box monitor-box1">
|
|
|
- <mainMonitor :maindata="mainList" />
|
|
|
- </div>
|
|
|
- <!-- 通风设备远程控制 -->
|
|
|
- <div class="monitor-box">
|
|
|
- <windDevice />
|
|
|
+ <div style="position: relative; width: 100%; height: 100%;">
|
|
|
+ <div class="home-container" v-if="pageType == 'home'">
|
|
|
+ <div class="header">
|
|
|
+ <div class="head-time">
|
|
|
+ <span>2022/03/28</span>
|
|
|
+ <span>星期一</span>
|
|
|
+ <span>13:46:37</span>
|
|
|
</div>
|
|
|
+ <div class="main-title">通防智能管控系统</div>
|
|
|
</div>
|
|
|
- <div class="center-content">
|
|
|
- <!-- 三维模型 -->
|
|
|
- <div class="three-box">
|
|
|
- <div class="three-nav">
|
|
|
- <div class="nav-item" v-for="(item, index) in navList" :key="index">
|
|
|
- <div class="item-label">{{ item.name }}</div>
|
|
|
- <div class="item-value">
|
|
|
- <div v-if="item.isShow" class="bg-box" v-for="(ite, ind) in item.valList" :key="ind">
|
|
|
- <div class="box-line"></div>
|
|
|
- <div class="value-text">{{ ite.val }}</div>
|
|
|
+ <div class="home-contents">
|
|
|
+ <div class="left-content">
|
|
|
+ <!-- 局部通风机 -->
|
|
|
+ <div class="monitor-box">
|
|
|
+ <fanMonitor @goDetail="goDetail" :fandata="fanLocalList" />
|
|
|
+ </div>
|
|
|
+ <!-- 主通风机 -->
|
|
|
+ <div class="monitor-box monitor-box1">
|
|
|
+ <mainMonitor @goDetail="goDetail"/>
|
|
|
+ </div>
|
|
|
+ <!-- 通风设备远程控制 -->
|
|
|
+ <div class="monitor-box">
|
|
|
+ <windDevice @goDetail="goDetail"/>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="center-content">
|
|
|
+ <!-- 三维模型 -->
|
|
|
+ <div class="three-box">
|
|
|
+ <div class="three-nav">
|
|
|
+ <div class="nav-item" v-for="(item, index) in navList" :key="index">
|
|
|
+ <div class="item-label">{{ item.name }}</div>
|
|
|
+ <div class="item-value">
|
|
|
+ <div v-if="item.isShow" class="bg-box" v-for="(ite, ind) in item.valList" :key="ind">
|
|
|
+ <div class="box-line"></div>
|
|
|
+ <div class="value-text">{{ ite.val }}</div>
|
|
|
+ </div>
|
|
|
+ <div v-else class="value-text1">{{ item.val }}</div>
|
|
|
</div>
|
|
|
- <div v-else class="value-text1">{{ item.val }}</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
+ <div class="three-modal" id="modalBox">
|
|
|
+ <!-- <iframe id="iframe" ref="iframe" src="http://10.10.150.72:8091/user/autologin" scrolling="auto" frameborder="0" width="100%" height="100%"></iframe> -->
|
|
|
+
|
|
|
+ </div>
|
|
|
</div>
|
|
|
- <div class="three-modal">
|
|
|
- <iframe id="iframe" ref="iframe" src="http://182.92.126.35:8091/user/autologin" scrolling="auto" frameborder="0" width="100%" height="100%"></iframe>
|
|
|
- <!-- <div id="content" style="width: 100%; height: 100%;"></div> -->
|
|
|
+ <!-- 风量监测 -->
|
|
|
+ <div class="wind-box">
|
|
|
+ <windMonitor @goDetail="goDetail"/>
|
|
|
</div>
|
|
|
</div>
|
|
|
- <!-- 风量监测 -->
|
|
|
- <div class="wind-box" >
|
|
|
- <windMonitor :flList="flList" />
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div class="right-content">
|
|
|
- <!-- 关键通风路线 -->
|
|
|
- <div class="monitor-box">
|
|
|
- <windLine :lineList="lineList"/>
|
|
|
- </div>
|
|
|
- <!-- 工作面智能管控 -->
|
|
|
- <div class="monitor-box monitor-box1">
|
|
|
- <workMonitor :workList="workList" />
|
|
|
- </div>
|
|
|
- <!-- 设备预警 -->
|
|
|
- <div class="monitor-box">
|
|
|
- <deviceWarn :warnData="warnData"/>
|
|
|
+ <div class="right-content">
|
|
|
+ <!-- 关键通风路线 -->
|
|
|
+ <div class="monitor-box">
|
|
|
+ <windLine @goDetail="goDetail"/>
|
|
|
+ </div>
|
|
|
+ <!-- 工作面智能管控 -->
|
|
|
+ <div class="monitor-box monitor-box1">
|
|
|
+ <workMonitor @goDetail="goDetail"/>
|
|
|
+ </div>
|
|
|
+ <!-- 设备预警 -->
|
|
|
+ <div class="monitor-box">
|
|
|
+ <deviceWarn @goDetail="goDetail"/>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
+ <DeviceMonitor v-else-if="pageType" :pageType="pageType" @goHome="goHome"/>
|
|
|
+ <div id="content" style="width: 100%; height: 100%; position: fixed;"></div>
|
|
|
</div>
|
|
|
+
|
|
|
</template>
|
|
|
<script lang="ts" setup>
|
|
|
- import { reactive, onMounted, ref } from 'vue';
|
|
|
- import { getActions } from '/@/qiankun/state';
|
|
|
+ import { reactive, onMounted, ref, nextTick } from 'vue';
|
|
|
import fanMonitor from './components/fan-monitor.vue';
|
|
|
import mainMonitor from './components/main-monitor.vue';
|
|
|
import windDevice from './components/wind-device.vue';
|
|
@@ -76,9 +80,9 @@
|
|
|
import workMonitor from './components/work-monitor.vue';
|
|
|
import deviceWarn from './components/device-warn.vue';
|
|
|
import { useGlobSetting } from '/@/hooks/setting';
|
|
|
- import {list} from './clique.api'
|
|
|
+ import { list } from './clique.api';
|
|
|
+ import DeviceMonitor from '../../monitorManager/deviceMonitor/index.vue'
|
|
|
|
|
|
-
|
|
|
let timer: NodeJS.Timeout | null = null;
|
|
|
let fanLocalList = reactive<any[]>([]); //局部风机数据
|
|
|
let mainList=ref<any[]>([])//主通风机数据
|
|
@@ -100,6 +104,38 @@
|
|
|
{ name: '外部漏风率', isShow: false, val:0 },
|
|
|
{ name: '有效风量率', isShow: false, val: 0 },
|
|
|
]);
|
|
|
+
|
|
|
+ const loading = ref(false);
|
|
|
+ const globSetting = useGlobSetting();
|
|
|
+ const openQianKun = globSetting.openQianKun;
|
|
|
+ let actions;
|
|
|
+ const pageType = ref('home')
|
|
|
+
|
|
|
+function goDetail(deviceType) {
|
|
|
+ pageType.value = deviceType
|
|
|
+ changeModalBox()
|
|
|
+}
|
|
|
+function goHome() {
|
|
|
+ pageType.value = 'home'
|
|
|
+ nextTick(() => {
|
|
|
+ changeModalBox()
|
|
|
+ })
|
|
|
+}
|
|
|
+function changeModalBox() {
|
|
|
+ if (pageType.value === 'home') {
|
|
|
+ const dom = document.getElementById('modalBox') as HTMLElement
|
|
|
+ if (dom && dom.parentElement) {
|
|
|
+ const contentDom = document.getElementById('content') as HTMLElement
|
|
|
+ contentDom?.setAttribute('style', `top: ${dom.parentElement.offsetTop + 20}px; left: ${dom.parentElement.offsetLeft + 20}px; width: ${dom.offsetWidth - 40}px; height: ${dom.offsetHeight - 40}px; position: fixed;`)
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ const dom = document.getElementById('modalBox') as HTMLElement
|
|
|
+ if (dom && dom.parentElement) {
|
|
|
+ const contentDom = document.getElementById('content') as HTMLElement
|
|
|
+ contentDom?.setAttribute('style', `top:0px; left: 0px; width: 100%; height: 100%; position: fixed;`)
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
function getList() {
|
|
|
list({}).then((res) => {
|
|
|
console.log(res, 'res-----------');
|
|
@@ -121,14 +157,27 @@
|
|
|
warnData.value=res.warn
|
|
|
});
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
onMounted(() => {
|
|
|
- // getList()
|
|
|
+ changeModalBox()
|
|
|
+ const renderModal = () => {
|
|
|
+ const element = document.getElementById('__qiankun_microapp_wrapper_for_micro_vent_3_d_modal__')
|
|
|
+ if(element){
|
|
|
+ element?.setAttribute('style', 'width: 100%; height: 100%');
|
|
|
+ }else{
|
|
|
+ setTimeout(() => {
|
|
|
+ renderModal()
|
|
|
+ }, 2000)
|
|
|
+ }
|
|
|
+ }
|
|
|
+ renderModal()
|
|
|
timer = Number(
|
|
|
setInterval(() => {
|
|
|
getList();
|
|
|
}, 10000)
|
|
|
);
|
|
|
- });
|
|
|
+ })
|
|
|
</script>
|
|
|
|
|
|
<style lang="less" scoped>
|
|
@@ -143,6 +192,7 @@
|
|
|
.home-container {
|
|
|
width: 100%;
|
|
|
height: 100%;
|
|
|
+ position: relative;
|
|
|
.header {
|
|
|
width: 100%;
|
|
|
height: 76px;
|
|
@@ -318,4 +368,4 @@
|
|
|
// width: 100% !important;
|
|
|
// height: 100% !important;
|
|
|
// }
|
|
|
-</style>
|
|
|
+</style>
|