<template>
|
<el-menu class="top-menu" :default-active="activeIndex" mode="horizontal" text-color="#333">
|
<el-menu-item index="0" @click="openHome(itemHome)">
|
<template #title>
|
<i :class="itemHome.source" style="padding-right: 5px"></i>
|
<span>{{ itemHome.name }}</span>
|
</template>
|
</el-menu-item>
|
|
<el-menu-item index="0" @click="openTodo(itemHome)">
|
|
<template #title>
|
|
|
<el-dropdown>
|
<span class="el-dropdown-link">
|
<el-badge ref="topbadge" :value="remindCount" :max="99" :offset="[10, 0]" :class="{'blink-badge':this.remindCount>0}">
|
<el-tooltip
|
class="box-item"
|
effect="dark"
|
:content="`您有${remindCount}条任务需要处理`"
|
placement="top-start"
|
>
|
{{ itemTodo.name }}
|
</el-tooltip>
|
</el-badge>
|
</span>
|
<template #dropdown>
|
<el-dropdown-menu>
|
|
<el-dropdown-item v-for="item in remindItems" @click.native="handleRemindClick(item)">{{item.text}}</el-dropdown-item>
|
|
</el-dropdown-menu>
|
</template>
|
|
</el-dropdown>
|
</template>
|
<!--
|
<el-dropdown>
|
<template #dropdown>
|
<el-dropdown-menu>
|
<el-dropdown-item>Action 1</el-dropdown-item>
|
<el-dropdown-item>Action 2</el-dropdown-item>
|
</el-dropdown-menu>
|
</template>
|
</el-dropdown>
|
-->
|
|
|
</el-menu-item>
|
|
<template v-for="(item, index) in items" :key="index">
|
<el-menu-item :index="item.id + ''" @click="openMenu(item)">
|
<template #title>
|
<i :class="item.source" style="padding-right: 5px"></i>
|
<span>{{ item.name }}</span>
|
</template>
|
</el-menu-item>
|
</template>
|
</el-menu>
|
</template>
|
|
<style lang="scss" scoped>
|
.todoItems {
|
margin-left:15px;
|
}
|
</style>
|
<script>
|
import { mapGetters } from 'vuex';
|
//import { getList } from '@/api/flow/todolist'; //任务提醒
|
export default {
|
name: 'top-menu',
|
data() {
|
return {
|
itemHome: {
|
name: '首页',
|
source: 'iconfont iconicon_work',
|
},
|
itemTodo: {
|
name: '任务提醒',
|
source: 'iconfont iconicon_work',
|
},
|
activeIndex: '0',
|
items: [],
|
|
todoCount:0,
|
exportCount:0,
|
remindCount:0, //提醒总数量
|
remindItems:[{text:'流程任务',id:"todo"},{text:'导出工控网',id:"todo1"},],
|
intervalId : undefined
|
};
|
},
|
inject: ['index'],
|
|
created() {
|
this.getMenu();
|
|
this.getCount();
|
|
window.remindIntervalId = setInterval(() => {
|
this.getCount();
|
}, 2*60*1000)//
|
window.myemitter.on('todochange', (data)=>{
|
this.getCount();
|
});
|
},
|
|
computed: {
|
...mapGetters(['tagCurrent', 'menu', 'tagWel']),
|
},
|
methods: {
|
openMenu(item) {
|
this.index.openMenu(item);
|
},
|
openHome(itemHome) {
|
this.index.openMenu(itemHome);
|
this.$router.push(this.tagWel);
|
},
|
getMenu() {
|
this.$store.dispatch('GetTopMenu').then(res => {
|
this.items = res;
|
});
|
},
|
handleRemindClick(item){
|
console.log(item)
|
if(item.id == 'todo'){
|
this.$router.push({ path: '/flow/todoindex' });
|
}else{
|
this.$router.push({ path: '/flowmgr/programexport' });
|
}
|
},
|
openTodo() {
|
this.$router.push({ path: '/flow/todoindex' });
|
//this.box = false;
|
},
|
|
getCount() {
|
axios({
|
url: '/blade-mdm/remind/task-count',
|
method: 'get',
|
params: {},
|
}).then(
|
res => {
|
if(res.data.code == 200){
|
this.todoCount = res.data.data.todoCount;
|
this.exportCount = res.data.data.exportCount;
|
this.remindCount = this.todoCount + this.exportCount;
|
this.setRemindItems();
|
|
}
|
},
|
error => {
|
console.log(error);
|
}
|
);
|
/*
|
try{
|
getList(1,1).then((res) => {
|
this.todoCount = res.data.data.total;
|
this.remindCount = this.todoCount + this.exportCount;
|
this.setRemindItems();
|
this.dataList = res.data.data.records;
|
|
}).catch(e=>{
|
|
clearInterval(this.intervalId);
|
});
|
}catch(e2){
|
console.log('e2',e2);
|
}*/
|
},
|
|
setRemindItems(){
|
this.remindItems=[];
|
if(this.todoCount>0){
|
this.remindItems.push({text:'流程任务('+this.todoCount+")",id:'todo'})
|
}
|
if(this.exportCount>0){
|
this.remindItems.push({text:'工控网导出('+this.exportCount+")",id:'export'})
|
}
|
}
|
},
|
};
|
</script>
|
<style lang="css">
|
@keyframes blink {
|
0% { opacity: 1; }
|
50% { opacity: 0.3; }
|
100% { opacity: 1; }
|
}
|
.blink-badge .el-badge__content {
|
animation: blink 2s infinite;
|
}
|
</style>
|