2020-03-27 15:41:26 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<span>
|
2020-03-29 16:33:49 +08:00
|
|
|
|
<!-- 副列表 -->
|
2020-03-27 15:41:26 +08:00
|
|
|
|
<div @mousedown="listResize" class="sub-list-resize" v-if="showSubList && !isFullScreen">一</div>
|
2020-05-12 14:56:43 +08:00
|
|
|
|
<div class="sub-list main-and-sub-transition" v-if="showSubList">
|
2020-03-27 15:41:26 +08:00
|
|
|
|
<!--窗口大小控制-->
|
|
|
|
|
|
<div class="sub-list-window-control">
|
2020-03-29 16:33:49 +08:00
|
|
|
|
<!--退出全屏-->
|
2020-03-27 15:41:26 +08:00
|
|
|
|
<div class="window-control-btn" v-if="isFullScreen" @click="exitFullScreen"><i class="nz-icon nz-icon-exit-full-screen"></i></div>
|
|
|
|
|
|
<!--全屏-->
|
|
|
|
|
|
<div class="window-control-btn" v-if="!isFullScreen" @click="fullScreen"><i class="el-icon-full-screen"></i></div>
|
|
|
|
|
|
<!--关闭-->
|
|
|
|
|
|
<div class="window-control-btn" @click="closeSubList"><i class="el-icon-close"></i></div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!------TAB区------>
|
|
|
|
|
|
<!--通用详情-->
|
2020-04-19 22:03:18 +08:00
|
|
|
|
<common-detail-tab v-show="subResizeShow" :obj="obj" :from="from" :detail="detail" :targetTab.sync="targetTab"
|
2020-03-27 15:41:26 +08:00
|
|
|
|
v-if="targetTab == 'detail'"
|
|
|
|
|
|
@changeTab="changeTab"
|
|
|
|
|
|
></common-detail-tab>
|
|
|
|
|
|
<!--机柜-->
|
|
|
|
|
|
<cabinet-tab v-show="subResizeShow" v-if="from == 'dc' && targetTab == 'cabinet'" :obj="obj" @changeTab="changeTab"></cabinet-tab>
|
2020-03-28 20:44:29 +08:00
|
|
|
|
<!--告警信息-->
|
|
|
|
|
|
<alert-message-tab v-show="subResizeShow" v-if="((from == 'alertRule' || from == 'asset') && targetTab == 'alertMessage')" :from="from" :obj="obj" @changeTab="changeTab"></alert-message-tab>
|
2020-03-30 19:46:03 +08:00
|
|
|
|
<!--asset页的endpoint列表-->
|
|
|
|
|
|
<endpoint-tab v-show="subResizeShow" v-if="from == 'asset' && targetTab == 'endpoint'" :from="from" :obj="obj" @changeTab="changeTab"></endpoint-tab>
|
2020-03-30 16:39:29 +08:00
|
|
|
|
<!--endpoint页的asset详情-->
|
2020-04-19 22:03:18 +08:00
|
|
|
|
<common-detail-tab v-show="subResizeShow" :obj="obj" :from="from" :detail="assetDetail" :targetTab.sync="targetTab"
|
2020-03-30 16:39:29 +08:00
|
|
|
|
v-if="targetTab == 'assetDetail' && from == 'endpoint'"
|
2020-04-06 22:11:25 +08:00
|
|
|
|
@changeTab="changeTab"></common-detail-tab>
|
2020-03-29 16:33:49 +08:00
|
|
|
|
<!--endpoint-query-->
|
2020-04-27 22:38:10 +08:00
|
|
|
|
<endpoint-query-tab v-show="subResizeShow" v-if="(from == 'endpoint' && targetTab == 'endpointQuery')" :from="from" :obj="obj" @changeTab="changeTab" ref="endpointQuery"></endpoint-query-tab>
|
2020-04-06 22:11:25 +08:00
|
|
|
|
|
|
|
|
|
|
<!--alertMessage页的详情-->
|
|
|
|
|
|
<template v-if="from == 'alertMessage'">
|
2020-04-19 22:03:18 +08:00
|
|
|
|
<common-detail-tab v-show="subResizeShow" :from="from" :targetTab.sync="targetTab" v-for="(item, index) in tabList" :key="index" :detail="detailList[index]"
|
2020-04-06 22:11:25 +08:00
|
|
|
|
v-if="targetTab == item" @changeTab="changeTab"></common-detail-tab>
|
|
|
|
|
|
</template>
|
2020-03-27 15:41:26 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</span>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
import commonDetailTab from "./tabs/commonDetailTab"
|
|
|
|
|
|
import cabinetTab from "./tabs/cabinetTab";
|
2020-03-28 20:44:29 +08:00
|
|
|
|
import alertMessageTab from "./tabs/alertMessageTab";
|
2020-03-29 16:33:49 +08:00
|
|
|
|
import endpointQueryTab from "./tabs/endpointQueryTab";
|
2020-03-30 19:46:03 +08:00
|
|
|
|
import endpointTab from "./tabs/endpointTab";
|
2020-03-27 15:41:26 +08:00
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
|
name: "cabinetBox",
|
|
|
|
|
|
components:{
|
|
|
|
|
|
'common-detail-tab': commonDetailTab,
|
|
|
|
|
|
'cabinet-tab': cabinetTab,
|
2020-03-28 20:44:29 +08:00
|
|
|
|
'alert-message-tab': alertMessageTab,
|
2020-03-29 16:33:49 +08:00
|
|
|
|
'endpoint-query-tab': endpointQueryTab,
|
2020-03-30 19:46:03 +08:00
|
|
|
|
'endpoint-tab': endpointTab,
|
2020-03-27 15:41:26 +08:00
|
|
|
|
},
|
|
|
|
|
|
props: {
|
|
|
|
|
|
isFullScreen: false, //是否全屏
|
|
|
|
|
|
showSubList: Boolean, //是否显示
|
|
|
|
|
|
subResizeShow: Boolean, //resize时,用v-show="subResizeShow"控制页面内容是否显示
|
|
|
|
|
|
obj: Object, //关联的实体对象
|
|
|
|
|
|
from: String, //来自哪个页面
|
2020-04-06 22:11:25 +08:00
|
|
|
|
tabList: Array, //动态页签列表
|
2020-03-27 15:41:26 +08:00
|
|
|
|
targetTab: String, //展示哪个页签
|
|
|
|
|
|
detail: Array, //对象详情内容
|
2020-04-06 22:11:25 +08:00
|
|
|
|
detailList: Array, //多个对象详情内容
|
2020-03-30 16:39:29 +08:00
|
|
|
|
|
|
|
|
|
|
assetDetail: Array, //endpoint页的asset详情
|
2020-03-27 15:41:26 +08:00
|
|
|
|
},
|
|
|
|
|
|
data() {
|
|
|
|
|
|
return {}
|
|
|
|
|
|
},
|
|
|
|
|
|
methods: {
|
|
|
|
|
|
exitFullScreen() {
|
|
|
|
|
|
this.$emit("exitFullScreen");
|
2020-04-27 22:38:10 +08:00
|
|
|
|
this.$nextTick(this.afterResize());
|
2020-03-27 15:41:26 +08:00
|
|
|
|
},
|
|
|
|
|
|
fullScreen() {
|
|
|
|
|
|
this.$emit("fullScreen");
|
2020-04-27 22:38:10 +08:00
|
|
|
|
this.$nextTick(this.afterResize());
|
2020-03-27 15:41:26 +08:00
|
|
|
|
},
|
|
|
|
|
|
closeSubList() {
|
|
|
|
|
|
this.$emit("closeSubList");
|
|
|
|
|
|
},
|
|
|
|
|
|
listResize(e) {
|
|
|
|
|
|
this.$emit('listResize', e);
|
2020-04-27 22:38:10 +08:00
|
|
|
|
this.$nextTick(this.afterResize());
|
2020-03-27 15:41:26 +08:00
|
|
|
|
},
|
|
|
|
|
|
changeTab(tab) {
|
2020-04-19 22:03:18 +08:00
|
|
|
|
this.$emit('update:targetTab', tab);
|
2020-04-27 22:38:10 +08:00
|
|
|
|
},
|
|
|
|
|
|
afterResize() {
|
|
|
|
|
|
if (this.from == 'endpoint' && this.targetTab == 'endpointQuery') {
|
|
|
|
|
|
this.$refs.endpointQuery.tableReload();
|
|
|
|
|
|
}
|
2020-03-27 15:41:26 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
</script>
|