From 3c46fcdb8c6217ff97e98c33d8f1e6e9b9cc7c1b Mon Sep 17 00:00:00 2001
From: hanbaoshan <hanbaoshan@aiotlink.com>
Date: 星期一, 02 十一月 2020 19:27:18 +0800
Subject: [PATCH] 桌面图标自适应,应用中心添加升级角标;应用中心算法卸载联调,tab名称更新;统计查询(集群)场景查询参数更新

---
 src/pages/desktop/index/components/ToolsEntry.vue |   97 +++++++++++++++++++++++++++++++-----------------
 1 files changed, 63 insertions(+), 34 deletions(-)

diff --git a/src/pages/desktop/index/components/ToolsEntry.vue b/src/pages/desktop/index/components/ToolsEntry.vue
index 8612ff5..2e38c2b 100644
--- a/src/pages/desktop/index/components/ToolsEntry.vue
+++ b/src/pages/desktop/index/components/ToolsEntry.vue
@@ -1,31 +1,35 @@
 <template>
   <div class="tools-entry">
     <div class="entry-wrap">
-      <el-carousel height="600px" :autoplay="false" arrow="never">
+      <el-carousel :height="rowSize==3?'600px':'770px'" :autoplay="false" arrow="never">
         <el-carousel-item v-for="(carousel,index) in carousels" :key="index">
-          <div class="app-list clearFix sdk-list" >
+          <div class="app-list clearFix sdk-list">
             <div v-for="item in carousel" :key="item.id">
               <div class="app" v-if="item.url" @click="dockClick(item)">
-              <div class="wrap">
-                <div class="app-icon">
-                  <img :src="item.src" :alt="item.alt" />
+                <div class="wrap">
+                  <div class="app-icon">
+                    <div
+                      class="badge"
+                      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>
-                <div class="app-name">{{item.title}}</div>
+              </div>
+              <div class="app sdk" v-if="item.sdk_name">
+                <div class="wrap">
+                  <div class="app-icon">
+                    <img
+                      :src="item.iconBlob.indexOf(',')>0? item.iconBlob:`data:image/png;base64,${item.iconBlob}`"
+                      style="width:82%"
+                    />
+                  </div>
+                  <div class="app-name">{{item.sdk_name}}</div>
+                </div>
               </div>
             </div>
-            <div class="app sdk" v-if="item.sdk_name">
-              <div class="wrap">
-                <div class="app-icon">
-                  <img
-                    :src="item.iconBlob.indexOf(',')>0? item.iconBlob:`data:image/png;base64,${item.iconBlob}`"
-                    style="width:82%"
-                  />
-                </div>
-                <div class="app-name">{{item.sdk_name}}</div>
-              </div>
-            </div>
-            </div>
-            
+
             <!-- <div class="app" v-for="dock in stateDocks" :key="dock.id" @click="dockClick(dock)">
               <div class="wrap">
                 <div class="app-icon">
@@ -44,7 +48,7 @@
                 </div>
                 <div class="app-name">{{item.sdk_name}}</div>
               </div>
-            </div> -->
+            </div>-->
           </div>
         </el-carousel-item>
       </el-carousel>
@@ -76,7 +80,9 @@
           src: '',
           title: '浜哄憳璺熻釜'
         }
-      ]
+      ],
+      rowSize: 3,
+      badgeNum: 0,
     }
   },
   computed: {
@@ -86,8 +92,17 @@
     carousels () {
       let pages = 0;
       let tempArr = this.stateDocks.concat(this.installedSdk);
-      
-      let arr = this.chunk(tempArr,18);
+      let upgradeArr = tempArr.filter(item => item.isUpgrade);
+      this.badgeNum = upgradeArr.length;
+      let arr = null;
+      //鏍规嵁灞忓箷楂樺害鏉ュ垽鏂槸灞曠ず3鎺掕繕鏄�4鎺� 闃堝��:970
+      if(window.innerHeight >= 930 ){
+        this.rowSize = 4;
+        arr = this.chunk(tempArr, 24);
+      }else{
+        this.rowSize = 3;
+        arr = this.chunk(tempArr, 18);
+      }
       console.log(arr)
       return arr
     }
@@ -114,17 +129,17 @@
 
   },
   methods: {
-    chunk(arr,size){
-      size = Math.max(size,0);
-      const len = arr == null ? 0: arr.length;
-      if(!len || size <1){
+    chunk (arr, size) {
+      size = Math.max(size, 0);
+      const len = arr == null ? 0 : arr.length;
+      if (!len || size < 1) {
         return []
       }
       let index = 0;
       let resIndex = 0;
-      const result = new Array(Math.ceil(len/size))
-      while(index<len){
-        result[resIndex++] = arr.slice(index,index+=size)
+      const result = new Array(Math.ceil(len / size))
+      while (index < len) {
+        result[resIndex++] = arr.slice(index, index += size)
       }
       return result
     },
@@ -209,15 +224,15 @@
 </script>
 
 <style lang="scss">
-.el-carousel__arrow--left{
+.el-carousel__arrow--left {
   left: 0 !important;
 }
-.el-carousel__arrow--right{
+.el-carousel__arrow--right {
   right: 0 !important;
 }
-.el-carousel__button{
+.el-carousel__button {
   width: 12px !important;
-  height: 12px !important;;
+  height: 12px !important;
   border-radius: 50% !important;
 }
 .tools-entry {
@@ -242,10 +257,24 @@
             width: 110px;
             height: 110px;
             margin: auto;
+            position: relative;
             img {
               vertical-align: middle;
               margin-right: -3px;
             }
+            .badge {
+              position: absolute;
+              top: 12px;
+              right: 5px;
+              width: 22px;
+              height: 22px;
+              font-size: 14px;
+              background-color: red;
+              border-radius: 50%;
+              color: #fff;
+              line-height: 22px;
+              text-align: center;
+            }
           }
           .el-loading-mask {
             border-radius: 8px;

--
Gitblit v1.8.0