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