# Conflicts:
#	src/layout/component/aside.vue
#	src/layout/component/header.vue
#	src/layout/navBars/tagsView/tagsView.vue
#	src/store/modules/tagsViewRoutes.ts
This commit is contained in:
21030442-mao 2021-07-27 08:51:34 +08:00
commit 0050120d79
8 changed files with 72 additions and 34 deletions

View File

@ -1,11 +1,14 @@
<template> <template>
<el-aside class="layout-aside" :class="setCollapseWidth" v-if="!isCurrenFullscreen && clientWidth > 1000"> <template v-if="clientWidth > 1000">
<el-aside class="layout-aside" :class="setCollapseWidth" v-show="!isCurrenFullscreen">
<Logo v-if="setShowLogo" /> <Logo v-if="setShowLogo" />
<el-scrollbar class="flex-auto" ref="layoutAsideScrollbarRef"> <el-scrollbar class="flex-auto" ref="layoutAsideScrollbarRef">
<Vertical :menuList="menuList" :class="setCollapseWidth" /> <Vertical :menuList="menuList" :class="setCollapseWidth" />
</el-scrollbar> </el-scrollbar>
</el-aside> </el-aside>
<el-drawer v-model="getThemeConfig.isCollapse" :with-header="false" direction="ltr" size="220px" v-else> </template>
<template v-else>
<el-drawer v-model="getThemeConfig.isCollapse" :with-header="false" direction="ltr" size="220px">
<el-aside class="layout-aside w100 h100"> <el-aside class="layout-aside w100 h100">
<Logo v-if="setShowLogo" /> <Logo v-if="setShowLogo" />
<el-scrollbar class="flex-auto" ref="layoutAsideScrollbarRef"> <el-scrollbar class="flex-auto" ref="layoutAsideScrollbarRef">
@ -14,6 +17,7 @@
</el-aside> </el-aside>
</el-drawer> </el-drawer>
</template> </template>
</template>
<script lang="ts"> <script lang="ts">
import { toRefs, reactive, computed, watch, getCurrentInstance, onBeforeMount } from 'vue'; import { toRefs, reactive, computed, watch, getCurrentInstance, onBeforeMount } from 'vue';

View File

@ -1,5 +1,5 @@
<template> <template>
<div class="layout-columns-aside"> <div class="layout-columns-aside" v-show="!isCurrenFullscreen">
<el-scrollbar> <el-scrollbar>
<ul> <ul>
<li <li
@ -70,6 +70,10 @@ export default {
const setColumnsAsidelayout = computed(() => { const setColumnsAsidelayout = computed(() => {
return store.state.themeConfig.themeConfig.columnsAsideLayout; return store.state.themeConfig.themeConfig.columnsAsideLayout;
}); });
//
const isCurrenFullscreen = computed(() => {
return store.state.tagsViewRoutes.isCurrenFullscreen;
});
// //
const setColumnsAsideMove = (k: number) => { const setColumnsAsideMove = (k: number) => {
state.liIndex = k; state.liIndex = k;
@ -152,6 +156,7 @@ export default {
setColumnsAsideStyle, setColumnsAsideStyle,
setColumnsAsidelayout, setColumnsAsidelayout,
onColumnsAsideMenuClick, onColumnsAsideMenuClick,
isCurrenFullscreen,
...toRefs(state), ...toRefs(state),
}; };
}, },
@ -211,8 +216,8 @@ export default {
position: absolute; position: absolute;
left: 50%; left: 50%;
top: 2px; top: 2px;
height: 44px; height: 50px;
width: 65px; width: 60px;
transform: translateX(-50%); transform: translateX(-50%);
z-index: 0; z-index: 0;
transition: 0.3s ease-in-out; transition: 0.3s ease-in-out;
@ -221,7 +226,6 @@ export default {
.columns-card { .columns-card {
@extend .columns-round; @extend .columns-round;
top: 0; top: 0;
height: 50px;
width: 100%; width: 100%;
border-radius: 0; border-radius: 0;
} }

View File

@ -1,5 +1,5 @@
<template> <template>
<el-header class="layout-header sackajljfs" :height="setHeaderHeight" v-show="!isCurrenFullscreen"> <el-header class="layout-header" :height="setHeaderHeight" v-show="!isCurrenFullscreen">
<NavBarsIndex /> <NavBarsIndex />
</el-header> </el-header>
</template> </template>

View File

@ -225,8 +225,19 @@ export default {
break; break;
} }
}; };
// F11
const initOnkeydown = () => {
document.onkeydown = (event) => {
var e = event || window.event || arguments.callee.caller.arguments[0];
if (e && e.keyCode === 122 && !state.isScreenfull) {
e.preventDefault();
onScreenfullClick();
}
};
};
// //
onMounted(() => { onMounted(() => {
initOnkeydown();
if (Local.get('themeConfig')) { if (Local.get('themeConfig')) {
initI18n(); initI18n();
initComponentSize(); initComponentSize();

View File

@ -185,21 +185,24 @@ export default {
addBrowserSetSession(state.tagsViewList); addBrowserSetSession(state.tagsViewList);
}; };
// 6 // 6
const openCurrenFullscreen = (path: string) => { const openCurrenFullscreen = (path: string, currentRouteInfo: object) => {
const item = state.tagsViewList.find((v: any) => v.path === path);
nextTick(() => { nextTick(() => {
router.push({ path, query: item.query }); const { meta, name, params, query } = currentRouteInfo;
store.dispatch('tagsViewRoutes/openCurrenFullscreen'); if (meta.isDynamic) router.push({ name, params });
else router.push({ path, query });
store.dispatch('tagsViewRoutes/setCurrenFullscreen');
}); });
}; };
// tagsView // tagsView
const getCurrentRouteItem = (path: string) => { const getCurrentRouteItem = (path: string) => {
if (!Session.get('tagsViewList')) return state.tagsViewList.find((v: any) => v.path === path);
return Session.get('tagsViewList').find((v: any) => v.path === path); return Session.get('tagsViewList').find((v: any) => v.path === path);
}; };
// //
const onCurrentContextmenuClick = (item) => { const onCurrentContextmenuClick = (item) => {
const { id, path } = item; const { id, path } = item;
const { meta, name, params, query } = getCurrentRouteItem(path); const currentRouteInfo = getCurrentRouteItem(path);
const { meta, name, params, query } = currentRouteInfo;
switch (id) { switch (id) {
case 0: case 0:
refreshCurrentTagsView(path); refreshCurrentTagsView(path);
@ -218,7 +221,7 @@ export default {
closeAllTagsView(path); closeAllTagsView(path);
break; break;
case 4: case 4:
openCurrenFullscreen(path); openCurrenFullscreen(path, currentRouteInfo);
break; break;
} }
}; };

View File

@ -1,4 +1,7 @@
import { Module } from 'vuex'; import { Module } from 'vuex';
import { ElMessage } from 'element-plus';
import screenfull from 'screenfull';
import { Local } from '/@/utils/storage';
// 此处加上 `.ts` 后缀报错,具体原因不详 // 此处加上 `.ts` 后缀报错,具体原因不详
import { TagsViewRoutesState, RootStateTypes } from '/@/store/interface/index'; import { TagsViewRoutesState, RootStateTypes } from '/@/store/interface/index';
import { ElMessage } from 'element-plus'; import { ElMessage } from 'element-plus';
@ -16,7 +19,7 @@ const tagsViewRoutesModule: Module<TagsViewRoutesState, RootStateTypes> = {
state.tagsViewRoutes = data; state.tagsViewRoutes = data;
}, },
// 设置卡片全屏 // 设置卡片全屏
setCurrenFullscreen(state: any, data: boolean) { getCurrenFullscreen(state: any, data: boolean) {
state.isCurrenFullscreen = data; state.isCurrenFullscreen = data;
}, },
}, },
@ -25,22 +28,34 @@ const tagsViewRoutesModule: Module<TagsViewRoutesState, RootStateTypes> = {
async setTagsViewRoutes({ commit }, data: Array<string>) { async setTagsViewRoutes({ commit }, data: Array<string>) {
commit('getTagsViewRoutes', data); commit('getTagsViewRoutes', data);
}, },
// 开启卡片全屏 // 设置卡片全屏
openCurrenFullscreen({ commit }) { setCurrenFullscreen({ commit }) {
if (!screenfull.isEnabled) { const screenfulls: any = screenfull;
if (!screenfulls.isEnabled) {
ElMessage.warning('暂不不支持全屏'); ElMessage.warning('暂不不支持全屏');
return false; return false;
} }
screenfull.toggle(); screenfulls.toggle();
const currenFullscreenChange = () => { const currenFullscreenChange = () => {
if (screenfull.isFullscreen) commit('setCurrenFullscreen', true); const layoutViewBgWhite = document.querySelector('.layout-view-bg-white') as HTMLElement;
else { if (screenfulls.isFullscreen) {
screenfull.off('change', currenFullscreenChange); commit('getCurrenFullscreen', true);
commit('setCurrenFullscreen', false); // 设置全屏时,设置有 `layout-view-bg-white` 类的高度
if (layoutViewBgWhite) layoutViewBgWhite.style.height = `calc(100vh - 30px)`;
} else {
screenfulls.off('change', currenFullscreenChange);
commit('getCurrenFullscreen', false);
if (!layoutViewBgWhite) return false;
const getThemeConfig = Local.get('themeConfig');
if (getThemeConfig) {
let { isTagsview } = getThemeConfig;
if (isTagsview) layoutViewBgWhite.style.height = `calc(100vh - 114px)`;
else layoutViewBgWhite.style.height = `calc(100vh - 80px)`;
}
} }
}; };
screenfull.on('change', currenFullscreenChange); screenfulls.on('change', currenFullscreenChange);
commit('setCurrenFullscreen', true); commit('getCurrenFullscreen', true);
}, },
}, },
}; };

View File

@ -54,6 +54,7 @@ body,
.el-scrollbar { .el-scrollbar {
width: 100%; width: 100%;
} }
// 此字段多次用到不可删除如需修改请重写覆盖样式
.layout-view-bg-white { .layout-view-bg-white {
background: white; background: white;
width: 100%; width: 100%;

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="chart-scrollbar" :style="{ height: `calc(100vh - ${initTagViewHeight}` }"> <div class="chart-scrollbar layout-view-bg-white" :style="{ height: `calc(100vh - ${initTagViewHeight}` }">
<div class="chart-warp layout-view-bg-white"> <div class="chart-warp">
<div class="chart-warp-top"> <div class="chart-warp-top">
<ChartHead /> <ChartHead />
</div> </div>