index.vue 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <!-- 纵向布局 -->
  2. <template>
  3. <el-container class="layout">
  4. <el-aside>
  5. <div class="aside-box" :style="{ width: isCollapse ? '65px' : '210px' }">
  6. <div class="logo flx-center">
  7. <img class="logo-img" src="@/assets/images/logo.svg" alt="logo" />
  8. <span v-show="!isCollapse" class="logo-text">{{ title }}</span>
  9. </div>
  10. <el-scrollbar>
  11. <el-menu :router="false" :default-active="activeMenu" :collapse="isCollapse" :unique-opened="accordion" :collapse-transition="false">
  12. <SubMenu :menu-list="menuList" />
  13. </el-menu>
  14. </el-scrollbar>
  15. </div>
  16. </el-aside>
  17. <el-container>
  18. <el-header>
  19. <ToolBarLeft />
  20. <ToolBarRight />
  21. </el-header>
  22. <Main />
  23. </el-container>
  24. </el-container>
  25. </template>
  26. <script setup lang="ts" name="layoutVertical">
  27. import { computed } from 'vue'
  28. import { useRoute } from 'vue-router'
  29. import { useAuthStore } from '@/stores/modules/auth'
  30. import { useGlobalStore } from '@/stores/modules/global'
  31. import Main from '@/layouts/components/Main/index.vue'
  32. import ToolBarLeft from '@/layouts/components/Header/ToolBarLeft.vue'
  33. import ToolBarRight from '@/layouts/components/Header/ToolBarRight.vue'
  34. import SubMenu from '@/layouts/components/Menu/SubMenu.vue'
  35. const title = import.meta.env.VITE_GLOB_APP_TITLE
  36. const route = useRoute()
  37. const authStore = useAuthStore()
  38. const globalStore = useGlobalStore()
  39. const accordion = computed(() => globalStore.accordion)
  40. const isCollapse = computed(() => globalStore.isCollapse)
  41. const menuList = computed(() => authStore.showMenuListGet)
  42. const activeMenu = computed(() => (route.meta.activeMenu ? route.meta.activeMenu : route.path) as string)
  43. </script>
  44. <style scoped lang="scss">
  45. @import './index.scss';
  46. </style>