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/ai/index/App.vue | 65 ++++++++++-----
vue.config.js | 2
src/pages/desktop/index/components/ToolsEntry.vue | 97 +++++++++++++++--------
src/api/search.ts | 2
public/apps.json | 4
src/pages/ai/index/api.ts | 9 ++
src/Pool/VideoPhotoData.ts | 8 +
7 files changed, 126 insertions(+), 61 deletions(-)
diff --git a/public/apps.json b/public/apps.json
index 6a9731a..7e5d3b6 100644
--- a/public/apps.json
+++ b/public/apps.json
@@ -318,9 +318,9 @@
"update_by": "",
"isDelete": 0,
"isDefault": false,
- "remoteVersion": "1.0.1",
+ "remoteVersion": "1.0.2",
"installed": true,
- "isUpgrade": false,
+ "isUpgrade": true,
"progressMsg": ""
},
{
diff --git a/src/Pool/VideoPhotoData.ts b/src/Pool/VideoPhotoData.ts
index cee90c3..33e5c3d 100644
--- a/src/Pool/VideoPhotoData.ts
+++ b/src/Pool/VideoPhotoData.ts
@@ -252,7 +252,13 @@
}
async queryTaskList() {
- const rsp: any = await getTaskList({});
+ let params:any = {};
+ if(this.searchFrom == 'cluster'){
+ params.isPlatform = 1
+ }
+ console.log(params)
+ debugger
+ const rsp: any = await getTaskList(params);
if (rsp && rsp.success) {
// this.tasks.splice(0, this.tasks.length)
// rsp.data.forEach(element => {
diff --git a/src/api/search.ts b/src/api/search.ts
index 6ca20c0..9e685f9 100644
--- a/src/api/search.ts
+++ b/src/api/search.ts
@@ -32,7 +32,7 @@
return request({
url: "/data/api-v/task/aggregateTaskList",
method: "get",
- data: query
+ params: query
});
};
diff --git a/src/pages/ai/index/App.vue b/src/pages/ai/index/App.vue
index 236b9d4..bbe69c6 100644
--- a/src/pages/ai/index/App.vue
+++ b/src/pages/ai/index/App.vue
@@ -19,7 +19,7 @@
@tab-click="handleTabClick"
style="height: calc(100% - 20px);"
>
- <el-tab-pane label="宸插畨瑁�" name="myAlgorithm">
+ <el-tab-pane label="宸叉縺娲�" name="myAlgorithm">
<div class="width-new-line task-list" v-show="activeName === 'myAlgorithm'">
<p class="src-title">绠楁硶杞欢</p>
<div class="flex-list">
@@ -86,13 +86,12 @@
<div v-if="item.remoteVersion">鏈�鏂扮増鏈�:{{item.remoteVersion}}</div>
</div>
<div class="mask-btn">
- <!-- <el-button
- v-if="!item.isDefault"
- @click="unLoad(item)"
+ <el-button
+ @click="unLoadSdk(item)"
type="primary"
size="small"
class="bot-btn"
- >鍗歌浇</el-button>-->
+ >鍗歌浇</el-button>
<el-button
v-if="item.isUpgrade"
@click="donwload(item)"
@@ -176,7 +175,7 @@
element-loading-background="rgba(0,0,0,.8)"
>
<i class="iconfont iconupdate" v-if="item.isUpgrade"></i>
- <div class="mask" v-if="!item.isDefault || item.isUpgrade">
+ <div class="mask" >
<div class="info-onmask">
<div>褰撳墠鐗堟湰:{{item.version}}</div>
<div v-if="item.remoteVersion">鏈�鏂扮増鏈�:{{item.remoteVersion}}</div>
@@ -233,6 +232,7 @@
>
<div class="mask">
<el-button
+ size="small"
type="primary"
class="bot-btn"
@click="downloadApp(item)"
@@ -474,7 +474,7 @@
</template>
<script>
-import { findAllSdk, downloadSdk, installSdk, getInstallInfo } from "./api";
+import { findAllSdk, downloadSdk, installSdk, getInstallInfo, removeSdk} from "./api";
import { getApps, installApp, removeApp, getUnActivedSdk, actPageAlg, getUnActivedApp, actApp } from "@/api/app";
import FileUploader from "@/components/subComponents/FileUpload/index";
@@ -679,26 +679,47 @@
this.installedApps = iArry;
this.storeApps = sArry;
},
+ //鍗歌浇绠楁硶
+ unLoadSdk(sdk){
+ let _this = this;
+ this.$confirm('纭畾瑕佸嵏杞借绠楁硶鍚�?','鎻愮ず').then(()=>{
+ sdk.unloadLoading = true;
+ removeSdk({ sdkId: sdk.id }).then(res => {
+ if (res && res.success) {
+ sdk.unloadLoading = false;
+ _this.getAllSdk();
+ window.parent.postMessage({
+ msg: "AppUpdate"
+ }, '*')
+ }
+ }).catch(e => {
+ console.log(e);
+ sdk.unloadLoading = false;
+ })
+ }).catch( e => {
+ console.log(e)
+ })
+ },
//鍗歌浇搴旂敤
unLoad(app) {
- app.unloadLoading = true;
let _this = this;
- removeApp({ appId: app.id }).then(res => {
-
- if (res && res.success) {
- //setTimeout(() => {
+ this.$confirm('纭畾瑕佸嵏杞借搴旂敤鍚�?','鎻愮ず').then(()=>{
+ app.unloadLoading = true;
+ removeApp({ appId: app.id }).then(res => {
+ if (res && res.success) {
+ app.unloadLoading = false;
+ _this.getAllApps();
+ window.parent.postMessage({
+ msg: "AppUpdate"
+ }, '*')
+ }
+ }).catch(e => {
+ console.log(e);
app.unloadLoading = false;
- _this.getAllApps();
- window.parent.postMessage({
- msg: "AppUpdate"
- }, '*')
- //}, 3000);
- }
- }).catch(e => {
- console.log(e);
- app.unloadLoading = false;
+ })
+ }).catch( e => {
+ console.log(e)
})
-
},
// actSdk (id) {
// this.actSdkId = id;
diff --git a/src/pages/ai/index/api.ts b/src/pages/ai/index/api.ts
index 550ea3e..7232d34 100644
--- a/src/pages/ai/index/api.ts
+++ b/src/pages/ai/index/api.ts
@@ -149,4 +149,13 @@
method: 'post',
params: file
})
+}
+
+//鍗歌浇宸插畨瑁呯畻娉�
+export const removeSdk = (sdk: any) => {
+ return request({
+ url: '/data/api-v/sdk/unInstall',
+ method: 'post',
+ data: sdk
+ })
}
\ No newline at end of file
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;
diff --git a/vue.config.js b/vue.config.js
index 153deec..47db11c 100644
--- a/vue.config.js
+++ b/vue.config.js
@@ -56,7 +56,7 @@
})
// config.module.rule('fonts').use('url-loader').loader('file-loader').options({ name: 'fonts/[name].[ext]', publicPath: '../' })
-
+ //config.module.rule('fonts').use('url-loader').loader('file-loader').options({ name: 'fonts/[name].[ext]', outputPath: '../' })
},
productionSourceMap: false,
filenameHashing: false,
--
Gitblit v1.8.0