Files
pqs-9100_client/frontend/src/layouts/LayoutClassic/index.vue

63 lines
2.3 KiB
Vue
Raw Normal View History

2024-08-22 11:27:06 +08:00
<!-- 经典布局 -->
<template>
2025-10-10 13:23:40 +08:00
<el-container class="layout">
<el-header>
<div class="header-lf mask-image">
<div class="logo flx-center">
<img class="logo-img" src="@/assets/images/logo.svg" alt="logo" />
<span class="logo-text">{{ title }}</span>
</div>
<ToolBarLeft />
</div>
<div class="header-ri">
<ToolBarRight />
</div>
</el-header>
<el-container class="classic-content">
<el-aside>
<div class="aside-box" :style="{ width: isCollapse ? '65px' : '210px' }">
<el-scrollbar>
<el-menu
:router="false"
:default-active="activeMenu"
:collapse="isCollapse"
:unique-opened="accordion"
:collapse-transition="false"
>
<SubMenu :menu-list="menuList" />
</el-menu>
</el-scrollbar>
</div>
</el-aside>
<el-container class="classic-main">
<Main />
</el-container>
</el-container>
2024-08-22 11:27:06 +08:00
</el-container>
</template>
<script setup lang="ts" name="layoutClassic">
2025-10-10 13:23:40 +08:00
import { computed } from 'vue'
import { useRoute } from 'vue-router'
import { useAuthStore } from '@/stores/modules/auth'
import { useGlobalStore } from '@/stores/modules/global'
import Main from '@/layouts/components/Main/index.vue'
import SubMenu from '@/layouts/components/Menu/SubMenu.vue'
import ToolBarLeft from '@/layouts/components/Header/ToolBarLeft.vue'
import ToolBarRight from '@/layouts/components/Header/ToolBarRight.vue'
2024-08-22 11:27:06 +08:00
2025-10-10 13:23:40 +08:00
const title = import.meta.env.VITE_GLOB_APP_TITLE
2024-08-22 11:27:06 +08:00
2025-10-10 13:23:40 +08:00
const route = useRoute()
const authStore = useAuthStore()
const globalStore = useGlobalStore()
const accordion = computed(() => globalStore.accordion)
const isCollapse = computed(() => globalStore.isCollapse)
const menuList = computed(() => authStore.showMenuListGet)
const activeMenu = computed(() => (route.meta.activeMenu ? route.meta.activeMenu : route.path) as string)
2024-08-22 11:27:06 +08:00
</script>
<style scoped lang="scss">
2025-10-10 13:23:40 +08:00
@use './index.scss';
2024-08-22 11:27:06 +08:00
</style>