|  | @@ -0,0 +1,960 @@
 | 
											
												
													
														|  | 
 |  | +<template>
 | 
											
												
													
														|  | 
 |  | +  <div id="nitrogen3D" style="width: 100%; height: 100%; position: absolute; overflow: hidden"></div>
 | 
											
												
													
														|  | 
 |  | +  <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" />
 | 
											
												
													
														|  | 
 |  | +    <div v-for="groupNum in monitorDataGroupNum" :key="groupNum" class="modal-monitor">
 | 
											
												
													
														|  | 
 |  | +      <fourBorderBg :class="`kyj${groupNum}`" :id="`nitrogenMonitor${groupNum}`">
 | 
											
												
													
														|  | 
 |  | +        <div class="title">空压机{{ groupNum }} </div>
 | 
											
												
													
														|  | 
 |  | +        <template v-for="(preMonitor, preMonitorIndex) in preMonitorList" :key="preMonitorIndex">
 | 
											
												
													
														|  | 
 |  | +          <div v-if="preMonitor.code !== 'signal'" class="monitor-item">
 | 
											
												
													
														|  | 
 |  | +            <span class="monitor-title">{{ preMonitor.title }}:</span>
 | 
											
												
													
														|  | 
 |  | +            <span class="monitor-val"
 | 
											
												
													
														|  | 
 |  | +              ><span class="val">{{ monitorData[preMonitor.code + groupNum] ? formatNum(monitorData[preMonitor.code + groupNum]) : '-' }}</span
 | 
											
												
													
														|  | 
 |  | +              ><span class="unit">{{ preMonitor.unit }}</span></span
 | 
											
												
													
														|  | 
 |  | +            >
 | 
											
												
													
														|  | 
 |  | +          </div>
 | 
											
												
													
														|  | 
 |  | +          <div v-else class="signal-item">
 | 
											
												
													
														|  | 
 |  | +            <div class="signal" v-for="(signal, childIndex) in preMonitor.child" :key="childIndex">
 | 
											
												
													
														|  | 
 |  | +              <span class="monitor-title">{{ signal.title }}</span>
 | 
											
												
													
														|  | 
 |  | +              <span style="display: inline-block; width: 30px; text-align: center" v-if="signal.isFault == -2">{{
 | 
											
												
													
														|  | 
 |  | +                monitorData[signal.code + groupNum] == '0' ? '就地' : monitorData[signal.code + groupNum] == '1' ? '远程' : '-'
 | 
											
												
													
														|  | 
 |  | +              }}</span>
 | 
											
												
													
														|  | 
 |  | +              <span style="display: inline-block; width: 30px; text-align: center" v-else-if="signal.isFault == -1">{{
 | 
											
												
													
														|  | 
 |  | +                monitorData[signal.code + groupNum] == '1' ? '加载' : monitorData[signal.code + groupNum] == '0' ? '卸载' : '-'
 | 
											
												
													
														|  | 
 |  | +              }}</span>
 | 
											
												
													
														|  | 
 |  | +              <span
 | 
											
												
													
														|  | 
 |  | +                v-else
 | 
											
												
													
														|  | 
 |  | +                :class="{
 | 
											
												
													
														|  | 
 |  | +                  'signal-round': true,
 | 
											
												
													
														|  | 
 |  | +                  'signal-round-run': !signal.isFault && monitorData[signal.code + groupNum] == '1',
 | 
											
												
													
														|  | 
 |  | +                  'signal-round-warning': signal.isFault && monitorData[signal.code + groupNum] == '1',
 | 
											
												
													
														|  | 
 |  | +                  'signal-round-gry': monitorData[signal.code + groupNum] != '1',
 | 
											
												
													
														|  | 
 |  | +                }"
 | 
											
												
													
														|  | 
 |  | +              ></span>
 | 
											
												
													
														|  | 
 |  | +            </div>
 | 
											
												
													
														|  | 
 |  | +          </div>
 | 
											
												
													
														|  | 
 |  | +        </template>
 | 
											
												
													
														|  | 
 |  | +      </fourBorderBg>
 | 
											
												
													
														|  | 
 |  | +    </div>
 | 
											
												
													
														|  | 
 |  | +  </div>
 | 
											
												
													
														|  | 
 |  | +  <div class="nitrogen-home">
 | 
											
												
													
														|  | 
 |  | +    <div class="nitrogen-container">
 | 
											
												
													
														|  | 
 |  | +      <div class="top-box">
 | 
											
												
													
														|  | 
 |  | +        <!-- 中间区域控制按钮 -->
 | 
											
												
													
														|  | 
 |  | +        <div class="center-item-box">
 | 
											
												
													
														|  | 
 |  | +          <div class="top-left">
 | 
											
												
													
														|  | 
 |  | +            <div class="button-box" @click="handlerDevice(airCompressorState[0], '主机启动')">上位机启动</div>
 | 
											
												
													
														|  | 
 |  | +            <div class="button-box" @click="handlerDevice(airCompressorState[0], '主机停止')">上位机停止</div>
 | 
											
												
													
														|  | 
 |  | +            <div class="button-box" @click="handlerDevice(airCompressorState[0], '备机启动')">上位复位</div>
 | 
											
												
													
														|  | 
 |  | +          </div>
 | 
											
												
													
														|  | 
 |  | +          <div class="top-center">
 | 
											
												
													
														|  | 
 |  | +            <div class="top-c-label">通信状态:</div>
 | 
											
												
													
														|  | 
 |  | +            <div class="top-c-val">{{ monitorData['netStatus'] == 1 ? '连接' : monitorData['netStatus'] == 0 ? '断开' : '未知' }}</div>
 | 
											
												
													
														|  | 
 |  | +          </div>
 | 
											
												
													
														|  | 
 |  | +          <div class="top-right">
 | 
											
												
													
														|  | 
 |  | +            <div class="control-type">
 | 
											
												
													
														|  | 
 |  | +              <div class="control-title">空压机远近控切换:</div>
 | 
											
												
													
														|  | 
 |  | +              <a-radio-group v-model:value="monitorData['RemSelect']">
 | 
											
												
													
														|  | 
 |  | +                <a-radio :value="`1`">远程</a-radio>
 | 
											
												
													
														|  | 
 |  | +                <a-radio :value="`0`">就地</a-radio>
 | 
											
												
													
														|  | 
 |  | +              </a-radio-group>
 | 
											
												
													
														|  | 
 |  | +            </div>
 | 
											
												
													
														|  | 
 |  | +            <div class="control-type">
 | 
											
												
													
														|  | 
 |  | +              <div class="control-title">制氮机远近控切换:</div>
 | 
											
												
													
														|  | 
 |  | +              <a-radio-group v-model:value="monitorData['LocSelect']">
 | 
											
												
													
														|  | 
 |  | +                <a-radio :value="`1`">远程</a-radio>
 | 
											
												
													
														|  | 
 |  | +                <a-radio :value="`0`">就地</a-radio>
 | 
											
												
													
														|  | 
 |  | +              </a-radio-group>
 | 
											
												
													
														|  | 
 |  | +            </div>
 | 
											
												
													
														|  | 
 |  | +          </div>
 | 
											
												
													
														|  | 
 |  | +        </div>
 | 
											
												
													
														|  | 
 |  | +        <!-- 左边监测数据 -->
 | 
											
												
													
														|  | 
 |  | +        <div class="lr-box left-box">
 | 
											
												
													
														|  | 
 |  | +          <ventBox1>
 | 
											
												
													
														|  | 
 |  | +            <template #title>
 | 
											
												
													
														|  | 
 |  | +              <div>注氮机监测</div>
 | 
											
												
													
														|  | 
 |  | +            </template>
 | 
											
												
													
														|  | 
 |  | +            <template #container>
 | 
											
												
													
														|  | 
 |  | +              <div class="input-item" v-for="(preFan, index) in nitrogenMonitorData" :key="index">
 | 
											
												
													
														|  | 
 |  | +                <div class="title">{{ preFan.title }}</div>
 | 
											
												
													
														|  | 
 |  | +                <div v-if="preFan.unit !== 'signal'" class="value">{{
 | 
											
												
													
														|  | 
 |  | +                  monitorData[preFan.code] >= 0 ? formatNum(Number(monitorData[preFan.code])) : '-'
 | 
											
												
													
														|  | 
 |  | +                }}</div>
 | 
											
												
													
														|  | 
 |  | +                <div
 | 
											
												
													
														|  | 
 |  | +                  v-else
 | 
											
												
													
														|  | 
 |  | +                  :class="{
 | 
											
												
													
														|  | 
 |  | +                    'signal-round': true,
 | 
											
												
													
														|  | 
 |  | +                    'signal-round-warning': monitorData[preFan.code] == '1',
 | 
											
												
													
														|  | 
 |  | +                    'signal-round-gry': monitorData[preFan.code] != '1',
 | 
											
												
													
														|  | 
 |  | +                  }"
 | 
											
												
													
														|  | 
 |  | +                ></div>
 | 
											
												
													
														|  | 
 |  | +                <div class="unit">{{ preFan.unit !== 'signal' ? `(${preFan.unit})` : '' }}</div>
 | 
											
												
													
														|  | 
 |  | +              </div>
 | 
											
												
													
														|  | 
 |  | +            </template>
 | 
											
												
													
														|  | 
 |  | +          </ventBox1>
 | 
											
												
													
														|  | 
 |  | +          <div class="item item-l" v-for="groupNum in monitorDataGroupNum" :key="groupNum">
 | 
											
												
													
														|  | 
 |  | +            <ventBox1>
 | 
											
												
													
														|  | 
 |  | +              <template #title>
 | 
											
												
													
														|  | 
 |  | +                <div>空压机{{ groupNum }}</div>
 | 
											
												
													
														|  | 
 |  | +              </template>
 | 
											
												
													
														|  | 
 |  | +              <template #container>
 | 
											
												
													
														|  | 
 |  | +                <div class="monitor-box">
 | 
											
												
													
														|  | 
 |  | +                  <div class="monitor-item">
 | 
											
												
													
														|  | 
 |  | +                    <div class="state-item" v-for="(preFan, index) in preFanMonitorData" :key="index">
 | 
											
												
													
														|  | 
 |  | +                      <div class="state-title">{{ preFan.title + (preFan.unit !== 'signal' ? `(${preFan.unit})` : '') }}</div>
 | 
											
												
													
														|  | 
 |  | +                      <div v-if="preFan.unit !== 'signal'" class="state-val">{{
 | 
											
												
													
														|  | 
 |  | +                        monitorData[preFan.code + groupNum] >= 0 ? formatNum(Number(monitorData[preFan.code + groupNum])) : '-'
 | 
											
												
													
														|  | 
 |  | +                      }}</div>
 | 
											
												
													
														|  | 
 |  | +                      <div
 | 
											
												
													
														|  | 
 |  | +                        v-else
 | 
											
												
													
														|  | 
 |  | +                        :class="{
 | 
											
												
													
														|  | 
 |  | +                          'signal-round': true,
 | 
											
												
													
														|  | 
 |  | +                          'signal-round-warning': monitorData[preFan.code + groupNum] == '1',
 | 
											
												
													
														|  | 
 |  | +                          'signal-round-gry': monitorData[preFan.code + groupNum] != '1',
 | 
											
												
													
														|  | 
 |  | +                        }"
 | 
											
												
													
														|  | 
 |  | +                      ></div>
 | 
											
												
													
														|  | 
 |  | +                    </div>
 | 
											
												
													
														|  | 
 |  | +                  </div>
 | 
											
												
													
														|  | 
 |  | +                </div>
 | 
											
												
													
														|  | 
 |  | +              </template>
 | 
											
												
													
														|  | 
 |  | +            </ventBox1>
 | 
											
												
													
														|  | 
 |  | +          </div>
 | 
											
												
													
														|  | 
 |  | +        </div>
 | 
											
												
													
														|  | 
 |  | +        <!-- 右边控制状态 -->
 | 
											
												
													
														|  | 
 |  | +        <div class="lr-box right-box">
 | 
											
												
													
														|  | 
 |  | +          <ventBox1 class="vent-margin-t-10">
 | 
											
												
													
														|  | 
 |  | +            <template #title>
 | 
											
												
													
														|  | 
 |  | +              <div>设备实时监测曲线</div>
 | 
											
												
													
														|  | 
 |  | +            </template>
 | 
											
												
													
														|  | 
 |  | +            <template #container>
 | 
											
												
													
														|  | 
 |  | +              <BarAndLine
 | 
											
												
													
														|  | 
 |  | +                v-if="chartsColumns.length > 0"
 | 
											
												
													
														|  | 
 |  | +                xAxisPropType="readTime"
 | 
											
												
													
														|  | 
 |  | +                :dataSource="echartData"
 | 
											
												
													
														|  | 
 |  | +                height="340px"
 | 
											
												
													
														|  | 
 |  | +                :chartsColumns="chartsColumns"
 | 
											
												
													
														|  | 
 |  | +                chartsType="listMonitor"
 | 
											
												
													
														|  | 
 |  | +                :option="echatsOption"
 | 
											
												
													
														|  | 
 |  | +              />
 | 
											
												
													
														|  | 
 |  | +            </template>
 | 
											
												
													
														|  | 
 |  | +          </ventBox1>
 | 
											
												
													
														|  | 
 |  | +          <div ref="playerRef" style="height: auto; width: 100%; margin-top: 10px"></div>
 | 
											
												
													
														|  | 
 |  | +        </div>
 | 
											
												
													
														|  | 
 |  | +      </div>
 | 
											
												
													
														|  | 
 |  | +    </div>
 | 
											
												
													
														|  | 
 |  | +  </div>
 | 
											
												
													
														|  | 
 |  | +</template>
 | 
											
												
													
														|  | 
 |  | +<script lang="ts" setup name="nitrogenHome">
 | 
											
												
													
														|  | 
 |  | +  import { onMounted, onUnmounted, ref, watch, reactive, defineProps, nextTick, inject } 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 BarAndLine from '/@/components/chart/BarAndLine.vue';
 | 
											
												
													
														|  | 
 |  | +  import { deviceControlApi } from '/@/api/vent/index';
 | 
											
												
													
														|  | 
 |  | +  import { preMonitorList, preFanMonitorData, nitrogenMonitorData } from '../nitrogen.data.dltj';
 | 
											
												
													
														|  | 
 |  | +  import { formatNum } from '/@/utils/ventutil';
 | 
											
												
													
														|  | 
 |  | +  import { useCamera } from '/@/hooks/system/useCamera';
 | 
											
												
													
														|  | 
 |  | +  import { message } from 'ant-design-vue';
 | 
											
												
													
														|  | 
 |  | +  import lodash from 'lodash';
 | 
											
												
													
														|  | 
 |  | +  const globalConfig = inject('globalConfig');
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  const props = defineProps({
 | 
											
												
													
														|  | 
 |  | +    deviceId: {
 | 
											
												
													
														|  | 
 |  | +      type: String,
 | 
											
												
													
														|  | 
 |  | +      require: true,
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    modalType: {
 | 
											
												
													
														|  | 
 |  | +      type: String,
 | 
											
												
													
														|  | 
 |  | +      require: true,
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +  const playerRef = ref();
 | 
											
												
													
														|  | 
 |  | +  const refresh = ref(false);
 | 
											
												
													
														|  | 
 |  | +  const modalTitle = ref(''); // 模态框标题显示内容,根据设备操作类型决定
 | 
											
												
													
														|  | 
 |  | +  const modalType = ref(''); // 模态框内容显示类型,设备操作类型
 | 
											
												
													
														|  | 
 |  | +  const modalIsShow = ref<boolean>(false); // 是否显示模态框
 | 
											
												
													
														|  | 
 |  | +  const loading = ref(true);
 | 
											
												
													
														|  | 
 |  | +  let kzParam = reactive<any>({
 | 
											
												
													
														|  | 
 |  | +    data: {},
 | 
											
												
													
														|  | 
 |  | +    isFw: null,
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  // 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 colors = ['#FDB146', '#EE6666', '#9BCB75', '#03C2EC', '#DA3914', '#9C83D9'];
 | 
											
												
													
														|  | 
 |  | +  const echatsOption = {
 | 
											
												
													
														|  | 
 |  | +    grid: {
 | 
											
												
													
														|  | 
 |  | +      top: '35%',
 | 
											
												
													
														|  | 
 |  | +      left: '15%',
 | 
											
												
													
														|  | 
 |  | +      right: '20px',
 | 
											
												
													
														|  | 
 |  | +      bottom: '8%',
 | 
											
												
													
														|  | 
 |  | +      // containLabel: true
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +    toolbox: {
 | 
											
												
													
														|  | 
 |  | +      feature: {},
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +  };
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  const monitorNetStatus = ref(0);
 | 
											
												
													
														|  | 
 |  | +  const monitorDataGroupNum = ref(2);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  let airCompressorState = reactive<any[]>([]);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  const chartsColumns = ref([
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +      legend: '瞬时流量',
 | 
											
												
													
														|  | 
 |  | +      seriesName: '(m³/h)',
 | 
											
												
													
														|  | 
 |  | +      ymax: 2000,
 | 
											
												
													
														|  | 
 |  | +      yname: 'm³/h',
 | 
											
												
													
														|  | 
 |  | +      linetype: 'line',
 | 
											
												
													
														|  | 
 |  | +      yaxispos: 'left',
 | 
											
												
													
														|  | 
 |  | +      color: '#FDB146',
 | 
											
												
													
														|  | 
 |  | +      sort: 1,
 | 
											
												
													
														|  | 
 |  | +      xRotate: 0,
 | 
											
												
													
														|  | 
 |  | +      dataIndex: 'InputFlux',
 | 
											
												
													
														|  | 
 |  | +    },
 | 
											
												
													
														|  | 
 |  | +  ]);
 | 
											
												
													
														|  | 
 |  | +  const { getCamera, webRtcServer } = useCamera();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  const monitorData = ref({});
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  //图表数据
 | 
											
												
													
														|  | 
 |  | +  let echartData = ref<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
 | 
											
												
													
														|  | 
 |  | +      );
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  async function getDataSource(systemID) {
 | 
											
												
													
														|  | 
 |  | +    const res = await getDevice({ devicetype: 'sys', systemID, type: 'all' });
 | 
											
												
													
														|  | 
 |  | +    if (res) {
 | 
											
												
													
														|  | 
 |  | +      const result = res;
 | 
											
												
													
														|  | 
 |  | +      // const result = {
 | 
											
												
													
														|  | 
 |  | +      //   cmd: 'monitordata',
 | 
											
												
													
														|  | 
 |  | +      //   msgTxt: [
 | 
											
												
													
														|  | 
 |  | +      //     {
 | 
											
												
													
														|  | 
 |  | +      //       datalist: [
 | 
											
												
													
														|  | 
 |  | +      //         {
 | 
											
												
													
														|  | 
 |  | +      //           msgType: null,
 | 
											
												
													
														|  | 
 |  | +      //           deviceID: '1760842915239510017',
 | 
											
												
													
														|  | 
 |  | +      //           strname: '52603注氮机',
 | 
											
												
													
														|  | 
 |  | +      //           strinstallpos: '52603注氮机',
 | 
											
												
													
														|  | 
 |  | +      //           fsectarea: 'null',
 | 
											
												
													
														|  | 
 |  | +      //           stationname: '52603注氮机',
 | 
											
												
													
														|  | 
 |  | +      //           deviceType: 'nitrogen_52603',
 | 
											
												
													
														|  | 
 |  | +      //           typeName: '52603注氮机',
 | 
											
												
													
														|  | 
 |  | +      //           netStatus: 1,
 | 
											
												
													
														|  | 
 |  | +      //           warnFlag: 0,
 | 
											
												
													
														|  | 
 |  | +      //           warnLevel: 0,
 | 
											
												
													
														|  | 
 |  | +      //           warnLevel_str: '正常',
 | 
											
												
													
														|  | 
 |  | +      //           warnTime: null,
 | 
											
												
													
														|  | 
 |  | +      //           readTime: '2024-02-28 17:29:15',
 | 
											
												
													
														|  | 
 |  | +      //           warnDes: '',
 | 
											
												
													
														|  | 
 |  | +      //           frontGateOpenCtrl: null,
 | 
											
												
													
														|  | 
 |  | +      //           rearGateOpenCtrl: null,
 | 
											
												
													
														|  | 
 |  | +      //           readData: {
 | 
											
												
													
														|  | 
 |  | +      //             ExhaustTemp1: '15',
 | 
											
												
													
														|  | 
 |  | +      //             Status2: '0',
 | 
											
												
													
														|  | 
 |  | +      //             ExhaustTemp2: '26',
 | 
											
												
													
														|  | 
 |  | +      //             RunTime2: '2136',
 | 
											
												
													
														|  | 
 |  | +      //             RunTime1: '5127',
 | 
											
												
													
														|  | 
 |  | +      //             sign: '0',
 | 
											
												
													
														|  | 
 |  | +      //             NitrogenPurity: '206.4',
 | 
											
												
													
														|  | 
 |  | +      //             SysVoltage1: '640',
 | 
											
												
													
														|  | 
 |  | +      //             SysVoltage2: '653',
 | 
											
												
													
														|  | 
 |  | +      //             CtrlMode2: '0',
 | 
											
												
													
														|  | 
 |  | +      //             ExhaustPreHighFault2: '1',
 | 
											
												
													
														|  | 
 |  | +      //             ExhaustPreHighFault1: '1',
 | 
											
												
													
														|  | 
 |  | +      //             HMIReset: '0',
 | 
											
												
													
														|  | 
 |  | +      //             HMIStop: '0',
 | 
											
												
													
														|  | 
 |  | +      //             InputFlux: '0',
 | 
											
												
													
														|  | 
 |  | +      //             LocSelect: '0',
 | 
											
												
													
														|  | 
 |  | +      //             OilPressureLowFault1: '1',
 | 
											
												
													
														|  | 
 |  | +      //             OilPressureLowFault2: '0',
 | 
											
												
													
														|  | 
 |  | +      //             PhaseSequenceFault2: '0',
 | 
											
												
													
														|  | 
 |  | +      //             PhaseSequenceFault1: '0',
 | 
											
												
													
														|  | 
 |  | +      //             LoadorUnload2: '1',
 | 
											
												
													
														|  | 
 |  | +      //             LoadorUnload1: '1',
 | 
											
												
													
														|  | 
 |  | +      //             CtrlMode1: '0',
 | 
											
												
													
														|  | 
 |  | +      //             PreMembraneTemperature: '15.4',
 | 
											
												
													
														|  | 
 |  | +      //             HMIStart: '0',
 | 
											
												
													
														|  | 
 |  | +      //             ExhaustPre2: '7',
 | 
											
												
													
														|  | 
 |  | +      //             ExhaustPre1: '8',
 | 
											
												
													
														|  | 
 |  | +      //             LoadTime2: '2133',
 | 
											
												
													
														|  | 
 |  | +      //             RemSelect: '0',
 | 
											
												
													
														|  | 
 |  | +      //             Status1: '0',
 | 
											
												
													
														|  | 
 |  | +      //             LoadTime1: '5121',
 | 
											
												
													
														|  | 
 |  | +      //             isRun: '-2',
 | 
											
												
													
														|  | 
 |  | +      //             FluxTotal: '7242',
 | 
											
												
													
														|  | 
 |  | +      //             LeakageLock1: '0',
 | 
											
												
													
														|  | 
 |  | +      //             LeakageLock2: '0',
 | 
											
												
													
														|  | 
 |  | +      //           },
 | 
											
												
													
														|  | 
 |  | +      //           readDataDes: null,
 | 
											
												
													
														|  | 
 |  | +      //           summaryHour: [],
 | 
											
												
													
														|  | 
 |  | +      //           summaryDay: [],
 | 
											
												
													
														|  | 
 |  | +      //           history: [],
 | 
											
												
													
														|  | 
 |  | +      //           totalInfo: null,
 | 
											
												
													
														|  | 
 |  | +      //           sign: null,
 | 
											
												
													
														|  | 
 |  | +      //           cameras: [],
 | 
											
												
													
														|  | 
 |  | +      //           links: [],
 | 
											
												
													
														|  | 
 |  | +      //           other1: null,
 | 
											
												
													
														|  | 
 |  | +      //           other2: null,
 | 
											
												
													
														|  | 
 |  | +      //           other3: null,
 | 
											
												
													
														|  | 
 |  | +      //           remarkInfo: null,
 | 
											
												
													
														|  | 
 |  | +      //         },
 | 
											
												
													
														|  | 
 |  | +      //       ],
 | 
											
												
													
														|  | 
 |  | +      //       avginfo: {
 | 
											
												
													
														|  | 
 |  | +      //         warnFlag: {
 | 
											
												
													
														|  | 
 |  | +      //           value: 0,
 | 
											
												
													
														|  | 
 |  | +      //         },
 | 
											
												
													
														|  | 
 |  | +      //       },
 | 
											
												
													
														|  | 
 |  | +      //       typeName: '52603注氮机',
 | 
											
												
													
														|  | 
 |  | +      //       type: 'nitrogen_52603',
 | 
											
												
													
														|  | 
 |  | +      //     },
 | 
											
												
													
														|  | 
 |  | +      //     {
 | 
											
												
													
														|  | 
 |  | +      //       subtype: 'sys_nitrogen',
 | 
											
												
													
														|  | 
 |  | +      //       datalist: [
 | 
											
												
													
														|  | 
 |  | +      //         {
 | 
											
												
													
														|  | 
 |  | +      //           msgType: null,
 | 
											
												
													
														|  | 
 |  | +      //           deviceID: '1760932094094950402',
 | 
											
												
													
														|  | 
 |  | +      //           strname: '注氮系统',
 | 
											
												
													
														|  | 
 |  | +      //           strinstallpos: '注氮系统',
 | 
											
												
													
														|  | 
 |  | +      //           fsectarea: 'null',
 | 
											
												
													
														|  | 
 |  | +      //           stationname: null,
 | 
											
												
													
														|  | 
 |  | +      //           deviceType: 'sys_nitrogen',
 | 
											
												
													
														|  | 
 |  | +      //           typeName: '注氮',
 | 
											
												
													
														|  | 
 |  | +      //           netStatus: 0,
 | 
											
												
													
														|  | 
 |  | +      //           warnFlag: 0,
 | 
											
												
													
														|  | 
 |  | +      //           warnLevel: null,
 | 
											
												
													
														|  | 
 |  | +      //           warnLevel_str: null,
 | 
											
												
													
														|  | 
 |  | +      //           warnTime: null,
 | 
											
												
													
														|  | 
 |  | +      //           readTime: '2024-02-28 17:21:14',
 | 
											
												
													
														|  | 
 |  | +      //           warnDes: '',
 | 
											
												
													
														|  | 
 |  | +      //           frontGateOpenCtrl: null,
 | 
											
												
													
														|  | 
 |  | +      //           rearGateOpenCtrl: null,
 | 
											
												
													
														|  | 
 |  | +      //           readData: {
 | 
											
												
													
														|  | 
 |  | +      //             sign: '0',
 | 
											
												
													
														|  | 
 |  | +      //             isRun: '-2',
 | 
											
												
													
														|  | 
 |  | +      //           },
 | 
											
												
													
														|  | 
 |  | +      //           readDataDes: null,
 | 
											
												
													
														|  | 
 |  | +      //           summaryHour: [],
 | 
											
												
													
														|  | 
 |  | +      //           summaryDay: [],
 | 
											
												
													
														|  | 
 |  | +      //           history: [],
 | 
											
												
													
														|  | 
 |  | +      //           totalInfo: null,
 | 
											
												
													
														|  | 
 |  | +      //           sign: null,
 | 
											
												
													
														|  | 
 |  | +      //           cameras: [],
 | 
											
												
													
														|  | 
 |  | +      //           links: [],
 | 
											
												
													
														|  | 
 |  | +      //           other1: null,
 | 
											
												
													
														|  | 
 |  | +      //           other2: null,
 | 
											
												
													
														|  | 
 |  | +      //           other3: null,
 | 
											
												
													
														|  | 
 |  | +      //           remarkInfo: '设备断线',
 | 
											
												
													
														|  | 
 |  | +      //         },
 | 
											
												
													
														|  | 
 |  | +      //       ],
 | 
											
												
													
														|  | 
 |  | +      //       typeName: '综合监测系统',
 | 
											
												
													
														|  | 
 |  | +      //       type: 'sys',
 | 
											
												
													
														|  | 
 |  | +      //     },
 | 
											
												
													
														|  | 
 |  | +      //   ],
 | 
											
												
													
														|  | 
 |  | +      // };
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +      if (!result || result.msgTxt.length < 1) return;
 | 
											
												
													
														|  | 
 |  | +      result.msgTxt.forEach((item) => {
 | 
											
												
													
														|  | 
 |  | +        if (item.type && item.type.startsWith('nitrogen')) {
 | 
											
												
													
														|  | 
 |  | +          airCompressorState.length = 0;
 | 
											
												
													
														|  | 
 |  | +          let netStatus = 0;
 | 
											
												
													
														|  | 
 |  | +          monitorData.value = Object.assign(item['datalist'][0], item['datalist'][0]['readData']);
 | 
											
												
													
														|  | 
 |  | +          if (monitorData.value['netStatus'] == 1) {
 | 
											
												
													
														|  | 
 |  | +            netStatus = 1;
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +          airCompressorState.push({
 | 
											
												
													
														|  | 
 |  | +            id: monitorData.value['deviceID'],
 | 
											
												
													
														|  | 
 |  | +            deviceType: monitorData.value['deviceType'],
 | 
											
												
													
														|  | 
 |  | +            HMIStart: monitorData.value['HMIStart'],
 | 
											
												
													
														|  | 
 |  | +            HMIStop: monitorData.value['HMIStop'],
 | 
											
												
													
														|  | 
 |  | +          });
 | 
											
												
													
														|  | 
 |  | +          monitorNetStatus.value = netStatus;
 | 
											
												
													
														|  | 
 |  | +          const airCompressor = { readTime: monitorData.value['readTime'].substring(11) };
 | 
											
												
													
														|  | 
 |  | +          const dataArr = lodash.cloneDeep(echartData.value);
 | 
											
												
													
														|  | 
 |  | +          //图表数据
 | 
											
												
													
														|  | 
 |  | +          if (dataArr.length <= 5) {
 | 
											
												
													
														|  | 
 |  | +            airCompressor[`FluxTotal`] = monitorData.value['FluxTotal'] || 0;
 | 
											
												
													
														|  | 
 |  | +            dataArr.push(airCompressor);
 | 
											
												
													
														|  | 
 |  | +          } else {
 | 
											
												
													
														|  | 
 |  | +            dataArr.shift();
 | 
											
												
													
														|  | 
 |  | +            dataArr.push(airCompressor);
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +          echartData.value = dataArr;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +      });
 | 
											
												
													
														|  | 
 |  | +      refresh.value = true;
 | 
											
												
													
														|  | 
 |  | +      nextTick(() => {
 | 
											
												
													
														|  | 
 |  | +        refresh.value = false;
 | 
											
												
													
														|  | 
 |  | +      });
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  function handlerDevice(data, bol) {
 | 
											
												
													
														|  | 
 |  | +    kzParam.data = data;
 | 
											
												
													
														|  | 
 |  | +    kzParam.isFw = bol;
 | 
											
												
													
														|  | 
 |  | +    if (bol) {
 | 
											
												
													
														|  | 
 |  | +      modalTitle.value = '一键复位';
 | 
											
												
													
														|  | 
 |  | +      modalType.value = '1';
 | 
											
												
													
														|  | 
 |  | +      modalIsShow.value = true;
 | 
											
												
													
														|  | 
 |  | +      kzParam.data.HMIReset = !data.HMIReset;
 | 
											
												
													
														|  | 
 |  | +    } else {
 | 
											
												
													
														|  | 
 |  | +      modalTitle.value = '一键启停';
 | 
											
												
													
														|  | 
 |  | +      modalType.value = '2';
 | 
											
												
													
														|  | 
 |  | +      modalIsShow.value = true;
 | 
											
												
													
														|  | 
 |  | +      kzParam.data.HMIStartStop = !data.HMIStartStop;
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +  function handleOK(passWord, handlerState) {
 | 
											
												
													
														|  | 
 |  | +    console.log(kzParam, 'kz----------');
 | 
											
												
													
														|  | 
 |  | +    // if (passWord !== '123456') {
 | 
											
												
													
														|  | 
 |  | +    //   message.warning('密码不正确,请重新输入');
 | 
											
												
													
														|  | 
 |  | +    //   return;
 | 
											
												
													
														|  | 
 |  | +    // }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    let data = {};
 | 
											
												
													
														|  | 
 |  | +    if (kzParam.isFw) {
 | 
											
												
													
														|  | 
 |  | +      data = {
 | 
											
												
													
														|  | 
 |  | +        deviceid: kzParam.data.id,
 | 
											
												
													
														|  | 
 |  | +        devicetype: kzParam.data.deviceType,
 | 
											
												
													
														|  | 
 |  | +        password: passWord,
 | 
											
												
													
														|  | 
 |  | +        HMIReset: kzParam.data.HMIReset,
 | 
											
												
													
														|  | 
 |  | +      };
 | 
											
												
													
														|  | 
 |  | +    } else {
 | 
											
												
													
														|  | 
 |  | +      data = {
 | 
											
												
													
														|  | 
 |  | +        deviceid: kzParam.data.id,
 | 
											
												
													
														|  | 
 |  | +        password: passWord,
 | 
											
												
													
														|  | 
 |  | +        devicetype: kzParam.data.deviceType,
 | 
											
												
													
														|  | 
 |  | +        HMIStartStop: kzParam.data.HMIStartStop,
 | 
											
												
													
														|  | 
 |  | +      };
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    deviceControlApi(data).then((res) => {
 | 
											
												
													
														|  | 
 |  | +      // 模拟时开启
 | 
											
												
													
														|  | 
 |  | +      if (res.success) {
 | 
											
												
													
														|  | 
 |  | +        modalIsShow.value = false;
 | 
											
												
													
														|  | 
 |  | +        getDataSource(props.deviceId);
 | 
											
												
													
														|  | 
 |  | +        if (globalConfig.History_Type == 'remote') {
 | 
											
												
													
														|  | 
 |  | +          message.success('指令已下发至生产管控平台成功!');
 | 
											
												
													
														|  | 
 |  | +        } else {
 | 
											
												
													
														|  | 
 |  | +          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;
 | 
											
												
													
														|  | 
 |  | +    });
 | 
											
												
													
														|  | 
 |  | +    await getCamera(props.deviceId, playerRef.value);
 | 
											
												
													
														|  | 
 |  | +  });
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  onUnmounted(() => {
 | 
											
												
													
														|  | 
 |  | +    destroy();
 | 
											
												
													
														|  | 
 |  | +    if (webRtcServer.length > 0) {
 | 
											
												
													
														|  | 
 |  | +      webRtcServer.forEach((item) => {
 | 
											
												
													
														|  | 
 |  | +        item.disconnect();
 | 
											
												
													
														|  | 
 |  | +      });
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +    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;
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    &: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: 20px;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    .nitrogen-container {
 | 
											
												
													
														|  | 
 |  | +      width: 100%;
 | 
											
												
													
														|  | 
 |  | +      height: calc(100% - 100px);
 | 
											
												
													
														|  | 
 |  | +      display: flex;
 | 
											
												
													
														|  | 
 |  | +      justify-content: space-between;
 | 
											
												
													
														|  | 
 |  | +      margin-bottom: 100px;
 | 
											
												
													
														|  | 
 |  | +      .device-state {
 | 
											
												
													
														|  | 
 |  | +        width: 100%;
 | 
											
												
													
														|  | 
 |  | +        position: absolute;
 | 
											
												
													
														|  | 
 |  | +        top: 20px;
 | 
											
												
													
														|  | 
 |  | +        color: #e90000;
 | 
											
												
													
														|  | 
 |  | +        display: flex;
 | 
											
												
													
														|  | 
 |  | +        justify-content: center;
 | 
											
												
													
														|  | 
 |  | +        font-size: 20px;
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +      .top-box {
 | 
											
												
													
														|  | 
 |  | +        width: 100%;
 | 
											
												
													
														|  | 
 |  | +        padding: 10px;
 | 
											
												
													
														|  | 
 |  | +        overflow: hidden;
 | 
											
												
													
														|  | 
 |  | +        display: flex;
 | 
											
												
													
														|  | 
 |  | +        justify-content: space-between;
 | 
											
												
													
														|  | 
 |  | +        // margin-top: 40px;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        .center-item-box {
 | 
											
												
													
														|  | 
 |  | +          position: absolute;
 | 
											
												
													
														|  | 
 |  | +          left: 50%;
 | 
											
												
													
														|  | 
 |  | +          top: 50px;
 | 
											
												
													
														|  | 
 |  | +          transform: translate(-48%, 0);
 | 
											
												
													
														|  | 
 |  | +          width: calc(100% - 720px);
 | 
											
												
													
														|  | 
 |  | +          height: 50px;
 | 
											
												
													
														|  | 
 |  | +          display: flex;
 | 
											
												
													
														|  | 
 |  | +          align-items: center;
 | 
											
												
													
														|  | 
 |  | +          pointer-events: auto;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .top-left {
 | 
											
												
													
														|  | 
 |  | +            display: flex;
 | 
											
												
													
														|  | 
 |  | +            flex: 1.5;
 | 
											
												
													
														|  | 
 |  | +            color: #fff;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .button-box {
 | 
											
												
													
														|  | 
 |  | +              position: relative;
 | 
											
												
													
														|  | 
 |  | +              width: auto;
 | 
											
												
													
														|  | 
 |  | +              height: 32px;
 | 
											
												
													
														|  | 
 |  | +              display: flex;
 | 
											
												
													
														|  | 
 |  | +              align-items: center;
 | 
											
												
													
														|  | 
 |  | +              justify-content: center;
 | 
											
												
													
														|  | 
 |  | +              border-radius: 5px;
 | 
											
												
													
														|  | 
 |  | +              color: #fff;
 | 
											
												
													
														|  | 
 |  | +              padding: 10px 15px;
 | 
											
												
													
														|  | 
 |  | +              margin: 0px 10px;
 | 
											
												
													
														|  | 
 |  | +              box-sizing: border-box;
 | 
											
												
													
														|  | 
 |  | +              cursor: pointer;
 | 
											
												
													
														|  | 
 |  | +              background: linear-gradient(#1fa6cb, #127cb5);
 | 
											
												
													
														|  | 
 |  | +              &:hover {
 | 
											
												
													
														|  | 
 |  | +                background: linear-gradient(#1fa6cbcc, #127cb5cc);
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +          .top-center {
 | 
											
												
													
														|  | 
 |  | +            display: flex;
 | 
											
												
													
														|  | 
 |  | +            flex: 1;
 | 
											
												
													
														|  | 
 |  | +            justify-content: center;
 | 
											
												
													
														|  | 
 |  | +            align-items: center;
 | 
											
												
													
														|  | 
 |  | +            font-size: 20px;
 | 
											
												
													
														|  | 
 |  | +            color: #fff;
 | 
											
												
													
														|  | 
 |  | +            .top-c-label {
 | 
											
												
													
														|  | 
 |  | +              color: yellow;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .top-right {
 | 
											
												
													
														|  | 
 |  | +            display: flex;
 | 
											
												
													
														|  | 
 |  | +            flex: 2;
 | 
											
												
													
														|  | 
 |  | +            justify-content: right;
 | 
											
												
													
														|  | 
 |  | +            align-items: center;
 | 
											
												
													
														|  | 
 |  | +            color: #fff;
 | 
											
												
													
														|  | 
 |  | +            .control-type {
 | 
											
												
													
														|  | 
 |  | +              display: flex;
 | 
											
												
													
														|  | 
 |  | +              color: #fff;
 | 
											
												
													
														|  | 
 |  | +              .control-title {
 | 
											
												
													
														|  | 
 |  | +                color: #73e8fe;
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        .lr-box {
 | 
											
												
													
														|  | 
 |  | +          height: 100%;
 | 
											
												
													
														|  | 
 |  | +          display: flex;
 | 
											
												
													
														|  | 
 |  | +          flex-direction: column;
 | 
											
												
													
														|  | 
 |  | +          position: relative;
 | 
											
												
													
														|  | 
 |  | +          // overflow: hidden;
 | 
											
												
													
														|  | 
 |  | +          z-index: 9999;
 | 
											
												
													
														|  | 
 |  | +          pointer-events: auto;
 | 
											
												
													
														|  | 
 |  | +          overflow-y: auto;
 | 
											
												
													
														|  | 
 |  | +          overflow-x: hidden;
 | 
											
												
													
														|  | 
 |  | +          height: calc(100% - 70px);
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        .item {
 | 
											
												
													
														|  | 
 |  | +          width: 305px;
 | 
											
												
													
														|  | 
 |  | +          height: auto;
 | 
											
												
													
														|  | 
 |  | +          position: relative;
 | 
											
												
													
														|  | 
 |  | +          border-radius: 5px;
 | 
											
												
													
														|  | 
 |  | +          margin-top: 10px;
 | 
											
												
													
														|  | 
 |  | +          margin-bottom: 0px;
 | 
											
												
													
														|  | 
 |  | +          pointer-events: auto;
 | 
											
												
													
														|  | 
 |  | +          color: #fff;
 | 
											
												
													
														|  | 
 |  | +          // overflow: hidden;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          &:first-child {
 | 
											
												
													
														|  | 
 |  | +            margin-top: 0px;
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .base-title {
 | 
											
												
													
														|  | 
 |  | +            color: #fff;
 | 
											
												
													
														|  | 
 |  | +            margin-bottom: 8px;
 | 
											
												
													
														|  | 
 |  | +            padding-left: 10px;
 | 
											
												
													
														|  | 
 |  | +            position: relative;
 | 
											
												
													
														|  | 
 |  | +            font-size: 16px;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            &::after {
 | 
											
												
													
														|  | 
 |  | +              content: '';
 | 
											
												
													
														|  | 
 |  | +              position: absolute;
 | 
											
												
													
														|  | 
 |  | +              display: block;
 | 
											
												
													
														|  | 
 |  | +              width: 4px;
 | 
											
												
													
														|  | 
 |  | +              height: 12px;
 | 
											
												
													
														|  | 
 |  | +              top: 7px;
 | 
											
												
													
														|  | 
 |  | +              left: 0px;
 | 
											
												
													
														|  | 
 |  | +              background: #45d3fd;
 | 
											
												
													
														|  | 
 |  | +              border-radius: 4px;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .monitor-item {
 | 
											
												
													
														|  | 
 |  | +            width: 100%;
 | 
											
												
													
														|  | 
 |  | +            display: flex;
 | 
											
												
													
														|  | 
 |  | +            flex-direction: row;
 | 
											
												
													
														|  | 
 |  | +            flex-wrap: wrap;
 | 
											
												
													
														|  | 
 |  | +            .state-item {
 | 
											
												
													
														|  | 
 |  | +              width: 50%;
 | 
											
												
													
														|  | 
 |  | +              padding: 5px;
 | 
											
												
													
														|  | 
 |  | +              display: flex;
 | 
											
												
													
														|  | 
 |  | +              align-items: center;
 | 
											
												
													
														|  | 
 |  | +              justify-content: space-between;
 | 
											
												
													
														|  | 
 |  | +              .state-title {
 | 
											
												
													
														|  | 
 |  | +                width: 100px;
 | 
											
												
													
														|  | 
 |  | +                color: #ffffffdd;
 | 
											
												
													
														|  | 
 |  | +                flex: 9;
 | 
											
												
													
														|  | 
 |  | +                font-size: 14px;
 | 
											
												
													
														|  | 
 |  | +                .unit {
 | 
											
												
													
														|  | 
 |  | +                  // color: #ffffffbb;
 | 
											
												
													
														|  | 
 |  | +                }
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +              .state-val {
 | 
											
												
													
														|  | 
 |  | +                flex: 1;
 | 
											
												
													
														|  | 
 |  | +                color: #e4a300;
 | 
											
												
													
														|  | 
 |  | +                margin-right: 5px;
 | 
											
												
													
														|  | 
 |  | +                text-align: right;
 | 
											
												
													
														|  | 
 |  | +                font-size: 14px;
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .signal-box {
 | 
											
												
													
														|  | 
 |  | +            margin: 5px 0;
 | 
											
												
													
														|  | 
 |  | +            display: flex;
 | 
											
												
													
														|  | 
 |  | +            align-items: center;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .signal-title {
 | 
											
												
													
														|  | 
 |  | +              color: #7af5ff;
 | 
											
												
													
														|  | 
 |  | +              margin: 0 5px;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            &:last-child {
 | 
											
												
													
														|  | 
 |  | +              margin-right: 0px;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .list-item {
 | 
											
												
													
														|  | 
 |  | +            padding: 0 10px;
 | 
											
												
													
														|  | 
 |  | +            display: flex;
 | 
											
												
													
														|  | 
 |  | +            justify-content: space-between;
 | 
											
												
													
														|  | 
 |  | +            align-items: center;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .item-data-key {
 | 
											
												
													
														|  | 
 |  | +              color: #ffffff99;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .item-data-box {
 | 
											
												
													
														|  | 
 |  | +            color: #fff;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .state-icon {
 | 
											
												
													
														|  | 
 |  | +              display: inline-block;
 | 
											
												
													
														|  | 
 |  | +              width: 12px;
 | 
											
												
													
														|  | 
 |  | +              height: 12px;
 | 
											
												
													
														|  | 
 |  | +              border-radius: 12px;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .open {
 | 
											
												
													
														|  | 
 |  | +              border: 5px solid #133a56;
 | 
											
												
													
														|  | 
 |  | +              background: #4ecb73;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .close {
 | 
											
												
													
														|  | 
 |  | +              border: 5px solid #192961;
 | 
											
												
													
														|  | 
 |  | +              background: #6d7898;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        .item-l {
 | 
											
												
													
														|  | 
 |  | +          width: 100%;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +          .monitor-box {
 | 
											
												
													
														|  | 
 |  | +            width: 100%;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .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);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +              .icon {
 | 
											
												
													
														|  | 
 |  | +                left: -12px;
 | 
											
												
													
														|  | 
 |  | +                top: -17px;
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +              span {
 | 
											
												
													
														|  | 
 |  | +                left: 18px;
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +              .item-col {
 | 
											
												
													
														|  | 
 |  | +                background-image: linear-gradient(to right, #39a3ff00, #39a3ff10);
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .device-parameter-title {
 | 
											
												
													
														|  | 
 |  | +              background-image: linear-gradient(to right, #3df6ff40, #3df6ff00);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +              .icon {
 | 
											
												
													
														|  | 
 |  | +                left: -10px;
 | 
											
												
													
														|  | 
 |  | +                top: -14px;
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +              span {
 | 
											
												
													
														|  | 
 |  | +                left: 18px;
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +              .item-col {
 | 
											
												
													
														|  | 
 |  | +                background-image: linear-gradient(to right, #3df6ff10, #3df6ff00);
 | 
											
												
													
														|  | 
 |  | +              }
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        .right-box {
 | 
											
												
													
														|  | 
 |  | +          width: 300px;
 | 
											
												
													
														|  | 
 |  | +          margin-top: 50px;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        .left-box {
 | 
											
												
													
														|  | 
 |  | +          width: 335px;
 | 
											
												
													
														|  | 
 |  | +          margin-top: 80px;
 | 
											
												
													
														|  | 
 |  | +          .input-item {
 | 
											
												
													
														|  | 
 |  | +            display: flex;
 | 
											
												
													
														|  | 
 |  | +            justify-content: space-between;
 | 
											
												
													
														|  | 
 |  | +            align-items: center;
 | 
											
												
													
														|  | 
 |  | +            padding: 4px 8px;
 | 
											
												
													
														|  | 
 |  | +            margin: 6px 0;
 | 
											
												
													
														|  | 
 |  | +            background-image: linear-gradient(to right, #39deff15, #3977e500);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .title {
 | 
											
												
													
														|  | 
 |  | +              width: 200px;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            .title-auto {
 | 
											
												
													
														|  | 
 |  | +              width: auto;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +            .input-value {
 | 
											
												
													
														|  | 
 |  | +              width: 80px;
 | 
											
												
													
														|  | 
 |  | +              height: 28px;
 | 
											
												
													
														|  | 
 |  | +              line-height: 28px !important;
 | 
											
												
													
														|  | 
 |  | +              background: transparent !important;
 | 
											
												
													
														|  | 
 |  | +              border-color: #228da2 !important;
 | 
											
												
													
														|  | 
 |  | +              color: #fff !important;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            .value {
 | 
											
												
													
														|  | 
 |  | +              width: 100px;
 | 
											
												
													
														|  | 
 |  | +              color: #00d8ff;
 | 
											
												
													
														|  | 
 |  | +              padding-right: 20px;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            .unit {
 | 
											
												
													
														|  | 
 |  | +              width: 80px;
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +          }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +      &: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;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +      .monitor-val {
 | 
											
												
													
														|  | 
 |  | +        color: #ffb700;
 | 
											
												
													
														|  | 
 |  | +        display: flex;
 | 
											
												
													
														|  | 
 |  | +        width: auto;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        .val {
 | 
											
												
													
														|  | 
 |  | +          width: 80px;
 | 
											
												
													
														|  | 
 |  | +          font-size: 14px;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        .unit {
 | 
											
												
													
														|  | 
 |  | +          color: #ffffffbb;
 | 
											
												
													
														|  | 
 |  | +          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;
 | 
											
												
													
														|  | 
 |  | +          border-radius: 50%;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +      .signal-round-gry {
 | 
											
												
													
														|  | 
 |  | +        background-color: #858585;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        &::after {
 | 
											
												
													
														|  | 
 |  | +          background-color: #85858544;
 | 
											
												
													
														|  | 
 |  | +          box-shadow: 0 0 1px 1px #85858599;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +      .signal-round-run {
 | 
											
												
													
														|  | 
 |  | +        background-color: #67fc00;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        &::after {
 | 
											
												
													
														|  | 
 |  | +          background-color: #67fc0044;
 | 
											
												
													
														|  | 
 |  | +          box-shadow: 0 0 1px 1px #c6ff77;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +      .signal-round-warning {
 | 
											
												
													
														|  | 
 |  | +        background-color: #e9170b;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        &::after {
 | 
											
												
													
														|  | 
 |  | +          background-color: #e9170b44;
 | 
											
												
													
														|  | 
 |  | +          box-shadow: 0 0 1px 1px #e9170b;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +  :deep(.zxm-radio-wrapper) {
 | 
											
												
													
														|  | 
 |  | +    color: #fff !important;
 | 
											
												
													
														|  | 
 |  | +  }
 | 
											
												
													
														|  | 
 |  | +</style>
 |