From 9ce05e3853b493c76cf39569eb00fe20db8a3022 Mon Sep 17 00:00:00 2001
From: ZZJ <zzjdsg2300@163.com>
Date: 星期五, 05 十一月 2021 14:09:49 +0800
Subject: [PATCH] fixed

---
 src/pages/ai/index/App.vue                                             |    4 
 src/pages/shuohuangMonitorAnalyze/index/App.vue                        |    2 
 vue.config.js                                                          |    2 
 src/pages/desktop/index/components/ToolsEntry.vue                      |  222 +++++++++++++++++++++---------
 src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue |  162 +++++++++++++++-------
 5 files changed, 265 insertions(+), 127 deletions(-)

diff --git a/src/pages/ai/index/App.vue b/src/pages/ai/index/App.vue
index 9659906..38592e9 100644
--- a/src/pages/ai/index/App.vue
+++ b/src/pages/ai/index/App.vue
@@ -665,11 +665,11 @@
                   <div class="imgwrap">
                     <img
                       v-if="item.type != 'video'"
-                      :src="'/httpImage/' + item.url"
+                      :src="item.url"
                       class="cursor-pointer"
                       preview
                     />
-                    <video v-if="item.type == 'video'" :src="'/httpImage/' + item.url" controls></video>
+                    <video v-if="item.type == 'video'" :src="item.url" controls></video>
                   </div>
                 </el-carousel-item>
               </el-carousel>
diff --git a/src/pages/desktop/index/components/ToolsEntry.vue b/src/pages/desktop/index/components/ToolsEntry.vue
index 6c84eb8..3fe47ce 100644
--- a/src/pages/desktop/index/components/ToolsEntry.vue
+++ b/src/pages/desktop/index/components/ToolsEntry.vue
@@ -2,35 +2,49 @@
   <div class="tools-entry">
     <div class="entry-wrap">
       <el-carousel
-        :height="rowSize==3?'600px':'770px'"
+        :height="rowSize == 3 ? '600px' : '770px'"
         :autoplay="false"
         arrow="never"
-        :indicator-position="carousels.length==1?'none':''"
+        :indicator-position="carousels.length == 1 ? 'none' : ''"
       >
-        <el-carousel-item v-for="(carousel,index) in carousels" :key="index">
+        <el-carousel-item v-for="(carousel, index) in carousels" :key="index">
           <div class="app-list clearFix sdk-list">
             <!-- <draggable v-model="carousel" @start="drag=true" @end="drag=false"> -->
             <div v-for="item in carousel" :key="item.id">
-              <div class="app" v-if="item.url" @click="dockClick(item)">
+              <div
+                class="app"
+                v-if="item.url && !item.sdk_name"
+                @click="dockClick(item)"
+              >
                 <div class="wrap">
                   <div class="app-icon">
                     <div
                       class="badge"
-                      v-if="item.name=='algorithmManage' && badgeNum > 0"
-                    >{{badgeNum}}</div>
+                      v-if="item.name == 'algorithmManage' && badgeNum > 0"
+                    >
+                      {{ badgeNum }}
+                    </div>
                     <img :src="item.src" :alt="item.alt" />
                   </div>
-                  <div class="app-name">{{item.title}}</div>
+                  <div class="app-name">{{ item.title }}</div>
                 </div>
               </div>
-              <div class="app sdk" v-if="item.sdk_name">
+              <div
+                class="app sdk"
+                v-if="item.sdk_name"
+                @click="openSdkVideo(item)"
+              >
                 <div class="wrap">
                   <div class="app-icon">
                     <img
-                      :src="item.iconBlob.indexOf(',')>0? item.iconBlob:`data:image/png;base64,${item.iconBlob}`"
+                      :src="
+                        item.iconBlob.indexOf(',') > 0
+                          ? item.iconBlob
+                          : `data:image/png;base64,${item.iconBlob}`
+                      "
                     />
                   </div>
-                  <div class="app-name">{{item.sdk_name}}</div>
+                  <div class="app-name">{{ item.sdk_name }}</div>
                 </div>
               </div>
             </div>
@@ -42,45 +56,70 @@
         <img :src="`${publicPath}images/desktop/desk-logo.png`" alt />
       </div>
     </div>
+
+    <div class="videolist_appbox" v-if="showVideo">
+      <div class="video_t">
+        <video
+          width="1164"
+          height="655"
+          :src="videoUrl"
+          type="video/mp4"
+          poster=""
+          controls="controls"
+          preload="none"
+          autoplay="autoplay"
+          controlslist="nodownload"
+        ></video>
+      </div>
+      <!-- <div class="mask"></div> -->
+      <div class="video_close" @click="showVideo = false">
+        <!-- <img src="../../assets/img/about_dot18.png"> -->
+        <!-- <span class="icon iconfont">&#xe70b;</span> -->
+        <i class="el-icon-close"></i>
+
+        
+      </div>
+    </div>
   </div>
 </template>
 
 <script>
-import draggable from "vuedraggable"
-import { findAllSdk } from '@/api/taskMange';
-import { chunkArr } from '@/scripts/util';
-import bus from '@/plugin/bus'
+import draggable from "vuedraggable";
+import { findAllSdk } from "@/api/taskMange";
+import { chunkArr } from "@/scripts/util";
+import bus from "@/plugin/bus";
 export default {
-  name: 'toolsEntry',
+  name: "toolsEntry",
   data() {
     return {
       publicPath: process.env.BASE_URL,
       loading: true,
-      //carousels: [],
+      showVideo: false,
       localApps: [],
       installedSdk: [],
+      videoUrl: "",
       sdkList: [
         {
-          src: '',
-          title: '涓綋闈欐'
+          src:
+            "",
+          title: "涓綋闈欐",
         },
         {
-          src: '',
-          title: '浜哄憳璺熻釜'
-        }
+          src:
+            "",
+          title: "浜哄憳璺熻釜",
+        },
       ],
-      //rowSize: 3,
-      // badgeNum: 0,
-    }
+    };
   },
   computed: {
     stateDocks() {
-      return this.$store.state.desktop.docks
+      return this.$store.state.desktop.docks;
     },
     carousels() {
       let pages = 0;
       let tempArr = this.stateDocks.concat(this.installedSdk);
-      let upgradeArr = tempArr.filter(item => item.isUpgrade);
+      let upgradeArr = tempArr.filter((item) => item.isUpgrade);
       let arr = null;
       //鏍规嵁灞忓箷楂樺害鏉ュ垽鏂槸灞曠ず3鎺掕繕鏄�4鎺� 闃堝��:970
       if (window.innerHeight >= 930) {
@@ -90,11 +129,11 @@
         //this.rowSize = 3;
         arr = this.chunk(tempArr, 18);
       }
-      return arr
+      return arr;
     },
     badgeNum() {
       let tempArr = this.stateDocks.concat(this.installedSdk);
-      return tempArr.filter(item => item.isUpgrade).length;
+      return tempArr.filter((item) => item.isUpgrade).length;
     },
     rowSize() {
       if (window.innerHeight >= 930) {
@@ -102,12 +141,12 @@
       } else {
         return 3;
       }
-    }
+    },
   },
   mounted() {
     this.getAllSdk();
-    //this.carousels = 
-    window.addEventListener('message', e => {
+    //this.carousels =
+    window.addEventListener("message", (e) => {
       if (e.data && e.data.msg) {
         let msg = e.data.msg;
         // token 涓嶅悎娉�, 閫�鍑�
@@ -117,125 +156,132 @@
         }
         if (msg.indexOf("toSearch") >= 0) {
           let params = msg.substring(7);
-          this.addFrameByName("search", params)
+          this.addFrameByName("search", params);
         }
         if (msg.indexOf("toCluster") >= 0) {
           let params = msg.substring(8);
-          this.addFrameByName("searchForCluster", params)
+          this.addFrameByName("searchForCluster", params);
         }
 
         if (msg.indexOf("toOpenApp") >= 0) {
           let id = msg.substring(10);
           console.log(id);
-          this.addFrameByID(id)
+          this.addFrameByID(id);
         }
       }
     });
-
   },
   methods: {
     chunk(arr, size) {
       size = Math.max(size, 0);
       const len = arr == null ? 0 : arr.length;
       if (!len || size < 1) {
-        return []
+        return [];
       }
       let index = 0;
       let resIndex = 0;
-      const result = new Array(Math.ceil(len / size))
+      const result = new Array(Math.ceil(len / size));
       while (index < len) {
-        result[resIndex++] = arr.slice(index, index += size)
+        result[resIndex++] = arr.slice(index, (index += size));
       }
-      return result
+      return result;
     },
     getAllSdk() {
-      findAllSdk().then(res => {
-        this.installedSdk = res.data.filter(item => item.installed)
-      }).catch(e => {
-        console.log(e)
-      })
+      findAllSdk()
+        .then((res) => {
+          this.installedSdk = res.data.filter((item) => item.installed);
+        })
+        .catch((e) => {
+          console.log(e);
+        });
     },
     dockClick(dock) {
-      if (dock.type === '1') {
+      debugger;
+      if (dock.type === "1") {
         window.open(dock.url);
-      } else if (dock.type === '2' && !dock.isOpen) {
-        this.$store.dispatch('desktop/addFrame', {
+      } else if (dock.type === "2" && !dock.isOpen) {
+        this.$store.dispatch("desktop/addFrame", {
           id: dock.id,
           icon: dock.src,
           title: dock.title,
-          url: dock.url
+          url: dock.url,
         });
-        this.$store.commit('desktop/addMinDock', {
+        this.$store.commit("desktop/addMinDock", {
           id: dock.id,
           src: dock.src,
           alt: dock.title,
           type: "3",
           highlight: true,
           url: dock.url,
-          screenshot: ''
+          screenshot: "",
         });
         //鎵撳紑搴旂敤鍚庡紓姝ユ姄鎷�,涔嬪悗鐨勬姄鎷嶉噰鐢ㄨ繖寮犲浐瀹氱殑
         //if(dock.name=='cameraVideo'||dock.name=='search'||dock.name=='library'||dock.name=='cameraAccess'||dock.name=='dataStack'){
         setTimeout(() => {
           this.$parent.screenShot(dock);
-        }, 1500)
+        }, 1500);
         //}
-      } else if (dock.type === '2' && dock.isOpen) {
-        this.$store.commit('desktop/resetMinFrame', dock.id);
+      } else if (dock.type === "2" && dock.isOpen) {
+        this.$store.commit("desktop/resetMinFrame", dock.id);
       }
-      
+    },
+    openSdkVideo(dock) {
+      if (dock.url && dock.sdk_name) {
+        this.videoUrl = dock.url;
+        this.showVideo = true;
+      }
     },
     resetDockItem() {
-      const dockItems = document.getElementsByClassName('dock-item');
-      const dockMask = document.getElementsByClassName('dock-mask')[0];
+      const dockItems = document.getElementsByClassName("dock-item");
+      const dockMask = document.getElementsByClassName("dock-mask")[0];
       for (let i = 0; i < dockItems.length; i++) {
         dockItems[i].width = 60;
         if (dockItems[i].parentNode.nextElementSibling) {
           dockItems[i].parentNode.nextElementSibling.style.marginLeft = "-35px";
         }
       }
-      dockMask.style.width = dockItems.length * 60 + 40 + 'px';
+      dockMask.style.width = dockItems.length * 60 + 40 + "px";
     },
     addFrameByName(name, params) {
       let dock = null;
-      this.$store.state.desktop.docks.forEach(app => {
+      this.$store.state.desktop.docks.forEach((app) => {
         if (app.name === name) {
           dock = app;
         }
       });
       if (dock.isOpen) {
-        this.$store.dispatch('desktop/closeFrame', dock);
+        this.$store.dispatch("desktop/closeFrame", dock);
       }
-      this.$store.dispatch('desktop/addFrame', {
+      this.$store.dispatch("desktop/addFrame", {
         id: dock.id,
         icon: dock.src,
         title: dock.title,
-        url: dock.url + "?" + params
+        url: dock.url + "?" + params,
       });
-      this.$store.commit('desktop/addMinDock', {
+      this.$store.commit("desktop/addMinDock", {
         id: dock.id,
         src: dock.src,
         alt: dock.title,
         type: "3",
         highlight: true,
         url: dock.url,
-        screenshot: ''
+        screenshot: "",
       });
     },
     addFrameByID(id, params) {
       let dock = null;
-      let toClose = null
-      this.$store.state.desktop.docks.forEach(app => {
+      let toClose = null;
+      this.$store.state.desktop.docks.forEach((app) => {
         if (app.id == id) {
           dock = app;
         }
         if (app.name == "algorithmManage") {
-          toClose = app
+          toClose = app;
         }
       });
-      this.dockClick(dock)
-    }
-  }
+      this.dockClick(dock);
+    },
+  },
 };
 </script>
 
@@ -335,5 +381,43 @@
       }
     }
   }
+  .videolist_appbox {
+    position: fixed;
+    width: 100%;
+    height: 100%;
+    top: 0;
+    left: 0;
+    z-index: 9999999;
+  }
+
+  .videolist_appbox .video_t {
+    z-index: 2;
+
+  }
+
+  .videolist_appbox .mask {
+    position: absolute;
+    z-index: 1;
+    left: 0;
+    top: 0;
+    width: 100%;
+    height: 100%;
+    background: rgba(0, 0, 0, 0.5);
+  }
+
+  .video_close {
+    position: absolute;
+    top: 0;
+    right: 0;
+    cursor: pointer;
+    z-index: 3;
+    color: #fff;
+    background: lightgray;
+    padding: 10px;
+    border-radius: 20px;
+    i{
+          font-size: 20px;
+    }
+  }
 }
 </style>
\ No newline at end of file
diff --git a/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue b/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue
index aefa6a1..464e7ea 100644
--- a/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue
+++ b/src/pages/shuohuangMonitorAnalyze/components/searchForVideoAnalyze.vue
@@ -11,7 +11,6 @@
           range-separator="鑷�"
           start-placeholder="寮�濮嬫棩鏈�"
           end-placeholder="缁撴潫鏃ユ湡"
-          align="right"
         ></el-date-picker>
         <el-input
           class="search-input"
@@ -84,7 +83,7 @@
                   v-for="(option, index) in config.data"
                   :key="index"
                 >
-                  <div v-show="config.isMultCheck">
+                  <div v-show="config.isMultCheck" class="check-name">
                     <el-checkbox v-model="option.isChecked"></el-checkbox>
                     <span>{{ option.name }}</span>
                   </div>
@@ -99,12 +98,16 @@
               </div>
               <div class="btns text-center" v-show="config.isMultCheck">
                 <el-button
+                  class="sure"
                   size="mini"
                   type="primary"
                   @click="checkOption(config)"
                   >纭畾</el-button
                 >
-                <el-button size="mini" @click="cancleMultCheck(config)"
+                <el-button
+                  size="mini"
+                  @click="cancleMultCheck(config)"
+                  class="cancel"
                   >鍙栨秷</el-button
                 >
               </div>
@@ -175,6 +178,7 @@
               v-model="IsFollow"
               size="mini"
               @change="filterSearchData"
+              style="width: 120px"
             >
               <el-option value label="鍏ㄩ儴"></el-option>
               <el-option :value="'1'" label="鏈叧娉�"></el-option>
@@ -186,6 +190,7 @@
               v-model="IsOperate"
               size="mini"
               @change="filterSearchData"
+              style="width: 120px"
             >
               <el-option value label="鍏ㄩ儴"></el-option>
               <el-option value="0" label="鏈鐞�"></el-option>
@@ -200,14 +205,15 @@
               :class="{ current: showType == 'menu' }"
               @click="checkType('menu')"
             >
-              <i class="el-icon-menu"></i>
+              <span class="iconfont icon">&#xe703; </span>
             </div>
             <div
-              class="type"
+              class="type list"
               :class="{ current: showType == 'list' }"
               @click="checkType('list')"
             >
-              <i class="el-icon-s-operation"></i>
+              <span class="iconfont icon">&#xe70f;</span>
+              <!-- <i class="el-icon-s-operation"></i> -->
             </div>
           </div>
         </div>
@@ -261,7 +267,7 @@
                       }}
                     </span>
                   </div>
-                  <div v-else>
+                  <div v-else class="no-error">
                     <span>鏃犲紓甯�</span>
                   </div>
                   <div
@@ -441,7 +447,7 @@
       keyword: "",
       IsFollow: "",
       searchTime: [
-        new Date(2020, 0, 1, 0, 0, 0),
+        new Date(2021, 0, 1, 0, 0, 0),
         new Date(2021, 11, 31, 23, 59, 59),
       ],
       curTabPage: 1,
@@ -877,14 +883,24 @@
 
 <style lang="scss">
 .search-for-video-analyze {
-  //鍑烘í鍚戞粴鍔ㄦ潯
-  padding: 25px 33px;
-  background-color: #fff;
-  margin: 33px;
+  background-color: #f4f6f9;
+  margin: 0 5px;
+  * {
+    box-sizing: content-box;
+  }
+  .el-input__inner {
+    border: 1px solid #d7dce8;
+    //  border-color: #CCD9F0;
+  }
   .flex-box {
     display: flex;
   }
   .filter-area {
+    background: #fff;
+    padding: 22px 33px;
+    box-shadow: 0px 3px 6px#D0D7F1;
+
+    border-radius: 10px;
     .input-area {
       display: flex;
       align-items: center;
@@ -908,15 +924,16 @@
       .el-date-editor {
         margin-right: 20px;
       }
-      .el-input-group__append,
-      .el-input-group__prepend {
+      .el-input-group__append {
         background-color: #2d52d7;
-        color: #fff;
         border: 1px solid #2d52d7;
         padding: 0 16px;
 
         white-space: nowrap;
         font-size: 18px;
+        .el-icon-search {
+          color: #fff;
+        }
       }
     }
     .checked-config {
@@ -961,16 +978,16 @@
         flex-wrap: no-wrap;
         cursor: pointer;
         border-bottom: 1px solid #d7dce8;
-
         .title {
           padding: 10px 20px;
-          width: 110px;
+          width: 105px;
           text-align: left;
-          color: #2d52d7;
           font-weight: bold;
-          font-size: 14px;
-          .icon {
+          span {
             font-size: 14px;
+            color: #2d52d7;
+          }
+          .icon {
             margin-right: 10px;
           }
         }
@@ -982,18 +999,25 @@
             height: 40px;
             overflow: hidden;
             .option {
-              padding: 10px 20px;
+              padding: 10px 0px;
               height: 20px;
               line-height: 20px;
+              min-width: 100px;
+              .check-name {
+                text-align: left;
+                padding-left: 10px;
+              }
               .option-name {
-                padding: 0 8px;
-                color: rgba(66, 82, 119, 1);
+                padding: 0 10px;
+                text-align: left;
+                width: fit-content;
               }
               &:hover > .option-name {
-                outline: 1px solid #a8b7ee;
-                padding: 0 8px;
+                // outline: 1px solid #a8b7ee;
                 background: #e2e7f9;
-                color: #2d52d7;
+                span {
+                  color: #2d52d7;
+                }
               }
               .el-checkbox {
                 padding-right: 6px;
@@ -1006,6 +1030,17 @@
               padding: 6px 17px;
               font-size: 12px;
               border-radius: 4px;
+            }
+            .sure span,
+            .cancel span {
+              color: #fff;
+            }
+            .cancel {
+              background: rgba(175, 185, 208, 1);
+              border-color: rgba(175, 185, 208, 1);
+            }
+            .el-button + .el-button {
+              margin-left: 20px;
             }
           }
         }
@@ -1036,7 +1071,12 @@
             padding: 0px 12px;
             border: 1px solid #d7dce7;
             border-radius: 2px;
-            color: #ee4e6e;
+            .el-icon-plus {
+              color: #ee4e6e;
+            }
+            span {
+              color: #ee4e6e;
+            }
             // &:hover {
             //   color: #7695ec;
             //   border-color: #7695ec;
@@ -1052,7 +1092,7 @@
         }
         .config-submenu {
           .el-menu--horizontal {
-            left: 20px !important;
+            // left: 20px !important;
             & > ul {
               flex-wrap: wrap;
             }
@@ -1063,6 +1103,9 @@
             border: none;
             color: #2c3e50;
             font-size: 12px;
+            padding: 0 10px;
+            min-width: 100px;
+            text-align: left;
           }
           .el-menu--popup {
             display: flex;
@@ -1087,9 +1130,14 @@
     }
   }
   .data-list {
-    margin-top: 20px;
+    margin-top: 24px;
+    background: #ffffff;
+    box-shadow: 0px 3px 6px #d0d7f1;
+    border-radius: 10px;
+    padding: 24px 33px;
     .header-bar {
-      padding-bottom: 10px;
+      margin-bottom: 24px;
+
       .left {
         float: left;
         display: flex;
@@ -1102,38 +1150,33 @@
         display: flex;
         .show-type {
           display: flex;
-          .type {
+          .list span {
             font-size: 20px;
-            padding: 2px 5px;
-            cursor: pointer;
-            border: 1px solid #eee;
-            background-color: #ecf0fc;
-            border-radius: 3px;
-            color: #777;
+          }
+          .type {
+            font-size: 18px;
+            padding: 2px 4px 0px 4px;
+            border-radius: 4px;
             &.menu {
               margin-right: 10px;
+              span {
+                font-size: 15px;
+              }
             }
             &.current {
-              border-color: #409eff;
-              background-color: #fff;
+              span {
+                color: #fff;
+              }
+              background-color: #2d52d7;
             }
           }
         }
       }
     }
     .content {
-      //padding-top: 14px;
-      background: #f5f5f5;
-      background: #fff;
-      margin: 0 -30px;
-      margin-bottom: -30px;
       padding: 0;
       .el-table__row {
         cursor: pointer;
-      }
-      .el-row {
-        padding-top: 20px;
-        background: #f5f5f5;
       }
       .el-col {
         margin-bottom: 10px;
@@ -1143,11 +1186,12 @@
         position: relative;
         text-align: left;
         background: #fff;
-        border-radius: 5px;
+        border-radius: 0 0 5px 5px;
         height: 360px;
         margin-bottom: 10px;
+        border: 1px solid#CCD9F0;
         &:hover {
-          box-shadow: 3px 2px 5px 1px rgba(0, 0, 0, 0.3);
+          box-shadow: 3px 3px 4px #d3def2;
         }
         .video-wrap {
           border-radius: 3px;
@@ -1160,7 +1204,7 @@
             top: 0;
             width: 100%;
             height: 100%;
-            object-fit: contain;
+            object-fit: unset;
           }
         }
         .video-info {
@@ -1186,6 +1230,15 @@
             .event-tag {
               margin-top: 10px;
             }
+            .no-error {
+              width: fit-content;
+              background: #2d52d7;
+              padding: 1px 5px;
+              border-radius: 2px;
+              span {
+                color: #fff;
+              }
+            }
           }
           .tag-info {
             color: #999;
@@ -1203,9 +1256,11 @@
           font-size: 20px;
           right: 10px;
           bottom: 10px;
-          color: #ccc;
+          i {
+            color: #c7d0e5;
+          }
           .follow {
-            color: #409eff;
+            color: #f90741;
           }
         }
       }
@@ -1229,7 +1284,6 @@
         text-align: center;
         margin: 0 -10px;
         padding: 10px 0 20px;
-        background: #f5f5f5;
       }
     }
     .el-dialog__wrapper {
diff --git a/src/pages/shuohuangMonitorAnalyze/index/App.vue b/src/pages/shuohuangMonitorAnalyze/index/App.vue
index 942ca36..83b0aac 100644
--- a/src/pages/shuohuangMonitorAnalyze/index/App.vue
+++ b/src/pages/shuohuangMonitorAnalyze/index/App.vue
@@ -241,7 +241,7 @@
     }
     .container {
       margin: 0px 0 0 30px;
-      padding-right: 40px;
+      padding-right: 30px;
       box-sizing: border-box;
       height: calc(100vh - 84px);
       overflow-y: auto;
diff --git a/vue.config.js b/vue.config.js
index 89da434..5a6817f 100644
--- a/vue.config.js
+++ b/vue.config.js
@@ -41,7 +41,7 @@
 })
 
 // const serverUrl = "http://58.118.225.79:41243" // 缇婁簲
-const serverUrl = "http://192.168.20.117:7009"
+const serverUrl = "http://192.168.8.117:7003"
 
 module.exports = {
   pages,

--
Gitblit v1.8.0