lxh 1 год назад
Родитель
Сommit
2deefecd00

+ 66 - 0
src/views/vent/monitorManager/compressor/components/modal.vue

@@ -0,0 +1,66 @@
+<template>
+  <a-modal v-model:visible="visible" :title="title" @ok="handleOk" @cancel="handleCancel">
+    <div class="modal-container">
+      <div class="vent-flex-row">
+        <ExclamationCircleFilled style="color: #ffb700; font-size: 30px" />
+        <div class="warning-text">您是否要进行{{ title }}操作?</div>
+      </div>
+      <div class="vent-flex-row input-box">
+        <div class="label">操作密码:</div>
+        <a-input size="small" type="password" v-model:value="passWord" />
+      </div>
+    </div>
+  </a-modal>
+</template>
+<script setup lang="ts">
+  import { watch, ref } from 'vue';
+  import { ExclamationCircleFilled } from '@ant-design/icons-vue';
+
+  const props = defineProps({
+    modalIsShow: {
+      type: Boolean,
+      default: false,
+    },
+    modalTitle: {
+      type: String,
+      default: '',
+    },
+    modalType: {
+      type: String,
+      default: '',
+    },
+  });
+
+  const emit = defineEmits(['handleOk', 'handleCancel']);
+
+  const visible = ref<Boolean>(false);
+  const title = ref<String>('');
+  const type = ref<String>('');
+  const passWord = ref('');
+
+  watch([() => props.modalIsShow, () => props.modalTitle, () => props.modalType], ([newVal, newModalTitle, newModalType]) => {
+    visible.value = newVal;
+    if (newModalTitle) title.value = newModalTitle;
+    if (newModalType) type.value = newModalType;
+    passWord.value = '';
+  });
+
+  function handleOk() {
+    //
+    emit('handleOk', passWord.value, type.value);
+  }
+  function handleCancel() {
+    //
+    emit('handleCancel');
+  }
+</script>
+<style scoped lang="less">
+  @ventSpace: zxm;
+
+  .label {
+    width: 80px;
+  }
+  .@{ventSpace}-input {
+    width: 150px;
+  }
+</style>

+ 580 - 557
src/views/vent/monitorManager/compressor/components/nitrogenHome1.vue

@@ -1,6 +1,9 @@
 <template>
-  <div id="nitrogenCss3D" class="threejs-Object-CSS"
-    style="width: 100%; height: 100%; position: absolute; pointer-events: none; overflow: hidden; z-index: 2; top: 0px; left: 0px">
+  <div
+    id="nitrogenCss3D"
+    class="threejs-Object-CSS"
+    style="width: 100%; height: 100%; position: absolute; pointer-events: none; overflow: hidden; z-index: 2; top: 0px; left: 0px"
+  >
     <a-spin :spinning="loading" />
     <template>
       <div v-for="groupNum in monitorDataGroupNum" :key="groupNum" class="modal-monitor">
@@ -8,37 +11,45 @@
           <div class="title">{{ monitorData[groupNum - 1]['strname'] }} </div>
           <div class="monitor-item">
             <span class="monitor-title">排气压力:</span>
-            <span class="monitor-val"><span class="val">{{ monitorData[groupNum - 1]['AirCompressor_ExhaustPre'] ?
-              monitorData[groupNum - 1]['AirCompressor_ExhaustPre'] : '-' }}</span><span class="unit">kPa</span></span>
+            <span class="monitor-val"
+              ><span class="val">{{
+                monitorData[groupNum - 1]['AirCompressor_ExhaustPre'] ? monitorData[groupNum - 1]['AirCompressor_ExhaustPre'] : '-'
+              }}</span
+              ><span class="unit">kPa</span></span
+            >
           </div>
           <div class="monitor-item">
             <span class="monitor-title">累计流量:</span>
-            <span class="monitor-val"><span class="val">{{ monitorData[groupNum - 1]['FluxTotal1'] ?
-              monitorData[groupNum - 1]['FluxTotal1'] : '-' }}</span><span class="unit">m³/h</span></span>
+            <span class="monitor-val"
+              ><span class="val">{{ monitorData[groupNum - 1]['FluxTotal1'] ? monitorData[groupNum - 1]['FluxTotal1'].toFixed(2) : '-' }}</span
+              ><span class="unit">m³/h</span></span
+            >
           </div>
           <div class="monitor-item">
             <span class="monitor-title">氮气纯度:</span>
-            <span class="monitor-val"><span class="val">{{ monitorData[groupNum - 1]['NitrogenPurity'] ?
-              monitorData[groupNum - 1]['NitrogenPurity'] : '-' }}</span><span class="unit">%</span></span>
+            <span class="monitor-val"
+              ><span class="val">{{ monitorData[groupNum - 1]['NitrogenPurity'] ? monitorData[groupNum - 1]['NitrogenPurity'].toFixed(2) : '-' }}</span
+              ><span class="unit">%</span></span
+            >
           </div>
           <div class="monitor-item">
             <span class="monitor-title">运行时间:</span>
-            <span class="monitor-val"><span class="val">{{ monitorData[groupNum - 1]['AirCompressor_RunTime'] ?
-              monitorData[groupNum - 1]['AirCompressor_RunTime'] : '-' }}</span><span class="unit">-</span></span>
+            <span class="monitor-val"
+              ><span class="val">{{
+                monitorData[groupNum - 1]['AirCompressor_RunTime'] ? monitorData[groupNum - 1]['AirCompressor_RunTime'] : '-'
+              }}</span
+              ><span class="unit">-</span></span
+            >
           </div>
           <div class="monitor-item">
             <span class="monitor-title">加载时间:</span>
-            <span class="monitor-val"><span class="val">{{ monitorData[groupNum - 1]['AirCompressor_LoadTime'] ?
-              monitorData[groupNum - 1]['AirCompressor_LoadTime'] : '-' }}</span><span class="unit">-</span></span>
+            <span class="monitor-val"
+              ><span class="val">{{
+                monitorData[groupNum - 1]['AirCompressor_LoadTime'] ? monitorData[groupNum - 1]['AirCompressor_LoadTime'] : '-'
+              }}</span
+              ><span class="unit">-</span></span
+            >
           </div>
-          <!-- <div class="signal-item">
-            <div class="signal"><span class="monitor-title">运行时间:</span><span
-                :class="{ 'signal-round': true, 'signal-round-run': monitorData[groupNum - 1]['AirCompressor_RunTime'], 'signal-round-gry': !monitorData[groupNum - 1]['AirCompressor_RunTime'] }"></span>
-            </div>
-            <div class="signal"><span class="monitor-title">加载时间:</span><span
-                :class="{ 'signal-round': true, 'signal-round-run': monitorData[groupNum - 1]['AirCompressor_LoadTime'], 'signal-round-gry': !monitorData[groupNum - 1]['AirCompressor_LoadTime'] }"></span>
-            </div>
-          </div> -->
         </fourBorderBg>
       </div>
     </template>
@@ -53,7 +64,6 @@
             <ventBox1>
               <template #title>
                 <div>{{ monitorData[groupNum - 1]['strname'] }}</div>
-                <!-- <div style="position: absolute;right:10px;font-size: 10px;color:#3fe4fc;cursor: pointer;" @click="getDetail(groupNum - 1)">查看详情>></div> -->
               </template>
               <template #container>
                 <div class="monitor-box">
@@ -63,15 +73,19 @@
                   <div class="state-item" v-for="(data, index) in groupParameterData" :key="index">
                     <div class="item-col">
                       <span class="state-title">{{ Object.values(data)[0] }} :</span>
-                      <span class="state-val">{{ (monitorData.length > 0 && monitorData[groupNum -
-                        1][Object.keys(data)[0]])
-                        >= 0 ? monitorData[groupNum - 1][Object.keys(data)[0]] : '-' }}</span>
+                      <span class="state-val">{{
+                        (monitorData.length > 0 && monitorData[groupNum - 1][Object.keys(data)[0]]) >= 0
+                          ? monitorData[groupNum - 1][Object.keys(data)[0]].toFixed(2)
+                          : '-'
+                      }}</span>
                     </div>
                     <div class="item-col" v-if="Object.keys(data)[1]">
                       <span class="state-title">{{ Object.values(data)[1] }} :</span>
-                      <span class="state-val">{{ (monitorData.length > 0 && monitorData[groupNum -
-                        1][Object.keys(data)[1]])
-                        >= 0 ? monitorData[groupNum - 1][Object.keys(data)[1]] : '-' }}</span>
+                      <span class="state-val">{{
+                        (monitorData.length > 0 && monitorData[groupNum - 1][Object.keys(data)[1]]) >= 0
+                          ? monitorData[groupNum - 1][Object.keys(data)[1]].toFixed(2)
+                          : '-'
+                      }}</span>
                     </div>
                   </div>
                 </div>
@@ -82,15 +96,19 @@
                   <div class="state-item" v-for="(data, index) in deviceParameterData" :key="index">
                     <div class="item-col">
                       <span class="state-title">{{ Object.values(data)[0] }} :</span>
-                      <span class="state-val">{{ (monitorData.length > 0 && monitorData[groupNum -
-                        1][Object.keys(data)[0]])
-                        >= 0 ? monitorData[groupNum - 1][Object.keys(data)[0]] : '-' }}</span>
+                      <span class="state-val">{{
+                        (monitorData.length > 0 && monitorData[groupNum - 1][Object.keys(data)[0]]) >= 0
+                          ? monitorData[groupNum - 1][Object.keys(data)[0]]
+                          : '-'
+                      }}</span>
                     </div>
                     <div class="item-col" v-if="Object.keys(data)[1]">
                       <span class="state-title">{{ Object.values(data)[1] }} :</span>
-                      <span class="state-val">{{ (monitorData.length > 0 && monitorData[groupNum -
-                        1][Object.keys(data)[1]])
-                        >= 0 ? monitorData[groupNum - 1][Object.keys(data)[1]] : '-' }}</span>
+                      <span class="state-val">{{
+                        (monitorData.length > 0 && monitorData[groupNum - 1][Object.keys(data)[1]]) >= 0
+                          ? monitorData[groupNum - 1][Object.keys(data)[1]]
+                          : '-'
+                      }}</span>
                     </div>
                   </div>
                 </div>
@@ -106,32 +124,19 @@
             </template>
             <template #container>
               <div class="control-group">
-                <div class="control-item" v-for="groupNum in monitorDataGroupNum" :key="groupNum">
+                <div class="control-item" v-for="(groupNum, index) in monitorDataGroupNum" :key="groupNum">
                   <div class="control-item-title">{{ monitorData[groupNum - 1]['strname'] }}</div>
                   <div class="control-item-state">
-                    <a-switch v-model="airCompressorState[groupNum - 1][`compressRunSigF1`]" size="small"
-                      checked-children="开启" un-checked-children="关闭"
+                    <a-switch
+                      v-model="airCompressorState[groupNum - 1][`compressRunSigF1`]"
+                      size="small"
+                      checked-children="开启"
+                      un-checked-children="关闭"
                       :disabled="airCompressorState[groupNum - 1][`controlModel`]"
-                      @change="handlerDevice(airCompressorState[groupNum - 1])">
-                    </a-switch>
+                      @change="handlerDevice(airCompressorState[groupNum - 1], index)"
+                    />
                   </div>
                 </div>
-                <!-- <div class="control-item" v-for="groupNum in monitorDataGroupNum" :key="groupNum">
-                  <div class="control-item-title">{{ kyjs[groupNum - 1] }}</div>
-                  <div class="control-item-state">
-                    <a-switch v-model="airCompressorState[groupNum - 1][`compressRunSigF1`]" size="small"
-                      checked-children="开启" un-checked-children="关闭"
-                      :disabled="airCompressorState[groupNum - 1][`controlModel`]"
-                      @change="handlerDevice(airCompressorState[groupNum - 1])">
-                    </a-switch>
-                  </div>
-                </div> -->
-                <!-- <div class="control-item">
-                  <div class="control-item-title">是否开启联动</div>
-                  <div class="control-item-state">
-                    <a-radio v-model:checked="isLink">开启</a-radio>
-                  </div>
-                </div> -->
               </div>
             </template>
           </ventBox1>
@@ -140,623 +145,641 @@
               <div>设备实时监测曲线</div>
             </template>
             <template #container>
-              <BarAndLineCustom xAxisPropType="readTime" :chartData="echartData" height="240px"
-                :propTypeArr="['FluxTotal1','InputFlux']" :option="zhudanOption" />
+              <BarAndLineCustom
+                xAxisPropType="readTime"
+                :chartData="echartData"
+                height="240px"
+                :propTypeArr="['FluxTotal1', 'InputFlux']"
+                :option="zhudanOption"
+              />
             </template>
           </ventBox1>
-          <!-- <div class="vent-margin-t-10">
-            <LivePlayer id="fm-player1" style="height: 250px;" ref="player1" :videoUrl="flvURL1()" muted live loading
-              controls />
-          </div> -->
         </div>
       </div>
     </div>
   </div>
-  <!-- <DetailModal @register="registerModal" /> -->
+  <HandleModal :modal-is-show="modalIsShow" :modal-title="modalTitle" :modal-type="modalType" @handle-ok="handleOK" @handle-cancel="handleCancel" />
 </template>
 <script lang="ts" setup name="nitrogenHome">
-import { onMounted, onUnmounted, ref, watch, reactive, defineProps, nextTick} from 'vue'
-import ventBox1 from '/@/components/vent/ventBox1.vue'
-import fourBorderBg from '../../../comment/components/fourBorderBg.vue'
-import { mountedThree, destroy, setModelType } from '../nitrogen.threejs'
-import { getDevice } from '../nitrogen.api'
-import { SvgIcon } from '/@/components/Icon'
-// import LivePlayer from '@liveqing/liveplayer-v3';
-import BarAndLineCustom from '/@/components/chart/BarAndLineCustom.vue';
-import { zhudanOption } from '../nitrogen.data.ts'
-
-
-// import DetailModal from './DetailModal.vue';
-// import { useModal } from '/@/components/Modal';
-
-const props = defineProps({
-  deviceId: {
-    type: String,
-    require: true
-  },
-  modalType: {
-    type: String,
-    require: true
-  }
-})
-const loading = ref(true)
-const isLink = ref(true)
-const isRefresh = ref(true)
-
-const zdjs = ['1号制氮机', '2号制氮机', '3号制氮机', '4号制氮机'];
-// const kyjs = ['1号空压机', '1号空压机', '1号空压机', '1号空压机'];
-
-const flvURL1 = () => {
-  // return `https://sf1-hscdn-tos.pstatp.com/obj/media-fe/xgplayer_doc_video/flv/xgplayer-demo-360p.flv`;
-  return ''
-};
-
-const monitorDataGroupNum = ref(0);
-
-let airCompressorState = reactive<any[]>([]);
-
-const groupParameterData = [
-  {
-    FluxTotal1: '累计流量',
-    InputFlux: '瞬时流量',
-  },
-  {
-    PreMembraneTemperature: '膜前温度(­°C)',
-    NitrogenPurity: '氮气纯度(%)',
-  },
-];
-const deviceParameterData = [
-  {
-    AirCompressor_ExhaustPre: '排气压力(KPa)',
-    AirCompressor_ExhaustTemp: '排气温度(­°C)',
-  },
-  {
-    AirCompressor_RunTime: '运行时间',
-    AirCompressor_LoadTime: '加载时间',
-  },
-
-
-];
-
-const monitorData = ref(new Array(3).fill({
-  // strName: '空压机',
-  // cumulativeFlow: '-',
-  // centerTemperature: '-',
-  // outletTemperature: '-',
-  // Ia: '-',
-  // Ib: '-',
-  // Ic: '-',
-  // Vab: '-',
-  // Vac: '-',
-  // Vbc: '-',
-  // compressGroupName: '',
-  // compressExhaustPressF1: '-',
-  // compressSeparatePressF1: '-',
-  // compressHostTempF1: '-',
-  // compressCrewTempF1: '-',
-  // compressRunTimeF1: '-',
-  // controlModel: 'LOC'
-}));
-
-//图表数据
-let echartData=reactive<any>([])
-
-
-// //详情弹框
-// const [registerModal, { openModal, closeModal }] = useModal();
-//查看详情
-// function getDetail(ind) {
-//   console.log(ind,'激活详情索引')
-//   switch(ind){
-//     case 0:
-
-//     openModal()
-//       break;
-//   }
-// }
-// https获取监测数据
-let timer: null | NodeJS.Timeout = null;
-async function getMonitor(flag?) {
-  if (Object.prototype.toString.call(timer) === '[object Null]') {
-    timer = await setTimeout(async () => {
-      if (props.deviceId) {
-        await getDataSource(props.deviceId)
-      }
-      if (timer) {
-        timer = null;
-      }
-      await getMonitor();
-    }, flag ? 0 : 3000);
-  }
-};
-
-async function getDataSource(systemID) {
-  const res = await getDevice({ devicetype: 'sys', systemID, type: 'all' });
-  console.log(res,'res---------------')
-  if (res) {
-    const result = res;
-    if (!result || result.msgTxt.length < 1) return
-    result.msgTxt.forEach(item => {
-      if (item.typeName.indexOf('制氮机')!=-1) {
-        monitorData.value = item['datalist'].filter((data) => {
-          const item = data.readData;
-          return Object.assign(data, item);
-        });
-        //图表数据
-          if(echartData.length<=5){
-            monitorData.value.forEach(el=>{
-              echartData.push(el)
-            })
-          }
-
-        airCompressorState.length = 0
-        item['datalist'].forEach(v => {
-          airCompressorState.push({
-            id: v.deviceID,
-            compressRunSigF1: false,
-            controlModel: false
-          })
-        })
-      }
+  import { onMounted, onUnmounted, ref, watch, reactive, defineProps, nextTick } from 'vue';
+  import ventBox1 from '/@/components/vent/ventBox1.vue';
+  import fourBorderBg from '../../../comment/components/fourBorderBg.vue';
+  import { mountedThree, destroy, setModelType } from '../nitrogen.threejs';
+  import { getDevice } from '../nitrogen.api';
+  import { SvgIcon } from '/@/components/Icon';
+  import BarAndLineCustom from '/@/components/chart/BarAndLineCustom.vue';
+  import { zhudanOption } from '../nitrogen.data.ts';
+  import HandleModal from './modal.vue';
+  import { deviceControlApi } from '/@/api/vent/index';
+  import { message } from 'ant-design-vue';
+
+  const props = defineProps({
+    deviceId: {
+      type: String,
+      require: true,
+    },
+    modalType: {
+      type: String,
+      require: true,
+    },
+  });
+  const modalTitle = ref(''); // 模态框标题显示内容,根据设备操作类型决定
+  const modalType = ref(''); // 模态框内容显示类型,设备操作类型
+  const modalIsShow = ref<boolean>(false); // 是否显示模态框
+  const loading = ref(true);
+  let kzParam = reactive<any>({
+    data: {},
+    activeIndex: 0,
+  });
+  // const kyjs = ['1号空压机', '1号空压机', '1号空压机', '1号空压机'];
+
+  const flvURL1 = () => {
+    // return `https://sf1-hscdn-tos.pstatp.com/obj/media-fe/xgplayer_doc_video/flv/xgplayer-demo-360p.flv`;
+    return '';
+  };
+
+  const monitorDataGroupNum = ref(0);
+
+  let airCompressorState = reactive<any[]>([]);
+
+  const groupParameterData = [
+    {
+      FluxTotal1: '累计流量',
+      InputFlux: '瞬时流量',
+    },
+    {
+      PreMembraneTemperature: '膜前温度(­°C)',
+      NitrogenPurity: '氮气纯度(%)',
+    },
+  ];
+  const deviceParameterData = [
+    {
+      AirCompressor_ExhaustPre: '排气压力(KPa)',
+      AirCompressor_ExhaustTemp: '排气温度(­°C)',
+    },
+    {
+      AirCompressor_RunTime: '运行时间',
+      AirCompressor_LoadTime: '加载时间',
+    },
+  ];
+
+  const monitorData = ref(
+    new Array(3).fill({
+      // strName: '空压机',
+      // cumulativeFlow: '-',
+      // centerTemperature: '-',
+      // outletTemperature: '-',
+      // Ia: '-',
+      // Ib: '-',
+      // Ic: '-',
+      // Vab: '-',
+      // Vac: '-',
+      // Vbc: '-',
+      // compressGroupName: '',
+      // compressExhaustPressF1: '-',
+      // compressSeparatePressF1: '-',
+      // compressHostTempF1: '-',
+      // compressCrewTempF1: '-',
+      // compressRunTimeF1: '-',
+      // controlModel: 'LOC'
     })
-    console.log(echartData,'echart----------')
-    monitorDataGroupNum.value = monitorData.value.length
+  );
+
+  //图表数据
+  let echartData = reactive<any>([]);
+
+  // https获取监测数据
+  let timer: null | NodeJS.Timeout = null;
+  async function getMonitor(flag?) {
+    if (Object.prototype.toString.call(timer) === '[object Null]') {
+      timer = await setTimeout(
+        async () => {
+          if (props.deviceId) {
+            await getDataSource(props.deviceId);
+          }
+          if (timer) {
+            timer = null;
+          }
+          await getMonitor();
+        },
+        flag ? 0 : 3000
+      );
+    }
   }
-};
 
-function handlerDevice(data) {
-
-  // if (data.length < 1) return
-  // handleAirCompressor({ id: data.id, compressRunF1: data.compressRunSigF1 }).then(res => {
-  //   if (res.success) {
-  //     message.success('操作成功')
-  //   } else {
-  //     message.warning(data.msg)
-  //   }
-  // })
-};
-function resetDevice(data) {
-
-}
-
-function handlerControlModel(data) {
+  async function getDataSource(systemID) {
+    const res = await getDevice({ devicetype: 'sys', systemID, type: 'all' });
+    console.log(res, 'res---------------');
+    if (res) {
+      const result = res;
+      if (!result || result.msgTxt.length < 1) return;
+      result.msgTxt.forEach((item) => {
+        if (item.typeName.indexOf('制氮机') != -1) {
+          monitorData.value = item['datalist'].filter((data) => {
+            const item = data.readData;
+            return Object.assign(data, item);
+          });
+          //图表数据
+          if (echartData.length <= 5) {
+            monitorData.value.forEach((el) => {
+              echartData.push(el);
+            });
+          }
 
-}
+          airCompressorState.length = 0;
+          item['datalist'].forEach((v) => {
+            airCompressorState.push({
+              id: v.deviceID,
+              deviceType:v.deviceType,
+              compressRunSigF1: false,
+              controlModel: false,
+            });
+          });
+        }
+      });
+      console.log(echartData, 'echart----------');
+      monitorDataGroupNum.value = monitorData.value.length;
+    }
+  }
 
-watch([monitorDataGroupNum, loading], ([newMonitorDataGroupNum, newLoading]) => {
-  nextTick(() => {
-    if (newMonitorDataGroupNum && !newLoading) {
-      setModelType(props.modalType, newMonitorDataGroupNum)
+  function handlerDevice(data, index) {
+    kzParam.data = data;
+    kzParam.activeIndex = index;
+    if (index == 1) {
+      modalTitle.value = '一键复位';
+      modalType.value = '1';
+      modalIsShow.value = true;
+      kzParam.data.compressRunSigF1 = !kzParam.data.compressRunSigF1;
+    } else {
+      modalTitle.value = '一键启停';
+      modalType.value = '2';
+      modalIsShow.value = true;
+      kzParam.data.compressRunSigF1 = !kzParam.data.compressRunSigF1;
     }
-  })
-})
-
-
-onMounted(async () => {
-  await getMonitor(true)
-  await mountedThree().then(() => {
-    loading.value = false
-  })
-})
-
-onUnmounted(() => {
-  destroy();
-  if (timer) {
-    clearTimeout(timer);
-    timer = undefined;
   }
-});
+  function handleOK(passWord, handlerState) {
+    console.log(kzParam, 'kz----------');
+    // if (passWord !== '123456') {
+    //   message.warning('密码不正确,请重新输入');
+    //   return;
+    // }
+
+    let data = {};
+    if (kzParam.activeIndex == 1) {
+      data = {
+        deviceid: kzParam.data.id,
+        devicetype:kzParam.data.deviceType,
+        password: passWord,
+        HMIReset: kzParam.data.compressRunSigF1,
+      };
+    } else {
+      data = {
+        deviceid: kzParam.data.id,
+        password: passWord,
+        devicetype:kzParam.data.deviceType,
+        HMIStartStop: kzParam.data.compressRunSigF1,
+      };
+    }
 
+    deviceControlApi(data).then((res) => {
+      // 模拟时开启
+      if (res.success) {
+        modalIsShow.value = false;
+        getDataSource(props.deviceId);
+        message.success('操作成功!');
+      }
+    });
+  }
+  function handleCancel() {
+    modalIsShow.value = false;
+    modalTitle.value = '';
+    modalType.value = '';
+  }
+
+  watch([monitorDataGroupNum, loading], ([newMonitorDataGroupNum, newLoading]) => {
+    nextTick(() => {
+      if (newMonitorDataGroupNum && !newLoading) {
+        setModelType(props.modalType, newMonitorDataGroupNum);
+      }
+    });
+  });
+
+  onMounted(async () => {
+    await getMonitor(true);
+    await mountedThree().then(() => {
+      loading.value = false;
+    });
+  });
+
+  onUnmounted(() => {
+    destroy();
+    if (timer) {
+      clearTimeout(timer);
+      timer = undefined;
+    }
+  });
 </script>
 
 <style lang="less" scoped>
-@ventSpace: zxm;
-
-.nitrogen-box {
-  width: 100%;
-  height: 100%;
-  display: flex;
-  justify-content: center;
-}
-
-#nitrogenCss3D {
-  .modal-monitor {
-    width: 200px;
-    position: absolute;
-    left: 0px;
-    top: 0px;
+  @ventSpace: zxm;
 
+  .nitrogen-box {
+    width: 100%;
+    height: 100%;
+    display: flex;
+    justify-content: center;
   }
 
-  &:deep(.win) {
-    margin: 0 !important;
-    background: #00000044;
+  #nitrogenCss3D {
+    .modal-monitor {
+      width: 200px;
+      position: absolute;
+      left: 0px;
+      top: 0px;
+    }
+
+    &:deep(.win) {
+      margin: 0 !important;
+      background: #00000044;
+    }
   }
 
-}
-
-.nitrogen-home {
-  width: 100%;
-  height: 100%;
-  position: fixed;
-  z-index: 9999;
-  display: flex;
-  flex-direction: column;
-  justify-content: center;
-  align-items: center;
-  pointer-events: none;
-  top: 60px;
-
-  .nitrogen-container {
+  .nitrogen-home {
     width: 100%;
-    height: calc(100%);
+    height: 100%;
+    position: fixed;
+    z-index: 9999;
     display: flex;
-    justify-content: space-between;
-    margin-bottom: 100px;
+    flex-direction: column;
+    justify-content: center;
+    align-items: center;
+    pointer-events: none;
+    top: 60px;
 
-    .top-box {
+    .nitrogen-container {
       width: 100%;
-      padding: 10px;
-      overflow: hidden;
+      height: calc(100%);
       display: flex;
       justify-content: space-between;
+      margin-bottom: 100px;
 
-      .lr-box {
-        height: fit-content;
-        display: flex;
-        flex-direction: column;
-        position: relative;
-        overflow: hidden;
-        z-index: 9999;
-        pointer-events: auto;
-      }
-
-      .item {
-        width: 335px;
-        height: auto;
-        position: relative;
-        border-radius: 5px;
-        margin-top: 10px;
-        margin-bottom: 0px;
-        pointer-events: auto;
-        color: #fff;
+      .top-box {
+        width: 100%;
+        padding: 10px;
         overflow: hidden;
+        display: flex;
+        justify-content: space-between;
 
-        &:first-child {
-          margin-top: 0px;
+        .lr-box {
+          height: fit-content;
+          display: flex;
+          flex-direction: column;
+          position: relative;
+          overflow: hidden;
+          z-index: 9999;
+          pointer-events: auto;
         }
 
-        .base-title {
-          color: #fff;
-          margin-bottom: 8px;
-          padding-left: 10px;
+        .item {
+          width: 335px;
+          height: auto;
           position: relative;
-          font-size: 16px;
-
-          &::after {
-            content: '';
-            position: absolute;
-            display: block;
-            width: 4px;
-            height: 12px;
-            top: 7px;
-            left: 0px;
-            background: #45d3fd;
-            border-radius: 4px;
-          }
-        }
+          border-radius: 5px;
+          margin-top: 10px;
+          margin-bottom: 0px;
+          pointer-events: auto;
+          color: #fff;
+          overflow: hidden;
 
-        .state-item {
-          display: flex;
-          flex-direction: row;
-          padding: 5px;
+          &:first-child {
+            margin-top: 0px;
+          }
 
-          .item-col {
-            width: calc(50% - 5px);
-            display: flex;
-            justify-content: center;
-            align-items: center;
-            padding-right: 4px;
-            background-image: linear-gradient(to right, #39A3FF00, #39A3FF10);
+          .base-title {
+            color: #fff;
+            margin-bottom: 8px;
+            padding-left: 10px;
+            position: relative;
+            font-size: 16px;
 
-            &:first-child {
-              margin-right: 10px;
+            &::after {
+              content: '';
+              position: absolute;
+              display: block;
+              width: 4px;
+              height: 12px;
+              top: 7px;
+              left: 0px;
+              background: #45d3fd;
+              border-radius: 4px;
             }
+          }
 
-            .state-title {
-              color: #ffffffcc;
-              flex: 9;
-              font-size: 14px;
-            }
+          .state-item {
+            display: flex;
+            flex-direction: row;
+            padding: 5px;
 
-            .state-val {
-              flex: 1;
-              color: #00eefffe;
-              margin-right: 5px;
-              text-align: right;
-              font-size: 14px;
+            .item-col {
+              width: calc(50% - 5px);
+              display: flex;
+              justify-content: center;
+              align-items: center;
+              padding-right: 4px;
+              background-image: linear-gradient(to right, #39a3ff00, #39a3ff10);
+
+              &:first-child {
+                margin-right: 10px;
+              }
+
+              .state-title {
+                color: #ffffffcc;
+                flex: 9;
+                font-size: 14px;
+              }
+
+              .state-val {
+                flex: 1;
+                color: #00eefffe;
+                margin-right: 5px;
+                text-align: right;
+                font-size: 14px;
+              }
             }
           }
-        }
 
-        .signal-box {
-          margin: 5px 0;
-          display: flex;
-          align-items: center;
+          .signal-box {
+            margin: 5px 0;
+            display: flex;
+            align-items: center;
 
-          .signal-title {
-            color: #7AF5FF;
-            margin: 0 5px;
-          }
+            .signal-title {
+              color: #7af5ff;
+              margin: 0 5px;
+            }
 
-          &:last-child {
-            margin-right: 0px;
+            &:last-child {
+              margin-right: 0px;
+            }
           }
-        }
 
-        .list-item {
-          padding: 0 10px;
-          display: flex;
-          justify-content: space-between;
-          align-items: center;
+          .list-item {
+            padding: 0 10px;
+            display: flex;
+            justify-content: space-between;
+            align-items: center;
 
-          .item-data-key {
-            color: #ffffff99;
+            .item-data-key {
+              color: #ffffff99;
+            }
           }
-        }
 
-        .item-data-box {
-          color: #fff;
+          .item-data-box {
+            color: #fff;
 
-          .state-icon {
-            display: inline-block;
-            width: 12px;
-            height: 12px;
-            border-radius: 12px;
-          }
+            .state-icon {
+              display: inline-block;
+              width: 12px;
+              height: 12px;
+              border-radius: 12px;
+            }
 
-          .open {
-            border: 5px solid #133a56;
-            background: #4ecb73;
-          }
+            .open {
+              border: 5px solid #133a56;
+              background: #4ecb73;
+            }
 
-          .close {
-            border: 5px solid #192961;
-            background: #6d7898;
+            .close {
+              border: 5px solid #192961;
+              background: #6d7898;
+            }
           }
         }
-      }
 
-      .item-l {
-        width: 100%;
-
-        .monitor-box {
+        .item-l {
           width: 100%;
 
-          .parameter-title {
-            position: relative;
+          .monitor-box {
             width: 100%;
-            height: 14px;
-            margin-top: 10px;
 
-            .icon,
-            span {
-              position: absolute;
-              top: -10px;
+            .parameter-title {
+              position: relative;
+              width: 100%;
+              height: 14px;
+              margin-top: 10px;
+
+              .icon,
+              span {
+                position: absolute;
+                top: -10px;
+              }
             }
 
-          }
+            .group-parameter-title {
+              background-image: linear-gradient(to right, #39a3ff50, #39a3ff00);
 
-          .group-parameter-title {
-            background-image: linear-gradient(to right, #39a3ff50, #39a3ff00);
+              .icon {
+                left: -12px;
+                top: -17px;
+              }
 
-            .icon {
-              left: -12px;
-              top: -17px;
-            }
+              span {
+                left: 18px;
+              }
 
-            span {
-              left: 18px;
+              .item-col {
+                background-image: linear-gradient(to right, #39a3ff00, #39a3ff10);
+              }
             }
 
-            .item-col {
-              background-image: linear-gradient(to right, #39A3FF00, #39A3FF10);
-            }
-          }
+            .device-parameter-title {
+              background-image: linear-gradient(to right, #3df6ff40, #3df6ff00);
 
-          .device-parameter-title {
-            background-image: linear-gradient(to right, #3df6ff40, #3df6ff00);
+              .icon {
+                left: -10px;
+                top: -14px;
+              }
 
-            .icon {
-              left: -10px;
-              top: -14px;
-            }
+              span {
+                left: 18px;
+              }
 
-            span {
-              left: 18px;
-            }
-
-            .item-col {
-              background-image: linear-gradient(to right, #3df6ff10, #3df6ff00);
+              .item-col {
+                background-image: linear-gradient(to right, #3df6ff10, #3df6ff00);
+              }
             }
           }
-
         }
-      }
-
-      .right-box {
-        width: 330px;
-        margin-top: 50px;
-
-        .control-group {
-          display: flex;
-          // justify-content: space-around;
-          flex-wrap: wrap;
 
-          .control-item {
+        .right-box {
+          width: 330px;
+          margin-top: 50px;
 
+          .control-group {
             display: flex;
-            flex-direction: column;
-            justify-content: center;
-            align-items: center;
-            padding: 0 4px;
+            // justify-content: space-around;
+            flex-wrap: wrap;
 
-            .control-item-title {
-              color: #A6DCE9;
-              position: relative;
-              top: 5px;
-            }
-
-            .control-item-state {
-              width: 94px;
-              height: 47px;
-              background: url('/@/assets/images/vent/control-switch-bg.png');
+            .control-item {
               display: flex;
+              flex-direction: column;
               justify-content: center;
               align-items: center;
-              color: #fff;
-            }
-
-            .button-box {
-              position: relative;
-              padding: 5px;
-              border: 1px transparent solid;
-              background-clip: border-box;
-              border-radius: 5px;
-              margin-left: 8px;
-            }
-
-            .a-button {
-              pointer-events: auto;
-            }
-
-            &::v-deep .a-button--mini {
-              padding: 6px 10px;
-            }
-
-            &::v-deep .a-button--mini.is-round {
-              padding: 6px 10px;
+              padding: 0 4px;
+
+              .control-item-title {
+                color: #a6dce9;
+                position: relative;
+                top: 5px;
+              }
+
+              .control-item-state {
+                width: 94px;
+                height: 47px;
+                background: url('/@/assets/images/vent/control-switch-bg.png');
+                display: flex;
+                justify-content: center;
+                align-items: center;
+                color: #fff;
+              }
+
+              .button-box {
+                position: relative;
+                padding: 5px;
+                border: 1px transparent solid;
+                background-clip: border-box;
+                border-radius: 5px;
+                margin-left: 8px;
+              }
+
+              .a-button {
+                pointer-events: auto;
+              }
+
+              &::v-deep .a-button--mini {
+                padding: 6px 10px;
+              }
+
+              &::v-deep .a-button--mini.is-round {
+                padding: 6px 10px;
+              }
             }
           }
+        }
 
+        .left-box {
+          width: 365px;
+          margin-top: 80px;
         }
       }
 
-      .left-box {
-        width: 365px;
-        margin-top: 80px;
+      &:deep(.win) {
+        width: 100%;
+        margin: 0 !important;
       }
     }
-
-    &:deep(.win) {
-      width: 100%;
-      margin: 0 !important;
-    }
   }
 
-}
-
-&:deep(.main) {
-  .title {
-    height: 34px;
-    text-align: center;
-    font-weight: 600;
-    color: #7AF5FF;
-    // background-image: url('../../../assets/img/yfj/light.png');
-    background-repeat: no-repeat;
-    background-position-x: center;
-    background-position-y: 100%;
-    background-size: 80%;
-    font-size: 16px;
-  }
-
-  .monitor-item {
-    width: 200px;
-    display: flex;
-    flex-direction: row;
-    width: auto;
-    margin-bottom: 3px;
+  &:deep(.main) {
+    .title {
+      height: 34px;
+      text-align: center;
+      font-weight: 600;
+      color: #7af5ff;
+      // background-image: url('../../../assets/img/yfj/light.png');
+      background-repeat: no-repeat;
+      background-position-x: center;
+      background-position-y: 100%;
+      background-size: 80%;
+      font-size: 16px;
+    }
 
-    .monitor-val {
-      color: #ffb700;
+    .monitor-item {
+      width: 200px;
       display: flex;
+      flex-direction: row;
       width: auto;
+      margin-bottom: 3px;
 
-      .val {
-        width: 80px;
-        font-size: 14px;
-      }
+      .monitor-val {
+        color: #ffb700;
+        display: flex;
+        width: auto;
 
-      .unit {
-        color: #ffffffbb;
-        font-size: 14px;
+        .val {
+          width: 80px;
+          font-size: 14px;
+        }
 
+        .unit {
+          color: #ffffffbb;
+          font-size: 14px;
+        }
       }
     }
-  }
 
-  .monitor-title {
-    width: 100px;
-    color: #7AF5FF;
-    font-weight: 400;
-    font-size: 14px;
-  }
+    .monitor-title {
+      width: 100px;
+      color: #7af5ff;
+      font-weight: 400;
+      font-size: 14px;
+    }
 
-  .signal-item {
-    display: flex;
-    justify-content: space-between;
-
-    // margin-bottom: 5px;
-    .signal-round {
-      display: inline-block;
-      width: 8px;
-      height: 8px;
-      border-radius: 50%;
-      margin: 0 10px;
-      position: relative;
-
-      &::after {
-        display: block;
-        content: '';
-        position: absolute;
-        width: 12px;
-        height: 12px;
-        top: -2px;
-        left: -2px;
+    .signal-item {
+      display: flex;
+      justify-content: space-between;
+
+      // margin-bottom: 5px;
+      .signal-round {
+        display: inline-block;
+        width: 8px;
+        height: 8px;
         border-radius: 50%;
+        margin: 0 10px;
+        position: relative;
+
+        &::after {
+          display: block;
+          content: '';
+          position: absolute;
+          width: 12px;
+          height: 12px;
+          top: -2px;
+          left: -2px;
+          border-radius: 50%;
+        }
       }
-    }
 
-    .signal-round-gry {
-      background-color: #858585;
+      .signal-round-gry {
+        background-color: #858585;
 
-      &::after {
-        background-color: #85858544;
-        box-shadow: 0 0 1px 1px #85858599;
+        &::after {
+          background-color: #85858544;
+          box-shadow: 0 0 1px 1px #85858599;
+        }
       }
-    }
 
-    .signal-round-run {
-      background-color: #67FC00;
+      .signal-round-run {
+        background-color: #67fc00;
 
-      &::after {
-        background-color: #67FC0044;
-        box-shadow: 0 0 1px 1px #c6ff77;
+        &::after {
+          background-color: #67fc0044;
+          box-shadow: 0 0 1px 1px #c6ff77;
+        }
       }
-    }
 
-    .signal-round-warning {
-      background-color: #E9170B;
+      .signal-round-warning {
+        background-color: #e9170b;
 
-      &::after {
-        background-color: #E9170B44;
-        box-shadow: 0 0 1px 1px #E9170B;
+        &::after {
+          background-color: #e9170b44;
+          box-shadow: 0 0 1px 1px #e9170b;
+        }
       }
     }
   }
-}
 
-:deep(.zxm-radio-wrapper) {
-  color: #fff !important;
-}
+  :deep(.zxm-radio-wrapper) {
+    color: #fff !important;
+  }
 </style>