Browse Source

Merge branch 'master' of http://182.92.126.35:3000/hrx/mky-vent-base

hongrunxia 1 month ago
parent
commit
0813d711a6
34 changed files with 1530 additions and 1577 deletions
  1. 1 1
      package.json
  2. 0 1
      src/components/jeecg/JVxeTable/src/hooks/useColumns.ts
  3. 0 1
      src/qiankun/index.ts
  4. 0 2
      src/store/modules/permission.ts
  5. 0 1
      src/store/modules/user.ts
  6. 0 1
      src/utils/echartsUtil.ts
  7. 0 1
      src/utils/threejs/useEvent.ts
  8. 0 1
      src/views/vent/deviceManager/comment/DeviceReportInfo.vue
  9. 4 6
      src/views/vent/deviceManager/comment/HistoryTable.vue
  10. 0 1
      src/views/vent/deviceManager/comment/warningTabel/BaseModal.vue
  11. 0 1
      src/views/vent/deviceManager/comment/warningTabel/index3.vue
  12. 0 1
      src/views/vent/home/clique/dustComponents/measure-detail.vue
  13. 0 1
      src/views/vent/monitorManager/alarmFire/index.vue
  14. 418 417
      src/views/vent/monitorManager/camera/index.vue
  15. 0 2
      src/views/vent/monitorManager/comment/HistoryTable.vue
  16. 0 1
      src/views/vent/monitorManager/deviceMC/HistoryTable.vue
  17. 71 76
      src/views/vent/monitorManager/deviceMonitor/components/device/index.vue
  18. 759 761
      src/views/vent/monitorManager/fanLocalMonitor/components/conditionAssistance.vue
  19. 0 2
      src/views/vent/monitorManager/fanLocalMonitor1/components/conditionAssistance1.vue
  20. 0 1
      src/views/vent/monitorManager/fanLocalMonitor1/index.vue
  21. 0 3
      src/views/vent/monitorManager/fireDoorMonitor/fireDoor.threejs.fireF.ts
  22. 0 1
      src/views/vent/monitorManager/fireDoorMonitor/fireDoor.threejs.ts
  23. 0 1
      src/views/vent/monitorManager/fireDoorMonitor/index.vue
  24. 0 1
      src/views/vent/monitorManager/gateMonitor/gate.threejs.noStation.ts
  25. 0 1
      src/views/vent/monitorManager/gateMonitor/gate.threejs.ts
  26. 0 1
      src/views/vent/monitorManager/gateMonitor/gate.threejs.window.ts
  27. 0 5
      src/views/vent/monitorManager/mainFanMonitor/mainWind.threejs.ts
  28. 0 1
      src/views/vent/monitorManager/mainFanMonitor/mainWind.xj.threejs.ts
  29. 0 1
      src/views/vent/monitorManager/nitrogen/nitrogen.threejs.ts
  30. 0 1
      src/views/vent/monitorManager/windowMonitor/dandaoFcBd2.threejs.ts
  31. 0 2
      src/views/vent/monitorManager/windowMonitor/shuangdaoFcBlt.threejs.ts
  32. 0 1
      src/views/vent/monitorManager/windowMonitor/window.threejs.ts
  33. 0 1
      src/views/vent/monitorManager/windrectMonitor/index.vue
  34. 277 278
      src/views/vent/safetyList/common/HistoryTable.vue

+ 1 - 1
package.json

@@ -10,7 +10,7 @@
     "pinstall": "pnpm install",
     "clean:cache": "rimraf node_modules/.cache/ && rimraf node_modules/.vite",
     "dev": "vite",
-    "build": "cross-env NODE_ENV=production NODE_OPTIONS=--max-old-space-size=81920 vite build && esno ./build/script/postBuild.ts",
+    "build": "cross-env NODE_ENV=production NODE_OPTIONS=--max-old-space-size=6144 vite build && esno ./build/script/postBuild.ts",
     "build:report": "pnpm clean:cache && cross-env REPORT=true npm run build",
     "preview": "npm run build && vite preview",
     "reinstall": "rimraf pnpm-lock.yaml && rimraf yarn.lock && rimraf package.lock.json && rimraf node_modules && npm run install",

+ 0 - 1
src/components/jeecg/JVxeTable/src/hooks/useColumns.ts

@@ -191,7 +191,6 @@ function handleExpandColumn({ props, data, col, columns }: HandleArgs) {
 
 /** 处理可排序列 */
 function handleDragSortColumn({ props, data, col, columns, renderOptions }: HandleArgs) {
-  debugger;
   // 是否可拖动排序
   if (props.dragSort) {
     let width = 40;

+ 0 - 1
src/qiankun/index.ts

@@ -64,7 +64,6 @@ const mountMicroApp = (path, toPath?) => {
 
 // 卸载app的方法
 const unmountMicroApps = (multipleApp) => {
-  debugger;
   if (JSON.stringify(activeApps) !== '{}' && multipleApp.some) {
     for (const key in activeApps) {
       const isExist = multipleApp.some((name) => name == key);

+ 0 - 2
src/store/modules/permission.ts

@@ -135,7 +135,6 @@ export const usePermissionStore = defineStore({
     },
 
     async buildRoutesAction(): Promise<AppRouteRecordRaw[]> {
-      debugger;
       const { t } = useI18n();
       const userStore = useUserStore();
       const appStore = useAppStoreWithOut();
@@ -277,7 +276,6 @@ export const usePermissionStore = defineStore({
           } catch (error) {
             console.error(error);
           }
-          debugger;
           // 组件地址前加斜杠处理  author: lsq date:2021-09-08
           routeList = addSlashToRouteComponent(routeList);
           // 动态引入组件

+ 0 - 1
src/store/modules/user.ts

@@ -184,7 +184,6 @@ export const useUserStore = defineStore({
       //获取用户信息
       const userInfo = await this.getUserInfoAction();
       const sessionTimeout = this.sessionTimeout;
-      debugger;
       if (sessionTimeout) {
         this.setSessionTimeout(false);
       } else {

+ 0 - 1
src/utils/echartsUtil.ts

@@ -36,7 +36,6 @@ export default class echartsUtil {
     const columns = JSON.parse(JSON.stringify(chartColumns));
     columns.forEach((column: any) => {
       if (!column) {
-        debugger;
       }
       const ylist = [];
       if (type == 'detail' || type == 'history') {

+ 0 - 1
src/utils/threejs/useEvent.ts

@@ -48,7 +48,6 @@ export default function useEvent() {
   };
 
   const mouseUpFn = (modal, minDistance = 5, renderCallBack?) => {
-    debugger;
     const endTime = new Date().getTime();
     if (endTime - startTime > 400) {
       intersect0 = null;

+ 0 - 1
src/views/vent/deviceManager/comment/DeviceReportInfo.vue

@@ -157,7 +157,6 @@
   onMounted(async () => {
     getColumns();
     let result;
-    debugger;
     if (!deviceData.devicekind) {
       result = await sysList({ id: deviceData.id });
     } else {

+ 4 - 6
src/views/vent/deviceManager/comment/HistoryTable.vue

@@ -65,7 +65,6 @@
       return props.columnsType;
     },
     async (newVal) => {
-      debugger;
       if (!newVal) return;
       deviceKide.value = newVal;
       if (historyTable.value) {
@@ -341,9 +340,8 @@
   }
 </style>
 <style lang="less" scoped>
-:deep(.zxm-picker-dropdown) {
-  top: 50px !important;
-  left: 5px !important;
-}
+  :deep(.zxm-picker-dropdown) {
+    top: 50px !important;
+    left: 5px !important;
+  }
 </style>
-

+ 0 - 1
src/views/vent/deviceManager/comment/warningTabel/BaseModal.vue

@@ -114,7 +114,6 @@
     const data = await getFieldsValue();
     const deviceId = data['deviceId'];
 
-    debugger;
     if (strtype) {
       await getDevicePointList(strtype);
       openModal();

+ 0 - 1
src/views/vent/deviceManager/comment/warningTabel/index3.vue

@@ -131,7 +131,6 @@
   const [register, { openModal, closeModal }] = useModal();
 
   function handleOpen(flag?, record?) {
-    debugger;
     if (record) {
       if (flag == 'update') {
         openModal(true, {

+ 0 - 1
src/views/vent/home/clique/dustComponents/measure-detail.vue

@@ -90,7 +90,6 @@
     (newS, oldV) => {
       if (newS.length != 0) {
         selectList.value = newS;
-        debugger;
         if (!oldV || oldV.length == 0) {
           const index = selectList.value.findIndex((item) => item['orgcode'] == selectVal.value);
           if (index > -1) {

+ 0 - 1
src/views/vent/monitorManager/alarmFire/index.vue

@@ -113,7 +113,6 @@
         if (item.type === 'fiber_v1') {
           // 光纤测温特殊处理
           const list = data[0]['fibreTemperature'] ? JSON.parse(data[0]['fibreTemperature']) : [];
-          debugger;
           list.filter((detailItem) => {
             detailItem['readTime'] = data[0]['readTime'];
             detailItem['strinstallpos'] = `测点${detailItem['pos']}`;

+ 418 - 417
src/views/vent/monitorManager/camera/index.vue

@@ -40,334 +40,271 @@
   </div>
 </template>
 <script lang="ts" setup>
-import { onMounted, onUnmounted, ref, reactive, computed } from 'vue';
-import { useRouter } from 'vue-router';
-import { Pagination, Empty } from 'ant-design-vue';
-import { list, cameraAddr, getCameraDevKind, getDevice, getVentanalyCamera } from './camera.api';
-import Player, { I18N } from 'xgplayer';
-import ZH from 'xgplayer/es/lang/zh-cn';
-import HlsPlugin from 'xgplayer-hls';
-import FlvPlugin from 'xgplayer-flv';
-import 'xgplayer/dist/index.min.css';
-import cameraTree from './common/cameraTree.vue';
-import { SvgIcon } from '/@/components/Icon';
-import treeIcon from './common/Icon/treeIcon.vue';
+  import { onMounted, onUnmounted, ref, reactive, computed } from 'vue';
+  import { useRouter } from 'vue-router';
+  import { Pagination, Empty } from 'ant-design-vue';
+  import { list, cameraAddr, getCameraDevKind, getDevice, getVentanalyCamera } from './camera.api';
+  import Player, { I18N } from 'xgplayer';
+  import ZH from 'xgplayer/es/lang/zh-cn';
+  import HlsPlugin from 'xgplayer-hls';
+  import FlvPlugin from 'xgplayer-flv';
+  import 'xgplayer/dist/index.min.css';
+  import cameraTree from './common/cameraTree.vue';
+  import { SvgIcon } from '/@/components/Icon';
+  import treeIcon from './common/Icon/treeIcon.vue';
 
-//当前选中树节点
-let selected = reactive<any>({
-  id: null,
-  pid: null,
-  title: '',
-  isFolder: false,
-});
-//tree菜单列表
-let listArr = reactive<any[]>([]);
-let searchParam = reactive({
-  devKind: '',
-  strType: '',
-});
+  //当前选中树节点
+  let selected = reactive<any>({
+    id: null,
+    pid: null,
+    title: '',
+    isFolder: false,
+  });
+  //tree菜单列表
+  let listArr = reactive<any[]>([]);
+  let searchParam = reactive({
+    devKind: '',
+    strType: '',
+  });
 
-I18N.use(ZH);
-let router = useRouter(); //路由
-const pageSize = ref(4);
-const current = ref(1);
-const total = ref(0);
-const playerList = ref([]);
-const webRtcServerList = <any[]>[];
-let addrList = ref<{ name: string; addr: string; cameraRate: number; devicekind: string }[]>([]);
-async function getCameraDevKindList() {
-  let res = await getCameraDevKind();
-  if (res.length != 0) {
-    listArr.length = 0;
-    listArr.push({
-      pid: 'root',
-      isFolder: true,
-      expanded: true,
-      title: '全部',
-      id: 0,
-      children: [],
-    });
-    res.forEach((el) => {
-      el.pid = 0;
-      el.isFolder = true; el.expanded = false; el.title = el.itemText;
-      el.id = el.subDictId;
-      el.children = [];
-      listArr[0].children.push(el);
-    });
-    selected.id = listArr[0].id;
-    selected.pid = listArr[0].pid;
-    selected.title = listArr[0].title;
-    selected.isFolder = listArr[0].isFolder;
+  I18N.use(ZH);
+  let router = useRouter(); //路由
+  const pageSize = ref(4);
+  const current = ref(1);
+  const total = ref(0);
+  const playerList = ref([]);
+  const webRtcServerList = <any[]>[];
+  let addrList = ref<{ name: string; addr: string; cameraRate: number; devicekind: string }[]>([]);
+  async function getCameraDevKindList() {
+    let res = await getCameraDevKind();
+    if (res.length != 0) {
+      listArr.length = 0;
+      listArr.push({
+        pid: 'root',
+        isFolder: true,
+        expanded: true,
+        title: '全部',
+        id: 0,
+        children: [],
+      });
+      res.forEach((el) => {
+        el.pid = 0;
+        el.isFolder = true;
+        el.expanded = false;
+        el.title = el.itemText;
+        el.id = el.subDictId;
+        el.children = [];
+        listArr[0].children.push(el);
+      });
+      selected.id = listArr[0].id;
+      selected.pid = listArr[0].pid;
+      selected.title = listArr[0].title;
+      selected.isFolder = listArr[0].isFolder;
+    }
   }
-}
 
-//点击目录
-async function onClick(node) {
-  if (selected.title === node.title && selected.id === node.id) return;
-  current.value = 1;
-  selected.id = node.id;
-  selected.pid = node.pid;
-  selected.title = node.title;
-  selected.isFolder = node.isFolder;
-  if (node.pid != 'root') {
-    if (node.isFolder) {
-      let types, devicetype;
-      if (node.itemValue.indexOf('&') != -1) {
-        types = node.itemValue.substring(node.itemValue.indexOf('&') + 1);
-        devicetype = node.itemValue.substring(0, node.itemValue.indexOf('&'));
+  //点击目录
+  async function onClick(node) {
+    if (selected.title === node.title && selected.id === node.id) return;
+    current.value = 1;
+    selected.id = node.id;
+    selected.pid = node.pid;
+    selected.title = node.title;
+    selected.isFolder = node.isFolder;
+    if (node.pid != 'root') {
+      if (node.isFolder) {
+        let types, devicetype;
+        if (node.itemValue.indexOf('&') != -1) {
+          types = node.itemValue.substring(node.itemValue.indexOf('&') + 1);
+          devicetype = node.itemValue.substring(0, node.itemValue.indexOf('&'));
+        } else {
+          types = '';
+          devicetype = '';
+        }
+        let res = await getDevice({ ids: types, devicetype: devicetype });
+        if (res.msgTxt.length != 0) {
+          res.msgTxt[0].datalist.forEach((el) => {
+            el.pid = node.id;
+            el.isFolder = false;
+            el.title = el.strinstallpos;
+            el.id = el.deviceID;
+          });
+          listArr[0].children.forEach((v) => {
+            if (v.id == node.id) {
+              v.children = res.msgTxt[0].datalist;
+            }
+          });
+        }
+        searchParam.devKind = node.itemValue;
+        searchParam.strType = '';
+        await getVideoAddrs();
+        getVideo();
       } else {
-        types = '';
-        devicetype = '';
+        await getVideoAddrsSon(node.deviceID);
+        getVideo();
       }
-      let res = await getDevice({ ids: types, devicetype: devicetype });
-      if (res.msgTxt.length != 0) {
-        res.msgTxt[0].datalist.forEach((el) => {
-          el.pid = node.id;
-          el.isFolder = false;
-          el.title = el.strinstallpos;
-          el.id = el.deviceID;
-        });
-        listArr[0].children.forEach((v) => {
-          if (v.id == node.id) {
-            v.children = res.msgTxt[0].datalist;
-          }
-        });
-      }
-      searchParam.devKind = node.itemValue;
+    } else {
+      searchParam.devKind = '';
       searchParam.strType = '';
       await getVideoAddrs();
       getVideo();
-    } else {
-      await getVideoAddrsSon(node.deviceID);
-      getVideo();
     }
-  } else {
-    searchParam.devKind = '';
-    searchParam.strType = '';
-    await getVideoAddrs();
-    getVideo();
   }
-}
 
-//点击详情跳转
-function onDetail(node) {
-  let str = listArr[0].children.filter((v) => v.id == node.pid)[0].itemValue;
-  let type = str.indexOf('&') != -1 ? str.substring(0, str.indexOf('&')) : '';
-  console.log(type, 'type--------');
-  switch (type) {
-    case 'pulping': //注浆
-      router.push('/grout-home');
-      break;
-    case 'window': //自动风窗
-      router.push('/monitorChannel/monitor-window?id=' + node.deviceID);
-      break;
-    case 'gate': //自动风门
-      router.push('/monitorChannel/monitor-gate?id=' + node.deviceID + '&deviceType=' + node.deviceType);
-      break;
-    case 'fanlocal': //局部风机
-      router.push('/monitorChannel/monitor-fanlocal?id=' + node.deviceID + '&deviceType=fanlocal');
-      break;
-    case 'fanmain': //主风机
-      router.push('/monitorChannel/monitor-fanmain?id=' + node.deviceID);
-      break;
-    case 'forcFan': //压风机
-      router.push('/forcFan/home');
-      break;
-    case 'pump': //瓦斯抽采泵
-      router.push('/monitorChannel/gasPump-home');
-      break;
-    case 'nitrogen': //制氮
-      router.push('/nitrogen-home');
-      break;
+  //点击详情跳转
+  function onDetail(node) {
+    let str = listArr[0].children.filter((v) => v.id == node.pid)[0].itemValue;
+    let type = str.indexOf('&') != -1 ? str.substring(0, str.indexOf('&')) : '';
+    console.log(type, 'type--------');
+    switch (type) {
+      case 'pulping': //注浆
+        router.push('/grout-home');
+        break;
+      case 'window': //自动风窗
+        router.push('/monitorChannel/monitor-window?id=' + node.deviceID);
+        break;
+      case 'gate': //自动风门
+        router.push('/monitorChannel/monitor-gate?id=' + node.deviceID + '&deviceType=' + node.deviceType);
+        break;
+      case 'fanlocal': //局部风机
+        router.push('/monitorChannel/monitor-fanlocal?id=' + node.deviceID + '&deviceType=fanlocal');
+        break;
+      case 'fanmain': //主风机
+        router.push('/monitorChannel/monitor-fanmain?id=' + node.deviceID);
+        break;
+      case 'forcFan': //压风机
+        router.push('/forcFan/home');
+        break;
+      case 'pump': //瓦斯抽采泵
+        router.push('/monitorChannel/gasPump-home');
+        break;
+      case 'nitrogen': //制氮
+        router.push('/nitrogen-home');
+        break;
+    }
   }
-}
 
-async function getVideoAddrs() {
-  clearCamera();
-  playerList.value = [];
-  let paramKind = searchParam.devKind.substring(0, searchParam.devKind.indexOf('&'));
-  let res = await list({ devKind: paramKind, strType: searchParam.strType, pageSize: pageSize.value, pageNo: current.value });
-  total.value = res['total'] || 0;
-  if (res.records.length != 0) {
-    const cameraList = <{ name: string; addr: string; cameraRate: number; devicekind: string }[]>[];
-    const cameras = res.records;
-    for (let i = 0; i < cameras.length; i++) {
-      const item = cameras[i];
+  async function getVideoAddrs() {
+    clearCamera();
+    playerList.value = [];
+    let paramKind = searchParam.devKind.substring(0, searchParam.devKind.indexOf('&'));
+    let res = await list({ devKind: paramKind, strType: searchParam.strType, pageSize: pageSize.value, pageNo: current.value });
+    total.value = res['total'] || 0;
+    if (res.records.length != 0) {
+      const cameraList = <{ name: string; addr: string; cameraRate: number; devicekind: string }[]>[];
+      const cameras = res.records;
+      for (let i = 0; i < cameras.length; i++) {
+        const item = cameras[i];
 
-      if (item['devicekind'] === 'toHKRtsp' || item['devicekind'] === 'toHKHLs' || item['devicekind'] === 'HLL') {
-        // 从海康平台接口获取视频流
-        const videoType = item['devicekind'] === 'toHKRtsp' ? 'rtsp' : '';
-        try {
-          const data = await cameraAddr({ cameraCode: item['addr'], videoType });
-          if (data && data['url']) {
-            cameraList.push({ name: item['name'], addr: data['url'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
+        if (item['devicekind'] === 'toHKRtsp' || item['devicekind'] === 'toHKHLs' || item['devicekind'] === 'HLL') {
+          // 从海康平台接口获取视频流
+          const videoType = item['devicekind'] === 'toHKRtsp' ? 'rtsp' : '';
+          try {
+            const data = await cameraAddr({ cameraCode: item['addr'], videoType });
+            if (data && data['url']) {
+              cameraList.push({ name: item['name'], addr: data['url'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
+            }
+            // cameraList.push({
+            //   name: item['name'],
+            //   // addr: 'http://219.151.31.38/liveplay-kk.rtxapp.com/live/program/live/hnwshd/4000000/mnf.m3u8'
+            //   addr: 'https://demo.unified-streaming.com/k8s/features/stable/video/tears-of-steel/tears-of-steel.mp4/.m3u8',
+            // });
+          } catch (error) {}
+        } else {
+          if (item['addr'].includes('0.0.0.0')) {
+            item['addr'] = item['addr'].replace('0.0.0.0', window.location.hostname);
           }
-          // cameraList.push({
-          //   name: item['name'],
-          //   // addr: 'http://219.151.31.38/liveplay-kk.rtxapp.com/live/program/live/hnwshd/4000000/mnf.m3u8'
-          //   addr: 'https://demo.unified-streaming.com/k8s/features/stable/video/tears-of-steel/tears-of-steel.mp4/.m3u8',
-          // });
-        } catch (error) { }
-      } else {
-        if (item['addr'].includes('0.0.0.0')) {
-          item['addr'] = item['addr'].replace('0.0.0.0', window.location.hostname);
+          cameraList.push({ name: item['name'], addr: item['addr'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
         }
-        cameraList.push({ name: item['name'], addr: item['addr'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
       }
+      addrList.value = cameraList;
+      console.log(addrList.value, ' addrList.value-------------');
     }
-    addrList.value = cameraList;
-    console.log(addrList.value, ' addrList.value-------------');
   }
-}
 
-async function getVideoAddrsSon(Id) {
-  clearCamera();
-  playerList.value = [];
-  let res = await getVentanalyCamera({ deviceid: Id });
-  if (res.records.length != 0) {
-    const cameraList = <{ name: string; addr: string; cameraRate: number; devicekind: string }[]>[];
-    const cameras = res.records;
-    for (let i = 0; i < cameras.length; i++) {
-      const item = cameras[i];
+  async function getVideoAddrsSon(Id) {
+    clearCamera();
+    playerList.value = [];
+    let res = await getVentanalyCamera({ deviceid: Id });
+    if (res.records.length != 0) {
+      const cameraList = <{ name: string; addr: string; cameraRate: number; devicekind: string }[]>[];
+      const cameras = res.records;
+      for (let i = 0; i < cameras.length; i++) {
+        const item = cameras[i];
 
-      if (item['devicekind'] === 'toHKRtsp' || item['devicekind'] === 'toHKHLs' || item['devicekind'] === 'HLL') {
-        // 从海康平台接口获取视频流
-        const videoType = item['devicekind'] === 'toHKRtsp' ? 'rtsp' : '';
-        try {
-          const data = await cameraAddr({ cameraCode: item['addr'], videoType });
-          if (data && data['url']) {
-            cameraList.push({ name: item['name'], addr: data['url'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
+        if (item['devicekind'] === 'toHKRtsp' || item['devicekind'] === 'toHKHLs' || item['devicekind'] === 'HLL') {
+          // 从海康平台接口获取视频流
+          const videoType = item['devicekind'] === 'toHKRtsp' ? 'rtsp' : '';
+          try {
+            const data = await cameraAddr({ cameraCode: item['addr'], videoType });
+            if (data && data['url']) {
+              cameraList.push({ name: item['name'], addr: data['url'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
+            }
+            // cameraList.push({
+            //   name: item['name'],
+            //   // addr: 'http://219.151.31.38/liveplay-kk.rtxapp.com/live/program/live/hnwshd/4000000/mnf.m3u8'
+            //   addr: 'https://demo.unified-streaming.com/k8s/features/stable/video/tears-of-steel/tears-of-steel.mp4/.m3u8',
+            // });
+          } catch (error) {}
+        } else {
+          if (item['addr'].includes('0.0.0.0')) {
+            item['addr'] = item['addr'].replace('0.0.0.0', window.location.hostname);
           }
-          // cameraList.push({
-          //   name: item['name'],
-          //   // addr: 'http://219.151.31.38/liveplay-kk.rtxapp.com/live/program/live/hnwshd/4000000/mnf.m3u8'
-          //   addr: 'https://demo.unified-streaming.com/k8s/features/stable/video/tears-of-steel/tears-of-steel.mp4/.m3u8',
-          // });
-        } catch (error) { }
-      } else {
-        if (item['addr'].includes('0.0.0.0')) {
-          item['addr'] = item['addr'].replace('0.0.0.0', window.location.hostname);
+          cameraList.push({ name: item['name'], addr: item['addr'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
         }
-        cameraList.push({ name: item['name'], addr: item['addr'], cameraRate: item['cameraRate'], devicekind: item['devicekind'] });
       }
+      addrList.value = cameraList;
     }
-    addrList.value = cameraList;
   }
-}
 
-async function onChange(page) {
-  current.value = page;
-  await getVideoAddrs();
-  getVideo();
-}
+  async function onChange(page) {
+    current.value = page;
+    await getVideoAddrs();
+    getVideo();
+  }
 
-function getVideo() {
-  const ip = VUE_APP_URL.webRtcUrl;
-  for (let i = 0; i < addrList.value.length; i++) {
-    const item = addrList.value[i];
-    if (item.addr.startsWith('rtsp://')) {
-      const dom = document.getElementById('video' + i) as HTMLVideoElement;
-      dom.muted = true;
-      dom.volume = 0;
-      const webRtcServer = new window['WebRtcStreamer'](dom, location.protocol + ip);
-      webRtcServerList.push(webRtcServer);
-      webRtcServer.connect(item.addr);
-    } else {
-      setNoRtspVideo('player' + i, item.addr, item.cameraRate, item.devicekind);
+  function getVideo() {
+    const ip = VUE_APP_URL.webRtcUrl;
+    for (let i = 0; i < addrList.value.length; i++) {
+      const item = addrList.value[i];
+      if (item.addr.startsWith('rtsp://')) {
+        const dom = document.getElementById('video' + i) as HTMLVideoElement;
+        dom.muted = true;
+        dom.volume = 0;
+        const webRtcServer = new window['WebRtcStreamer'](dom, location.protocol + ip);
+        webRtcServerList.push(webRtcServer);
+        webRtcServer.connect(item.addr);
+      } else {
+        setNoRtspVideo('player' + i, item.addr, item.cameraRate, item.devicekind);
+      }
     }
   }
-}
 
-function setNoRtspVideo(id, videoAddr, cameraRate, devicekind) {
-  debugger;
-  const fileExtension = videoAddr.split('.').pop();
-  if (fileExtension === 'flv' || devicekind == 'flv') {
-    const player = new Player({
-      lang: 'zh',
-      id: id,
-      url: videoAddr,
-      width: 589,
-      height: 330,
-      poster: '/src/assets/images/vent/noSinge.png',
-      plugins: [FlvPlugin],
-      fluid: true,
-      autoplay: true,
-      isLive: true,
-      playsinline: true,
-      screenShot: true,
-      whitelist: [''],
-      ignores: ['time', 'progress', 'play', 'i18n', 'volume', 'fullscreen', 'screenShot', 'playbackRate'],
-      closeVideoClick: true,
-      customConfig: {
-        isClickPlayBack: false,
-      },
-      defaultPlaybackRate: cameraRate || 1,
-      controls: false,
-      flv: {
-        retryCount: 3, // 重试 3 次,默认值
-        retryDelay: 1000, // 每次重试间隔 1 秒,默认值
-        loadTimeout: 10000, // 请求超时时间为 10 秒,默认值
-        fetchOptions: {
-          // 该参数会透传给 fetch,默认值为 undefined
-          mode: 'cors',
-        },
-        targetLatency: 10, // 直播目标延迟,默认 10 秒
-        maxLatency: 20, // 直播允许的最大延迟,默认 20 秒
-        disconnectTime: 10, // 直播断流时间,默认 0 秒,(独立使用时等于 maxLatency)
-        maxJumpDistance: 10,
-      },
-    });
-    playerList.value.push(player);
-  }
-  if (fileExtension === 'm3u8' || devicekind == 'm3u8') {
-    let player;
-    if (document.createElement('video').canPlayType('application/vnd.apple.mpegurl')) {
-      // 原生支持 hls 播放
-      player = new Player({
+  function setNoRtspVideo(id, videoAddr, cameraRate, devicekind) {
+    const fileExtension = videoAddr.split('.').pop();
+    if (fileExtension === 'flv' || devicekind == 'flv') {
+      const player = new Player({
         lang: 'zh',
         id: id,
         url: videoAddr,
         width: 589,
         height: 330,
-        isLive: true,
-        autoplay: true,
-        autoplayMuted: true,
-        cors: true,
-        ignores: ['time', 'progress', 'play', 'i18n', 'volume', 'fullscreen', 'screenShot', 'playbackRate'],
         poster: '/src/assets/images/vent/noSinge.png',
-        defaultPlaybackRate: cameraRate || 1,
-        controls: false,
-        hls: {
-          retryCount: 3, // 重试 3 次,默认值
-          retryDelay: 1000, // 每次重试间隔 1 秒,默认值
-          loadTimeout: 10000, // 请求超时时间为 10 秒,默认值
-          fetchOptions: {
-            // 该参数会透传给 fetch,默认值为 undefined
-            mode: 'cors',
-          },
-          targetLatency: 10, // 直播目标延迟,默认 10 秒
-          maxLatency: 20, // 直播允许的最大延迟,默认 20 秒
-          disconnectTime: 10, // 直播断流时间,默认 0 秒,(独立使用时等于 maxLatency)
-          maxJumpDistance: 10,
-        },
-      });
-    } else if (HlsPlugin.isSupported()) {
-      // 第一步
-      player = new Player({
-        lang: 'zh',
-        id: id,
-        url: videoAddr,
-        width: 589,
-        height: 330,
-        isLive: true,
+        plugins: [FlvPlugin],
+        fluid: true,
         autoplay: true,
-        autoplayMuted: true,
-        plugins: [HlsPlugin], // 第二步
-        poster: '/src/assets/images/vent/noSinge.png',
+        isLive: true,
+        playsinline: true,
+        screenShot: true,
+        whitelist: [''],
         ignores: ['time', 'progress', 'play', 'i18n', 'volume', 'fullscreen', 'screenShot', 'playbackRate'],
+        closeVideoClick: true,
+        customConfig: {
+          isClickPlayBack: false,
+        },
         defaultPlaybackRate: cameraRate || 1,
         controls: false,
-        hls: {
+        flv: {
           retryCount: 3, // 重试 3 次,默认值
           retryDelay: 1000, // 每次重试间隔 1 秒,默认值
           loadTimeout: 10000, // 请求超时时间为 10 秒,默认值
@@ -381,164 +318,228 @@ function setNoRtspVideo(id, videoAddr, cameraRate, devicekind) {
           maxJumpDistance: 10,
         },
       });
+      playerList.value.push(player);
+    }
+    if (fileExtension === 'm3u8' || devicekind == 'm3u8') {
+      let player;
+      if (document.createElement('video').canPlayType('application/vnd.apple.mpegurl')) {
+        // 原生支持 hls 播放
+        player = new Player({
+          lang: 'zh',
+          id: id,
+          url: videoAddr,
+          width: 589,
+          height: 330,
+          isLive: true,
+          autoplay: true,
+          autoplayMuted: true,
+          cors: true,
+          ignores: ['time', 'progress', 'play', 'i18n', 'volume', 'fullscreen', 'screenShot', 'playbackRate'],
+          poster: '/src/assets/images/vent/noSinge.png',
+          defaultPlaybackRate: cameraRate || 1,
+          controls: false,
+          hls: {
+            retryCount: 3, // 重试 3 次,默认值
+            retryDelay: 1000, // 每次重试间隔 1 秒,默认值
+            loadTimeout: 10000, // 请求超时时间为 10 秒,默认值
+            fetchOptions: {
+              // 该参数会透传给 fetch,默认值为 undefined
+              mode: 'cors',
+            },
+            targetLatency: 10, // 直播目标延迟,默认 10 秒
+            maxLatency: 20, // 直播允许的最大延迟,默认 20 秒
+            disconnectTime: 10, // 直播断流时间,默认 0 秒,(独立使用时等于 maxLatency)
+            maxJumpDistance: 10,
+          },
+        });
+      } else if (HlsPlugin.isSupported()) {
+        // 第一步
+        player = new Player({
+          lang: 'zh',
+          id: id,
+          url: videoAddr,
+          width: 589,
+          height: 330,
+          isLive: true,
+          autoplay: true,
+          autoplayMuted: true,
+          plugins: [HlsPlugin], // 第二步
+          poster: '/src/assets/images/vent/noSinge.png',
+          ignores: ['time', 'progress', 'play', 'i18n', 'volume', 'fullscreen', 'screenShot', 'playbackRate'],
+          defaultPlaybackRate: cameraRate || 1,
+          controls: false,
+          hls: {
+            retryCount: 3, // 重试 3 次,默认值
+            retryDelay: 1000, // 每次重试间隔 1 秒,默认值
+            loadTimeout: 10000, // 请求超时时间为 10 秒,默认值
+            fetchOptions: {
+              // 该参数会透传给 fetch,默认值为 undefined
+              mode: 'cors',
+            },
+            targetLatency: 10, // 直播目标延迟,默认 10 秒
+            maxLatency: 20, // 直播允许的最大延迟,默认 20 秒
+            disconnectTime: 10, // 直播断流时间,默认 0 秒,(独立使用时等于 maxLatency)
+            maxJumpDistance: 10,
+          },
+        });
+      }
+      playerList.value.push(player);
     }
-    playerList.value.push(player);
   }
-}
 
-function goFullScreen(domId) {
-  const videoDom = document.getElementById(domId) as HTMLVideoElement;
-  if (videoDom.requestFullscreen) {
-    videoDom.requestFullscreen();
-    videoDom.play();
-  } else if (videoDom.mozRequestFullscreen) {
-    videoDom.mozRequestFullscreen();
-    videoDom.play();
-  } else if (videoDom.webkitRequestFullscreen) {
-    videoDom.webkitRequestFullscreen();
-    videoDom.play();
-  } else if (videoDom.msRequestFullscreen) {
-    videoDom.msRequestFullscreen();
-    videoDom.play();
+  function goFullScreen(domId) {
+    const videoDom = document.getElementById(domId) as HTMLVideoElement;
+    if (videoDom.requestFullscreen) {
+      videoDom.requestFullscreen();
+      videoDom.play();
+    } else if (videoDom.mozRequestFullscreen) {
+      videoDom.mozRequestFullscreen();
+      videoDom.play();
+    } else if (videoDom.webkitRequestFullscreen) {
+      videoDom.webkitRequestFullscreen();
+      videoDom.play();
+    } else if (videoDom.msRequestFullscreen) {
+      videoDom.msRequestFullscreen();
+      videoDom.play();
+    }
   }
-}
 
-function clearCamera() {
-  const num = webRtcServerList.length;
-  for (let i = 0; i < num; i++) {
-    if (webRtcServerList[i]) {
-      webRtcServerList[i].disconnect();
-      webRtcServerList[i] = null;
+  function clearCamera() {
+    const num = webRtcServerList.length;
+    for (let i = 0; i < num; i++) {
+      if (webRtcServerList[i]) {
+        webRtcServerList[i].disconnect();
+        webRtcServerList[i] = null;
+      }
     }
+    for (let i = 0; i < playerList.value.length; i++) {
+      const player = playerList.value[i];
+      if (player.destroy) player.destroy();
+    }
+    playerList.value = [];
   }
-  for (let i = 0; i < playerList.value.length; i++) {
-    const player = playerList.value[i];
-    if (player.destroy) player.destroy();
-  }
-  playerList.value = [];
-}
 
-onMounted(async () => {
-  await getCameraDevKindList();
-  await getVideoAddrs();
-  getVideo();
-});
+  onMounted(async () => {
+    await getCameraDevKindList();
+    await getVideoAddrs();
+    getVideo();
+  });
 
-onUnmounted(() => {
-  clearCamera();
-});
+  onUnmounted(() => {
+    clearCamera();
+  });
 </script>
 <style lang="less">
-@import '/@/design/theme.less';
+  @import '/@/design/theme.less';
 
-@{theme-deepblue} {
-  .camera-container {
-    --image-camera_bg: url('/@/assets/images/themify/deepblue/vent/camera_bg.png');
+  @{theme-deepblue} {
+    .camera-container {
+      --image-camera_bg: url('/@/assets/images/themify/deepblue/vent/camera_bg.png');
+    }
   }
-}
 
-.camera-container {
-  --image-camera_bg: url('/@/assets/images/vent/camera_bg.png');
-  position: relative;
-  width: calc(100% - 30px);
-  height: calc(100% - 84px);
-  display: flex;
-  margin: 15px;
-  justify-content: space-between;
-  align-items: center;
+  .camera-container {
+    --image-camera_bg: url('/@/assets/images/vent/camera_bg.png');
+    position: relative;
+    width: calc(100% - 30px);
+    height: calc(100% - 84px);
+    display: flex;
+    margin: 15px;
+    justify-content: space-between;
+    align-items: center;
 
-  .left-area {
-    width: 15%;
-    height: 100%;
-    padding: 20px;
-    border: 1px solid #99e8ff66;
-    background: #27546e1a;
-    box-shadow: 0px 0px 20px 7px rgba(145, 233, 254, 0.7) inset;
-    -moz-box-shadow: 0px 0px 20px 7px rgba(145, 233, 254, 0.7) inset;
-    -webkit-box-shadow: 0px 0px 50px 1px rgb(149 235 255 / 5%) inset;
-    box-sizing: border-box;
+    .left-area {
+      width: 15%;
+      height: 100%;
+      padding: 20px;
+      border: 1px solid #99e8ff66;
+      background: #27546e1a;
+      box-shadow: 0px 0px 20px 7px rgba(145, 233, 254, 0.7) inset;
+      -moz-box-shadow: 0px 0px 20px 7px rgba(145, 233, 254, 0.7) inset;
+      -webkit-box-shadow: 0px 0px 50px 1px rgb(149 235 255 / 5%) inset;
+      box-sizing: border-box;
 
-    // lxh
-    .iconfont {
-      color: #fff;
-      font-size: 12px;
-      margin-left: 5px;
+      // lxh
+      .iconfont {
+        color: #fff;
+        font-size: 12px;
+        margin-left: 5px;
+      }
     }
-  }
 
-  .right-area {
-    width: 85%;
-    height: 100%;
-    padding: 0px 0px 0px 15px;
-    box-sizing: border-box;
+    .right-area {
+      width: 85%;
+      height: 100%;
+      padding: 0px 0px 0px 15px;
+      box-sizing: border-box;
 
-    .camera-box {
-      width: 100%;
-      height: calc(100% - 60px);
-      display: flex;
-      justify-content: space-around;
-      align-items: flex-start;
-      flex-wrap: wrap;
-      overflow-y: auto;
-    }
+      .camera-box {
+        width: 100%;
+        height: calc(100% - 60px);
+        display: flex;
+        justify-content: space-around;
+        align-items: flex-start;
+        flex-wrap: wrap;
+        overflow-y: auto;
+      }
 
-    .camera-box1 {
-      width: 100%;
-      height: calc(100% - 60px);
-      display: flex;
-      justify-content: flex-start;
-      align-items: flex-start;
-      flex-wrap: wrap;
-      overflow-y: auto;
-    }
+      .camera-box1 {
+        width: 100%;
+        height: calc(100% - 60px);
+        display: flex;
+        justify-content: flex-start;
+        align-items: flex-start;
+        flex-wrap: wrap;
+        overflow-y: auto;
+      }
 
-    .player-box {
-      width: 626px;
-      height: 370px;
-      padding: 17px 18px;
-      background: var(--image-camera_bg);
-      background-size: 100% 100%;
-      position: relative;
-      margin: 10px;
+      .player-box {
+        width: 626px;
+        height: 370px;
+        padding: 17px 18px;
+        background: var(--image-camera_bg);
+        background-size: 100% 100%;
+        position: relative;
+        margin: 10px;
 
-      .player-name {
-        font-size: 14px;
-        position: absolute;
-        top: 35px;
-        right: 15px;
-        color: #fff;
-        background-color: hsla(0, 0%, 50%, 0.5);
-        border-radius: 2px;
-        padding: 1px 5px;
-        max-width: 120px;
-        overflow: hidden;
-        white-space: nowrap;
-        text-overflow: ellipsis;
-        z-index: 999;
+        .player-name {
+          font-size: 14px;
+          position: absolute;
+          top: 35px;
+          right: 15px;
+          color: #fff;
+          background-color: hsla(0, 0%, 50%, 0.5);
+          border-radius: 2px;
+          padding: 1px 5px;
+          max-width: 120px;
+          overflow: hidden;
+          white-space: nowrap;
+          text-overflow: ellipsis;
+          z-index: 999;
+        }
+
+        .click-box {
+          position: absolute;
+          width: 100%;
+          height: 100%;
+          top: 0;
+          left: 0;
+        }
       }
 
-      .click-box {
-        position: absolute;
+      .pagination {
         width: 100%;
-        height: 100%;
-        top: 0;
-        left: 0;
+        height: 60px;
+        display: flex;
+        justify-content: center;
+        align-items: center;
       }
     }
-
-    .pagination {
-      width: 100%;
-      height: 60px;
-      display: flex;
-      justify-content: center;
-      align-items: center;
-    }
   }
-}
 
-:deep(video) {
-  width: 100% !important;
-  height: 100% !important;
-  object-fit: cover !important;
-}
+  :deep(video) {
+    width: 100% !important;
+    height: 100% !important;
+    object-fit: cover !important;
+  }
 </style>

+ 0 - 2
src/views/vent/monitorManager/comment/HistoryTable.vue

@@ -117,7 +117,6 @@
       return props.columnsType;
     },
     async (newVal) => {
-      debugger;
       if (!newVal) return;
       deviceKide.value = newVal;
       if (historyTable.value) {
@@ -450,7 +449,6 @@
       },
       beforeFetch() {
         const newParams = { ...resetFormParam() };
-        debugger;
         return newParams;
       },
       // afterFetch(result) {

+ 0 - 1
src/views/vent/monitorManager/deviceMC/HistoryTable.vue

@@ -197,7 +197,6 @@
     const stationTypeStr = stationType.value;
     const formData = getForm().getFieldsValue();
     const pagination = getPaginationRef();
-    debugger;
     formData['pageNo'] = pagination['current'];
     formData['pageSize'] = pagination['pageSize'];
     formData['column'] = 'createTime';

+ 71 - 76
src/views/vent/monitorManager/deviceMonitor/components/device/index.vue

@@ -762,7 +762,6 @@
     if (treeData.value?.length > 0) return;
     const result = await getDeviceTypeList({});
     if (result.length > 0) {
-      debugger;
       const dataSource = <TreeProps['treeData']>[];
       let key = '0';
       const getData = (resultList, dataSourceList, keyVal) => {
@@ -1083,7 +1082,6 @@
   }
 
   function goDetail(record?) {
-    debugger;
     if (record) {
       activeID.value = record.deviceID;
       if (deviceType.value.startsWith('fiber')) {
@@ -1351,7 +1349,6 @@
       }
       nextTick(() => {
         isRefresh.value = true;
-        debugger;
         // if (pageObj && pageObj.pageType && pageObj.pageType.startsWith('sys_')) {
         //   findTreeDataValue({ deviceid: systemID.value });
         // } else {
@@ -2052,7 +2049,7 @@
       opacity: 0;
     }
   }
-  :deep(.@{ventSpace}-picker-datetime-panel){
+  :deep(.@{ventSpace}-picker-datetime-panel) {
     height: 200px !important;
     overflow-y: auto !important;
   }
@@ -2080,99 +2077,97 @@
     }
   }
 
-
   .device-button {
-      height: 26px;
-      display: flex;
-      justify-content: center;
-      align-items: center;
-      color: var(--vent-font-color);
-      position: relative;
-      cursor: pointer;
-      padding: 0 20px;
-      background: linear-gradient(45deg, #04e6fb55, #0c5cab55);
-      clip-path: polygon(10px 0, 0 50%, 10px 100%, 100% 100%, calc(100% - 10px) 50%, 100% 0);
-      &:nth-child(1) {
-        left: calc(-6px * 1);
-      }
-      &:nth-child(2) {
-        left: calc(-6px * 2);
-      }
+    height: 26px;
+    display: flex;
+    justify-content: center;
+    align-items: center;
+    color: var(--vent-font-color);
+    position: relative;
+    cursor: pointer;
+    padding: 0 20px;
+    background: linear-gradient(45deg, #04e6fb55, #0c5cab55);
+    clip-path: polygon(10px 0, 0 50%, 10px 100%, 100% 100%, calc(100% - 10px) 50%, 100% 0);
+    &:nth-child(1) {
+      left: calc(-6px * 1);
+    }
+    &:nth-child(2) {
+      left: calc(-6px * 2);
+    }
 
-      &:nth-child(3) {
-        left: calc(-6px * 3);
-      }
+    &:nth-child(3) {
+      left: calc(-6px * 3);
+    }
 
-      &:nth-child(4) {
-        left: calc(-6px * 4);
-      }
+    &:nth-child(4) {
+      left: calc(-6px * 4);
+    }
 
-      &:nth-child(5) {
-        left: calc(-6px * 5);
-      }
+    &:nth-child(5) {
+      left: calc(-6px * 5);
+    }
 
-      &:nth-child(6) {
-        left: calc(-6px * 6);
-      }
+    &:nth-child(6) {
+      left: calc(-6px * 6);
+    }
 
-      &:nth-child(7) {
-        left: calc(-6px * 7);
-      }
+    &:nth-child(7) {
+      left: calc(-6px * 7);
+    }
 
-      &:nth-child(8) {
-        left: calc(-6px * 8);
-      }
+    &:nth-child(8) {
+      left: calc(-6px * 8);
+    }
 
-      &:nth-child(9) {
-        left: calc(-6px * 9);
-      }
+    &:nth-child(9) {
+      left: calc(-6px * 9);
+    }
 
-      &:nth-child(10) {
-        left: calc(-6px * 10);
-      }
+    &:nth-child(10) {
+      left: calc(-6px * 10);
+    }
 
-      &:nth-child(11) {
-        left: calc(-6px * 11);
-      }
+    &:nth-child(11) {
+      left: calc(-6px * 11);
+    }
 
-      &:nth-child(12) {
-        left: calc(-6px * 12);
-      }
+    &:nth-child(12) {
+      left: calc(-6px * 12);
+    }
 
-      &:nth-child(13) {
-        left: calc(-6px * 13);
-      }
+    &:nth-child(13) {
+      left: calc(-6px * 13);
+    }
 
-      &:nth-child(14) {
-        left: calc(-6px * 14);
-      }
+    &:nth-child(14) {
+      left: calc(-6px * 14);
+    }
 
-      &:nth-child(15) {
-        left: calc(-6px * 15);
-      }
+    &:nth-child(15) {
+      left: calc(-6px * 15);
+    }
 
-      &:nth-child(16) {
-        left: calc(-6px * 16);
-      }
+    &:nth-child(16) {
+      left: calc(-6px * 16);
+    }
 
-      &:nth-child(17) {
-        left: calc(-6px * 17);
-      }
+    &:nth-child(17) {
+      left: calc(-6px * 17);
+    }
 
-      &:nth-child(18) {
-        left: calc(-6px * 18);
-      }
+    &:nth-child(18) {
+      left: calc(-6px * 18);
+    }
 
-      &:nth-child(19) {
-        left: calc(-6px * 19);
-      }
+    &:nth-child(19) {
+      left: calc(-6px * 19);
+    }
 
-      // &:first-child {
-      //   clip-path: polygon(0 0, 10px 50%, 0 100%, 100% 100%, calc(100% - 10px) 50%, 100% 0);
-      // }
+    // &:first-child {
+    //   clip-path: polygon(0 0, 10px 50%, 0 100%, 100% 100%, calc(100% - 10px) 50%, 100% 0);
+    // }
   }
 
-
   // :deep(.@{ventSpace}-pagination){
   //   margin-right: 20px !important;
   //   margin-top: 5px !important;

+ 759 - 761
src/views/vent/monitorManager/fanLocalMonitor/components/conditionAssistance.vue

@@ -80,862 +80,860 @@
 </template>
 
 <script lang="ts" setup>
-//ts语法
-import { ref, onMounted, reactive, nextTick, computed } from 'vue';
-import echarts from '/@/utils/lib/echarts';
-import { option, initData, fanInfoData, chartsColumnList, echatsOption } from '../fanLocal.data';
-import { BasicModal, useModalInner } from '/@/components/Modal';
-import { useForm } from '/@/components/Form/index';
-import { Input, InputNumber } from 'ant-design-vue';
-import { Decoration7 as DvDecoration7 } from '@kjgl77/datav-vue3';
-import { message } from 'ant-design-vue';
-import { formatNum } from '/@/utils/ventutil';
-import BarAndLine from '/@/components/chart/BarAndLine.vue';
-import { cloneDeep } from 'lodash-es';
-import dayjs from 'dayjs';
-import { SendOutlined } from '@ant-design/icons-vue';
-
-const emit = defineEmits(['close', 'register', 'openModal']);
-const props = defineProps({
-  dataSource: {
-    type: Array,
-    default: () => [],
-  },
-  frequency: {
-    type: Number,
-    default: 30,
-  },
-  m3: {
-    type: Number,
-    default: 670.8,
-  },
-  // gasWarningMax: { type: Number, default: 0.5 },
-  // gasWarningVal: { type: Number, default: 0.6 },
-  // windQuantity: { type: Number, default: 635.84 },
-});
-type AssistanceItemType = {
-  angle: number;
-  Hz: number;
-  a: number;
-  b: number;
-  c: number;
-  min: number;
-  max: number;
-};
-
-// 注册 modal
-const [register, { closeModal }] = useModalInner((data) => {
-  nextTick(() => {
-    computeAssistance();
-    if (option['xAxis']) option['xAxis']['data'] = xData;
-    option['series'] = yDataList;
-    if (JSON.stringify(data) !== '{}') {
-      uQ1.value = Number(data['m3']);
-      uHz.value = Math.ceil(data['frequency']);
-      gasWarningVal.value = data['gasWarningVal'];
-      isComputeGas.value = true;
-      nextTick(() => {
-        computeUH(data['frequency'], data['m3']);
-        initEcharts();
-        setTimeout(() => {
-          // 根据频率计算uH
-          makeLine();
-        }, 2000);
-      });
-    } else {
-      initEcharts();
-      isComputeGas.value = false;
-    }
+  //ts语法
+  import { ref, onMounted, reactive, nextTick, computed } from 'vue';
+  import echarts from '/@/utils/lib/echarts';
+  import { option, initData, fanInfoData, chartsColumnList, echatsOption } from '../fanLocal.data';
+  import { BasicModal, useModalInner } from '/@/components/Modal';
+  import { useForm } from '/@/components/Form/index';
+  import { Input, InputNumber } from 'ant-design-vue';
+  import { Decoration7 as DvDecoration7 } from '@kjgl77/datav-vue3';
+  import { message } from 'ant-design-vue';
+  import { formatNum } from '/@/utils/ventutil';
+  import BarAndLine from '/@/components/chart/BarAndLine.vue';
+  import { cloneDeep } from 'lodash-es';
+  import dayjs from 'dayjs';
+  import { SendOutlined } from '@ant-design/icons-vue';
+
+  const emit = defineEmits(['close', 'register', 'openModal']);
+  const props = defineProps({
+    dataSource: {
+      type: Array,
+      default: () => [],
+    },
+    frequency: {
+      type: Number,
+      default: 30,
+    },
+    m3: {
+      type: Number,
+      default: 670.8,
+    },
+    // gasWarningMax: { type: Number, default: 0.5 },
+    // gasWarningVal: { type: Number, default: 0.6 },
+    // windQuantity: { type: Number, default: 635.84 },
   });
-});
-const loadding = ref<boolean>(false);
-const formShow = ref(false);
-const formType = ref('');
-const ChartRef = ref();
-const myChart = ref();
-const refresh = ref(true);
-const xDataMax = 1000;
-let xDataMin = 0;
-const xData: any[] = [];
-const yDataList: [] = [];
-let lineNum = 0;
-const lineEquation = ref<string[]>([]);
-const assistanceData = ref([]);
-const monitorData = ref([]);
-const gasWarningVal = ref(0);
-const gasWarningMax = ref(0.5);
-const isComputeGas = ref(false);
-const isStartCompute = ref(0);
-const uHz = ref(0);
-const uQ1 = ref(0);
-const uQ = computed(() => {
-  if (uQ1.value) {
-    if (gasWarningVal.value) {
-      return ((uQ1.value * gasWarningVal.value) / gasWarningMax.value) * 1.08;
-    }
-    return uQ1.value;
-  } else {
-    return 0;
-  }
-});
-const uH = ref<number | undefined>(undefined); //  - 1000
-const isHaCross = ref(true);
-const resultObj = ref<{ x: number; y: number; Hz: number } | null>(null);
-
-const [registerForm, {}] = useForm({
-  labelWidth: 120,
-  actionColOptions: {
-    span: 24,
-  },
-  compact: true,
-  showSubmitButton: true,
-  submitButtonOptions: {
-    text: '提交',
-    preIcon: '',
-  },
-  showResetButton: true,
-  resetButtonOptions: {
-    text: '关闭',
-    preIcon: '',
-  },
-  resetFunc: async () => {
-    formShow.value = false;
-  },
-});
-
-function computeAssistance() {
-  assistanceData.value = initData();
-  lineNum = 0;
-  const assistanceDataList = [];
-  const lineEquationList: string[] = [];
-  for (const key in assistanceData.value) {
-    const item = assistanceData.value[key];
-    assistanceDataList.push(item);
-    lineEquationList.push(
-      `H${parseInt(item['Hz'])} = ${item['a']}Q² ${Number(item['b']) > 0 ? '+' : '-'} ${Math.abs(Number(item['b'])).toFixed(4)}Q ${
-        Number(item['c']) > 0 ? '+' : '-'
-      } ${Math.abs(Number(item['c'])).toFixed(4)}`
-    );
-  }
-  lineEquation.value = lineEquationList;
-  lineNum = assistanceDataList.length;
-  xDataMin =
-    Math.min.apply(
-      Math,
-      assistanceDataList.map((item) => {
-        return item.min;
-      })
-    ) - 100;
-  // const xDataMax = Math.max.apply(Math, assistanceDataList.map(item => { return item.max }))
-  fanInfoData.flfw = `${xDataMin}~${xDataMax}`;
-  const computeItem = (item: AssistanceItemType) => {
-    const min = item.min;
-    const max = item.max;
-    const HList: number[] = [];
-    for (let i = xDataMin; i <= xDataMax; i++) {
-      if (i < min) {
-        HList.push(null);
-      } else if (i > max) {
-        HList.push(null);
+  type AssistanceItemType = {
+    angle: number;
+    Hz: number;
+    a: number;
+    b: number;
+    c: number;
+    min: number;
+    max: number;
+  };
+
+  // 注册 modal
+  const [register, { closeModal }] = useModalInner((data) => {
+    nextTick(() => {
+      computeAssistance();
+      if (option['xAxis']) option['xAxis']['data'] = xData;
+      option['series'] = yDataList;
+      if (JSON.stringify(data) !== '{}') {
+        uQ1.value = Number(data['m3']);
+        uHz.value = Math.ceil(data['frequency']);
+        gasWarningVal.value = data['gasWarningVal'];
+        isComputeGas.value = true;
+        nextTick(() => {
+          computeUH(data['frequency'], data['m3']);
+          initEcharts();
+          setTimeout(() => {
+            // 根据频率计算uH
+            makeLine();
+          }, 2000);
+        });
       } else {
-        HList.push(item.a * i * i + item.b * i + item.c);
+        initEcharts();
+        isComputeGas.value = false;
       }
+    });
+  });
+  const loadding = ref<boolean>(false);
+  const formShow = ref(false);
+  const formType = ref('');
+  const ChartRef = ref();
+  const myChart = ref();
+  const refresh = ref(true);
+  const xDataMax = 1000;
+  let xDataMin = 0;
+  const xData: any[] = [];
+  const yDataList: [] = [];
+  let lineNum = 0;
+  const lineEquation = ref<string[]>([]);
+  const assistanceData = ref([]);
+  const monitorData = ref([]);
+  const gasWarningVal = ref(0);
+  const gasWarningMax = ref(0.5);
+  const isComputeGas = ref(false);
+  const isStartCompute = ref(0);
+  const uHz = ref(0);
+  const uQ1 = ref(0);
+  const uQ = computed(() => {
+    if (uQ1.value) {
+      if (gasWarningVal.value) {
+        return ((uQ1.value * gasWarningVal.value) / gasWarningMax.value) * 1.08;
+      }
+      return uQ1.value;
+    } else {
+      return 0;
     }
-    return HList;
-  };
+  });
+  const uH = ref<number | undefined>(undefined); //  - 1000
+  const isHaCross = ref(true);
+  const resultObj = ref<{ x: number; y: number; Hz: number } | null>(null);
+
+  const [registerForm, {}] = useForm({
+    labelWidth: 120,
+    actionColOptions: {
+      span: 24,
+    },
+    compact: true,
+    showSubmitButton: true,
+    submitButtonOptions: {
+      text: '提交',
+      preIcon: '',
+    },
+    showResetButton: true,
+    resetButtonOptions: {
+      text: '关闭',
+      preIcon: '',
+    },
+    resetFunc: async () => {
+      formShow.value = false;
+    },
+  });
 
-  for (const key in assistanceData.value) {
-    const element: AssistanceItemType = assistanceData.value[key];
-    const yData: number[] = computeItem(element);
-    const series = {
-      type: 'line',
-      name: `${element['Hz']}Hz`,
-      smooth: true,
-      showSymbol: false,
-      symbol: 'none',
-      emphasis: {
-        focus: 'series',
-      },
-      itemStyle: { normal: { label: { show: true } } },
-      lineStyle: {
-        width: 1,
-        color: '#ffffff88',
-      },
-      zlevel: 0,
-      z: 1,
-      endLabel: {
-        show: true,
-        formatter: '{a}',
-        distance: 0,
-        color: '#39E9FE99',
-        backgroundColor: 'transparent',
-        padding: [3, 3, 2, 3],
-      },
-      data: yData,
+  function computeAssistance() {
+    assistanceData.value = initData();
+    lineNum = 0;
+    const assistanceDataList = [];
+    const lineEquationList: string[] = [];
+    for (const key in assistanceData.value) {
+      const item = assistanceData.value[key];
+      assistanceDataList.push(item);
+      lineEquationList.push(
+        `H${parseInt(item['Hz'])} = ${item['a']}Q² ${Number(item['b']) > 0 ? '+' : '-'} ${Math.abs(Number(item['b'])).toFixed(4)}Q ${
+          Number(item['c']) > 0 ? '+' : '-'
+        } ${Math.abs(Number(item['c'])).toFixed(4)}`
+      );
+    }
+    lineEquation.value = lineEquationList;
+    lineNum = assistanceDataList.length;
+    xDataMin =
+      Math.min.apply(
+        Math,
+        assistanceDataList.map((item) => {
+          return item.min;
+        })
+      ) - 100;
+    // const xDataMax = Math.max.apply(Math, assistanceDataList.map(item => { return item.max }))
+    fanInfoData.flfw = `${xDataMin}~${xDataMax}`;
+    const computeItem = (item: AssistanceItemType) => {
+      const min = item.min;
+      const max = item.max;
+      const HList: number[] = [];
+      for (let i = xDataMin; i <= xDataMax; i++) {
+        if (i < min) {
+          HList.push(null);
+        } else if (i > max) {
+          HList.push(null);
+        } else {
+          HList.push(item.a * i * i + item.b * i + item.c);
+        }
+      }
+      return HList;
     };
 
-    yDataList.push(series);
-  }
+    for (const key in assistanceData.value) {
+      const element: AssistanceItemType = assistanceData.value[key];
+      const yData: number[] = computeItem(element);
+      const series = {
+        type: 'line',
+        name: `${element['Hz']}Hz`,
+        smooth: true,
+        showSymbol: false,
+        symbol: 'none',
+        emphasis: {
+          focus: 'series',
+        },
+        itemStyle: { normal: { label: { show: true } } },
+        lineStyle: {
+          width: 1,
+          color: '#ffffff88',
+        },
+        zlevel: 0,
+        z: 1,
+        endLabel: {
+          show: true,
+          formatter: '{a}',
+          distance: 0,
+          color: '#39E9FE99',
+          backgroundColor: 'transparent',
+          padding: [3, 3, 2, 3],
+        },
+        data: yData,
+      };
+
+      yDataList.push(series);
+    }
 
-  for (let i = xDataMin; i <= xDataMax; i++) {
-    xData.push(i);
+    for (let i = xDataMin; i <= xDataMax; i++) {
+      xData.push(i);
+    }
   }
-}
 
-function computeUH(Hz: number, uQ: number) {
-  debugger;
-  const equation = assistanceData.value.find((item) => {
-    return Math.ceil(Hz) == item['Hz'];
-  });
-  if (equation) {
-    const uHMax = Math.round((equation['a'] * equation['min'] * equation['min'] + equation['b'] * equation['min'] + equation['c']) * 100) / 100;
-    const uHMin = Math.round((equation['a'] * equation['max'] * equation['max'] + equation['b'] * equation['max'] + equation['c']) * 100) / 100;
-    const uH1 = Math.round((equation['a'] * uQ * uQ + equation['b'] * uQ + equation['c']) * 100) / 100;
-    if (uH1 >= uHMin && uH1 <= uHMax) {
-      uH.value = uH1;
-      isHaCross.value = true;
-    } else {
-      isHaCross.value = false;
+  function computeUH(Hz: number, uQ: number) {
+    const equation = assistanceData.value.find((item) => {
+      return Math.ceil(Hz) == item['Hz'];
+    });
+    if (equation) {
+      const uHMax = Math.round((equation['a'] * equation['min'] * equation['min'] + equation['b'] * equation['min'] + equation['c']) * 100) / 100;
+      const uHMin = Math.round((equation['a'] * equation['max'] * equation['max'] + equation['b'] * equation['max'] + equation['c']) * 100) / 100;
+      const uH1 = Math.round((equation['a'] * uQ * uQ + equation['b'] * uQ + equation['c']) * 100) / 100;
+      if (uH1 >= uHMin && uH1 <= uHMax) {
+        uH.value = uH1;
+        isHaCross.value = true;
+      } else {
+        isHaCross.value = false;
+      }
     }
   }
-}
 
-function computeRLine() {
-  console.log('计算后的风量为------------>', uQ.value);
-  if (uH.value && uQ.value) {
-    const R = uH.value / Number(uQ.value) / Number(uQ.value);
-    const yAxis: number[] = [];
-    for (let i = 0; i < xData.length; i++) {
-      const x = xData[i];
-      const y = R * x * x;
-      if (x == uQ.value) {
-        uH.value = y;
+  function computeRLine() {
+    console.log('计算后的风量为------------>', uQ.value);
+    if (uH.value && uQ.value) {
+      const R = uH.value / Number(uQ.value) / Number(uQ.value);
+      const yAxis: number[] = [];
+      for (let i = 0; i < xData.length; i++) {
+        const x = xData[i];
+        const y = R * x * x;
+        if (x == uQ.value) {
+          uH.value = y;
+        }
+        yAxis.push(y);
       }
-      yAxis.push(y);
-    }
-    const series = {
-      name: 'R',
-      type: 'line',
-      smooth: true,
-      showSymbol: false,
-      zlevel: 0,
-      emphasis: {
-        focus: 'series',
-      },
-      itemStyle: { normal: { label: { show: true } } },
-      lineStyle: {
-        width: 2,
-        color: '#D0A343',
-      },
-      endLabel: {
-        show: true,
-        formatter: '{a}',
-        distance: 0,
-        color: '#D0A343',
-      },
-      data: yAxis,
-    };
-    yDataList[lineNum] = series;
+      const series = {
+        name: 'R',
+        type: 'line',
+        smooth: true,
+        showSymbol: false,
+        zlevel: 0,
+        emphasis: {
+          focus: 'series',
+        },
+        itemStyle: { normal: { label: { show: true } } },
+        lineStyle: {
+          width: 2,
+          color: '#D0A343',
+        },
+        endLabel: {
+          show: true,
+          formatter: '{a}',
+          distance: 0,
+          color: '#D0A343',
+        },
+        data: yAxis,
+      };
+      yDataList[lineNum] = series;
+    }
   }
-}
-
-function reSetLine() {
-  let minIndex = -1;
-  for (let i = 0; i < yDataList.length; i++) {
-    if (i !== lineNum && i != lineNum + 1) {
-      if (yDataList[i]['lineStyle']) yDataList[i]['lineStyle']['color'] = '#ffffff88';
-      if (yDataList[i]['lineStyle']) yDataList[i]['lineStyle']['width'] = 1;
-      if (yDataList[i]['endLabel'] && yDataList[i]['endLabel']['color']) {
-        yDataList[i]['endLabel']['color'] = '#39E9FE99';
+
+  function reSetLine() {
+    let minIndex = -1;
+    for (let i = 0; i < yDataList.length; i++) {
+      if (i !== lineNum && i != lineNum + 1) {
+        if (yDataList[i]['lineStyle']) yDataList[i]['lineStyle']['color'] = '#ffffff88';
+        if (yDataList[i]['lineStyle']) yDataList[i]['lineStyle']['width'] = 1;
+        if (yDataList[i]['endLabel'] && yDataList[i]['endLabel']['color']) {
+          yDataList[i]['endLabel']['color'] = '#39E9FE99';
+        }
+        if (yDataList[i]['endLabel'] && yDataList[i]['endLabel']['backgroundColor']) yDataList[i]['endLabel']['backgroundColor'] = 'transparent';
+        if (yDataList[i]['z']) yDataList[i]['z'] = 1;
       }
-      if (yDataList[i]['endLabel'] && yDataList[i]['endLabel']['backgroundColor']) yDataList[i]['endLabel']['backgroundColor'] = 'transparent';
-      if (yDataList[i]['z']) yDataList[i]['z'] = 1;
-    }
 
-    if (resultObj.value && `${resultObj.value.Hz}Hz` == yDataList[i]['name']) {
-      minIndex = i;
+      if (resultObj.value && `${resultObj.value.Hz}Hz` == yDataList[i]['name']) {
+        minIndex = i;
+      }
+    }
+    if (minIndex != -1) {
+      yDataList[minIndex]['lineStyle']['color'] = '#9A60B4';
+      yDataList[minIndex]['lineStyle']['width'] = 2;
+      yDataList[minIndex]['endLabel']['color'] = '#9A60B4';
+      yDataList[minIndex]['endLabel']['backgroundColor'] = '#111';
+      yDataList[minIndex]['z'] = 999;
     }
   }
-  if (minIndex != -1) {
-    yDataList[minIndex]['lineStyle']['color'] = '#9A60B4';
-    yDataList[minIndex]['lineStyle']['width'] = 2;
-    yDataList[minIndex]['endLabel']['color'] = '#9A60B4';
-    yDataList[minIndex]['endLabel']['backgroundColor'] = '#111';
-    yDataList[minIndex]['z'] = 999;
-  }
-}
-
-// 根据风量计算压差
-function computePa() {
-  debugger;
-  const R = uH.value / Number(uQ.value) / Number(uQ.value);
-  const pointX = Number(uQ.value);
-  const pointY = Number(uH.value);
-  type ItemType = {
-    x: number;
-    y: number;
-    Hz: number;
-  };
-  const paList = new Map<number, ItemType>(); // key 是最近距离
-  const getIntersectionPoint = (a, b, c, R, min, max) => {
-    const obj: { x: undefined | number; y: undefined | number; min: number; max: number } = { x: undefined, y: undefined, min: min, max: max };
-    // 计算二次方程的判别式
-    const discriminant = b * b - 4 * (a - R) * c;
-
-    if (discriminant > 0) {
-      // 有两个实根
-      const x1 = (-b + Math.sqrt(discriminant)) / (2 * (a - R));
-      const x2 = (-b - Math.sqrt(discriminant)) / (2 * (a - R));
-
-      const y1 = R * x1 * x1;
-      const y2 = R * x2 * x2;
-      if (x1 >= min && x1 <= max) {
-        obj.x = x1;
-        obj.y = y1;
+
+  // 根据风量计算压差
+  function computePa() {
+    const R = uH.value / Number(uQ.value) / Number(uQ.value);
+    const pointX = Number(uQ.value);
+    const pointY = Number(uH.value);
+    type ItemType = {
+      x: number;
+      y: number;
+      Hz: number;
+    };
+    const paList = new Map<number, ItemType>(); // key 是最近距离
+    const getIntersectionPoint = (a, b, c, R, min, max) => {
+      const obj: { x: undefined | number; y: undefined | number; min: number; max: number } = { x: undefined, y: undefined, min: min, max: max };
+      // 计算二次方程的判别式
+      const discriminant = b * b - 4 * (a - R) * c;
+
+      if (discriminant > 0) {
+        // 有两个实根
+        const x1 = (-b + Math.sqrt(discriminant)) / (2 * (a - R));
+        const x2 = (-b - Math.sqrt(discriminant)) / (2 * (a - R));
+
+        const y1 = R * x1 * x1;
+        const y2 = R * x2 * x2;
+        if (x1 >= min && x1 <= max) {
+          obj.x = x1;
+          obj.y = y1;
+        } else {
+          obj.x = x2;
+          obj.y = y2;
+        }
+      } else if (discriminant === 0) {
+        // 有一个实根
+        const x = -b / (2 * (a - R));
+        const y = R * x * x;
+        if (x >= min && x <= max) {
+          obj.x = x;
+          obj.y = y;
+        }
+        // console.log(`唯一交点: (${x}, ${y})`);
       } else {
-        obj.x = x2;
-        obj.y = y2;
-      }
-    } else if (discriminant === 0) {
-      // 有一个实根
-      const x = -b / (2 * (a - R));
-      const y = R * x * x;
-      if (x >= min && x <= max) {
-        obj.x = x;
-        obj.y = y;
+        // 没有实根,交点在虚数域
+        console.log('没有实数交点');
+        isHaCross.value = false;
       }
-      // console.log(`唯一交点: (${x}, ${y})`);
-    } else {
-      // 没有实根,交点在虚数域
-      console.log('没有实数交点');
-      isHaCross.value = false;
-    }
-    return obj;
-  };
+      return obj;
+    };
 
-  for (let key in assistanceData.value) {
-    const item: AssistanceItemType = assistanceData.value[key];
-    paList.set(item.Hz, getIntersectionPoint(item.a, item.b, item.c, R, item.min, item.max));
-  }
+    for (let key in assistanceData.value) {
+      const item: AssistanceItemType = assistanceData.value[key];
+      paList.set(item.Hz, getIntersectionPoint(item.a, item.b, item.c, R, item.min, item.max));
+    }
 
-  const min = (points: Map<number, ItemType>) => {
-    const targetX = uQ.value;
-    const targetY = uH.value;
-    let minDistance = Number.POSITIVE_INFINITY;
-    let closestPoint = null;
-    let keyVal = '';
-    // 遍历已知点数组,计算距离并更新最小距离和对应的点
-    for (const [key, point] of points) {
-      const distance = Math.sqrt((targetX - point.x) ** 2 + (targetY - point.y) ** 2);
-      if (distance < minDistance) {
-        minDistance = distance;
-        closestPoint = point;
-        keyVal = key;
+    const min = (points: Map<number, ItemType>) => {
+      const targetX = uQ.value;
+      const targetY = uH.value;
+      let minDistance = Number.POSITIVE_INFINITY;
+      let closestPoint = null;
+      let keyVal = '';
+      // 遍历已知点数组,计算距离并更新最小距离和对应的点
+      for (const [key, point] of points) {
+        const distance = Math.sqrt((targetX - point.x) ** 2 + (targetY - point.y) ** 2);
+        if (distance < minDistance) {
+          minDistance = distance;
+          closestPoint = point;
+          keyVal = key;
+        }
       }
-    }
 
-    if (closestPoint !== null) {
-      // console.log(`距离最小的点是 (${closestPoint.x}, ${closestPoint.y}), 距离为 ${minDistance}`);
-      if (closestPoint.x < closestPoint.min || closestPoint.x > closestPoint.max) {
+      if (closestPoint !== null) {
+        // console.log(`距离最小的点是 (${closestPoint.x}, ${closestPoint.y}), 距离为 ${minDistance}`);
+        if (closestPoint.x < closestPoint.min || closestPoint.x > closestPoint.max) {
+          resultObj.value = null;
+          isHaCross.value = false;
+          console.log('没有找到最小距离的点');
+        } else {
+          resultObj.value = { x: closestPoint.x, y: closestPoint.y, Hz: keyVal };
+          isHaCross.value = true;
+        }
+      } else {
         resultObj.value = null;
         isHaCross.value = false;
         console.log('没有找到最小距离的点');
-      } else {
-        resultObj.value = { x: closestPoint.x, y: closestPoint.y, Hz: keyVal };
-        isHaCross.value = true;
       }
-    } else {
-      resultObj.value = null;
-      isHaCross.value = false;
-      console.log('没有找到最小距离的点');
-    }
-  };
-  min(paList);
-}
-
-function computeR() {
-  if (uQ.value && uH.value) {
-    computeRLine();
-    computePa();
-    const x = resultObj.value && resultObj.value.x ? resultObj.value.x.toFixed(0) : -100;
-    const y = resultObj.value && resultObj.value.y ? Number(resultObj.value.y.toFixed(0)) : -100;
-    const series = {
-      type: 'effectScatter',
-      symbolSize: 5,
-      // symbolOffset:[1, 1],
-      showEffectOn: 'render',
-      // 涟漪特效相关配置。
-      rippleEffect: {
-        // 波纹的绘制方式,可选 'stroke' 和 'fill'。
-        brushType: 'stroke',
-      },
-      zlevel: 1,
-      z: 999,
-      itemStyle: {
-        color: '#C60000',
-      },
-      data: [[x, y]],
     };
-    yDataList[lineNum + 1] = series;
-  }
-  // // 根据计算后的得到的频率,风量,瓦斯浓度
-  // getMonitor();
-}
-
-function getMonitor() {
-  clearTimeout(timer);
-  timer = undefined;
-  const n = 10;
-  const windQuantity = uQ1.value;
-  const obj = {
-    m3: windQuantity,
-    gas: gasWarningVal.value,
-    time: '',
-    Hz: uHz.value,
-  };
-  const monitorList: { m3: number; gas: number; Hz: number; time: string }[] = [];
-  for (let i = 0; i < n; i++) {
-    const item = cloneDeep(obj);
-    const m3Temp = (Math.random() * 2 - 1) * Math.random() * 20;
-    const gas = m3Temp * 0.0002;
-    item.time = dayjs(new Date().getTime() - (n + i) * 3000).format('HH:mm:ss');
-    item.m3 = (obj.m3 + m3Temp).toFixed(2);
-    item.gas = (obj.gas + gas).toFixed(4);
-    item.Hz = (obj.Hz + Math.random()).toFixed(2);
-    monitorList.unshift(item);
+    min(paList);
+  }
+
+  function computeR() {
+    if (uQ.value && uH.value) {
+      computeRLine();
+      computePa();
+      const x = resultObj.value && resultObj.value.x ? resultObj.value.x.toFixed(0) : -100;
+      const y = resultObj.value && resultObj.value.y ? Number(resultObj.value.y.toFixed(0)) : -100;
+      const series = {
+        type: 'effectScatter',
+        symbolSize: 5,
+        // symbolOffset:[1, 1],
+        showEffectOn: 'render',
+        // 涟漪特效相关配置。
+        rippleEffect: {
+          // 波纹的绘制方式,可选 'stroke' 和 'fill'。
+          brushType: 'stroke',
+        },
+        zlevel: 1,
+        z: 999,
+        itemStyle: {
+          color: '#C60000',
+        },
+        data: [[x, y]],
+      };
+      yDataList[lineNum + 1] = series;
+    }
+    // // 根据计算后的得到的频率,风量,瓦斯浓度
+    // getMonitor();
   }
-  monitorData.value = cloneDeep(monitorList);
 
-  setTimeout(() => {
+  function getMonitor() {
     clearTimeout(timer);
     timer = undefined;
-
-    timer = 0;
-    if (uQ1.value && uH.value && uQ.value) {
-      openTimer(cloneDeep(obj), 0);
-    } else {
-      openTimer(cloneDeep(obj), 0);
-    }
-  }, 1000);
-}
-
-function startCompute() {
-  setTimeout(() => {
-    message.success('指令下发成功!');
-    isStartCompute.value = 1;
-  }, 800);
-}
-
-function resetCompute() {
-  setTimeout(() => {
-    message.success('指令下发成功!');
-    isStartCompute.value = -1;
-    tempList.length = 0;
-    n = 0;
-  }, 800);
-}
-
-let timer = undefined;
-let n = 0;
-let tempList = [];
-function openTimer(obj: { m3: number; gas: number; Hz: number; time: string }) {
-  // 打开定时器
-  const monitorList = cloneDeep(monitorData.value);
-  if (timer !== undefined) {
-    timer = setTimeout(() => {
-      obj.m3 = Number(obj.m3);
-      obj.gas = Number(obj.gas);
-      obj.Hz = Number(obj.Hz);
+    const n = 10;
+    const windQuantity = uQ1.value;
+    const obj = {
+      m3: windQuantity,
+      gas: gasWarningVal.value,
+      time: '',
+      Hz: uHz.value,
+    };
+    const monitorList: { m3: number; gas: number; Hz: number; time: string }[] = [];
+    for (let i = 0; i < n; i++) {
       const item = cloneDeep(obj);
-      item.time = dayjs(new Date().getTime()).format('HH:mm:ss');
-      if (resultObj.value && resultObj.value.x && resultObj.value.y && isStartCompute.value != 0) {
-        if (isStartCompute.value == 1 && Number(obj.m3) > uQ.value && Number(obj.gas) < gasWarningMax.value) {
-          isStartCompute.value = 0;
-          n = 0;
-        } else if (isStartCompute.value == -1 && Number(obj.m3) < uQ1.value) {
-          isStartCompute.value = 0;
-          n = 0;
-        }
-      }
+      const m3Temp = (Math.random() * 2 - 1) * Math.random() * 20;
+      const gas = m3Temp * 0.0002;
+      item.time = dayjs(new Date().getTime() - (n + i) * 3000).format('HH:mm:ss');
+      item.m3 = (obj.m3 + m3Temp).toFixed(2);
+      item.gas = (obj.gas + gas).toFixed(4);
+      item.Hz = (obj.Hz + Math.random()).toFixed(2);
+      monitorList.unshift(item);
+    }
+    monitorData.value = cloneDeep(monitorList);
 
-      if (!isStartCompute.value) {
-        const m3Temp = (Math.random() * 2 - 1) * Math.random() * Math.random() * 10;
-        const gas = m3Temp * 0.0002;
-        item.m3 = (obj.m3 + m3Temp).toFixed(2);
-        item.gas = (obj.gas + gas).toFixed(4);
-        item.Hz = (obj.Hz + Math.random()).toFixed(2);
-        n = 0;
+    setTimeout(() => {
+      clearTimeout(timer);
+      timer = undefined;
+
+      timer = 0;
+      if (uQ1.value && uH.value && uQ.value) {
+        openTimer(cloneDeep(obj), 0);
       } else {
-        if (n < 2) {
-          const item1 = cloneDeep(obj);
-          const m3Temp = Math.random() * Math.random() * 10;
-          const gas = m3Temp * 0.0002;
-          item1.m3 = (obj.m3 + m3Temp).toFixed(2);
-          item1.gas = (obj.gas + gas).toFixed(4);
-          item1.Hz = (obj.Hz + (Math.random() * 2 - 1) * Math.random()).toFixed(2);
-          tempList.push(item1);
+        openTimer(cloneDeep(obj), 0);
+      }
+    }, 1000);
+  }
+
+  function startCompute() {
+    setTimeout(() => {
+      message.success('指令下发成功!');
+      isStartCompute.value = 1;
+    }, 800);
+  }
+
+  function resetCompute() {
+    setTimeout(() => {
+      message.success('指令下发成功!');
+      isStartCompute.value = -1;
+      tempList.length = 0;
+      n = 0;
+    }, 800);
+  }
+
+  let timer = undefined;
+  let n = 0;
+  let tempList = [];
+  function openTimer(obj: { m3: number; gas: number; Hz: number; time: string }) {
+    // 打开定时器
+    const monitorList = cloneDeep(monitorData.value);
+    if (timer !== undefined) {
+      timer = setTimeout(() => {
+        obj.m3 = Number(obj.m3);
+        obj.gas = Number(obj.gas);
+        obj.Hz = Number(obj.Hz);
+        const item = cloneDeep(obj);
+        item.time = dayjs(new Date().getTime()).format('HH:mm:ss');
+        if (resultObj.value && resultObj.value.x && resultObj.value.y && isStartCompute.value != 0) {
+          if (isStartCompute.value == 1 && Number(obj.m3) > uQ.value && Number(obj.gas) < gasWarningMax.value) {
+            isStartCompute.value = 0;
+            n = 0;
+          } else if (isStartCompute.value == -1 && Number(obj.m3) < uQ1.value) {
+            isStartCompute.value = 0;
+            n = 0;
+          }
         }
 
-        // 计算  uQ1 -> uQ  gas -> gasWarningMax.value Hz -> resultObj.value.Hz
-        if (isStartCompute.value == 1) {
-          if (resultObj.value.Hz - obj.Hz > 0) {
-            item.Hz = (uHz.value + (2 * n * (resultObj.value.Hz - uHz.value)) / 20).toFixed(2);
-            if (resultObj.value.Hz - obj.Hz < 0) {
+        if (!isStartCompute.value) {
+          const m3Temp = (Math.random() * 2 - 1) * Math.random() * Math.random() * 10;
+          const gas = m3Temp * 0.0002;
+          item.m3 = (obj.m3 + m3Temp).toFixed(2);
+          item.gas = (obj.gas + gas).toFixed(4);
+          item.Hz = (obj.Hz + Math.random()).toFixed(2);
+          n = 0;
+        } else {
+          if (n < 2) {
+            const item1 = cloneDeep(obj);
+            const m3Temp = Math.random() * Math.random() * 10;
+            const gas = m3Temp * 0.0002;
+            item1.m3 = (obj.m3 + m3Temp).toFixed(2);
+            item1.gas = (obj.gas + gas).toFixed(4);
+            item1.Hz = (obj.Hz + (Math.random() * 2 - 1) * Math.random()).toFixed(2);
+            tempList.push(item1);
+          }
+
+          // 计算  uQ1 -> uQ  gas -> gasWarningMax.value Hz -> resultObj.value.Hz
+          if (isStartCompute.value == 1) {
+            if (resultObj.value.Hz - obj.Hz > 0) {
+              item.Hz = (uHz.value + (2 * n * (resultObj.value.Hz - uHz.value)) / 20).toFixed(2);
+              if (resultObj.value.Hz - obj.Hz < 0) {
+                item.Hz = (resultObj.value.Hz + Math.random() * 0.5).toFixed(2);
+              }
+            } else {
+              // item.Hz = (resultObj.value.Hz + (Math.random() * 2 - 1) * Math.random() * 2).toFixed(2);
               item.Hz = (resultObj.value.Hz + Math.random() * 0.5).toFixed(2);
             }
+            item.m3 = (obj.m3 + (0.027 * n * item.Hz * (item.Hz - uHz.value) * (uQ.value - uQ1.value)) / 600).toFixed(2);
+            if (Number(item.m3) > uQ.value) {
+              item.m3 = (uQ.value + Math.random() * 10).toFixed(2);
+            }
+            item.gas = (
+              gasWarningVal.value -
+              (0.015 * item.Hz * n * (item.Hz - uHz.value) * (gasWarningVal.value - gasWarningMax.value)) / 200
+            ).toFixed(4);
           } else {
-            // item.Hz = (resultObj.value.Hz + (Math.random() * 2 - 1) * Math.random() * 2).toFixed(2);
-            item.Hz = (resultObj.value.Hz + Math.random() * 0.5).toFixed(2);
+            // 复位
+            if (obj.Hz - uHz.value > 0) {
+              item.Hz = (obj.Hz - (2 * n * (resultObj.value.Hz - uHz.value)) / 30).toFixed(2);
+              if (item.Hz - uHz.value < 0) {
+                item.Hz = uHz.value - 0.3;
+              }
+            } else {
+              item.Hz = (uHz.value + (Math.random() * 2 - 1) * Math.random() * 2).toFixed(2);
+            }
+            item.m3 = (obj.m3 - (0.02 * n * n * item.Hz * (resultObj.value.Hz - uHz.value) * (uQ.value - uQ1.value)) / 400).toFixed(2);
+            if (item.m3 < uQ1.value) {
+              item.m3 = uQ1.value - Math.random() * 10;
+            }
+            item.gas = (obj.gas + (0.015 * item.Hz * n * (uHz.value - item.Hz) * (gasWarningVal.value - gasWarningMax.value)) / 800).toFixed(4);
           }
-          item.m3 = (obj.m3 + (0.027 * n * item.Hz * (item.Hz - uHz.value) * (uQ.value - uQ1.value)) / 600).toFixed(2);
-          if (Number(item.m3) > uQ.value) {
-            item.m3 = (uQ.value + Math.random() * 10).toFixed(2);
+        }
+        if (monitorList.length >= 10) {
+          monitorList.shift();
+          const monitor = cloneDeep(item);
+          const data = tempList.shift();
+          if (data) {
+            item['m3'] = data['m3'];
+            item['gas'] = data['gas'];
           }
-          item.gas = (
-            gasWarningVal.value -
-            (0.015 * item.Hz * n * (item.Hz - uHz.value) * (gasWarningVal.value - gasWarningMax.value)) / 200
-          ).toFixed(4);
+          tempList.push(monitor);
+          monitorList.push(item);
         } else {
-          // 复位
-          if (obj.Hz - uHz.value > 0) {
-            item.Hz = (obj.Hz - (2 * n * (resultObj.value.Hz - uHz.value)) / 30).toFixed(2);
-            if (item.Hz - uHz.value < 0) {
-              item.Hz = uHz.value - 0.3;
-            }
+          monitorList.push(item);
+        }
+        monitorData.value = monitorList;
+        // console.log('瓦斯监测数据-------------->', monitorData.value);
+        if (timer) {
+          if (!isStartCompute.value) {
+            // n++;
+            openTimer(cloneDeep(obj));
           } else {
-            item.Hz = (uHz.value + (Math.random() * 2 - 1) * Math.random() * 2).toFixed(2);
-          }
-          item.m3 = (obj.m3 - (0.02 * n * n * item.Hz * (resultObj.value.Hz - uHz.value) * (uQ.value - uQ1.value)) / 400).toFixed(2);
-          if (item.m3 < uQ1.value) {
-            item.m3 = uQ1.value - Math.random() * 10;
+            n++;
+            openTimer(cloneDeep(item));
           }
-          item.gas = (obj.gas + (0.015 * item.Hz * n * (uHz.value - item.Hz) * (gasWarningVal.value - gasWarningMax.value)) / 800).toFixed(4);
-        }
-      }
-      if (monitorList.length >= 10) {
-        monitorList.shift();
-        const monitor = cloneDeep(item);
-        const data = tempList.shift();
-        if (data) {
-          item['m3'] = data['m3'];
-          item['gas'] = data['gas'];
-        }
-        tempList.push(monitor);
-        monitorList.push(item);
-      } else {
-        monitorList.push(item);
-      }
-      monitorData.value = monitorList;
-      // console.log('瓦斯监测数据-------------->', monitorData.value);
-      if (timer) {
-        if (!isStartCompute.value) {
-          // n++;
-          openTimer(cloneDeep(obj));
-        } else {
-          n++;
-          openTimer(cloneDeep(item));
         }
-      }
-    }, 3000);
+      }, 3000);
+    }
   }
-}
 
-function edit(flag) {
-  if (flag == 'info') {
-    formType.value = '编辑风机信息';
+  function edit(flag) {
+    if (flag == 'info') {
+      formType.value = '编辑风机信息';
+    }
+    if (flag == 'line') {
+      formType.value = '编辑特性曲线';
+    }
+    if (formShow.value == true) {
+      formShow.value = false;
+      nextTick(() => {
+        formShow.value = true;
+      });
+    } else {
+      formShow.value = true;
+    }
   }
-  if (flag == 'line') {
-    formType.value = '编辑特性曲线';
+
+  function onSubmit() {
+    emit('close');
+    closeModal();
+    ChartRef.value = null;
+    uQ.value = undefined;
+    uH.value = undefined;
+    formType.value = '';
+    refresh.value = true;
+    xData.length = 0;
+    yDataList.length = 0;
+    lineNum = 0;
+    lineEquation.value = [];
+    resultObj.value = null;
+    monitorData.value = [];
+    clearTimeout(timer);
+    timer = undefined;
   }
-  if (formShow.value == true) {
-    formShow.value = false;
-    nextTick(() => {
-      formShow.value = true;
+
+  async function onCancel() {
+    return new Promise((resolve) => {
+      if (isStartCompute.value == 0) {
+        onSubmit();
+        resolve(true);
+      } else {
+        message.warning('为保障矿井安全生产,请确保已复位!!!');
+        resolve(false);
+      }
     });
-  } else {
-    formShow.value = true;
   }
-}
-
-function onSubmit() {
-  emit('close');
-  closeModal();
-  ChartRef.value = null;
-  uQ.value = undefined;
-  uH.value = undefined;
-  formType.value = '';
-  refresh.value = true;
-  xData.length = 0;
-  yDataList.length = 0;
-  lineNum = 0;
-  lineEquation.value = [];
-  resultObj.value = null;
-  monitorData.value = [];
-  clearTimeout(timer);
-  timer = undefined;
-}
-
-async function onCancel() {
-  return new Promise((resolve) => {
-    if (isStartCompute.value == 0) {
-      onSubmit();
-      resolve(true);
-    } else {
-      message.warning('为保障矿井安全生产,请确保已复位!!!');
-      resolve(false);
+
+  function initEcharts() {
+    if (ChartRef.value) {
+      reSetLine();
+      myChart.value = echarts.init(ChartRef.value);
+      option && myChart.value.setOption(option);
+      refresh.value = false;
+      getMonitor();
+      nextTick(() => {
+        setTimeout(() => {
+          refresh.value = true;
+        }, 0);
+      });
     }
-  });
-}
-
-function initEcharts() {
-  if (ChartRef.value) {
-    reSetLine();
-    myChart.value = echarts.init(ChartRef.value);
-    option && myChart.value.setOption(option);
-    refresh.value = false;
-    getMonitor();
-    nextTick(() => {
-      setTimeout(() => {
-        refresh.value = true;
-      }, 0);
-    });
   }
-}
 
-function makeLine() {
-  if (uQ.value && uH.value) {
-    loadding.value = true;
+  function makeLine() {
+    if (uQ.value && uH.value) {
+      loadding.value = true;
+      setTimeout(() => {
+        computeR();
+        reSetLine();
+        option && myChart.value.setOption(option);
+        loadding.value = false;
+      }, 1200);
+    }
+  }
+  function handleSubmit() {
+    message.success('提交成功');
     setTimeout(() => {
-      computeR();
-      reSetLine();
-      option && myChart.value.setOption(option);
-      loadding.value = false;
-    }, 1200);
+      formShow.value = false;
+    }, 800);
   }
-}
-function handleSubmit() {
-  message.success('提交成功');
-  setTimeout(() => {
-    formShow.value = false;
-  }, 800);
-}
-onMounted(() => {
-  timer = undefined;
-});
+  onMounted(() => {
+    timer = undefined;
+  });
 </script>
 
 <style scoped lang="less">
-.modal-box {
-  display: flex;
-  flex-direction: row;
-  background-color: #ffffff05;
-  padding: 20px 8px 0 8px;
-  border: 1px solid #00d8ff22;
-  position: relative;
-  // min-height: 600px;
-  .box-title {
-    width: calc(100% - 40px);
-    text-align: center;
-    background-color: #1dc1f522;
-  }
-  .info-item {
+  .modal-box {
     display: flex;
-    justify-content: space-between;
-    align-items: center;
-    padding: 2px 0px;
-    margin: 10px 0;
-    line-height: 30px;
-    background-image: linear-gradient(to right, #39deff15, #3977e500);
-    &:first-child {
-      margin-top: 0;
-    }
-    .title {
-      width: 200px;
-      text-align: left;
-      padding-left: 20px;
-      color: #f1f1f1cc;
-    }
-    .value {
-      width: 150px;
-      color: #00d8ff;
-      padding-right: 20px;
-      text-align: right;
+    flex-direction: row;
+    background-color: #ffffff05;
+    padding: 20px 8px 0 8px;
+    border: 1px solid #00d8ff22;
+    position: relative;
+    // min-height: 600px;
+    .box-title {
+      width: calc(100% - 40px);
+      text-align: center;
+      background-color: #1dc1f522;
     }
-  }
-  .right-box {
-    width: 320px;
-    .info-lines {
-      width: calc(100% - 2px);
-      height: 450px;
-      box-shadow: 0px 0px 50px #86baff08 inset;
-      overflow-y: auto;
-      margin-top: 5px;
+    .info-item {
+      display: flex;
+      justify-content: space-between;
+      align-items: center;
+      padding: 2px 0px;
+      margin: 10px 0;
+      line-height: 30px;
+      background-image: linear-gradient(to right, #39deff15, #3977e500);
+      &:first-child {
+        margin-top: 0;
+      }
       .title {
-        width: 100%;
+        width: 200px;
+        text-align: left;
+        padding-left: 20px;
         color: #f1f1f1cc;
       }
+      .value {
+        width: 150px;
+        color: #00d8ff;
+        padding-right: 20px;
+        text-align: right;
+      }
     }
-  }
-  .center-box {
-    flex: 1;
-    margin: 0 10px;
-    display: flex;
-    .info-echarts {
-      // background-color: #ffffff11;
-    }
-    .result-tip {
-      text-align: center;
-      background-color: #00000011;
-      line-height: 28px;
-      margin: 10px 50px 0 50px;
-      border: 1px solid #00d8ff22;
-      border-radius: 2px;
+    .right-box {
+      width: 320px;
+      .info-lines {
+        width: calc(100% - 2px);
+        height: 450px;
+        box-shadow: 0px 0px 50px #86baff08 inset;
+        overflow-y: auto;
+        margin-top: 5px;
+        .title {
+          width: 100%;
+          color: #f1f1f1cc;
+        }
+      }
     }
-  }
-  .tip-box {
-    width: 1040px;
-    height: 44px;
-    position: absolute;
-    top: 417px;
-    display: flex;
-    padding: 0 20px;
-    .title {
-      width: 142px;
-      height: 43px;
+    .center-box {
+      flex: 1;
+      margin: 0 10px;
       display: flex;
-      align-items: center;
-      padding-left: 30px;
-      background-image: url('@/assets/images/fanlocal-tip/tip-title.png');
-      position: relative;
-      &::before {
-        content: '';
-        display: inline-block;
-        position: absolute;
-        width: 31px;
-        height: 31px;
-        top: 5px;
-        left: -8px;
-        background-image: url('@/assets/images/fanlocal-tip/tip-icon.png');
+      .info-echarts {
+        // background-color: #ffffff11;
+      }
+      .result-tip {
+        text-align: center;
+        background-color: #00000011;
+        line-height: 28px;
+        margin: 10px 50px 0 50px;
+        border: 1px solid #00d8ff22;
+        border-radius: 2px;
       }
     }
-    .tip-container {
-      width: 898px;
+    .tip-box {
+      width: 1040px;
       height: 44px;
-      line-height: 44px;
+      position: absolute;
+      top: 417px;
       display: flex;
-      background-image: url('@/assets/images/fanlocal-tip/tip-bg.png');
-      background-size: cover;
+      padding: 0 20px;
+      .title {
+        width: 142px;
+        height: 43px;
+        display: flex;
+        align-items: center;
+        padding-left: 30px;
+        background-image: url('@/assets/images/fanlocal-tip/tip-title.png');
+        position: relative;
+        &::before {
+          content: '';
+          display: inline-block;
+          position: absolute;
+          width: 31px;
+          height: 31px;
+          top: 5px;
+          left: -8px;
+          background-image: url('@/assets/images/fanlocal-tip/tip-icon.png');
+        }
+      }
+      .tip-container {
+        width: 898px;
+        height: 44px;
+        line-height: 44px;
+        display: flex;
+        background-image: url('@/assets/images/fanlocal-tip/tip-bg.png');
+        background-size: cover;
+      }
     }
   }
-}
-.setting-box {
-  width: 1170px;
-  height: 70px;
-  margin: 10px 0;
-  background-color: #ffffff05;
-  border: 1px solid #00d8ff22;
-  display: flex;
-  align-items: center;
-  justify-content: space-between;
-
-  .right-inputs {
-    width: 100%;
+  .setting-box {
+    width: 1170px;
+    height: 70px;
+    margin: 10px 0;
+    background-color: #ffffff05;
+    border: 1px solid #00d8ff22;
     display: flex;
-    height: 40px;
-    margin: 0 10px;
+    align-items: center;
     justify-content: space-between;
-  }
-  .left-buttons {
-    display: flex;
-    height: 40px;
 
-    .btn {
+    .right-inputs {
+      width: 100%;
+      display: flex;
+      height: 40px;
       margin: 0 10px;
+      justify-content: space-between;
     }
-  }
-  .border-clip {
-    width: 1px;
-    height: 25px;
-    border-right: 1px solid #8b8b8b77;
-  }
-  .input-title {
-    max-width: 150px;
-  }
-  .input-box {
-    width: 220px !important;
-    background: transparent !important;
-    border-color: #00d8ff44 !important;
-    margin-right: 20px;
-    color: #fff !important;
-  }
-  .btn {
-    padding: 8px 20px;
-    position: relative;
-    border-radius: 2px;
-    color: #fff;
-    width: fit-content;
-    cursor: pointer;
+    .left-buttons {
+      display: flex;
+      height: 40px;
 
-    &::before {
-      position: absolute;
-      display: block;
-      content: '';
-      width: calc(100% - 4px);
-      height: calc(100% - 4px);
-      top: 2px;
-      left: 2px;
-      border-radius: 2px;
-      z-index: -1;
+      .btn {
+        margin: 0 10px;
+      }
     }
-  }
-
-  .btn1 {
-    border: 1px solid #5cfaff;
+    .border-clip {
+      width: 1px;
+      height: 25px;
+      border-right: 1px solid #8b8b8b77;
+    }
+    .input-title {
+      max-width: 150px;
+    }
+    .input-box {
+      width: 220px !important;
+      background: transparent !important;
+      border-color: #00d8ff44 !important;
+      margin-right: 20px;
+      color: #fff !important;
+    }
+    .btn {
+      padding: 8px 20px;
+      position: relative;
+      border-radius: 2px;
+      color: #fff;
+      width: fit-content;
+      cursor: pointer;
 
-    &::before {
-      background-image: linear-gradient(#2effee92, #0cb1d592);
+      &::before {
+        position: absolute;
+        display: block;
+        content: '';
+        width: calc(100% - 4px);
+        height: calc(100% - 4px);
+        top: 2px;
+        left: 2px;
+        border-radius: 2px;
+        z-index: -1;
+      }
     }
 
-    &:hover {
-      border: 1px solid #5cfaffaa;
+    .btn1 {
+      border: 1px solid #5cfaff;
 
       &::before {
-        background-image: linear-gradient(#2effee72, #0cb1d572);
+        background-image: linear-gradient(#2effee92, #0cb1d592);
+      }
+
+      &:hover {
+        border: 1px solid #5cfaffaa;
+
+        &::before {
+          background-image: linear-gradient(#2effee72, #0cb1d572);
+        }
       }
     }
   }
-}
-.is-open {
-  animation: open 0.5s;
-  animation-iteration-count: 1;
-  animation-fill-mode: forwards;
-  animation-timing-function: ease-in;
-}
-.is-close {
-  height: 0px;
-}
-
-@keyframes open {
-  0% {
+  .is-open {
+    animation: open 0.5s;
+    animation-iteration-count: 1;
+    animation-fill-mode: forwards;
+    animation-timing-function: ease-in;
+  }
+  .is-close {
     height: 0px;
   }
-  100% {
-    height: fit-content;
+
+  @keyframes open {
+    0% {
+      height: 0px;
+    }
+    100% {
+      height: fit-content;
+    }
   }
-}
 
-@keyframes close {
-  0% {
-    height: fit-content;
+  @keyframes close {
+    0% {
+      height: fit-content;
+    }
+    100% {
+      height: 0px;
+    }
   }
-  100% {
-    height: 0px;
+  :deep(.zxm-divider-inner-text) {
+    color: #cacaca88 !important;
+  }
+  :deep(.zxm-form-item) {
+    margin-bottom: 10px;
   }
-}
-:deep(.zxm-divider-inner-text) {
-  color: #cacaca88 !important;
-}
-:deep(.zxm-form-item) {
-  margin-bottom: 10px;
-}
 </style>

+ 0 - 2
src/views/vent/monitorManager/fanLocalMonitor1/components/conditionAssistance1.vue

@@ -283,7 +283,6 @@
   }
 
   function computeUH(Hz: number, uQ: number) {
-    debugger;
     const equation = assistanceData.value.find((item) => {
       return Math.ceil(Hz) == item['Hz'];
     });
@@ -367,7 +366,6 @@
 
   // 根据风量计算压差
   function computePa() {
-    debugger;
     const R = uH.value / Number(uQ.value) / Number(uQ.value);
     const pointX = Number(uQ.value);
     const pointY = Number(uH.value);

+ 0 - 1
src/views/vent/monitorManager/fanLocalMonitor1/index.vue

@@ -740,7 +740,6 @@
         const dataArr = res.msgTxt[0].datalist || [];
         dataSource.value = [];
         selectRowIndex.value = dataArr.findIndex((item) => item.deviceID === deviceId.value);
-        debugger;
         if (selectRowIndex.value > -1) {
           if (!deviceType.value) deviceType.value = dataArr[selectRowIndex.value]['deviceType'];
           let data = dataArr[selectRowIndex.value];

+ 0 - 3
src/views/vent/monitorManager/fireDoorMonitor/fireDoor.threejs.fireF.ts

@@ -78,11 +78,9 @@ class FireDoorF {
 
   /* 提取风门序列帧,初始化前后门动画 */
   initAnimation() {
-    debugger;
     const fireGroup = this.group.children[0]?.getObjectByName('Fire-doorf');
     if (fireGroup) {
       const tracks = fireGroup.animations[0].tracks;
-      debugger;
       this.mixers = new THREE.AnimationMixer(fireGroup.children[0]);
 
       const door = new THREE.AnimationClip('door', 100, tracks);
@@ -95,7 +93,6 @@ class FireDoorF {
 
   // 播放动画
   play(handlerState, timeScale = 0.01) {
-    debugger;
     let handler = () => {};
     if (this.clipActionArr.door) {
       switch (handlerState) {

+ 0 - 1
src/views/vent/monitorManager/fireDoorMonitor/fireDoor.threejs.ts

@@ -47,7 +47,6 @@ const mouseEvent = (event) => {
 };
 
 export const play = (handlerState, flag?) => {
-  debugger;
   if (fmType === 'fireDoor' && fireDoor) {
     return fireDoor.play.call(fireDoor, handlerState, flag);
   }

+ 0 - 1
src/views/vent/monitorManager/fireDoorMonitor/index.vue

@@ -411,7 +411,6 @@
   let doorDeviceState = 1; //记录设备状态,为了与下一次监测数据做比较
   function monitorAnimation(selectData) {
     const timeScale = 0.005;
-    debugger;
     // 打开
     if (selectData.frontGateOpen == '1' && !isdoorOpenRunning) {
       isdoorOpenRunning = true;

+ 0 - 1
src/views/vent/monitorManager/gateMonitor/gate.threejs.noStation.ts

@@ -351,7 +351,6 @@ class FmNoStation {
         resolve(null);
       }
       this.model.setGLTFModel('Fm-noStation').then((gltf) => {
-        debugger;
         const fmModal = gltf[0];
         fmModal.name = 'Fm-noStation';
         this.group?.add(fmModal);

+ 0 - 1
src/views/vent/monitorManager/gateMonitor/gate.threejs.ts

@@ -143,7 +143,6 @@ export function computePlay(data, maxarea, isFirst = false) {
   // 前门前窗 frontPresentValue1
   // 后门后窗 rearPresentValue2
   // 后门前窗 frontPresentValue2
-  debugger;
   // if (data.OpenDegree1 || data.OpenDegree2) {
   //   maxarea = 90;
   //   rotationParam.frontDeg0 = (90 / maxarea) * Number(isFirst ? 0 : data.OpenDegree1);

+ 0 - 1
src/views/vent/monitorManager/gateMonitor/gate.threejs.window.ts

@@ -224,7 +224,6 @@ class FmDc {
       const parentGroup = fmGroup.getObjectByName('MeiCangLianLuoHangFengMen');
       // const frontGroup = parentGroup.getObjectByName('FengMen2');
       // const backGroup = parentGroup.getObjectByName('FengMen1');
-      debugger;
       this.mixers = new THREE.AnimationMixer(parentGroup);
 
       const frontDoor = new THREE.AnimationClip('frontDoor', 2.5, fontTracks);

+ 0 - 5
src/views/vent/monitorManager/mainFanMonitor/mainWind.threejs.ts

@@ -173,7 +173,6 @@ class mainWindRect {
   mouseUpModel() {}
 
   async setDeviceFrequency(deviceType, state, frequencyVal?) {
-    debugger;
     // 调节频率
     if (frequencyVal) {
       this.resetSmokeParam(deviceType, frequencyVal, 0);
@@ -204,7 +203,6 @@ class mainWindRect {
       await this.lookMotor(deviceType, 'open', duration);
       await this.openOrCloseValve(deviceType, 'open', duration);
       this.startGearAnimation(deviceType, 'open', smokeDirection, frequencyVal, duration);
-      debugger;
       smoke.startSmoke(duration);
     }
   }
@@ -355,7 +353,6 @@ class mainWindRect {
    * @param state // 打开、关闭状态
    */
   async playSmoke(controlType, deviceType, frequencyVal, state, smokeDirection) {
-    debugger;
     if (frequencyVal) {
       this.resetSmokeParam(deviceType, frequencyVal);
     }
@@ -378,7 +375,6 @@ class mainWindRect {
       if (smoke && smoke.frameId) {
         await smoke.stopSmoke();
         await this.setSmokeDirection(deviceType, smokeDirection);
-        debugger;
         smoke.startSmoke();
       }
     } else if (controlType === 'frequency') {
@@ -757,7 +753,6 @@ class mainWindRect {
         this.group?.position.set(-0.44, 19.88, 22.37);
         this.initSmokeMass();
         await this.setSmokePosition();
-        debugger;
         const ztfjGroup = this.group?.getObjectByName('ztfj') as THREE.Group;
         const fbmGroup = this.group?.getObjectByName('fbm') as THREE.Group;
         const fcGroup = this.group?.getObjectByName('ztfj-fc') as THREE.Group;

+ 0 - 1
src/views/vent/monitorManager/mainFanMonitor/mainWind.xj.threejs.ts

@@ -684,7 +684,6 @@ class mainXjWindRect {
 
   mountedThree() {
     this.group = new THREE.Group();
-    debugger;
     return new Promise(async (resolve) => {
       this.model.setGLTFModel('ztfj-xj').then(async (gltf) => {
         const ztfjModal = gltf[0].children[0];

+ 0 - 1
src/views/vent/monitorManager/nitrogen/nitrogen.threejs.ts

@@ -88,7 +88,6 @@ export const setModelType = (modalTypeName) => {
     const oldControlsPosition = { x: 0, y: 0, z: 0 };
     let newCameraPosition = { x: 0, y: 0, z: 0 },
       newControlsPosition = { x: 0, y: 0, z: 0 };
-    debugger;
     if (group?.children.length == 7) {
       newCameraPosition = { x: -150.124016817707, y: 73.73471355835353, z: 6.421728063746754 };
       newControlsPosition = { x: -3.0365054180427618, y: -14.182088742518898, z: 6.336141914568813 };

+ 0 - 1
src/views/vent/monitorManager/windowMonitor/dandaoFcBd2.threejs.ts

@@ -171,7 +171,6 @@ class ddFc_2 {
     if (fcGroup) {
       const frontObjNames = ['FengChuang_1_3', 'FengChuang_1_2', 'FengChuang_1_18'];
       const backObjNames = ['FengChuang_1_20', 'FengChuang_1_21', 'FengChuang_1_22'];
-      debugger;
       frontObjNames.filter((name) => {
         const obj = fcGroup?.getObjectByName(name);
         if (obj) {

+ 0 - 2
src/views/vent/monitorManager/windowMonitor/shuangdaoFcBlt.threejs.ts

@@ -160,7 +160,6 @@ class sdFc_3 {
     const fcObj2 = fc?.getObjectByName('FengChuang_2_1');
     const frontObjNames = ['FengChuang_1_2', 'FengChuang_1_3', 'FengChuang_1_4', 'FengChuang_1_5'];
     const backObjNames = ['FengChuang_2_2', 'FengChuang_2_3', 'FengChuang_2_4', 'FengChuang_2_5'];
-    debugger;
     frontObjNames.filter((name) => {
       const obj = fcObj1?.getObjectByName(name);
       if (obj) {
@@ -180,7 +179,6 @@ class sdFc_3 {
   }
 
   play(rotationParam, flag) {
-    debugger;
     if (this.windowsActionArr.frontWindow.length <= 0 || this.windowsActionArr.backWindow.length <= 0) {
       return;
     }

+ 0 - 1
src/views/vent/monitorManager/windowMonitor/window.threejs.ts

@@ -340,7 +340,6 @@ export const mountedThree = () => {
     model.camera.position.set(100, 0, 1000);
     // 根据模型类型判断要初始化哪些模型
     const dictCodes = getDictItemsByCode('windowModalType');
-    debugger;
     for (let i = 0; i < dictCodes.length; i++) {
       const dict = dictCodes[i];
 

+ 0 - 1
src/views/vent/monitorManager/windrectMonitor/index.vue

@@ -562,7 +562,6 @@
   }
   // 切换检测数据
   async function getSelectRow(selectRow, index) {
-    debugger;
     if (selectRow) {
       loading.value = true;
       selectRowIndex.value = index;

+ 277 - 278
src/views/vent/safetyList/common/HistoryTable.vue

@@ -10,315 +10,314 @@
 </template>
 
 <script lang="ts" setup>
-//ts语法
-import { watchEffect, ref, watch, defineExpose, inject, nextTick, onMounted, computed } from 'vue';
-import { subStationList } from '../safetyList.api';
-import { historyColumns } from '../historyLsit.data';
-import { FormSchema } from '/@/components/Form/index';
-import { BasicTable } from '/@/components/Table';
-import { useListPage } from '/@/hooks/system/useListPage';
-import { getTableHeaderColumns } from '/@/hooks/web/useWebColumns';
-import { useMethods } from '/@/hooks/system/useMethods';
-import { defHttp } from '/@/utils/http/axios';
-import dayjs from 'dayjs';
-import { getAutoScrollContainer } from '/@/utils/common/compUtils';
+  //ts语法
+  import { watchEffect, ref, watch, defineExpose, inject, nextTick, onMounted, computed } from 'vue';
+  import { subStationList } from '../safetyList.api';
+  import { historyColumns } from '../historyLsit.data';
+  import { FormSchema } from '/@/components/Form/index';
+  import { BasicTable } from '/@/components/Table';
+  import { useListPage } from '/@/hooks/system/useListPage';
+  import { getTableHeaderColumns } from '/@/hooks/web/useWebColumns';
+  import { useMethods } from '/@/hooks/system/useMethods';
+  import { defHttp } from '/@/utils/http/axios';
+  import dayjs from 'dayjs';
+  import { getAutoScrollContainer } from '/@/utils/common/compUtils';
 
-const props = defineProps({
-  columnsType: {
-    type: String,
-  },
-  columns: {
-    type: Array,
-    // required: true,
-    default: () => [],
-  },
-  historyColumns: {
-    type: Array,
-    default: () => [],
-  },
-  stationId: {
-    type: String,
-  },
-  scroll: {
-    type: Object,
-    default: { y: 0 },
-  },
-  formSchemas: {
-    type: Array<FormSchema>,
-    default: () => [],
-  },
-});
-const postExportXlsUrl = '/safety/ventanalySubStation/export158StatusLog';
-//获取分站数据
-const historyTable = ref();
-const loading = ref(false);
-const dataSource = ref([]);
+  const props = defineProps({
+    columnsType: {
+      type: String,
+    },
+    columns: {
+      type: Array,
+      // required: true,
+      default: () => [],
+    },
+    historyColumns: {
+      type: Array,
+      default: () => [],
+    },
+    stationId: {
+      type: String,
+    },
+    scroll: {
+      type: Object,
+      default: { y: 0 },
+    },
+    formSchemas: {
+      type: Array<FormSchema>,
+      default: () => [],
+    },
+  });
+  const postExportXlsUrl = '/safety/ventanalySubStation/export158StatusLog';
+  //获取分站数据
+  const historyTable = ref();
+  const loading = ref(false);
+  const dataSource = ref([]);
 
-const emit = defineEmits(['change']);
+  const emit = defineEmits(['change']);
 
-const deviceKide = ref('');
-const columns = ref([]);
-const tableScroll = props.scroll.y ? ref({ y: props.scroll.y - 100 }) : ref({});
-loading.value = true;
+  const deviceKide = ref('');
+  const columns = ref([]);
+  const tableScroll = props.scroll.y ? ref({ y: props.scroll.y - 100 }) : ref({});
+  loading.value = true;
 
-watch(
-  () => {
-    return props.columnsType;
-  },
-  async (newVal) => {
-    debugger;
-    if (!newVal) return;
-    deviceKide.value = newVal;
-    if (historyTable.value) {
-      getForm().resetFields();
-      // getForm().updateSchema();
-      // getForm();
+  watch(
+    () => {
+      return props.columnsType;
+    },
+    async (newVal) => {
+      if (!newVal) return;
+      deviceKide.value = newVal;
+      if (historyTable.value) {
+        getForm().resetFields();
+        // getForm().updateSchema();
+        // getForm();
+      }
+      dataSource.value = [];
+      nextTick(() => {
+        getDataSource();
+      });
+
+      if (historyTable.value) reload();
+    },
+    {
+      immediate: true,
     }
-    dataSource.value = [];
-    nextTick(() => {
-      getDataSource();
-    });
+  );
 
-    if (historyTable.value) reload();
-  },
-  {
-    immediate: true,
-  }
-);
+  watch(
+    () => props.scroll.y,
+    (newVal) => {
+      if (newVal) {
+        tableScroll.value = { y: newVal - 100 };
+      } else {
+        tableScroll.value = {};
+      }
+    }
+  );
 
-watch(
-  () => props.scroll.y,
-  (newVal) => {
-    if (newVal) {
-      tableScroll.value = { y: newVal - 100 };
-    } else {
-      tableScroll.value = {};
+  watch(
+    () => props.stationId,
+    async () => {
+      await getForm().setFieldsValue({});
     }
-  }
-);
+  );
 
-watch(
-  () => props.stationId,
-  async () => {
-    await getForm().setFieldsValue({});
+  function resetFormParam() {
+    const formData = getForm().getFieldsValue();
+    const pagination = getPaginationRef();
+    formData['pageNo'] = pagination['current'];
+    formData['pageSize'] = pagination['pageSize'];
+    const params = {
+      pageNo: pagination['current'],
+      pageSize: pagination['pageSize'],
+      createTime_begin: formData['starttime_begin'],
+      createTime_end: formData['starttime_end'],
+      stationId: props.stationId,
+      status: formData['status'],
+    };
+    return params;
   }
-);
 
-function resetFormParam() {
-  const formData = getForm().getFieldsValue();
-  const pagination = getPaginationRef();
-  formData['pageNo'] = pagination['current'];
-  formData['pageSize'] = pagination['pageSize'];
-  const params = {
-    pageNo: pagination['current'],
-    pageSize: pagination['pageSize'],
-    createTime_begin: formData['starttime_begin'],
-    createTime_end: formData['starttime_end'],
-    stationId: props.stationId,
-    status: formData['status'],
-  };
-  return params;
-}
-
-async function getDataSource() {
-  dataSource.value = [];
-  setLoading(true);
-  const params = await resetFormParam();
-  const res = await defHttp.post(
-    { url: '/safety/ventanalySubStation/get158StatusLog', params: params },
-    { joinParamsToUrl: true, isTransformResponse: false }
-  );
-  console.log(res.result['records']);
-  if (res.result['records'].length > 0) {
-    dataSource.value = res.result['records'];
-    setLoading(false);
-  } else {
+  async function getDataSource() {
     dataSource.value = [];
-    setLoading(false);
+    setLoading(true);
+    const params = await resetFormParam();
+    const res = await defHttp.post(
+      { url: '/safety/ventanalySubStation/get158StatusLog', params: params },
+      { joinParamsToUrl: true, isTransformResponse: false }
+    );
+    console.log(res.result['records']);
+    if (res.result['records'].length > 0) {
+      dataSource.value = res.result['records'];
+      setLoading(false);
+    } else {
+      dataSource.value = [];
+      setLoading(false);
+    }
+  }
+  //导入导出方法
+  function onExportXlsFn() {
+    const { exportXlsPost0 } = useMethods();
+    const params = resetFormParam();
+    exportXlsPost0('历史数据', postExportXlsUrl, params);
   }
-}
-//导入导出方法
-function onExportXlsFn() {
-  const { exportXlsPost0 } = useMethods();
-  const params = resetFormParam();
-  exportXlsPost0('历史数据', postExportXlsUrl, params);
-}
 
-// 列表页面公共参数、方法
-const { tableContext } = useListPage({
-  tableProps: {
-    // api: list,
-    columns: props.historyColumns ? props.historyColumns : (props.historyColumns as any[]),
-    canResize: true,
-    showTableSetting: false,
-    showActionColumn: false,
-    bordered: false,
-    size: 'small',
-    scroll: tableScroll,
-    showIndexColumn: true,
-    tableLayout: 'auto',
-    formConfig: {
-      labelAlign: 'left',
-      showAdvancedButton: false,
-      showSubmitButton: false,
-      showResetButton: false,
-      baseColProps: {
-        xs: 24,
-        sm: 24,
-        md: 24,
-        lg: 9,
-        xl: 7,
-        xxl: 4,
-      },
-      schemas:
-        props.formSchemas.length > 0
-          ? props.formSchemas
-          : [
-              {
-                field: 'starttime_begin',
-                label: '开始时间',
-                component: 'DatePicker',
-                defaultValue: dayjs().startOf('date'),
-                required: true,
-                componentProps: {
-                  showTime: true,
-                  valueFormat: 'YYYY-MM-DD HH:mm:ss',
-                  getPopupContainer: getAutoScrollContainer,
+  // 列表页面公共参数、方法
+  const { tableContext } = useListPage({
+    tableProps: {
+      // api: list,
+      columns: props.historyColumns ? props.historyColumns : (props.historyColumns as any[]),
+      canResize: true,
+      showTableSetting: false,
+      showActionColumn: false,
+      bordered: false,
+      size: 'small',
+      scroll: tableScroll,
+      showIndexColumn: true,
+      tableLayout: 'auto',
+      formConfig: {
+        labelAlign: 'left',
+        showAdvancedButton: false,
+        showSubmitButton: false,
+        showResetButton: false,
+        baseColProps: {
+          xs: 24,
+          sm: 24,
+          md: 24,
+          lg: 9,
+          xl: 7,
+          xxl: 4,
+        },
+        schemas:
+          props.formSchemas.length > 0
+            ? props.formSchemas
+            : [
+                {
+                  field: 'starttime_begin',
+                  label: '开始时间',
+                  component: 'DatePicker',
+                  defaultValue: dayjs().startOf('date'),
+                  required: true,
+                  componentProps: {
+                    showTime: true,
+                    valueFormat: 'YYYY-MM-DD HH:mm:ss',
+                    getPopupContainer: getAutoScrollContainer,
+                  },
+                  colProps: {
+                    span: 8,
+                  },
                 },
-                colProps: {
-                  span: 8,
+                {
+                  field: 'starttime_end',
+                  label: '结束时间',
+                  component: 'DatePicker',
+                  defaultValue: dayjs(),
+                  required: true,
+                  componentProps: {
+                    showTime: true,
+                    valueFormat: 'YYYY-MM-DD HH:mm:ss',
+                    getPopupContainer: getAutoScrollContainer,
+                  },
+                  colProps: {
+                    span: 8,
+                  },
                 },
-              },
-              {
-                field: 'starttime_end',
-                label: '结束时间',
-                component: 'DatePicker',
-                defaultValue: dayjs(),
-                required: true,
-                componentProps: {
-                  showTime: true,
-                  valueFormat: 'YYYY-MM-DD HH:mm:ss',
-                  getPopupContainer: getAutoScrollContainer,
+                {
+                  label: '连接状态',
+                  field: 'status',
+                  component: 'Select',
+                  defaultValue: 1,
+                  componentProps: {
+                    options: [
+                      { label: '连接成功', value: 1 },
+                      { label: '连接失败', value: 0 },
+                    ],
+                  },
+                  colProps: {
+                    span: 8,
+                  },
                 },
-                colProps: {
-                  span: 8,
-                },
-              },
-              {
-                label: '连接状态',
-                field: 'status',
-                component: 'Select',
-                defaultValue: 1,
-                componentProps: {
-                  options: [
-                    { label: '连接成功', value: 1 },
-                    { label: '连接失败', value: 0 },
-                  ],
-                },
-                colProps: {
-                  span: 8,
-                },
-              },
-            ],
-    },
-    // fetchSetting: {
-    pagination: {
-      current: 1,
-      pageSize: 20,
-      pageSizeOptions: ['10', '30', '50', '100'],
-      showQuickJumper: false,
-    },
+              ],
+      },
+      // fetchSetting: {
+      pagination: {
+        current: 1,
+        pageSize: 20,
+        pageSizeOptions: ['10', '30', '50', '100'],
+        showQuickJumper: false,
+      },
 
-    beforeFetch() {
-      const newParams = { ...resetFormParam() };
-      // debugger;
-      return newParams;
+      beforeFetch() {
+        const newParams = { ...resetFormParam() };
+        // debugger;
+        return newParams;
+      },
+    },
+    exportConfig: {
+      name: '历史列表',
+      url: postExportXlsUrl,
     },
-  },
-  exportConfig: {
-    name: '历史列表',
-    url: postExportXlsUrl,
-  },
-});
+  });
 
-//注册table数据
-const [registerTable, { reload, setLoading, getForm, setColumns, getPaginationRef, setPagination }] = tableContext;
+  //注册table数据
+  const [registerTable, { reload, setLoading, getForm, setColumns, getPaginationRef, setPagination }] = tableContext;
 
-watchEffect(() => {
-  if (historyTable.value && dataSource) {
-    const data = dataSource.value || [];
-    emit('change', data);
-  }
-});
+  watchEffect(() => {
+    if (historyTable.value && dataSource) {
+      const data = dataSource.value || [];
+      emit('change', data);
+    }
+  });
 
-onMounted(async () => {
-  if (props.stationId) {
-    nextTick(async () => {
-      await getDataSource();
-    });
-  }
-});
-defineExpose({ setLoading });
+  onMounted(async () => {
+    if (props.stationId) {
+      nextTick(async () => {
+        await getDataSource();
+      });
+    }
+  });
+  defineExpose({ setLoading });
 </script>
 
 <style scoped lang="less">
-@import '/@/design/theme.less';
+  @import '/@/design/theme.less';
 
-:deep(.@{ventSpace}-table-body) {
-  height: auto !important;
-}
-:deep(.zxm-picker) {
-  height: 30px !important;
-}
-.history-table {
-  width: 100%;
-  :deep(.jeecg-basic-table-form-container) {
-    .@{ventSpace}-form {
-      padding: 0 !important;
-      border: none !important;
-      margin-bottom: 0 !important;
-      .@{ventSpace}-picker,
-      .@{ventSpace}-select-selector {
-        width: 100% !important;
-        height: 100%;
-        background: #00000017;
-        border: 1px solid #b7b7b7;
-        input,
-        .@{ventSpace}-select-selection-item,
-        .@{ventSpace}-picker-suffix {
-          color: #fff;
-        }
-        .@{ventSpace}-select-selection-placeholder {
-          color: #ffffffaa;
-        }
-        .@{ventSpace}-zxm-select-selection-item {
-          color: #00000017 !important;
+  :deep(.@{ventSpace}-table-body) {
+    height: auto !important;
+  }
+  :deep(.zxm-picker) {
+    height: 30px !important;
+  }
+  .history-table {
+    width: 100%;
+    :deep(.jeecg-basic-table-form-container) {
+      .@{ventSpace}-form {
+        padding: 0 !important;
+        border: none !important;
+        margin-bottom: 0 !important;
+        .@{ventSpace}-picker,
+        .@{ventSpace}-select-selector {
+          width: 100% !important;
+          height: 100%;
+          background: #00000017;
+          border: 1px solid #b7b7b7;
+          input,
+          .@{ventSpace}-select-selection-item,
+          .@{ventSpace}-picker-suffix {
+            color: #fff;
+          }
+          .@{ventSpace}-select-selection-placeholder {
+            color: #ffffffaa;
+          }
+          .@{ventSpace}-zxm-select-selection-item {
+            color: #00000017 !important;
+          }
         }
       }
+      .@{ventSpace}-table-title {
+        min-height: 0 !important;
+      }
     }
-    .@{ventSpace}-table-title {
-      min-height: 0 !important;
-    }
-  }
-  .pagination-box {
-    display: flex;
-    justify-content: flex-end;
-    align-items: center;
-    .page-num {
-      border: 1px solid #0090d8;
-      padding: 4px 8px;
-      margin-right: 5px;
-      color: #0090d8;
-    }
-    .btn {
-      margin-right: 10px;
+    .pagination-box {
+      display: flex;
+      justify-content: flex-end;
+      align-items: center;
+      .page-num {
+        border: 1px solid #0090d8;
+        padding: 4px 8px;
+        margin-right: 5px;
+        color: #0090d8;
+      }
+      .btn {
+        margin-right: 10px;
+      }
     }
   }
-}
 </style>
 <style lang="less" scoped>
-:deep(.zxm-picker-dropdown) {
-  top: 50px !important;
-  left: 5px !important;
-}
+  :deep(.zxm-picker-dropdown) {
+    top: 50px !important;
+    left: 5px !important;
+  }
 </style>