From b4495445fbfc616a2126587ce9eec205fc1cbe19 Mon Sep 17 00:00:00 2001
From: ZZJ <zzjdsg2300@163.com>
Date: 星期三, 20 四月 2022 13:52:11 +0800
Subject: [PATCH] 授权时间修改

---
 public/images/diy/9.png                                                     |    0 
 src/Pool/PollData.ts                                                        |    9 
 vue.config.js                                                               |    6 
 src/views/hashrate/CameraManage/index.vue                                   |    2 
 src/views/productDetail/components/ConfirmOrder.vue                         |    3 
 src/views/personalCenter/components/SubAccount.vue                          |   45 +-
 src/views/hashrate/index.vue                                                |   14 
 src/views/productDetail/components/Function.vue                             |    3 
 src/views/search/index.vue                                                  |    2 
 src/components/giantTree/zTree/ztree.vue                                    |   36 +-
 src/views/index/components/commendContent.vue                               |    4 
 src/views/equipmentManagement/equipmentList/components/FormList.vue         |    6 
 src/views/equipmentManagement/components/Banner.vue                         |    8 
 public/images/diy/2.png                                                     |    0 
 public/images/search/数据查看.png                                               |    0 
 src/views/productDetail/components/PayCard.vue                              |    4 
 src/components/wasmPlayer/index.vue                                         |    6 
 src/views/index/components/userCard.vue                                     |   12 
 src/router/index.js                                                         |   10 
 public/images/diy/3.png                                                     |    0 
 public/images/diy/1_open.png                                                |    0 
 public/images/diy/open.png                                                  |    0 
 src/views/equipmentManagement/equipmentDetail/components/FormArea.vue       |    4 
 src/views/login/components/loginForm.vue                                    |    3 
 src/views/hashrate/HashManage/components/EquipmentForm.vue                  |   43 +-
 src/views/equipmentManagement/index.vue                                     |   14 
 public/images/diy/4.png                                                     |    0 
 src/api/timeRule.ts                                                         |    8 
 public/images/diy/close.png                                                 |    0 
 public/images/diy/5.png                                                     |    0 
 public/images/diy/working.png                                               |    0 
 src/components/wasmPlayer/wasm/player.js                                    |  223 ++++++-------
 src/views/search/components/Flow.vue                                        |   68 ++++
 src/views/trialCenter/components/SdkItem.vue                                |    6 
 public/images/diy/6.png                                                     |    0 
 public/images/search/开通统计查询.png                                             |    0 
 public/images/diy/1_close.png                                               |    0 
 src/components/Price.vue                                                    |   27 +
 src/views/search/components/LeftNav.vue                                     |    6 
 src/views/search/components/giantTree/zTree/ztree.vue                       |    2 
 public/images/diy/unfold.png                                                |    0 
 src/views/equipmentManagement/equipmentList/components/JoinClusterBox.vue   |    9 
 src/views/search/components/Banner.vue                                      |   55 +++
 src/api/user.ts                                                             |    8 
 src/views/search/searchOpen.vue                                             |   50 +++
 public/images/diy/7.png                                                     |    0 
 src/views/hashrate/CameraManage/CameraRules/components/LinkageCameraBox.vue |   15 
 src/api/product.ts                                                          |    6 
 public/images/diy/fold.png                                                  |    0 
 public/images/diy/camera.png                                                |    0 
 public/images/search/数据实时监控.png                                             |    0 
 src/views/manageCenter/index.vue                                            |   27 +
 public/images/search/录像查看.png                                               |    0 
 src/views/hashrate/components/Banner.vue                                    |    8 
 public/libs/wasmPlayer/turbo.js                                             |  182 +++++-----
 public/images/diy/8.png                                                     |    0 
 56 files changed, 615 insertions(+), 319 deletions(-)

diff --git a/src/components/giantTree/zTree/img/diy/1_close.png b/public/images/diy/1_close.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/1_close.png
rename to public/images/diy/1_close.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/1_open.png b/public/images/diy/1_open.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/1_open.png
rename to public/images/diy/1_open.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/2.png b/public/images/diy/2.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/2.png
rename to public/images/diy/2.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/3.png b/public/images/diy/3.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/3.png
rename to public/images/diy/3.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/4.png b/public/images/diy/4.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/4.png
rename to public/images/diy/4.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/5.png b/public/images/diy/5.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/5.png
rename to public/images/diy/5.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/6.png b/public/images/diy/6.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/6.png
rename to public/images/diy/6.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/7.png b/public/images/diy/7.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/7.png
rename to public/images/diy/7.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/8.png b/public/images/diy/8.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/8.png
rename to public/images/diy/8.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/9.png b/public/images/diy/9.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/9.png
rename to public/images/diy/9.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/camera.png b/public/images/diy/camera.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/camera.png
rename to public/images/diy/camera.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/close.png b/public/images/diy/close.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/close.png
rename to public/images/diy/close.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/fold.png b/public/images/diy/fold.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/fold.png
rename to public/images/diy/fold.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/open.png b/public/images/diy/open.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/open.png
rename to public/images/diy/open.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/unfold.png b/public/images/diy/unfold.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/unfold.png
rename to public/images/diy/unfold.png
Binary files differ
diff --git a/src/components/giantTree/zTree/img/diy/working.png b/public/images/diy/working.png
similarity index 100%
rename from src/components/giantTree/zTree/img/diy/working.png
rename to public/images/diy/working.png
Binary files differ
diff --git "a/public/images/search/\345\274\200\351\200\232\347\273\237\350\256\241\346\237\245\350\257\242.png" "b/public/images/search/\345\274\200\351\200\232\347\273\237\350\256\241\346\237\245\350\257\242.png"
new file mode 100644
index 0000000..dd2e880
--- /dev/null
+++ "b/public/images/search/\345\274\200\351\200\232\347\273\237\350\256\241\346\237\245\350\257\242.png"
Binary files differ
diff --git "a/public/images/search/\345\275\225\345\203\217\346\237\245\347\234\213.png" "b/public/images/search/\345\275\225\345\203\217\346\237\245\347\234\213.png"
new file mode 100644
index 0000000..dc597c1
--- /dev/null
+++ "b/public/images/search/\345\275\225\345\203\217\346\237\245\347\234\213.png"
Binary files differ
diff --git "a/public/images/search/\346\225\260\346\215\256\345\256\236\346\227\266\347\233\221\346\216\247.png" "b/public/images/search/\346\225\260\346\215\256\345\256\236\346\227\266\347\233\221\346\216\247.png"
new file mode 100644
index 0000000..969996c
--- /dev/null
+++ "b/public/images/search/\346\225\260\346\215\256\345\256\236\346\227\266\347\233\221\346\216\247.png"
Binary files differ
diff --git "a/public/images/search/\346\225\260\346\215\256\346\237\245\347\234\213.png" "b/public/images/search/\346\225\260\346\215\256\346\237\245\347\234\213.png"
new file mode 100644
index 0000000..6c4607c
--- /dev/null
+++ "b/public/images/search/\346\225\260\346\215\256\346\237\245\347\234\213.png"
Binary files differ
diff --git a/public/libs/wasmPlayer/turbo.js b/public/libs/wasmPlayer/turbo.js
index e4ce4b4..7ba1df1 100644
--- a/public/libs/wasmPlayer/turbo.js
+++ b/public/libs/wasmPlayer/turbo.js
@@ -1,78 +1,78 @@
 Module = {
   onRuntimeInitialized: function() {
-    onWasmLoaded()
+    onWasmLoaded();
   },
-}
-importScripts('libffmpeg.js')
+};
+importScripts("libffmpeg.js");
 
-var MediaName = null
-var IsStream = true
-var FileLen = -1
+var MediaName = null;
+var IsStream = true;
+var FileLen = -1;
 
-var SocketObj //WebSocket
-var CPointer_Buffer = null
-var CPointer_Cap = 0
+var SocketObj; //WebSocket
+var CPointer_Buffer = null;
+var CPointer_Cap = 0;
 
 function onWasmLoaded() {
   DeliverVideo = Module.addFunction(function(Buf, BufLen, TimeStamp) {
-    var CPointer_Array = Module.HEAPU8.subarray(Buf, Buf + BufLen)
+    var CPointer_Array = Module.HEAPU8.subarray(Buf, Buf + BufLen);
     var message = {
-      command: 'deliver_video',
+      command: "deliver_video",
       sample: { time_stamp: TimeStamp, buf: new Uint8Array(CPointer_Array) },
-    }
-    self.postMessage(message, [message.sample.buf.buffer])
-  }, 'viii')
+    };
+    self.postMessage(message, [message.sample.buf.buffer]);
+  }, "viii");
 
   DeliverAudio = Module.addFunction(function(Buf, BufLen, TimeStamp) {
-    var CPointer_Array = Module.HEAPU8.subarray(Buf, Buf + BufLen)
+    var CPointer_Array = Module.HEAPU8.subarray(Buf, Buf + BufLen);
     var message = {
-      command: 'deliver_audio',
+      command: "deliver_audio",
       sample: { time_stamp: TimeStamp, buf: new Uint8Array(CPointer_Array) },
-    }
-    self.postMessage(message, [message.sample.buf.buffer])
-  }, 'viii')
+    };
+    self.postMessage(message, [message.sample.buf.buffer]);
+  }, "viii");
 
   GetFileLength = Module.addFunction(function() {
     if (FileLen == -1) {
-      var xhr = new XMLHttpRequest()
-      xhr.open('get', MediaName, false) //false: syn mode
-      xhr.send()
-      FileLen = xhr.getResponseHeader('Content-Length')
-      xhr.abort()
+      var xhr = new XMLHttpRequest();
+      xhr.open("get", MediaName, false); //false: syn mode
+      xhr.send();
+      FileLen = xhr.getResponseHeader("Content-Length");
+      xhr.abort();
     }
-    return FileLen
-  }, 'i')
+    return FileLen;
+  }, "i");
 
   ReadFile = Module.addFunction(function(Buf, Pos, Size) {
-    var xhr = new XMLHttpRequest()
-    xhr.open('get', MediaName, false)
-    xhr.responseType = 'arraybuffer'
-    xhr.setRequestHeader('Range', 'bytes=' + Pos + '-' + (Pos + Size - 1))
-    xhr.send()
-    Module.HEAPU8.set(new Uint8Array(xhr.response), Buf) //Uint8Array(xhr.response).length
-    xhr.abort()
-  }, 'viii')
+    var xhr = new XMLHttpRequest();
+    xhr.open("get", MediaName, false);
+    xhr.responseType = "arraybuffer";
+    xhr.setRequestHeader("Range", "bytes=" + Pos + "-" + (Pos + Size - 1));
+    xhr.send();
+    Module.HEAPU8.set(new Uint8Array(xhr.response), Buf); //Uint8Array(xhr.response).length
+    xhr.abort();
+  }, "viii");
 
   CreateVideo = Module.addFunction(function(Duration, Width, Height) {
     self.postMessage({
-      command: 'create_video',
+      command: "create_video",
       param: { duration: Duration, width: Width, height: Height },
-    })
-  }, 'viii')
+    });
+  }, "viii");
 
   CreateAudio = Module.addFunction(function(Channel, SampleRate) {
     self.postMessage({
-      command: 'create_audio',
+      command: "create_audio",
       param: { channel: Channel, sample_rate: SampleRate },
-    })
-  }, 'vii')
+    });
+  }, "vii");
 
   Notify = Module.addFunction(function(Type, Value) {
     //type 1:鎾斁澶辫触 2:鏂囦欢鎾斁鍒版湯灏�
     //console.log(Type+" "+Value);
-    if (Type == 1) self.postMessage({ command: 'play_failed' })
-    else if (Type == 2) self.postMessage({ command: 'play_end' })
-  }, 'vii')
+    if (Type == 1) self.postMessage({ command: "play_failed" });
+    else if (Type == 2) self.postMessage({ command: "play_end" });
+  }, "vii");
 
   Module._Initialize(
     DeliverVideo,
@@ -82,87 +82,87 @@
     CreateVideo,
     CreateAudio,
     Notify
-  )
+  );
 
-  self.postMessage({ command: 'initialized' })
+  self.postMessage({ command: "initialized" });
 }
 
 function OnTimer() {
-  Module._Turbo0(null, 0)
+  Module._Turbo0(null, 0);
 }
 
 function requestWebsocket(url, msg, cb_message) {
-  SocketObj = new WebSocket(url)
-  SocketObj.binaryType = 'arraybuffer'
+  SocketObj = new WebSocket(url);
+  SocketObj.binaryType = "arraybuffer";
   SocketObj.onopen = function(evt) {
-    SocketObj.send(msg)
-  }
+    SocketObj.send(msg);
+  };
   SocketObj.onerror = function(evt) {
-    console.log('Ws connect error ' + evt.data)
-  }
-  SocketObj.onmessage = cb_message
+    console.log("Ws connect error " + evt.data);
+  };
+  SocketObj.onmessage = cb_message;
   SocketObj.onclose = function() {
-    console.log('Ws closed.')
-  }
+    console.log("Ws closed.");
+  };
 }
 
 function downloadFileByWebsocket(ws, payload) {
   this.requestWebsocket(ws, payload, function(evt) {
     if (evt.data.byteLength > CPointer_Cap) {
-      if (CPointer_Buffer != null) Module._free(CPointer_Buffer)
-      CPointer_Cap = evt.data.byteLength
-      CPointer_Buffer = Module._malloc(CPointer_Cap)
+      if (CPointer_Buffer != null) Module._free(CPointer_Buffer);
+      CPointer_Cap = evt.data.byteLength;
+      CPointer_Buffer = Module._malloc(CPointer_Cap);
     }
 
-    var typedArray = new Uint8Array(evt.data)
-    Module.HEAPU8.set(typedArray, CPointer_Buffer)
+    var typedArray = new Uint8Array(evt.data);
+    Module.HEAPU8.set(typedArray, CPointer_Buffer);
     //console.log("websocket data: "+typedArray.length);
-    Module._Turbo0(CPointer_Buffer, typedArray.length)
-  })
+    Module._Turbo0(CPointer_Buffer, typedArray.length);
+  });
 }
 
 self.onmessage = function(evt) {
   switch (evt.data.command) {
-    case 'play': {
-      MediaName = evt.data.media_name
-      IsStream = evt.data.other
+    case "play": {
+      MediaName = evt.data.media_name;
+      IsStream = evt.data.other;
       if (IsStream) {
-        downloadFileByWebsocket(MediaName, evt.data.payload)
+        downloadFileByWebsocket(MediaName, evt.data.payload);
       }
 
-      Module._Play(null, !IsStream)
-      TimerID = setInterval(OnTimer, 5) //姝ゅ�艰秺灏�,娓叉煋绮惧害瓒婇珮,涓斿彲澧炲己'鍙岀嚎绋嬬紦鍐插钩婊戞満鍒�'鍙潬鎬�
-      break
+      Module._Play(null, !IsStream);
+      TimerID = setInterval(OnTimer, 5); //姝ゅ�艰秺灏�,娓叉煋绮惧害瓒婇珮,涓斿彲澧炲己'鍙岀嚎绋嬬紦鍐插钩婊戞満鍒�'鍙潬鎬�
+      break;
     }
-    case 'pause': {
-      Module._Pause()
-      clearInterval(TimerID)
-      break
+    case "pause": {
+      Module._Pause();
+      clearInterval(TimerID);
+      break;
     }
-    case 'resume': {
-      Module._Resume()
-      TimerID = setInterval(OnTimer, 5)
-      break
+    case "resume": {
+      Module._Resume();
+      TimerID = setInterval(OnTimer, 5);
+      break;
     }
-    case 'stop': {
-      Module._Stop()
-      clearInterval(TimerID)
+    case "stop": {
+      Module._Stop();
+      clearInterval(TimerID);
       if (IsStream) {
-        SocketObj.close()
+        SocketObj.close();
         if (CPointer_Buffer != null) {
-          Module._free(CPointer_Buffer)
-          CPointer_Buffer = null
-          CPointer_Cap = 0
+          Module._free(CPointer_Buffer);
+          CPointer_Buffer = null;
+          CPointer_Cap = 0;
         }
       }
-      close() //exit worker
-      break
+      close(); //exit worker
+      break;
     }
-    case 'seek': {
-      Module._Seek(evt.data.pos)
-      break
+    case "seek": {
+      Module._Seek(evt.data.pos);
+      break;
     }
     default:
-      return
+      return;
   }
-}
+};
diff --git a/src/Pool/PollData.ts b/src/Pool/PollData.ts
index da79eb0..1a50fc4 100644
--- a/src/Pool/PollData.ts
+++ b/src/Pool/PollData.ts
@@ -159,7 +159,9 @@
       res  = await clusterSysInfo({});
     }
     else {
-      res  = await devicesSysInfo({});
+      res  = await devicesSysInfo({
+        deviceId:[sessionStorage.getItem('devId')],
+      });
     }
     if (res && res.success ) {
       this.CpuUsedPercent =res.data.cpu.usedPercent.toFixed(2)
@@ -178,7 +180,10 @@
       res  = await clusterStatisticRunInfo({});
     }
     else {
-      res  = await deviceStatisticRunInfo({});
+      res  = await deviceStatisticRunInfo({
+        deviceId:[sessionStorage.getItem('devId')],
+        userId:''
+      });
     }
    
     if (res && res.success) {
diff --git a/src/api/product.ts b/src/api/product.ts
index bf26038..d605cad 100644
--- a/src/api/product.ts
+++ b/src/api/product.ts
@@ -264,7 +264,7 @@
 //鑾峰彇杞挱鍥�
 export const getIndexPics = () => {
     return request({
-        url: `/saas/api-i/saasIndex/getIndexPics`,
+        url: `/cloud/api-i/saasIndex/getIndexPics`,
         method: 'get',
     })
 }
@@ -281,7 +281,7 @@
 //鑾峰彇鎺ㄨ崘绠楁硶
 export const getIndexModelRecommend = (data: any) => {
     return request({
-        url: `/saas/api-i/saasIndex/getIndexModelRecommend`,
+        url: `/cloud/api-i/saasIndex/getIndexModelRecommend`,
         method: 'post',
         data,
     })
@@ -290,7 +290,7 @@
 //鑾峰彇棣栭〉妯″潡
 export const getModelList = () => {
     return request({
-        url: `/saas/api-i/saasIndex/getModelList`,
+        url: `/cloud/api-i/saasIndex/getModelList`,
         method: 'get',
     })
 }
diff --git a/src/api/timeRule.ts b/src/api/timeRule.ts
index ef5da6d..87798f7 100644
--- a/src/api/timeRule.ts
+++ b/src/api/timeRule.ts
@@ -9,15 +9,15 @@
 
 export const deleteTimeRule = (query: any) => {
   return request({
-    url: "/data/api-v/cameraTimerule/delete",
-    method: "get",
-    params: query
+    url: "/saas/api-s/cameraTimerule/delete",
+    method: "delete",
+    data: query
   });
 };
 
 export const saveTimeRule = (params: any) => {
   return request({
-    url: "/data/api-v/cameraTimerule/save",
+    url: "/saas/api-s/cameraTimerule/save",
     method: "post",
     data: params
   });
diff --git a/src/api/user.ts b/src/api/user.ts
index ced0a13..c187723 100644
--- a/src/api/user.ts
+++ b/src/api/user.ts
@@ -100,3 +100,11 @@
     data: params
   });
 };
+
+export const enableMenu = (params: any) => {
+  return request({
+    url: "/saas/api-u/menu/enableMenu",
+    method: "post",
+    data: params
+  });
+};
diff --git a/src/components/Price.vue b/src/components/Price.vue
index 9d641b5..5078dc4 100644
--- a/src/components/Price.vue
+++ b/src/components/Price.vue
@@ -1,6 +1,6 @@
 
 <template>
-  <div class="Price" v-if="priceNew">
+  <div class="Price">
     锟�<span class="newPrice">{{ priceN1 }}</span
     >{{ priceN2 }}/骞�
     <span class="iconSave" v-if="showIcon">鐪�</span>
@@ -11,7 +11,9 @@
 <script>
 export default {
   props: {
-    priceNew: {},
+    priceNew: {
+      default: 0,
+    },
     showIcon: {
       default: false,
     },
@@ -42,6 +44,27 @@
       this.priceO2 = ".00";
     }
   },
+
+  watch: {
+    priceNew() {
+      const priceO = (this.priceNew * 1.2 + "").split(".");
+      const priceN = (this.priceNew + "").split(".");
+      if (priceN.length > 1) {
+        this.priceN1 = priceN[0];
+        this.priceN2 = "." + priceN[1];
+      } else {
+        this.priceN1 = priceN[0];
+        this.priceN2 = ".00";
+      }
+      if (priceO.length > 1) {
+        this.priceO1 = priceO[0];
+        this.priceO2 = "." + priceO[1];
+      } else {
+        this.priceO1 = priceO[0];
+        this.priceO2 = ".00";
+      }
+    },
+  },
 };
 </script>
 
diff --git a/src/components/giantTree/zTree/ztree.vue b/src/components/giantTree/zTree/ztree.vue
index 88db186..c66a40c 100644
--- a/src/components/giantTree/zTree/ztree.vue
+++ b/src/components/giantTree/zTree/ztree.vue
@@ -411,7 +411,7 @@
   padding: 0 0 0 18px;
 }
 .ztree li ul.line {
-  /* background: url(./img/line_conn.gif) 0 0 repeat-y; */
+  /* background: url(/images/line_conn.gif) 0 0 repeat-y; */
   background: url()
     0 0 repeat-y;
 }
@@ -502,8 +502,8 @@
   background-color: transparent;
   background-repeat: no-repeat;
   background-attachment: scroll;
-  /* background-image: url("./img/zTreeStandard.png"); */
-  /* *background-image: url("./img/zTreeStandard.gif"); */
+  /* background-image: url("/images/zTreeStandard.png"); */
+  /* *background-image: url("/images/zTreeStandard.gif"); */
 
   background-image: url();
   *background-image: url();
@@ -581,57 +581,57 @@
   height: 18px;
 }
 .ztree li span.button.root_open {
-  background-image: url("./img/diy/unfold.png");
+  background-image: url("/images/diy/unfold.png");
   background-position: center 5px;
 
   margin-right: 8px;
 }
 .ztree li span.button.root_close {
-  background-image: url("./img/diy/fold.png");
+  background-image: url("/images/diy/fold.png");
   background-position: center 5px;
   margin-right: 8px;
 }
 .ztree li span.button.roots_open {
-  background-image: url("./img/diy/unfold.png");
+  background-image: url("/images/diy/unfold.png");
   background-position: center 5px;
 
   margin-right: 8px;
 }
 .ztree li span.button.roots_close {
-  background-image: url("./img/diy/fold.png");
+  background-image: url("/images/diy/fold.png");
   background-position: center 5px;
   margin-right: 8px;
 }
 .ztree li span.button.center_open {
-  background-image: url("./img/diy/unfold.png");
+  background-image: url("/images/diy/unfold.png");
   background-position: center 5px;
 
   margin-right: 8px;
 }
 .ztree li span.button.center_close {
-  background-image: url("./img/diy/fold.png");
+  background-image: url("/images/diy/fold.png");
   background-position: center 5px;
   margin-right: 8px;
 }
 .ztree li span.button.bottom_open {
-  background-image: url("./img/diy/unfold.png");
+  background-image: url("/images/diy/unfold.png");
   background-position: center 5px;
 
   margin-right: 8px;
 }
 .ztree li span.button.bottom_close {
-  background-image: url("./img/diy/fold.png");
+  background-image: url("/images/diy/fold.png");
   background-position: center 5px;
   margin-right: 8px;
 }
 .ztree li span.button.noline_open {
-  background-image: url("./img/diy/unfold.png");
+  background-image: url("/images/diy/unfold.png");
   background-position: center 5px;
 
   margin-right: 8px;
 }
 .ztree li span.button.noline_close {
-  background-image: url("./img/diy/fold.png");
+  background-image: url("/images/diy/fold.png");
   background-position: center 5px;
   margin-right: 8px;
 }
@@ -655,11 +655,11 @@
   margin-right: 2px;
   vertical-align: top;
   *vertical-align: middle;
-  background-image: url("./img/diy/open.png");
+  background-image: url("/images/diy/open.png");
 }
 .ztree li span.button.ico_close {
   margin-right: 2px;
-  background-image: url("./img/diy/close.png");
+  background-image: url("/images/diy/close.png");
   vertical-align: top;
   *vertical-align: middle;
 }
@@ -684,7 +684,7 @@
 
 .ztree li span.button.ico_loading {
   margin-right: 2px;
-  /* background: url(./img/loading.gif) no-repeat scroll 0 0 transparent; */
+  /* background: url(/images/loading.gif) no-repeat scroll 0 0 transparent; */
   background: url()
     no-repeat scroll 0 0 transparent;
   vertical-align: top;
@@ -709,8 +709,8 @@
   background-repeat: no-repeat;
   background-attachment: scroll;
   background-position: -110px -80px;
-  /* background-image: url("./img/zTreeStandard.png"); */
-  /* *background-image: url("./img/zTreeStandard.gif"); */
+  /* background-image: url("/images/zTreeStandard.png"); */
+  /* *background-image: url("/images/zTreeStandard.gif"); */
   background-image: url();
   *background-image: url();
 }
diff --git a/src/components/wasmPlayer/index.vue b/src/components/wasmPlayer/index.vue
index f5de5c1..9f43bdf 100644
--- a/src/components/wasmPlayer/index.vue
+++ b/src/components/wasmPlayer/index.vue
@@ -460,6 +460,12 @@
 
       this.videoLoading = true;
       if (this.player.hPlayer == 0) {
+        console.log(url);
+        console.log(this.$refs.playCanvas);
+        console.log(this.isStream);
+        console.log(this.$refs.timeTrack);
+        console.log(this.$refs.timeLabel);
+        console.log(payload);
         this.player.play(
           url,
           this.$refs.playCanvas,
diff --git a/src/components/wasmPlayer/wasm/player.js b/src/components/wasmPlayer/wasm/player.js
index 307117f..71c7aac 100644
--- a/src/components/wasmPlayer/wasm/player.js
+++ b/src/components/wasmPlayer/wasm/player.js
@@ -1,27 +1,27 @@
-import { PCMPlayer } from './pcm-player'
-import { WebGLPlayer } from './webgl'
+import { PCMPlayer } from "./pcm-player";
+import { WebGLPlayer } from "./webgl";
 
 export function Player() {
-  this.hPlayer = 0
-  this.PlayOrPause = 0
-  this.MediaName = null
-  this.isStream = false
-  this.canvas = null
-  this.timeLabel = null
-  this.timeTrack = null
-  this.CurPos = 0
-  this.displayDuration = '00:00:00'
+  this.hPlayer = 0;
+  this.PlayOrPause = 0;
+  this.MediaName = null;
+  this.isStream = false;
+  this.canvas = null;
+  this.timeLabel = null;
+  this.timeTrack = null;
+  this.CurPos = 0;
+  this.displayDuration = "00:00:00";
 
-  this.pcmPlayer = null
-  this.webglPlayer = null
+  this.pcmPlayer = null;
+  this.webglPlayer = null;
 
-  this.trackTimer = null
-  this.loop = false
-  this.preload = true
-  this.preloadFlag = 0
+  this.trackTimer = null;
+  this.loop = false;
+  this.preload = true;
+  this.preloadFlag = 0;
   this.statusCallback = (stat) => {
-    console.log(stat)
-  }
+    console.log(stat);
+  };
 }
 
 Player.prototype.play = function(
@@ -32,181 +32,180 @@
   timeLabel,
   payload
 ) {
-  if (this.hPlayer != 0) return
+  if (this.hPlayer != 0) return;
 
-  this.MediaName = url
+  this.MediaName = url;
 
-  this.isStream = isStream
+  this.isStream = isStream;
 
-  this.canvas = canvas //hWnd
+  this.canvas = canvas; //hWnd
 
-  this.timeTrack = timeTrack
-  this.timeLabel = timeLabel
+  this.timeTrack = timeTrack;
+  this.timeLabel = timeLabel;
 
-  var This = this
+  var This = this;
   this.timeTrack.oninput = function() {
-    This.seek(This.timeTrack.value)
-  }
+    This.seek(This.timeTrack.value);
+  };
 
-  this.TurboWorker = new Worker('/libs/wasmPlayer/turbo.js')
-  this.hPlayer = 1
-  this.PlayOrPause = 1
+  this.TurboWorker = new Worker("/libs/wasmPlayer/turbo.js");
+  this.hPlayer = 1;
+  this.PlayOrPause = 1;
 
   this.TurboWorker.onmessage = function(evt) {
     switch (evt.data.command) {
-      case 'initialized': {
+      case "initialized": {
         This.TurboWorker.postMessage({
-          command: 'play',
+          command: "play",
           media_name: url,
           other: isStream,
           payload: payload,
-        })
-        break
+        });
+        break;
       }
-      case 'create_video': {
-        This.VideoParam = evt.data.param //{duration:xxx,width:xxx,height:xxx}
-        This.webglPlayer = new WebGLPlayer(This.canvas)
+      case "create_video": {
+        This.VideoParam = evt.data.param; //{duration:xxx,width:xxx,height:xxx}
+        This.webglPlayer = new WebGLPlayer(This.canvas);
         if (This.timeTrack) {
-          This.timeTrack.min = 0
-          This.timeTrack.max = This.VideoParam.duration
-          This.timeTrack.value = 0
+          This.timeTrack.min = 0;
+          This.timeTrack.max = This.VideoParam.duration;
+          This.timeTrack.value = 0;
           This.displayDuration = This.formatTime(
             This.VideoParam.duration / 1000
-          )
+          );
         }
-        This.startTrackTimer()
+        This.startTrackTimer();
 
-        This.statusCallback(0)
-        break
+        This.statusCallback(0);
+        break;
       }
-      case 'create_audio': {
-        This.AudioParam = evt.data.param //{channel:Channel,sample_rate:SampleRate}
+      case "create_audio": {
+        This.AudioParam = evt.data.param; //{channel:Channel,sample_rate:SampleRate}
         This.pcmPlayer = new PCMPlayer({
-          encoding: '16bitInt',
+          encoding: "16bitInt",
           channels: This.AudioParam.channel,
           sampleRate: This.AudioParam.sample_rate,
           flushingTime: 5000,
-        })
+        });
 
-        This.statusCallback(1)
-        break
+        This.statusCallback(1);
+        break;
       }
-      case 'deliver_video': {
+      case "deliver_video": {
         if (!This.isStream && This.preload && This.preloadFlag == 0) {
-          This.preloadFlag = 1
-          This.pause()
-          This.statusCallback(0)
+          This.preloadFlag = 1;
+          This.pause();
+          This.statusCallback(0);
         }
 
         //sample:{time_stamp:xxx,data:xxx}
-        This.CurPos = evt.data.sample.time_stamp
+        This.CurPos = evt.data.sample.time_stamp;
         This.webglPlayer.renderFrame(
           evt.data.sample.buf,
           This.VideoParam.width,
           This.VideoParam.height
-        )
-        break
+        );
+        break;
       }
-      case 'deliver_audio': {
+      case "deliver_audio": {
         //sample:{time_stamp:xxx,data:xxx}
-        This.pcmPlayer.play(evt.data.sample.buf)
-        break
+        This.pcmPlayer.play(evt.data.sample.buf);
+        break;
       }
-      case 'play_failed': {
-        This.statusCallback(-1)
-        This.stop()
-        break
+      case "play_failed": {
+        This.statusCallback(-1);
+        This.stop();
+        break;
       }
-      case 'play_end': {
+      case "play_end": {
         if (This.loop) {
-          This.seek(0)
+          This.seek(0);
         }
-        break
+        break;
       }
 
       default:
-        return
+        return;
     }
-  }
-}
+  };
+};
 
 Player.prototype.pause = function() {
-  if (this.hPlayer == 0 || this.PlayOrPause == 0) return
-  this.PlayOrPause = 0
-  this.TurboWorker.postMessage({ command: 'pause' })
-}
+  if (this.hPlayer == 0 || this.PlayOrPause == 0) return;
+  this.PlayOrPause = 0;
+  this.TurboWorker.postMessage({ command: "pause" });
+};
 
 Player.prototype.resume = function() {
-  if (this.hPlayer == 0 || this.PlayOrPause == 1) return
-  this.PlayOrPause = 1
-  this.TurboWorker.postMessage({ command: 'resume' })
-}
+  if (this.hPlayer == 0 || this.PlayOrPause == 1) return;
+  this.PlayOrPause = 1;
+  this.TurboWorker.postMessage({ command: "resume" });
+};
 
 Player.prototype.stop = function() {
-  if (this.hPlayer == 0) return
-  this.hPlayer = 0
-  this.TurboWorker.postMessage({ command: 'stop' })
-  this.stopTrackTimer()
+  if (this.hPlayer == 0) return;
+  this.hPlayer = 0;
+  this.TurboWorker.postMessage({ command: "stop" });
+  this.stopTrackTimer();
   if (this.pcmPlayer) {
-    this.pcmPlayer.destroy()
-    this.pcmPlayer = null
+    this.pcmPlayer.destroy();
+    this.pcmPlayer = null;
   }
   //webglPlayer?
-}
+};
 
 Player.prototype.seek = function(ms) {
-  if (this.hPlayer == 0) return
-  this.TurboWorker.postMessage({ command: 'seek', pos: ms })
+  if (this.hPlayer == 0) return;
+  this.TurboWorker.postMessage({ command: "seek", pos: ms });
 
   if (this.pcmPlayer != null) {
-    this.pcmPlayer.destroy()
+    this.pcmPlayer.destroy();
     this.pcmPlayer = new PCMPlayer({
-      encoding: '16bitInt',
+      encoding: "16bitInt",
       channels: this.AudioParam.channel,
       sampleRate: this.AudioParam.sample_rate,
       flushingTime: 5000,
-    })
+    });
   }
-}
+};
 
 Player.prototype.fullscreen = function() {
-  if (this.webglPlayer) this.webglPlayer.fullscreen()
-}
+  if (this.webglPlayer) this.webglPlayer.fullscreen();
+};
 
 Player.prototype.exitfullscreen = function() {
-  if (this.webglPlayer) this.webglPlayer.exitfullscreen()
-}
-
+  if (this.webglPlayer) this.webglPlayer.exitfullscreen();
+};
 
 Player.prototype.startTrackTimer = function() {
-  var This = this
+  var This = this;
   this.trackTimer = setInterval(function() {
-    if (This.timeTrack) This.timeTrack.value = This.CurPos
+    if (This.timeTrack) This.timeTrack.value = This.CurPos;
 
     if (This.timeLabel)
       This.timeLabel.innerHTML =
-        This.formatTime(This.CurPos / 1000) + '/' + This.displayDuration
-  }, 500)
-}
+        This.formatTime(This.CurPos / 1000) + "/" + This.displayDuration;
+  }, 500);
+};
 
 Player.prototype.stopTrackTimer = function() {
   if (this.trackTimer != null) {
-    clearInterval(this.trackTimer)
-    this.trackTimer = null
+    clearInterval(this.trackTimer);
+    this.trackTimer = null;
   }
-}
+};
 
 Player.prototype.formatTime = function(s) {
   var h =
     Math.floor(s / 3600) < 10
-      ? '0' + Math.floor(s / 3600)
-      : Math.floor(s / 3600)
+      ? "0" + Math.floor(s / 3600)
+      : Math.floor(s / 3600);
   var m =
     Math.floor((s / 60) % 60) < 10
-      ? '0' + Math.floor((s / 60) % 60)
-      : Math.floor((s / 60) % 60)
+      ? "0" + Math.floor((s / 60) % 60)
+      : Math.floor((s / 60) % 60);
   var s =
-    Math.floor(s % 60) < 10 ? '0' + Math.floor(s % 60) : Math.floor(s % 60)
+    Math.floor(s % 60) < 10 ? "0" + Math.floor(s % 60) : Math.floor(s % 60);
 
-  return h + ':' + m + ':' + s
-}
+  return h + ":" + m + ":" + s;
+};
diff --git a/src/router/index.js b/src/router/index.js
index 989b613..05fb9d6 100644
--- a/src/router/index.js
+++ b/src/router/index.js
@@ -45,9 +45,7 @@
     path: "/personalCenter",
     name: "personalCenter",
     component: () =>
-      import(
-        /* webpackChunkName: "about" */ "../views/personalCenter"
-      ),
+      import(/* webpackChunkName: "about" */ "../views/personalCenter"),
   },
   {
     path: "/equipmentDetail",
@@ -71,6 +69,12 @@
     component: () => import(/* webpackChunkName: "about" */ "../views/search"),
   },
   {
+    path: "/searchOpen",
+    name: "searchOpen",
+    component: () =>
+      import(/* webpackChunkName: "about" */ "../views/search/searchOpen"),
+  },
+  {
     path: "/product",
     name: "product",
     component: () => import(/* webpackChunkName: "about" */ "../views/product"),
diff --git a/src/views/equipmentManagement/components/Banner.vue b/src/views/equipmentManagement/components/Banner.vue
index 0cd4200..2627dbf 100644
--- a/src/views/equipmentManagement/components/Banner.vue
+++ b/src/views/equipmentManagement/components/Banner.vue
@@ -11,9 +11,15 @@
 </template>
 
 <script>
+import { enableMenu } from "@/api/user";
+
 export default {
   methods: {
-    jump() {
+    async jump() {
+      await enableMenu({
+        userId: JSON.parse(sessionStorage.getItem("userInfo")).id,
+        menuId: "deviceMng",
+      });
       this.$router.push("/equipmentList");
     },
   },
diff --git a/src/views/equipmentManagement/equipmentDetail/components/FormArea.vue b/src/views/equipmentManagement/equipmentDetail/components/FormArea.vue
index e89f41a..a973aea 100644
--- a/src/views/equipmentManagement/equipmentDetail/components/FormArea.vue
+++ b/src/views/equipmentManagement/equipmentDetail/components/FormArea.vue
@@ -4,7 +4,7 @@
     <div class="formAlgorithm">
       <div class="formHead">
         绠楁硶鍗曞厓<span class="des"
-          >姝e湪杩涜{{ data.algos.length }}涓畻娉曞崟鍏�</span
+          >姝e湪杩涜{{ data.algos && data.algos.length }}涓畻娉曞崟鍏�</span
         >
       </div>
       <el-table :data="data.algos" stripe style="width: 100%">
@@ -38,7 +38,7 @@
     <div class="formApplication">
       <div class="formHead">
         搴旂敤鍗曞厓<span class="des"
-          >姝e湪杩涜{{ data.apps.length }}涓簲鐢ㄥ崟鍏�</span
+          >姝e湪杩涜{{ data.algos && data.apps.length }}涓簲鐢ㄥ崟鍏�</span
         >
       </div>
       <el-table :data="data.apps" stripe style="width: 100%">
diff --git a/src/views/equipmentManagement/equipmentList/components/FormList.vue b/src/views/equipmentManagement/equipmentList/components/FormList.vue
index 2185910..01bd855 100644
--- a/src/views/equipmentManagement/equipmentList/components/FormList.vue
+++ b/src/views/equipmentManagement/equipmentList/components/FormList.vue
@@ -260,15 +260,15 @@
       let param = {
         page: this.page,
         size: this.size,
-        // startTime: this.searchTime[0],
-        // endTime: this.searchTime[1],
+        startTime: this.searchTime[0],
+        endTime: this.searchTime[1],
+        clusterId: this.cluster,
         inputText: this.inputText,
       };
       findDevList(param)
         .then((res) => {
           this.dataList = res.data.list;
           //鏃堕棿鍒嗚鏄剧ず
-
           this.dataList.forEach((item) => {
             item.installTime = item.installTime.split(" ");
             item.firstUseTime = item.firstUseTime.split(" ");
diff --git a/src/views/equipmentManagement/equipmentList/components/JoinClusterBox.vue b/src/views/equipmentManagement/equipmentList/components/JoinClusterBox.vue
index 90bd0e4..a417afa 100644
--- a/src/views/equipmentManagement/equipmentList/components/JoinClusterBox.vue
+++ b/src/views/equipmentManagement/equipmentList/components/JoinClusterBox.vue
@@ -97,14 +97,6 @@
         <div class="search" @click="searchCluster">鎼滅储闆嗙兢</div>
       </el-form-item>
 
-      <el-form-item prop="ip" label="闆嗙兢IP">
-        <ip-input
-          :ip="formData2.virtualIp"
-          :on-blur="onClusterIpBlur"
-          class="ip-input-comp"
-        ></ip-input>
-      </el-form-item>
-
       <div class="clusterList" v-if="showClusterList">
         <div
           class="clusterItem"
@@ -242,7 +234,6 @@
       let res = await joinCluster({
         clusterId: this.formData2.clusterId,
         password: this.formData2.password,
-        virtualIp: this.formData2.virtualIp,
         nodeIps: [this.formData2.nodeIps],
         nodeId: this.equipment.devId,
       });
diff --git a/src/views/equipmentManagement/index.vue b/src/views/equipmentManagement/index.vue
index dc9469b..dd75b8c 100644
--- a/src/views/equipmentManagement/index.vue
+++ b/src/views/equipmentManagement/index.vue
@@ -19,6 +19,20 @@
     Flow,
     Footer,
   },
+  created() {
+    this.checkpermission();
+  },
+  methods: {
+    checkpermission() {
+      const userInfo = JSON.parse(sessionStorage.getItem("userInfo"));
+      const val = userInfo.permissions.find((item) => {
+        return item == "deviceMng";
+      });
+      if (val) {
+        this.$router.push("/equipmentList");
+      }
+    },
+  },
 };
 </script>
 
diff --git a/src/views/hashrate/CameraManage/CameraRules/components/LinkageCameraBox.vue b/src/views/hashrate/CameraManage/CameraRules/components/LinkageCameraBox.vue
index 74bf857..7990282 100644
--- a/src/views/hashrate/CameraManage/CameraRules/components/LinkageCameraBox.vue
+++ b/src/views/hashrate/CameraManage/CameraRules/components/LinkageCameraBox.vue
@@ -16,7 +16,7 @@
         </div>
 
         <div class="body">
-          <div class="row">
+          <div class="row" v-if="camera.analytics">
             <div class="label">澶勭悊鏂瑰紡:</div>
             <div
               class="button pollingBtn"
@@ -120,19 +120,21 @@
 
     //瀹炴椂銆佽疆璇㈠垏鎹�
     changePoll(row, index) {
-      if (!this.cameraArr[index].analytics) {
-        return;
-      }
-
       //鍒ゆ柇鏄柊澧炶繕鏄洿鏂�
+      console.log(this.cameraArr[index]);
+
       if (
         this.cameraArr[index].cameraId &&
         this.cameraArr[index].cameraId !== undefined
       ) {
+        console.log(1);
         if (this.PollData.RealTimeSum < this.PollData.channelTotal) {
           if (row) {
+            console.log(2);
             this.cameraArr[index].dealWay = true;
           } else {
+            console.log(3);
+
             this.cameraArr[index].dealWay = false;
           }
           changeRunType({
@@ -188,9 +190,10 @@
         const rsp = await getCameraInfo(id);
         if (rsp.success) {
           this.cameraArr.push({
+            cameraId: rsp.data.id,
             cameraName: rsp.data.name ? rsp.data.name : "",
             analytics: rsp.data.runType !== -1 ? true : false,
-            dealWay: rsp.data.runType !== 1 ? true : false,
+            dealWay: rsp.data.runType == 1 ? true : false,
             camearInfo: {
               resolutionWidth: rsp.data.resolutionWidth,
               resolutionHeight: rsp.data.resolutionHeight,
diff --git a/src/views/hashrate/CameraManage/index.vue b/src/views/hashrate/CameraManage/index.vue
index 9fba6ac..8e4bb27 100644
--- a/src/views/hashrate/CameraManage/index.vue
+++ b/src/views/hashrate/CameraManage/index.vue
@@ -135,6 +135,8 @@
   beforeDestroy() {
     clearInterval(this.intervalTimer);
     //this.TreeDataPool.treeActiveName = "camera";
+    sessionStorage.removeItem("devId");
+    sessionStorage.removeItem("clusterId");
   },
   mounted() {
     this.$nextTick(() => {
diff --git a/src/views/hashrate/HashManage/components/EquipmentForm.vue b/src/views/hashrate/HashManage/components/EquipmentForm.vue
index 5522d29..bbf7174 100644
--- a/src/views/hashrate/HashManage/components/EquipmentForm.vue
+++ b/src/views/hashrate/HashManage/components/EquipmentForm.vue
@@ -83,10 +83,10 @@
         </el-table-column>
         <el-table-column label="瀹炴椂/杞" align="center" width="100px">
           <template slot-scope="scope">
-            <span v-if="scope.row.runType === -1">-</span>
+            <span v-if="scope.row.runType == -1">-</span>
             <toggle-button
               v-else
-              :value="scope.row.runType === 1"
+              :value="scope.row.runType == 1"
               :width="60"
               :labels="{ checked: '瀹炴椂', unchecked: '杞' }"
               :color="{
@@ -126,6 +126,8 @@
 <script>
 import SettingBox from "./SettingBox";
 import { getCameraByPage } from "@/api/clusterManage";
+import { changeRunType } from "@/api/pollConfig";
+
 export default {
   props: {
     id: {},
@@ -185,25 +187,26 @@
       this.$emit("hiddenList");
     },
     pollSwitch(row) {
-      changeRunType({ camera_ids: [row.id], run_type: row.run_type ^ 1 }).then(
-        (rsp) => {
-          if (rsp && rsp.success) {
-            this.$notify({
-              type: "success",
-              message: "閰嶇疆鎴愬姛",
-            });
-
-            row.run_type = row.run_type ^ 1;
-          } else {
-            this.$notify({
-              type: "error",
-              message: "閰嶇疆澶辫触",
-            });
-          }
-
-          // this.PollData.fetchPollList();
+      row.runType = row.runType ^ 1;
+      changeRunType({
+        camera_ids: [row.id],
+        run_type: row.runType ^ 1,
+        clusterId: row.clusterId,
+      }).then((rsp) => {
+        if (rsp && rsp.success) {
+          this.$notify({
+            type: "success",
+            message: "閰嶇疆鎴愬姛",
+          });
+        } else {
+          this.$notify({
+            type: "error",
+            message: "閰嶇疆澶辫触",
+          });
         }
-      );
+
+        // this.PollData.fetchPollList();
+      });
     },
   },
   filters: {
diff --git a/src/views/hashrate/components/Banner.vue b/src/views/hashrate/components/Banner.vue
index d0a84f6..63fb6a8 100644
--- a/src/views/hashrate/components/Banner.vue
+++ b/src/views/hashrate/components/Banner.vue
@@ -11,9 +11,15 @@
 </template>
 
 <script>
+import { enableMenu } from "@/api/user";
+
 export default {
   methods: {
-    jump() {
+    async jump() {
+      await enableMenu({
+        userId: JSON.parse(sessionStorage.getItem("userInfo")).id,
+        menuId: "analysisMng",
+      });
       this.$router.push("/hashrateDetail");
     },
   },
diff --git a/src/views/hashrate/index.vue b/src/views/hashrate/index.vue
index c516729..dd7568f 100644
--- a/src/views/hashrate/index.vue
+++ b/src/views/hashrate/index.vue
@@ -20,6 +20,20 @@
     Flow,
     Footer,
   },
+  created() {
+    this.checkpermission();
+  },
+  methods: {
+    checkpermission() {
+      const userInfo = JSON.parse(sessionStorage.getItem("userInfo"));
+      const val = userInfo.permissions.find((item) => {
+        return item == "analysisMng";
+      });
+      if (val) {
+        this.$router.push("/hashrateDetail");
+      }
+    },
+  },
 };
 </script>
 
diff --git a/src/views/index/components/commendContent.vue b/src/views/index/components/commendContent.vue
index c0f8693..42c45dc 100644
--- a/src/views/index/components/commendContent.vue
+++ b/src/views/index/components/commendContent.vue
@@ -10,8 +10,8 @@
     >
       <img :src="'/httpImage/' + item.logoUrl" alt="" />
       <div class="title">{{ item.productName }}</div>
-      <div class="des limitoRow2">{{ item.description }}</div>
-      <price :priceNew="item.priceBase"></price>
+      <div class="des limitRow2">{{ item.description }}</div>
+      <price :priceNew="item.priceBase ? item.priceBase : 0"></price>
       <div class="button" @click="buyProduct(item.productName)">绔嬪嵆璐拱</div>
     </div>
   </div>
diff --git a/src/views/index/components/userCard.vue b/src/views/index/components/userCard.vue
index 59ed19c..c7eb57c 100644
--- a/src/views/index/components/userCard.vue
+++ b/src/views/index/components/userCard.vue
@@ -4,7 +4,12 @@
       <img src="/images/index/榛樿澶村儚-01.png" alt="" />
     </div>
     <div class="notification" v-if="!userInfo">
-      Hi!璇� <span class="login">鐧诲綍</span>鎴�<span class="register">娉ㄥ唽</span>
+      Hi!璇�
+      <span class="login" @click="jump('/login')">鐧诲綍</span>鎴�<span
+        class="register"
+        @click="jump('/register')"
+        >娉ㄥ唽</span
+      >
     </div>
     <div class="des" v-if="!userInfo">鐧诲綍鍚庢煡鐪嬩釜浜哄伐鍏锋爮</div>
     <div class="userName" v-else>{{ userInfo.username }}</div>
@@ -49,6 +54,11 @@
       userInfo: null, //鐢ㄦ埛淇℃伅
     };
   },
+  methods: {
+    jump(url) {
+      this.$router.push(url);
+    },
+  },
 };
 </script>
 
diff --git a/src/views/login/components/loginForm.vue b/src/views/login/components/loginForm.vue
index 627f100..1681e3c 100644
--- a/src/views/login/components/loginForm.vue
+++ b/src/views/login/components/loginForm.vue
@@ -279,10 +279,9 @@
           getMenuPermission().then((rep) => {
             data.userInfo.permissions = rep.data.permissions;
             sessionStorage.setItem("userInfo", JSON.stringify(data.userInfo));
+            this.$router.push("/");
           });
           this.loading.close();
-
-          this.$router.push("/");
         })
         .catch((err) => {
           this.loading.close();
diff --git a/src/views/manageCenter/index.vue b/src/views/manageCenter/index.vue
index 88843ea..b5e1305 100644
--- a/src/views/manageCenter/index.vue
+++ b/src/views/manageCenter/index.vue
@@ -19,7 +19,7 @@
             class="productItem"
             v-for="(item, index) in productList"
             :key="index"
-            @click="jump(item.path)"
+            @click="jump(item)"
           >
             <img :src="item.icon" alt="" />
             <div class="name">{{ item.name }}</div>
@@ -270,19 +270,25 @@
         {
           name: "璁惧绠$悊",
           icon: "/images/manageCenter/璁惧绠$悊.png",
-          path: "/equipmentManagement",
+          openPath: "/equipmentManagement",
+          path: "/equipmentList",
+          permission: "deviceMng",
         },
 
         {
           name: "绠楀姏绠$悊",
           icon: "/images/manageCenter/绠楀姏绠$悊.png",
-          path: "/hashrate",
+          openPath: "/hashrate",
+          path: "/hashrateDetail",
+          permission: "analysisMng",
         },
 
         {
           name: "缁熻鏌ヨ",
           icon: "/images/manageCenter/绠楀姏绠$悊.png",
-          path: "/",
+          openPath: "/searchOpen",
+          path: "/search",
+          permission: "statisticMng",
         },
       ],
       timeList: [
@@ -851,8 +857,17 @@
       let myChart = echarts.init(pieDom);
       myChart.setOption(this.pieOption);
     },
-    jump(path) {
-      this.$router.push(path);
+    jump(route) {
+      const userInfo = JSON.parse(sessionStorage.getItem("userInfo"));
+
+      const val = userInfo.permissions.find((item) => {
+        return item == route.permission;
+      });
+      if (val) {
+        this.$router.push(route.path);
+      } else if (!userInfo.parentId) {
+        this.$router.push(route.openPath);
+      }
     },
     refrash() {},
     handleSizeChange() {},
diff --git a/src/views/personalCenter/components/SubAccount.vue b/src/views/personalCenter/components/SubAccount.vue
index 8be3ee9..46f5518 100644
--- a/src/views/personalCenter/components/SubAccount.vue
+++ b/src/views/personalCenter/components/SubAccount.vue
@@ -69,10 +69,9 @@
             <span>{{ scope.row.userType == 1 ? "涓汉" : "鍏徃" }}</span>
           </template>
         </el-table-column>
-        <el-table-column prop="authDuration" label="鎺堟潈鏃堕暱" > </el-table-column>
-        <el-table-column prop="dataNames" label="鏉冮檺">
-
+        <el-table-column prop="authDuration" label="鎺堟潈鏃堕暱">
         </el-table-column>
+        <el-table-column prop="dataNames" label="鏉冮檺"> </el-table-column>
 
         <el-table-column label="鐘舵��">
           <template slot-scope="scope">
@@ -171,8 +170,9 @@
           style="width: 350px"
           placeholder="璇烽�夋嫨鎺堟潈鏃堕暱"
         >
-          <el-option label="涓�骞�" value="涓�骞�"></el-option>
-          <el-option label="涓ゅ勾" value="涓ゅ勾"></el-option>
+          <el-option label="涓�骞�" :value="1"></el-option>
+          <el-option label="涓ゅ勾" :value="2"></el-option>
+          <el-option label="涓夊勾" :value="3"></el-option>
         </el-select>
       </el-form-item>
 
@@ -228,17 +228,15 @@
 </template>
 
 <script>
-import { findUserList, saveSubUser, getMenu, getDataTree} from "@/api/user";
+import { findUserList, saveSubUser, getMenu, getDataTree } from "@/api/user";
 import { getAreas, getDic } from "@/api/login";
 
 import Steps from "./Steps";
 import StepsCard from "./StepCard";
-import TreeBox from "./TreeBox";
 export default {
   components: {
     Steps,
     StepsCard,
-    TreeBox,
   },
   data() {
     return {
@@ -278,24 +276,29 @@
       dataList: [],
       isShowAdd: false, //鏄惁灞曠ず鏂板寮圭獥
       isShowUnbind: false, //鏄惁灞曠ず瑙g粦寮圭獥
-      isShowRelate: false,isEditing: false,
+      isShowRelate: false,
+      isEditing: false,
       unbindId: "",
       durationArr: [
         {
-          value: "涓�骞�",
+          value: 1,
           label: "涓�骞�",
         },
         {
-          value: "涓ゅ勾",
+          value: 2,
           label: "涓ゅ勾",
+        },
+        {
+          value: 3,
+          label: "涓夊勾",
         },
       ], //鎵�灞為泦缇や笅鎷夋
       timeLength: null, //閫変腑鐨勬巿鏉冩椂闀�
       showQuit: false, //灞曠ず閫�鍑洪泦缇ょ殑寮圭獥
       showJoin: false, //灞曠ず鍔犲叆闆嗙兢鐨勫脊绐�
       activeEquipment: null, //澶勭悊涓殑璁惧
-      checkedData:[],
-      checkedMenu:[],
+      checkedData: [],
+      checkedMenu: [],
       ruleForm: {
         id: "",
         username: "",
@@ -358,7 +361,7 @@
     },
     editUser(row) {
       this.isShowAdd = true;
-      this.isEditing = true
+      this.isEditing = true;
       this.ruleForm.id = row.id;
       this.ruleForm.username = row.username;
       this.ruleForm.userType = row.userType;
@@ -367,9 +370,9 @@
       this.ruleForm.email = row.email;
       this.ruleForm.isChangePwd = row.isChangePwd;
       this.ruleForm.industryId = row.industryId;
-      this.ruleForm.areaId =row.areaId ;
-      debugger
-      this.ruleForm.address  = [ row.provinceId,row.areaId]
+      this.ruleForm.areaId = row.areaId;
+      debugger;
+      this.ruleForm.address = [row.provinceId, row.areaId];
       this.ruleForm.provinceId = row.provinceId;
       this.ruleForm.authDuration = row.authDuration;
       this.checkedMenu = row.menuIds;
@@ -404,7 +407,7 @@
       this.ruleForm.menuIds = this.$refs.treeMenus.getCheckedKeys();
       this.ruleForm.dataIds = this.$refs.treeData.getCheckedKeys();
       let json = {
-        id: this.isEditing? this.ruleForm.id:"",
+        id: this.isEditing ? this.ruleForm.id : "",
         username: this.ruleForm.username,
         password: this.ruleForm.password,
         isChangePwd: this.ruleForm.isChangePwd,
@@ -417,7 +420,7 @@
         menuIds: this.ruleForm.menuIds,
         dataIds: this.ruleForm.dataIds,
       };
-      debugger
+      debugger;
       saveSubUser(json).then((res) => {
         debugger;
       });
@@ -435,7 +438,7 @@
     },
     goback() {
       this.isShowAdd = false;
-      this.isEditing =false
+      this.isEditing = false;
       this.isShowRelate = false;
       this.activeIndex = 0;
     },
@@ -773,7 +776,7 @@
 
     .option {
       margin-right: 10px;
-         font-size: 14px;
+      font-size: 14px;
       color: rgb(0, 101, 255);
       cursor: pointer;
     }
diff --git a/src/views/productDetail/components/ConfirmOrder.vue b/src/views/productDetail/components/ConfirmOrder.vue
index 6c2d2da..23226d8 100644
--- a/src/views/productDetail/components/ConfirmOrder.vue
+++ b/src/views/productDetail/components/ConfirmOrder.vue
@@ -218,9 +218,10 @@
       if (this.orderInfo.orderMoney == 0) {
         resumePay({ orderId, payMethod: 5 }).then((res) => {
           if (res.success) {
+            this.$router.push("/trialCenter");
             this.$notify({
               type: "success",
-              message: "鍏嶈垂璇曠敤",
+              message: "鎴愬姛璇曠敤",
               duration: 2500,
               offset: 57,
             });
diff --git a/src/views/productDetail/components/Function.vue b/src/views/productDetail/components/Function.vue
index 1f8fe4b..58664e3 100644
--- a/src/views/productDetail/components/Function.vue
+++ b/src/views/productDetail/components/Function.vue
@@ -88,7 +88,8 @@
     flex-wrap: wrap;
 
     .sceneItem {
-      width: 600px;
+      width: 599px;
+      margin-bottom: 20px;
 
       .sceneTitle {
         margin-bottom: 10px;
diff --git a/src/views/productDetail/components/PayCard.vue b/src/views/productDetail/components/PayCard.vue
index 54b97c4..182540f 100644
--- a/src/views/productDetail/components/PayCard.vue
+++ b/src/views/productDetail/components/PayCard.vue
@@ -300,7 +300,9 @@
 
       <div class="btns">
         <div class="button addCar">鍔犲叆璐墿杞�</div>
-        <div class="button pay" @click="confirmNow">绔嬪嵆璐拱</div>
+        <div class="button pay" @click="confirmNow">
+          {{ data.priceBase ? "绔嬪嵆璐拱" : "鍏嶈垂璇曠敤" }}
+        </div>
       </div>
     </div>
 
diff --git a/src/views/search/components/Banner.vue b/src/views/search/components/Banner.vue
new file mode 100644
index 0000000..9a3248b
--- /dev/null
+++ b/src/views/search/components/Banner.vue
@@ -0,0 +1,55 @@
+<template>
+  <div class="Banner">
+    <div class="heart">
+      <div class="title">缁熻鏌ヨ</div>
+      <div class="des">缁熻鏌ヨ鏀寔瀵规墍鏈夎澶囪繎3涓湀鏁版嵁杩涜缁熶竴鏌ヨ銆�</div>
+      <div class="button" @click="jump">绔嬪嵆寮�閫�</div>
+    </div>
+  </div>
+</template>
+
+<script>
+import { enableMenu } from "@/api/user";
+
+export default {
+  methods: {
+    async jump() {
+      console.log(JSON.parse(sessionStorage.getItem("userInfo")).id);
+      await enableMenu({
+        userId: JSON.parse(sessionStorage.getItem("userInfo")).id,
+        menuId: "statisticMng",
+      });
+      this.$router.push("/search");
+    },
+  },
+};
+</script>
+
+<style scoped lang="scss">
+.Banner {
+  overflow: hidden;
+  height: 480px;
+  background-image: url("/images/hashrate/banner.png");
+  color: #fff;
+
+  .title {
+    margin: 122px 0 10px 0;
+    font-size: 48px;
+  }
+
+  .des {
+    margin-bottom: 82px;
+    width: 560px;
+    font-size: 16px;
+    line-height: 24px;
+  }
+
+  .button {
+    width: 160px;
+    height: 56px;
+    background: #0065ff;
+    text-align: center;
+    line-height: 56px;
+  }
+}
+</style>
\ No newline at end of file
diff --git a/src/views/search/components/Flow.vue b/src/views/search/components/Flow.vue
new file mode 100644
index 0000000..3d82ef5
--- /dev/null
+++ b/src/views/search/components/Flow.vue
@@ -0,0 +1,68 @@
+<template>
+  <div class="Flow heart">
+    <div class="title">绠楀姏绠$悊鐨勪娇鐢ㄦ祦绋�</div>
+
+    <div class="flowList">
+      <div class="flowItem" v-for="(item, index) in flowList" :key="index">
+        <img :src="item.img" alt="" />
+        <div class="flowTitle">{{ item.title }}</div>
+      </div>
+    </div>
+  </div>
+</template>
+
+<script>
+export default {
+  data() {
+    return {
+      flowList: [
+        {
+          img: "/images/search/寮�閫氱粺璁℃煡璇�.png",
+          title: "寮�閫氱粺璁℃煡璇�",
+        },
+        { img: "/images/search/鏁版嵁鏌ョ湅.png", title: "鏁版嵁鏌ョ湅" },
+        {
+          img: "/images/search/褰曞儚鏌ョ湅.png",
+          title: "褰曞儚鏌ョ湅",
+        },
+        {
+          img: "/images/search/鏁版嵁瀹炴椂鐩戞帶.png",
+          title: "鏁版嵁瀹炴椂鐩戞帶",
+        },
+      ],
+    };
+  },
+};
+</script>
+
+<style scoped lang="scss">
+.Flow {
+  overflow: hidden;
+  height: 540px;
+  text-align: center;
+
+  .title {
+    margin: 60px 0;
+    font-size: 28px;
+    color: #3d3d3d;
+  }
+
+  .flowList {
+    display: flex;
+
+    .flowItem {
+      width: 260px;
+      margin-right: 80px;
+
+      &:last-child {
+        margin-right: 0;
+      }
+
+      .flowTitle {
+        margin-top: 20px;
+        font-size: 16px;
+      }
+    }
+  }
+}
+</style>
\ No newline at end of file
diff --git a/src/views/search/components/LeftNav.vue b/src/views/search/components/LeftNav.vue
index 54f263c..3fd4403 100644
--- a/src/views/search/components/LeftNav.vue
+++ b/src/views/search/components/LeftNav.vue
@@ -939,14 +939,14 @@
   }
 }
 .area-add {
-  left: 100px;
+  // left: 100px;
 }
 .camera-add {
-  left: 128px;
+  // left: 128px;
 }
 
 .import-btn {
-  left: 156px;
+  //  left: 156px;
 }
 .tree-font {
   font-family: PingFangSC-Medium;
diff --git a/src/views/search/components/giantTree/zTree/ztree.vue b/src/views/search/components/giantTree/zTree/ztree.vue
index 6ec0d4e..10b94fc 100644
--- a/src/views/search/components/giantTree/zTree/ztree.vue
+++ b/src/views/search/components/giantTree/zTree/ztree.vue
@@ -569,13 +569,11 @@
 
 .ztree li span.button.ico_open {
   margin-right: 2px;
-  background-position: -110px -16px;
   vertical-align: top;
   *vertical-align: middle;
 }
 .ztree li span.button.ico_close {
   margin-right: 2px;
-  background-position: -110px 0;
   vertical-align: top;
   *vertical-align: middle;
 }
diff --git a/src/views/search/index.vue b/src/views/search/index.vue
index 43a99f3..addbb62 100644
--- a/src/views/search/index.vue
+++ b/src/views/search/index.vue
@@ -53,7 +53,7 @@
   height: calc(100vh - 130px);
 }
 .left-tree-box .el-tabs--border-card .el-tabs__header {
-  display: block !important;
+  display: block;
   margin-bottom: 10px;
 }
 .column {
diff --git a/src/views/search/searchOpen.vue b/src/views/search/searchOpen.vue
new file mode 100644
index 0000000..261719b
--- /dev/null
+++ b/src/views/search/searchOpen.vue
@@ -0,0 +1,50 @@
+<template>
+  <div class="searchOpen">
+    <IndexHeader></IndexHeader>
+    <Banner></Banner>
+    <Flow></Flow>
+    <Footer></Footer>
+  </div>
+</template>
+
+<script>
+import IndexHeader from "@/components/IndexHeader";
+import Banner from "@/views/search/components/Banner";
+import Flow from "@/views/search/components/Flow";
+import Footer from "@/components/Footer";
+
+export default {
+  components: {
+    IndexHeader,
+    Banner,
+    Flow,
+    Footer,
+  },
+  created() {
+    this.checkpermission();
+  },
+  methods: {
+    checkpermission() {
+      const userInfo = JSON.parse(sessionStorage.getItem("userInfo"));
+      const val = userInfo.permissions.find((item) => {
+        return item == "statisticMng";
+      });
+      if (val) {
+        this.$router.push("/search");
+      }
+    },
+  },
+};
+</script>
+
+<style lang="scss" scoped>
+.IndexHeader {
+  ::v-deep .header {
+    position: fixed;
+    z-index: 2;
+    top: 0;
+    right: 0;
+    left: 0;
+  }
+}
+</style>
\ No newline at end of file
diff --git a/src/views/trialCenter/components/SdkItem.vue b/src/views/trialCenter/components/SdkItem.vue
index adf0be5..ebba2ba 100644
--- a/src/views/trialCenter/components/SdkItem.vue
+++ b/src/views/trialCenter/components/SdkItem.vue
@@ -4,7 +4,7 @@
       <img :src="'/httpImage/' + sdk.logoUrl" alt="" />
     </div>
     <div class="title">{{ sdk.productName }}</div>
-    <div class="des limitoRow2">
+    <div class="des limitRow2">
       {{ sdk.description }}
     </div>
     <div class="button" @click="buyProduct(sdk.productName)">绔嬪嵆璇曠敤</div>
@@ -35,6 +35,7 @@
   height: 280px;
   background-color: #fff;
   text-align: center;
+  position: relative;
   .icon img {
     margin-top: 20px;
     width: 96px;
@@ -55,6 +56,9 @@
   }
 
   .button {
+    position: absolute;
+    left: 0;
+    bottom: 10px;
     width: 100%;
     height: 40px;
     box-shadow: 0px 2px 8px rgba(0, 43, 106, 0.12);
diff --git a/vue.config.js b/vue.config.js
index bed67fb..703743d 100644
--- a/vue.config.js
+++ b/vue.config.js
@@ -29,6 +29,12 @@
 
         changeOrigin: true, //寮�鍚唬鐞�
       },
+
+      "/ws": {
+        target: "http://192.168.20.189:7009",
+        // ws: true,
+        changeOrigin: true,
+      },
     },
   },
 };

--
Gitblit v1.8.0