Files
orion-visor/orion-ops-ui/src/layout/default-layout.vue

171 lines
4.7 KiB
Vue
Raw Normal View History

2023-07-24 10:05:07 +08:00
<template>
<a-layout class="layout" :class="{ mobile: appStore.hideMenu }">
2023-07-27 18:48:15 +08:00
<!-- tab bar -->
2023-07-24 10:05:07 +08:00
<div v-if="navbar" class="layout-navbar">
<NavBar />
</div>
2023-11-23 19:16:57 +08:00
<a-layout>
2023-09-26 01:11:57 +08:00
<!-- 左侧菜单栏 -->
<a-layout-sider v-if="renderMenu"
v-show="!hideMenu"
class="layout-sider"
breakpoint="xl"
:collapsed="collapsed"
:collapsible="true"
:width="menuWidth"
:style="{ paddingTop: navbar ? '60px' : '' }"
:hide-trigger="true"
@collapse="setCollapsed">
<div class="menu-wrapper">
2024-03-07 23:00:34 +08:00
<menu-tree />
2023-09-26 01:11:57 +08:00
</div>
</a-layout-sider>
<!-- 顶部菜单栏 -->
<a-drawer v-if="hideMenu"
:visible="drawerVisible"
placement="left"
:header="false"
:footer="false"
mask-closable
:closable="false"
@cancel="drawerCancel">
2024-03-07 23:00:34 +08:00
<menu-tree style="padding: 12px 16px;" />
2023-09-26 01:11:57 +08:00
</a-drawer>
<!-- body -->
<a-layout class="layout-content" :style="paddingStyle">
2023-11-10 19:02:38 +08:00
<!-- 页签 -->
2023-09-26 01:11:57 +08:00
<TabBar v-if="appStore.tabBar" />
2023-11-10 19:02:38 +08:00
<!-- 页面 -->
2023-12-01 01:54:50 +08:00
<a-layout-content style="height: 100%; width: 100%;">
2023-11-24 14:42:58 +08:00
<!-- 水印 -->
<a-watermark :grayscale="true"
:alpha=".6"
:z-index="9999"
style="width: 100%; height: 100%;"
:content="userStore.username || ''">
<PageLayout />
</a-watermark>
2023-09-26 01:11:57 +08:00
</a-layout-content>
2023-11-10 19:02:38 +08:00
<!-- 页脚 -->
2023-12-01 01:54:50 +08:00
<Footer v-if="visibleFooter" />
2023-07-24 10:05:07 +08:00
</a-layout>
</a-layout>
</a-layout>
</template>
<script lang="ts" setup>
2023-07-29 13:11:19 +08:00
import { computed, onMounted, provide, ref } from 'vue';
import { useRoute, useRouter } from 'vue-router';
2023-11-24 14:42:58 +08:00
import { useAppStore, useUserStore } from '@/store';
2024-03-07 23:00:34 +08:00
import useResponsive from '@/hooks/responsive';
import { toggleDrawerMenuKey } from '@/types/symbol';
import PageLayout from './page-layout.vue';
import MenuTree from '@/components/system/menu/tree/index.vue';
2023-10-18 17:11:27 +08:00
import NavBar from '@/components/app/navbar/index.vue';
import Footer from '@/components/app/footer/index.vue';
import TabBar from '@/components/app/tab-bar/index.vue';
2023-07-24 10:05:07 +08:00
const isInit = ref(false);
const appStore = useAppStore();
2023-11-24 14:42:58 +08:00
const userStore = useUserStore();
2023-07-24 10:05:07 +08:00
const router = useRouter();
const route = useRoute();
useResponsive(true);
const navbarHeight = `60px`;
const navbar = computed(() => appStore.navbar);
const renderMenu = computed(() => appStore.menu && !appStore.topMenu);
const hideMenu = computed(() => appStore.hideMenu);
2023-12-01 01:54:50 +08:00
const visibleFooter = computed(() => appStore.footer);
2023-07-24 10:05:07 +08:00
const menuWidth = computed(() => {
return appStore.menuCollapse ? 48 : appStore.menuWidth;
});
2023-07-27 18:48:15 +08:00
2023-07-24 10:05:07 +08:00
const collapsed = computed(() => {
return appStore.menuCollapse;
});
2023-07-27 18:48:15 +08:00
2023-07-24 10:05:07 +08:00
const paddingStyle = computed(() => {
2023-07-27 18:48:15 +08:00
const paddingLeft = renderMenu.value && !hideMenu.value
? { paddingLeft: `${menuWidth.value}px` }
: {};
2023-07-24 10:05:07 +08:00
const paddingTop = navbar.value ? { paddingTop: navbarHeight } : {};
return { ...paddingLeft, ...paddingTop };
});
2023-07-27 18:48:15 +08:00
2023-11-10 19:02:38 +08:00
// 设置菜单展开状态
2023-07-24 10:05:07 +08:00
const setCollapsed = (val: boolean) => {
2023-07-27 18:48:15 +08:00
if (!isInit.value) return;
2023-07-24 10:05:07 +08:00
appStore.updateSettings({ menuCollapse: val });
};
2023-07-27 18:48:15 +08:00
2023-07-24 10:05:07 +08:00
const drawerVisible = ref(false);
const drawerCancel = () => {
drawerVisible.value = false;
};
2023-07-27 18:48:15 +08:00
// 对外暴露触发收缩菜单
2023-09-26 01:11:57 +08:00
provide(toggleDrawerMenuKey, () => {
2023-07-24 10:05:07 +08:00
drawerVisible.value = !drawerVisible.value;
});
2023-07-27 18:48:15 +08:00
2023-07-24 10:05:07 +08:00
onMounted(() => {
isInit.value = true;
});
</script>
2023-10-25 10:26:14 +08:00
<style lang="less" scoped>
2023-07-24 10:05:07 +08:00
@nav-size-height: 60px;
@layout-max-width: 1100px;
.layout {
width: 100%;
height: 100%;
}
.layout-navbar {
position: fixed;
top: 0;
left: 0;
2023-11-10 19:02:38 +08:00
z-index: 120;
2023-07-24 10:05:07 +08:00
width: 100%;
height: @nav-size-height;
}
.layout-sider {
position: fixed;
top: 0;
left: 0;
z-index: 99;
height: 100%;
transition: all 0.2s cubic-bezier(0.34, 0.69, 0.1, 1);
&::after {
position: absolute;
top: 0;
right: -1px;
display: block;
width: 1px;
height: 100%;
background-color: var(--color-border);
content: '';
}
> :deep(.arco-layout-sider-children) {
overflow-y: hidden;
}
}
.menu-wrapper {
height: 100%;
overflow: auto;
overflow-x: hidden;
}
.layout-content {
min-height: 100vh;
overflow-y: hidden;
background-color: var(--color-fill-2);
transition: padding 0.2s cubic-bezier(0.34, 0.69, 0.1, 1);
}
</style>