| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601 | <template>  <a-spin tip="Loading..." :spinning="loading">    <div class="monitor-container">      <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"        :chartData="mockData"        :visible="true"      /> </div  ></a-spin></template><script setup lang="ts">import { ref, onMounted, onUnmounted, defineProps } from 'vue';import { mountedThree, destroy, setModelType, updateText, play } from '../balancePress.threejs';import { list, getO2PressData } from '../balancePress.api';import ModuleCommon from '../../../home/configurable/components/ModuleCommon.vue';import { useInitConfigs } from '../../../home/configurable/hooks/useInit';import { useGlobSetting } from '/@/hooks/setting';import ventBox1 from '/@/components/vent/ventBox1.vue';import CustomChart from '@/views/vent/home/configurable/components/detail/CustomChart.vue';import { PressO2Option, mockData1 } from '../balancePressO2.data';// import { Config } from '../../../deviceManager/configurationTable/types';const props = defineProps({  deviceId: {    type: String,    require: true,  },});const { sysOrgCode } = useGlobSetting();const loading = ref(false);// 监测数据const selectData = ref();const mockData = ref<{ chartData: { dateTime: string; o2Val: string; pressureVal: string }[] }>({  chartData: [],});const O2PressDataFetched = ref(false);const modelsensorO2Data = ref<any[]>([]);// https获取监测数据let timer: any = null;function getMonitor(flag?) {  if (Object.prototype.toString.call(timer) === '[object Null]') {    timer = setTimeout(      async () => {        if (props.deviceId) {          const data = await getDataSource(props.deviceId);          // Object.assign(selectData, data);          updateText(selectData);          selectData.value = data;        }        if (timer) {          timer = null;        }        await getMonitor();        loading.value = false;      },      flag ? 0 : 1000    );  }}async function getDataSource(systemID) {  const res = await list({ devicetype: 'sys', systemID });  const result = Array.from(res.msgTxt).reduce(    (obj: any, e: any) => {      // if (true) {      modelsensorO2Data.value = [];      if (sysOrgCode === 'sdmtjtswmk') {        if (e.type.startsWith('fanlocal')) {          obj.fanlocal.datalist.push(...e.datalist);        }        if (e.type.startsWith('safetymonitor')) {          e.datalist.forEach((ele) => {            if (ele.strinstallpos.includes('风门')) {              obj.gate.datalist.push(ele);            } else if (ele.strinstallpos.includes('风窗')) {              obj.window.datalist.push(ele);            } else if (ele.strinstallpos.includes('工作面')) {              obj.work_surface.datalist.push(ele);            } else {              obj.others.datalist.push(ele);            }          });        }        if (e.type.startsWith('avgpressure_lowoxygen')) {          e.datalist.forEach((ele) => {            ele.strinstallpos = ele.strinstallpos.replaceAll(' ', '');            ele.strname = ele.strname.replaceAll(' ', '');          });        }      }      if (e.type.includes('modelsensor_o2')) {        modelsensorO2Data.value.push(...e.datalist);        console.log(modelsensorO2Data.value, '氧气数据');        if (!O2PressDataFetched.value) {          O2PressDataFetched.value = true;          getO2Press(modelsensorO2Data.value);        }      }      obj[e.type] = e;      return obj;    },    {      /** 用于归类fanlocal */      fanlocal: { datalist: [] },      /** 用于归类gate */      gate: { datalist: [] },      /** 用于归类window */      window: { datalist: [] },      /** 用于归类work_surface */      work_surface: { datalist: [] },      others: { datalist: [] },    }  );  return result;}// const configs = ref<Config[]>([//   {//     deviceType: 'fanlocal',//     moduleName: '局部风机',//     pageType: 'balancePressHome',//     moduleData: {//       header: {//         show: true,//         readFrom: 'datalist',//         selector: {//           show: true,//           value: '${deviceID}',//           trans: {//             '1910221332833665026': '主机',//             '1910221283626090497': '备机',//           },//         },//         slot: {//           show: false,//           value: '',//         },//       },//       background: {//         show: false,//         type: 'image',//         link: '',//       },//       layout: {//         direction: 'column',//         items: [//           {//             name: 'tabs',//             basis: '100%',//           },//         ],//       },//       complex_list: [],//       chart: [],//       table: [],//       gallery: [],//       list: [],//       tabs: [//         {//           type: 'K',//           readFrom: '',//           mapFromData: false,//           items: [//             {//               title: '电机1',//               contents: [//                 {//                   label: '输出功率',//                   value: '${readData.Fan1StartStatus}',//                   color: 'blue',//                 },//                 {//                   label: '输出电压',//                   value: '${readData.Fan1StartStatus}',//                   color: 'blue',//                 },//               ],//             },//             {//               title: '电机2',//               contents: [//                 {//                   label: '输出功率',//                   value: '${readData.Fan2StartStatus}',//                   color: 'blue',//                 },//                 {//                   label: '输出电压',//                   value: '${readData.Fan2StartStatus}',//                   color: 'blue',//                 },//                 {//                   label: '输出电压',//                   value: '${readData.Fan2StartStatus}',//                   color: 'blue',//                 },//                 {//                   label: '输出电压',//                   value: '${readData.Fan2StartStatus}',//                   color: 'blue',//                 },//               ],//             },//           ],//         },//       ],//       gallery_list: [],//       preset: [],//       to: '',//     },//     showStyle: {//       size: 'width:470px;height:260px;',//       version: '原版',//       position: 'top:20px;left:0;',//     },//   },//   {//     deviceType: '',//     moduleName: '风门',//     pageType: 'balancePressHome',//     moduleData: {//       header: {//         show: false,//         readFrom: '',//         selector: {//           show: false,//           value: '',//         },//         slot: {//           show: false,//           value: '',//         },//       },//       background: {//         show: false,//         type: 'image',//         link: '',//       },//       layout: {//         direction: 'column',//         items: [//           {//             name: 'complex_list',//             basis: '100%',//           },//         ],//       },//       complex_list: [//         {//           type: 'G',//           readFrom: 'gate.datalist',//           mapFromData: true,//           items: [//             {//               title: '${deviceID}',//               trans: {//                 '1915631893453004802': '22107胶运顺槽入口自动风门2',//                 '1915631893478170626': '22107胶运顺槽入口自动风门1',//                 '1915631897043329025': '22107辅回撤通道自动风门1',//                 '1915631895088783362': '22107辅回撤通道自动风门2',//               },//               contents: [//                 {//                   label: '状态',//                   value: '${readData.V}',//                   color: 'blue',//                 },//               ],//             },//           ],//         },//       ],//       chart: [],//       table: [],//       gallery: [],//       list: [],//       gallery_list: [],//       preset: [],//       to: '',//     },//     showStyle: {//       size: 'width:470px;height:320px;',//       version: '原版',//       position: 'top:290px;left:0;',//     },//   },//   {//     deviceType: '',//     moduleName: '综采工作面推进度',//     pageType: 'balancePressHome',//     moduleData: {//       header: {//         show: false,//         readFrom: '',//         selector: {//           show: false,//           value: '',//         },//         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: '50%',//               color: 'blue',//             },//             {//               label: '埋深',//               value: '2000km',//               color: 'blue',//             },//           ],//         },//       ],//       gallery_list: [],//       preset: [],//       to: '',//     },//     showStyle: {//       size: 'width:470px;height:130px;',//       version: '原版',//       position: 'top:620px;left:0;',//     },//   },//   {//     deviceType: '',//     moduleName: '重点监控传感器',//     pageType: 'balancePressHome',//     moduleData: {//       header: {//         show: false,//         readFrom: '',//         selector: {//           show: false,//           value: '',//         },//         slot: {//           show: false,//           value: '',//         },//       },//       background: {//         show: false,//         type: 'image',//         link: '',//       },//       layout: {//         direction: 'column',//         items: [//           {//             name: 'complex_list',//             basis: '100%',//           },//         ],//       },//       complex_list: [//         {//           type: 'G',//           readFrom: 'avgpressure_lowoxygen_normal.datalist',//           mapFromData: true,//           items: [//             {//               title: '${strinstallpos}',//               contents: [//                 {//                   label: '网络状态',//                   value: '${readData.netStatus_str}',//                   color: 'blue',//                 },//               ],//             },//           ],//         },//       ],//       chart: [],//       table: [],//       gallery: [],//       list: [],//       gallery_list: [],//       preset: [],//       to: '',//     },//     showStyle: {//       size: 'width:470px;height:230px;',//       version: '原版',//       position: 'top:20px;right:0;',//     },//   },//   {//     deviceType: '',//     moduleName: '辅助巡检传感器',//     pageType: 'balancePressHome',//     moduleData: {//       header: {//         show: false,//         readFrom: '',//         selector: {//           show: false,//           value: '',//         },//         slot: {//           show: false,//           value: '',//         },//       },//       background: {//         show: false,//         type: 'image',//         link: '',//       },//       layout: {//         direction: 'column',//         items: [//           {//             name: 'complex_list',//             basis: '100%',//           },//         ],//       },//       complex_list: [//         {//           type: 'G',//           readFrom: 'others.datalist',//           mapFromData: true,//           items: [//             {//               title: '${strinstallpos}',//               contents: [//                 {//                   label: '网络状态',//                   value: '${readData.netStatus_str}',//                   color: 'blue',//                 },//               ],//             },//           ],//         },//       ],//       chart: [],//       table: [],//       gallery: [],//       list: [],//       gallery_list: [],//       preset: [],//       to: '',//     },//     showStyle: {//       size: 'width:470px;height:230px;',//       version: '原版',//       position: 'top:260px;right:0;',//     },//   },//   {//     deviceType: '',//     moduleName: '地面大气压',//     pageType: 'balancePressHome',//     moduleData: {//       header: {//         show: false,//         readFrom: '',//         selector: {//           show: false,//           value: '',//         },//         slot: {//           show: false,//           value: '',//         },//       },//       background: {//         show: false,//         type: 'image',//         link: '',//       },//       layout: {//         direction: 'column',//         items: [//           {//             name: 'chart',//             basis: '100%',//           },//         ],//       },//       complex_list: [],//       chart: [//         {//           type: 'line_smooth',//           readFrom: 'surface_history.datalist',//           legend: { show: true },//           xAxis: [{ show: true }],//           yAxis: [//             { show: true, name: '压力1(Pa)', position: 'left' },//             { show: true, name: '压力2(Pa)', position: 'right' },//           ],//           series: [//             { readFrom: '', xprop: 'time', yprop: 'pressure1', label: '压力1' },//             // { readFrom: 'datalist', xprop: 'strinstallpos', yprop: 'readData.va', label: '风速' },//           ],//         },//       ],//       table: [],//       gallery: [],//       list: [],//       gallery_list: [],//       preset: [],//       to: '',//     },//     showStyle: {//       size: 'width:470px;height:250px;',//       version: '原版',//       position: 'top:500px;right:0;',//     },//   },// ]);async function getO2Press(params) {  console.log(params[0]?.deviceID, 'ID数据');  const deviceID = params[0]?.deviceID;  const param = {    deviceId: deviceID,  };  const res = await getO2PressData(param);  const chartData = [...res?.o2HistoryDataList, ...res?.o2List];  mockData.value = { chartData };  O2PressDataFetched.value = true;}const { configs, fetchConfigs } = useInitConfigs();onMounted(async () => {  // getMonitor()  fetchConfigs('balancePressHome');  loading.value = true;  // mountedThree().then(async () => {  //   await setModelType('balancePressTun'); //balancePressBase  //   loading.value = false;  //   timer = null;  //   await getMonitor(true);  //   play('startSmoke', 'top', 30, 'open', 0);  // });  timer = null;  await getMonitor(true);  loading.value = false;});onUnmounted(() => {  destroy();  if (timer) {    clearTimeout(timer);  }});</script><style lang="less" scoped>@import '/@/design/vent/modal.less';@import '../../comment/less/workFace.less';@ventSpace: zxm;.monitor-container {  margin-top: 60px;}.lr {  width: 340px !important;}.fix-box {  margin-right: 19% !important;  margin-top: 1% !important;}</style>
 |