Ver código fonte

[Wip 0000] 保德瓦斯抽采泵监测开发

houzekong 5 meses atrás
pai
commit
23ae694715

+ 854 - 0
src/views/vent/monitorManager/gasPumpMonitor/components/gasPumpHomeBD.vue

@@ -0,0 +1,854 @@
+<template>
+  <div class="monitor-container">
+    <div id="FlowSensor" class="FlowSensor-box" style="position: absolute; display: none">
+      <!-- <div class="elementContent" v-if="selectData['deviceType'].startsWith('pump_under') || selectData['deviceType'] == 'pump_n12m2pq'">
+        <fourBorderBg>
+          <template v-for="(item, index) in modelMonitor" :key="index">
+            <div class="gas-monitor-row">
+              <div class="title">{{ item.title }}</div>
+              <div class="value">{{ selectData[item.code] ? selectData[item.code] : '-' }}</div>
+            </div>
+          </template>
+        </fourBorderBg>
+      </div> -->
+    </div>
+    <!-- 布尔台新瓦斯泵模型上的数据 -->
+    <div class="elementContent" style="position: absolute; display: none">
+      <div v-for="(tag, index) in modelMonitorTags" :key="index" :id="tag.domId" class="modal-monitor-box">
+        <div class="title">{{ tag.title }}</div>
+        <div
+          v-if="tag.type == 'sign'"
+          class="signal-round"
+          :class="{ 'signal-round-gry': selectData[tag.code] != 1, 'signal-round-run': selectData[tag.code] == 1 }"
+        ></div>
+        <div v-else class="value">{{ selectData[tag.code] }}</div>
+      </div>
+    </div>
+    <div v-if="selectData['netStatus'] == 0" class="device-state">网络断开</div>
+    <ModuleCommon
+      v-for="cfg in configs"
+      :key="cfg.deviceType"
+      :show-style="cfg.showStyle"
+      :module-data="cfg.moduleData"
+      :module-name="cfg.moduleName"
+      :device-type="cfg.deviceType"
+      :data="selectData"
+      :visible="true"
+    />
+    <div class="lr left-box"></div>
+    <div class="lr right-box">
+      <div class="item-box sensor-container">
+        <ventBox1 class="vent-margin-t-10">
+          <template #title>
+            <div>泵站远程集中控制</div>
+          </template>
+          <template #container>
+            <div class="top-btn">
+              <div class="btn-group">
+                <a-button class="btn-item" type="primary" @click="handlerFn('zfw')">总复位</a-button>
+                <a-button class="btn-item" type="default" disabled @click="handlerFn('change')">一键切换</a-button>
+              </div>
+              <div class="btn-group">
+                <a-button style="width: calc(100% - 16px); padding: 0 8px" type="primary" @click="openModal">瓦斯泵控制</a-button>
+              </div>
+              <div>
+                <div class="control-item">
+                  <div class="control-title">控制模式:</div>
+                  <div class="control-container">
+                    <a-radio-group v-model:value="selectData['ykjdqh']">
+                      <a-radio :value="'0'">就地</a-radio>
+                      <a-radio :value="'1'">远程</a-radio>
+                    </a-radio-group>
+                    <div class="btn-box">
+                      <div class="btn btn1" @click="changeCtr(0)">就地</div>
+                      <div class="btn btn1" @click="changeCtr(1)">远程</div>
+                    </div>
+                  </div>
+                </div>
+                <div class="control-item">
+                  <div class="control-title">检修模式:</div>
+                  <div class="control-container">
+                    <a-radio-group v-model:value="selectData['jxmsqh']">
+                      <a-radio :value="'0'">关闭</a-radio>
+                      <a-radio :value="'1'">开启</a-radio>
+                    </a-radio-group>
+                    <div class="btn-box">
+                      <div class="btn btn1" @click="changeMode(0)">关闭</div>
+                      <div class="btn btn1" @click="changeMode(1)">开启</div>
+                    </div>
+                  </div>
+                </div>
+              </div>
+            </div>
+          </template>
+        </ventBox1>
+      </div>
+    </div>
+    <div ref="playerRef" class="player-box"></div>
+  </div>
+  <DetailModal @register="register" :device-type="deviceType" :device-id="deviceId" />
+  <PasswordModal
+    :modal-is-show="passwordModalIsShow"
+    modal-title="密码检验"
+    :modal-type="handlerType"
+    @handle-ok="handleOK"
+    @handle-cancel="handleCancel"
+  />
+</template>
+
+<script setup lang="ts">
+  import { ref, onMounted, onUnmounted, reactive, defineProps, watch, inject, nextTick, onBeforeUnmount } from 'vue';
+  import ventBox1 from '/@/components/vent/ventBox1.vue';
+  import ModuleCommon from '../../../home/configurable/components/ModuleCommon.vue';
+  import { setModelType, playAnimate } from '../gasPump.threejs';
+  import ListItem from '@/views/vent/gas/components/list/listItem.vue';
+  import {
+    stateWarningHeader,
+    valveWarningState,
+    pumpMonitorData,
+    waterPumpData,
+    dewateringPumpData,
+    modelMonitor,
+    getModelMonitorTags,
+    valveCtrlType,
+  } from '../gasPump.data';
+  import { list } from '../gasPump.api';
+  import { SvgIcon } from '/@/components/Icon';
+  import { formatNum } from '/@/utils/ventutil';
+  import DetailModal from './DetailModal.vue';
+  import { useModal } from '/@/components/Modal';
+  import { deviceControlApi } from '/@/api/vent/index';
+  import PasswordModal from '../../comment/components/PasswordModal.vue';
+  import { message } from 'ant-design-vue';
+  import fourBorderBg from '/@/components/vent/fourBorderBg.vue';
+  import { useCamera } from '/@/hooks/system/useCamera';
+  import { Config } from '../../../deviceManager/configurationTable/types';
+  import { useInitConfigs } from '../../../home/configurable/hooks/useInit';
+
+  const globalConfig = inject('globalConfig');
+
+  const props = defineProps({
+    deviceId: {
+      type: String,
+      require: true,
+    },
+    deviceType: {
+      type: String,
+      require: true,
+    },
+  });
+  const [register, { openModal }] = useModal();
+  const modelMonitorTags = getModelMonitorTags();
+  const loading = ref(false);
+  const passwordModalIsShow = ref(false);
+  const handlerType = ref('');
+  const playerRef = ref();
+
+  // 监测数据
+  const selectData = ref({
+    pump1: false,
+    pump2: false,
+    pump3: false,
+    pump4: false,
+    waterPump1: false,
+    waterPump2: false,
+    waterPump3: false,
+    waterPump4: false,
+    inValve1: false,
+    outValve1: false,
+    inValve2: false,
+    outValve2: false,
+    inValve3: false,
+    outValve3: false,
+    inValve4: false,
+    outValve4: false,
+    jxmsqh: '1',
+    ykjdqh: '1',
+    FlowSensor_InputFlux: '-',
+    deviceType: '',
+  });
+
+  const { getCamera, removeCamera } = useCamera();
+
+  // https获取监测数据
+  let timer: null | NodeJS.Timeout = null;
+  function getMonitor(flag?) {
+    if (Object.prototype.toString.call(timer) === '[object Null]') {
+      return new Promise((resolve) => {
+        timer = setTimeout(
+          async () => {
+            if (props.deviceId) {
+              const data = await getDataSource(props.deviceId);
+              selectData.value = data;
+              selectData.value = {
+                msgType: null,
+                deviceID: '1917403438771486722',
+                strname: '康孙62联巷变电所19号分站',
+                strinstallpos: '康孙62联巷变电所19号分站',
+                fsectarea: 'null',
+                stationname: '瓦斯抽放',
+                stationtype: 'more_txt_com',
+                deviceType: 'gasdrainage_bd',
+                typeName: '瓦斯抽放-保德',
+                netStatus: 1,
+                warnFlag: 0,
+                warnLevel: 0,
+                warnLevel_str: '正常',
+                syswarnLevel: null,
+                syswarnLevel_str: null,
+                syswarnLevel_des: null,
+                warnTime: null,
+                readTime: '2025-05-08 16:01:40',
+                warnDes: '',
+                frontGateOpenCtrl: null,
+                rearGateOpenCtrl: null,
+                readData: {
+                  value_status: '交流正常',
+                  unit: '',
+                  dataTypeName: '701001',
+                  sign: '0',
+                  dataTypeName_str: '分站',
+                  time: '2025-05-08 16:00:35',
+                  id: '019F00',
+                  isRun: '-2',
+                  value: '2',
+                },
+                readDataDes: null,
+                summaryHour: [],
+                summaryDay: [],
+                history: [],
+                dayhistory: [],
+                totalInfo: null,
+                sign: null,
+                cameras: [],
+                links: [],
+                avgParam: {},
+                other1: null,
+                other2: null,
+                other3: null,
+                remarkInfo: null,
+                linkInfo: null,
+                addrIndex: null,
+                warnLogNotOkCount: 0,
+                otherInfo: null,
+                orderNum: 0,
+              };
+              playAnimate(data);
+              // Object.assign(selectData, data);
+            }
+            if (timer) {
+              timer = null;
+            }
+            resolve(null);
+            await getMonitor();
+            loading.value = false;
+          },
+          flag ? 0 : 1000
+        );
+      });
+    }
+  }
+
+  async function getDataSource(systemID) {
+    const res = await list({ devicetype: props.deviceType, ids: systemID });
+    const result = res.msgTxt[0]['datalist'][0];
+    Object.assign(result, result['readData']);
+    return result;
+  }
+
+  function handler(passWord, paramcode) {
+    let value = '';
+    if (paramcode == 'ykjdqh') {
+      value = selectData.value['ykjdqh'] == '1' ? '2' : '1';
+    }
+    if (paramcode == 'jxmsqh') {
+      value = selectData.value['jxmsqh'] == '1' ? '2' : '1';
+    }
+    const data = {
+      deviceid: selectData.value['deviceID'],
+      devicetype: selectData.value['deviceType'],
+      paramcode: paramcode,
+      password: passWord,
+      value: value,
+    };
+    deviceControlApi(data)
+      .then((res) => {
+        if (globalConfig.History_Type == 'remote') {
+          message.success('指令已下发至生产管控平台成功!');
+        } else {
+          message.success('指令已下发成功!');
+        }
+      })
+      .catch((err) => {
+        message.success('控制异常');
+      });
+  }
+
+  function changeCtr(e) {
+    if (e == 1) {
+      // 就地
+      handlerType.value = 'jxmsqh';
+    } else if (e == 2) {
+      // 远程
+      handlerType.value = 'jxmsqh';
+    }
+    passwordModalIsShow.value = true;
+  }
+
+  function changeMode(e) {
+    if (e == 1) {
+      // 检修开
+      handlerType.value = 'ykjdqh';
+    } else if (e == 2) {
+      // 检修关
+      handlerType.value = 'ykjdqh';
+    }
+    passwordModalIsShow.value = true;
+  }
+
+  function handlerFn(paramcode) {
+    handlerType.value = paramcode;
+    passwordModalIsShow.value = true;
+  }
+
+  function handleOK(passWord, handlerState) {
+    handler(passWord, handlerState);
+    passwordModalIsShow.value = false;
+    handlerType.value = '';
+  }
+
+  function handleCancel() {
+    passwordModalIsShow.value = false;
+    handlerType.value = '';
+  }
+
+  watch(
+    () => props.deviceType,
+    () => {
+      removeCamera();
+      nextTick(async () => {
+        if (props.deviceType == 'pump_over') {
+          setModelType('gasPump');
+        } else if (props.deviceType?.startsWith('pump_under') || props.deviceType == 'pump_n12m2pq') {
+          setModelType('gasPumpUnder');
+        }
+      });
+    }
+  );
+  watch(
+    () => props.deviceId,
+    async (deviceID) => {
+      removeCamera();
+      if (deviceID) await getCamera(deviceID, playerRef.value);
+    }
+  );
+
+  onMounted(async () => {
+    timer = null;
+    await getMonitor(true);
+    // fetchConfigs("gasPumpMonitor")
+    // if (selectData && selectData['deviceID']) await getCamera(selectData['deviceID'], playerRef.value);
+  });
+
+  onBeforeUnmount(() => {
+    removeCamera();
+  });
+
+  onUnmounted(() => {
+    removeCamera();
+    if (timer) {
+      clearTimeout(timer);
+      timer = undefined;
+    }
+  });
+
+  // const { configs, fetchConfigs } = useInitConfigs();
+  const configs = ref<Config[]>([
+    {
+      deviceType: '',
+      moduleName: '瓦斯泵',
+      pageType: '',
+      moduleData: {
+        header: {
+          show: false,
+          readFrom: '',
+          selector: {
+            show: false,
+            value: '${strinstallpos}',
+          },
+          slot: {
+            show: false,
+            value: '',
+          },
+        },
+        background: {
+          show: false,
+          type: 'image',
+          link: '',
+        },
+        layout: {
+          direction: 'column',
+          items: [
+            {
+              name: 'list',
+              basis: '100%',
+            },
+          ],
+        },
+        complex_list: [],
+        chart: [],
+        table: [],
+        gallery: [],
+        list: [
+          {
+            type: 'K',
+            readFrom: '',
+            items: [
+              {
+                label: '状态',
+                value: '${readData.value_status}',
+                color: 'blue',
+              },
+            ],
+          },
+        ],
+        gallery_list: [],
+        preset: [],
+        to: '',
+      },
+      showStyle: {
+        size: 'width:348px;height:300px;',
+        version: '原版',
+        position: 'top:30px;left:10px;',
+      },
+    },
+    {
+      deviceType: '',
+      moduleName: '注水泵',
+      pageType: '',
+      moduleData: {
+        header: {
+          show: false,
+          readFrom: '',
+          selector: {
+            show: false,
+            value: '${strinstallpos}',
+          },
+          slot: {
+            show: false,
+            value: '',
+          },
+        },
+        background: {
+          show: false,
+          type: 'image',
+          link: '',
+        },
+        layout: {
+          direction: 'column',
+          items: [
+            {
+              name: 'list',
+              basis: '100%',
+            },
+          ],
+        },
+        complex_list: [],
+        chart: [],
+        table: [],
+        gallery: [],
+        list: [
+          {
+            type: 'K',
+            readFrom: '',
+            items: [
+              {
+                label: '阀门2开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+              {
+                label: '阀门3开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+              {
+                label: '阀门1开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+            ],
+          },
+        ],
+        gallery_list: [],
+        preset: [],
+        to: '',
+      },
+      showStyle: {
+        size: 'width:348px;height:200px;',
+        version: '原版',
+        position: 'top:340px;left:10px;',
+      },
+    },
+    {
+      deviceType: '',
+      moduleName: '排水泵',
+      pageType: '',
+      moduleData: {
+        header: {
+          show: false,
+          readFrom: '',
+          selector: {
+            show: false,
+            value: '${strinstallpos}',
+          },
+          slot: {
+            show: false,
+            value: '',
+          },
+        },
+        background: {
+          show: false,
+          type: 'image',
+          link: '',
+        },
+        layout: {
+          direction: 'column',
+          items: [
+            {
+              name: 'list',
+              basis: '100%',
+            },
+          ],
+        },
+        complex_list: [],
+        chart: [],
+        table: [],
+        gallery: [],
+        list: [
+          {
+            type: 'K',
+            readFrom: '',
+            items: [
+              {
+                label: '阀门2开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+              {
+                label: '阀门3开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+              {
+                label: '阀门1开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+            ],
+          },
+        ],
+        gallery_list: [],
+        preset: [],
+        to: '',
+      },
+      showStyle: {
+        size: 'width:348px;height:200px;',
+        version: '原版',
+        position: 'top:550px;left:10px;',
+      },
+    },
+    {
+      deviceType: '',
+      moduleName: '泵站检测详情',
+      pageType: '',
+      moduleData: {
+        header: {
+          show: false,
+          readFrom: '',
+          selector: {
+            show: false,
+            value: '${strinstallpos}',
+          },
+          slot: {
+            show: false,
+            value: '',
+          },
+        },
+        background: {
+          show: false,
+          type: 'image',
+          link: '',
+        },
+        layout: {
+          direction: 'column',
+          items: [
+            {
+              name: 'list',
+              basis: '100%',
+            },
+          ],
+        },
+        complex_list: [
+          // {
+          //   type: 'G',
+          //   readFrom: '',
+          //   items: [
+          //     {
+          //       title: 'datalist细则',
+          //       contents: [
+          //         {
+          //           label: '阀门2开度',
+          //           value: '${readData.Fan1fI}',
+          //           color: 'blue',
+          //         },
+          //       ],
+          //     },
+          //   ],
+          // },
+        ],
+        chart: [],
+        table: [],
+        gallery: [],
+        list: [
+          {
+            type: 'K',
+            readFrom: '',
+            items: [
+              {
+                label: '阀门2开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+              {
+                label: '阀门3开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+              {
+                label: '阀门1开度',
+                value: '${readData.Fan1fI}',
+                color: 'blue',
+              },
+            ],
+          },
+        ],
+        gallery_list: [],
+        preset: [],
+        to: '',
+      },
+      showStyle: {
+        size: 'width:348px;height:490px;',
+        version: '原版',
+        position: 'top:220px;right:0px;',
+      },
+    },
+  ]);
+</script>
+<style lang="less" scoped>
+  @import '/@/design/theme.less';
+  @import '/@/design/vent/modal.less';
+  @import '../../comment/less/workFace.less';
+  @ventSpace: zxm;
+
+  .elementContent {
+    :deep(.main-container) {
+      display: flex;
+      flex-wrap: wrap;
+      width: 690px;
+      padding: 10px 12px 10px 15px;
+      border: 1px solid #d3e1ff33;
+      background-color: #061c2a55;
+      box-shadow: 0 0 15px #3b567f55;
+      background-color: #38383833;
+      .gas-monitor-row {
+        display: flex;
+        flex-direction: row;
+        flex-wrap: wrap;
+        color: #fff;
+        line-height: 32px;
+        .title {
+          width: 250px;
+          color: #baeaff;
+        }
+        .value {
+          width: 80px;
+          color: #efae05;
+        }
+      }
+    }
+  }
+  .modal-monitor-box {
+    background-color: #000;
+    color: #fff;
+    padding: 0 5px;
+    display: flex;
+    align-items: center;
+    justify-content: center;
+    .title {
+      margin-right: 5px;
+    }
+    .signal-round {
+      margin-left: 5px;
+    }
+    .value {
+      width: 30px;
+      color: #efae05;
+    }
+  }
+  .device-state {
+    width: 100%;
+    position: absolute;
+    top: 20px;
+    color: #e90000;
+    display: flex;
+    justify-content: center;
+    font-size: 20px;
+  }
+
+  .lr {
+    margin-top: 0 !important;
+  }
+  .left-box {
+    width: 360px !important;
+    direction: rtl;
+    overflow-y: auto;
+    overflow-x: hidden;
+    height: calc(100% - 60px);
+    margin-top: 30px !important;
+
+    .left-container {
+      direction: ltr;
+    }
+  }
+  .right-box {
+    width: 350px !important;
+    overflow-y: auto;
+    overflow-x: hidden;
+    .environment-monitor {
+      .item {
+        flex: 1;
+        margin: 0 5px;
+        .title {
+          color: #7ae5ff;
+          text-align: center;
+          margin-bottom: 2px;
+        }
+        .num {
+          width: 100%;
+          height: 30px;
+          text-align: center;
+          border-top: 2px solid #50c8fc;
+          border-radius: 4px;
+          background-image: linear-gradient(#2e4d5955, #3780b499, #2e465955);
+        }
+      }
+    }
+    .pool-box {
+      width: 327px;
+      height: 65px;
+      padding: 0 5px;
+      background: url('/@/assets/images/vent/pump1.png') no-repeat;
+      background-size: cover;
+      background-origin: content-box;
+      margin-top: 2px;
+      .num {
+        color: aqua;
+      }
+      .center {
+        padding-right: 5px;
+      }
+    }
+  }
+  .player-box {
+    position: absolute;
+    height: 100%;
+    width: 100%;
+    padding: 0 20px 0 20px;
+    z-index: 9999;
+    display: flex;
+    align-items: end;
+    bottom: 80px;
+    :deep(#LivePlayerBox) {
+      display: flex;
+      justify-content: end;
+    }
+  }
+
+  .input-box {
+    width: calc(100%);
+    display: flex;
+    flex-direction: row !important;
+    flex-wrap: wrap !important;
+    .input-item {
+      width: calc(50% - 8px);
+      padding: 0 2px;
+
+      &:nth-child(2n) {
+        margin-left: 4px;
+      }
+    }
+  }
+  .btn-group {
+    display: flex;
+    justify-content: space-around;
+    .btn-item {
+      width: 82px;
+      text-align: center;
+    }
+  }
+  .top-btn {
+    .btn-group {
+      margin-bottom: 8px;
+      .btn-item {
+        width: calc(50% - 16px);
+        margin: 0 4px;
+      }
+    }
+    .control-item {
+      margin-left: 10px;
+      margin-bottom: 8px;
+      display: flex;
+      .control-title {
+        width: 80px;
+        color: var(--vent-font-action-link);
+      }
+      .control-container {
+        display: flex;
+      }
+    }
+  }
+  .btn-box {
+    display: flex;
+    .btn {
+      padding: 0 8px !important;
+      margin: 0 2px;
+    }
+  }
+  .state-header {
+    display: flex;
+    color: var(--vent-font-action-link);
+    .header-item {
+      width: 25%;
+      text-align: center;
+    }
+  }
+  .device-row {
+    display: flex;
+    margin-top: 10px;
+    .state {
+      width: 25%;
+      text-align: center;
+      font-size: 13px;
+    }
+  }
+
+  :deep(.@{ventSpace}-tabs-tabpane-active) {
+    overflow: auto;
+  }
+  :deep(.list-item__background) {
+    background-image: linear-gradient(to right, #39deff15, #3977e500) !important;
+    line-height: 30px !important;
+    height: 30px !important;
+  }
+</style>