index.vue 1.9 KB

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