|
@@ -1,73 +1,78 @@
|
|
|
<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 />
|
|
|
- </div>
|
|
|
- <!-- 主通风机 -->
|
|
|
- <div class="monitor-box monitor-box1">
|
|
|
- <mainMonitor />
|
|
|
- </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"/>
|
|
|
+ </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://10.10.150.72: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 />
|
|
|
- </div>
|
|
|
- </div>
|
|
|
- <div class="right-content">
|
|
|
- <!-- 关键通风路线 -->
|
|
|
- <div class="monitor-box">
|
|
|
- <windLine />
|
|
|
- </div>
|
|
|
- <!-- 工作面智能管控 -->
|
|
|
- <div class="monitor-box monitor-box1">
|
|
|
- <workMonitor />
|
|
|
- </div>
|
|
|
- <!-- 设备预警 -->
|
|
|
- <div class="monitor-box">
|
|
|
- <deviceWarn />
|
|
|
+ <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,8 +81,9 @@
|
|
|
import workMonitor from './components/work-monitor.vue';
|
|
|
import deviceWarn from './components/device-warn.vue';
|
|
|
import { useGlobSetting } from '/@/hooks/setting';
|
|
|
+ import { onUnmounted } from 'vue';
|
|
|
+ import DeviceMonitor from '../../monitorManager/deviceMonitor/index.vue'
|
|
|
|
|
|
-
|
|
|
let navList = reactive([
|
|
|
{ name: '总风量(m³/min)', isShow: true, valList: [{ val: '2' }, { val: '1' }, { val: '3' }, { val: '3' }, { val: '0' }] },
|
|
|
{ name: '总阻力(Pa)', isShow: true, valList: [{ val: '0' }, { val: '2' }, { val: '4' }, { val: '6' }, { val: '3' }] },
|
|
@@ -89,23 +95,36 @@
|
|
|
const globSetting = useGlobSetting();
|
|
|
const openQianKun = globSetting.openQianKun;
|
|
|
let actions;
|
|
|
- if (openQianKun == 'true') {
|
|
|
- actions = getActions();
|
|
|
- actions.setGlobalState({ isMounted: false });
|
|
|
- actions.onGlobalStateChange((newState, prev) => {
|
|
|
- for (const key in newState) {
|
|
|
- if (key === 'isMounted') {
|
|
|
- if (newState[key] !== prev[key] && newState[key] === true) {
|
|
|
- loading.value = false;
|
|
|
- console.log('首页已经渲染完毕');
|
|
|
-
|
|
|
- }
|
|
|
- }
|
|
|
+
|
|
|
+ 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;`)
|
|
|
}
|
|
|
- });
|
|
|
+ }
|
|
|
}
|
|
|
-
|
|
|
onMounted(() => {
|
|
|
+ changeModalBox()
|
|
|
const renderModal = () => {
|
|
|
const element = document.getElementById('__qiankun_microapp_wrapper_for_micro_vent_3_d_modal__')
|
|
|
if(element){
|
|
@@ -118,6 +137,8 @@
|
|
|
}
|
|
|
renderModal()
|
|
|
})
|
|
|
+ onUnmounted(() => {
|
|
|
+ })
|
|
|
</script>
|
|
|
|
|
|
<style lang="less" scoped>
|
|
@@ -132,6 +153,7 @@
|
|
|
.home-container {
|
|
|
width: 100%;
|
|
|
height: 100%;
|
|
|
+ position: relative;
|
|
|
.header {
|
|
|
width: 100%;
|
|
|
height: 76px;
|