<template>
|
<div class="tools-entry">
|
<div class="entry-wrap">
|
<el-carousel height="600px" :autoplay="false" >
|
<el-carousel-item v-for="(carousel,index) in carousels" :key="index">
|
<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>
|
<div class="app-name">{{item.title}}</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">
|
<img :src="dock.src" :alt="dock.alt" />
|
</div>
|
<div class="app-name">{{dock.title}}</div>
|
</div>
|
</div>
|
<div class="app sdk" v-for="(item,index) in sdkList" :key="index+'sdk'">
|
<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>
|
</el-carousel-item>
|
</el-carousel>
|
|
<div class="logo">
|
<img :src="`${publicPath}images/desktop/desk-logo.png`" alt />
|
</div>
|
</div>
|
</div>
|
</template>
|
|
<script>
|
import { findAllSdk } from '@/api/taskMange';
|
export default {
|
name: 'toolsEntry',
|
data () {
|
return {
|
publicPath: process.env.BASE_URL,
|
loading: true,
|
//carousels: [],
|
localApps: [],
|
installedSdk: [],
|
sdkList: [
|
{
|
src: '',
|
title: '个体静止'
|
},
|
{
|
src: '',
|
title: '人员跟踪'
|
}
|
]
|
}
|
},
|
computed: {
|
stateDocks () {
|
return this.$store.state.desktop.docks
|
},
|
carousels () {
|
let pages = 0;
|
let tempArr = this.stateDocks.concat(this.installedSdk);
|
|
let arr = this.chunk(tempArr,18);
|
console.log(arr)
|
return arr
|
}
|
},
|
mounted () {
|
this.getAllSdk();
|
//this.carousels =
|
window.addEventListener('message', e => {
|
if (e.data && e.data.msg) {
|
let msg = e.data.msg;
|
// token 不合法, 退出
|
if (msg === "logout") {
|
location.assign("/");
|
return;
|
}
|
|
// 打开检索, toSearch?showType=findByPic&targetId=108ba0bc-b0a1-433d-8e1e-d5d2e712b53b&picSmUrl=192.168.20.10:6700/47628,7cc869f3a9c714&compType=1
|
if (msg.indexOf("toSearch") >= 0) {
|
let params = msg.substring(7);
|
this.addFrameByName("search", params)
|
}
|
}
|
});
|
|
},
|
methods: {
|
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)
|
}
|
return result
|
},
|
getAllSdk () {
|
findAllSdk().then(res => {
|
this.installedSdk = res.data.filter(item => item.installed)
|
}).catch(e => {
|
console.log(e)
|
})
|
},
|
dockClick (dock) {
|
if (dock.type === '1') {
|
window.open(dock.url);
|
} else if (dock.type === '2' && !dock.isOpen) {
|
|
this.$store.dispatch('desktop/addFrame', {
|
id: dock.id,
|
icon: dock.src,
|
title: dock.title,
|
url: dock.url
|
});
|
this.$store.commit('desktop/addMinDock', {
|
id: dock.id,
|
src: dock.src,
|
alt: dock.title,
|
type: "3",
|
highlight: true,
|
url: dock.url,
|
screenshot: ''
|
});
|
//打开应用后异步抓拍,之后的抓拍采用这张固定的
|
//if(dock.name=='cameraVideo'||dock.name=='search'||dock.name=='library'||dock.name=='cameraAccess'||dock.name=='dataStack'){
|
setTimeout(() => {
|
this.$parent.screenShot(dock);
|
}, 1500)
|
//}
|
} else if (dock.type === '2' && dock.isOpen) {
|
this.$store.commit('desktop/resetMinFrame', dock.id);
|
}
|
},
|
resetDockItem () {
|
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';
|
},
|
addFrameByName (name, params) {
|
|
let dock = null;
|
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/addFrame', {
|
id: dock.id,
|
icon: dock.src,
|
title: dock.title,
|
url: dock.url + "?" + params
|
});
|
this.$store.commit('desktop/addMinDock', {
|
id: dock.id,
|
src: dock.src,
|
alt: dock.title,
|
type: "3",
|
highlight: true,
|
url: dock.url,
|
screenshot: ''
|
});
|
}
|
}
|
};
|
</script>
|
|
<style lang="scss">
|
.el-carousel__arrow--left{
|
left: 0 !important;
|
}
|
.el-carousel__arrow--right{
|
right: 0 !important;
|
}
|
.tools-entry {
|
//margin-top: 130px;
|
position: absolute;
|
top: 142px;
|
left: 50%;
|
transform: translateX(-50%);
|
.entry-wrap {
|
width: 1180px;
|
padding: 0 60px;
|
margin: 0 auto;
|
.app-list {
|
.app {
|
width: 16.6%;
|
margin-bottom: 54px;
|
float: left;
|
.wrap {
|
.app-icon {
|
text-align: center;
|
line-height: 110px;
|
width: 110px;
|
height: 110px;
|
margin: auto;
|
img {
|
vertical-align: middle;
|
margin-right: -3px;
|
}
|
}
|
.el-loading-mask {
|
border-radius: 8px;
|
}
|
.el-loading-spinner {
|
top: 20px;
|
}
|
.el-loading-spinner .path {
|
stroke: #78adf7;
|
}
|
.el-loading-spinner .el-loading-text {
|
line-height: 1;
|
margin-top: -30px;
|
color: #78adf7;
|
}
|
.app-name {
|
padding-top: 10px;
|
text-align: center;
|
font: Bold 16px/16px Microsoft JhengHei;
|
color: #fff;
|
}
|
}
|
|
&:hover {
|
.app-icon {
|
background: rgba(0, 0, 0, 0.4);
|
}
|
}
|
}
|
}
|
.logo {
|
text-align: right;
|
padding-right: 50px;
|
user-select: none;
|
margin-top: -100px;
|
img {
|
user-select: none;
|
-webkit-user-drag: none;
|
}
|
}
|
}
|
}
|
</style>
|