index.vue 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <!-- 顶部菜单模式:top -->
  2. <template>
  3. <el-container class="le-layout-wrap--top">
  4. <el-header class="le-layout-header">
  5. <div class="logo">
  6. <!-- <SvgIcon class="logo-img sidebar-logo" icon-class="logo" />-->
  7. <img class="logo-img" src="@/assets/icons/logo.svg" alt="logo" />
  8. <span class="logo-text text-overflow_ellipsis" :title="title">{{ title }}</span>
  9. </div>
  10. <el-menu class="layout-menu-wrap" mode="horizontal" :router="false" :default-active="activeMenu">
  11. <!-- 不能直接使用 SubMenu 组件,无法触发 el-menu 隐藏省略功能 -->
  12. <template v-for="subItem in menuList" :key="subItem.path">
  13. <el-sub-menu
  14. v-if="subItem.children?.length"
  15. :key="subItem.path"
  16. popper-class="layout-menu-popper-wrap"
  17. :index="subItem.path + 'el-sub-menu'"
  18. >
  19. <template #title>
  20. <PickerIcon v-if="subItem.meta.icon" :icon-class="subItem.meta.icon" />
  21. <span>{{ generateTitle(subItem.meta?.title) }}</span>
  22. </template>
  23. <SubMenu :menu-list="subItem.children" />
  24. </el-sub-menu>
  25. <el-menu-item
  26. v-else
  27. :key="subItem.path + 'el-menu-item'"
  28. popper-class="layout-menu-popper-wrap"
  29. :index="subItem.path"
  30. @click="handleClickMenu(subItem)"
  31. >
  32. <PickerIcon v-if="subItem.meta.icon" :icon-class="subItem.meta.icon" />
  33. <template #title>
  34. <span>{{ generateTitle(subItem.meta?.title) }}</span>
  35. </template>
  36. </el-menu-item>
  37. </template>
  38. </el-menu>
  39. <ToolBarRight />
  40. </el-header>
  41. <AppMain />
  42. </el-container>
  43. </template>
  44. <script setup lang="ts" name="layoutTop">
  45. import { computed } from 'vue'
  46. import { useRoute, useRouter } from 'vue-router'
  47. import AppMain from '@/layout/components/AppMain.vue'
  48. import ToolBarRight from '@/layout/components/Header/ToolBarRight.vue'
  49. import SubMenu from '@/layout/components/Menu/SubMenu.vue'
  50. import PickerIcon from '@/components/IconPicker/PickerIcon.vue'
  51. import useStore from '@/store'
  52. import { generateTitle } from '@/utils/i18n'
  53. import { isExternal } from '@/utils/validate.ts'
  54. // import { AppRouteRecordRaw } from '@/router/types'
  55. const title = import.meta.env.VITE_APP_TITLE
  56. const { permission, setting, app } = useStore()
  57. const route = useRoute()
  58. const router = useRouter()
  59. const menuList = computed(() => permission.showMenuList)
  60. const activeMenu = computed(() => (route.meta?.activeMenu ? route.meta.activeMenu : route.path) as string)
  61. const handleClickMenu = (subItem: RouteMenu.Item) => {
  62. if (isExternal(subItem.path)) return window.open(subItem.path, '_blank')
  63. router.push(subItem.path)
  64. }
  65. </script>
  66. <style lang="scss">
  67. @import './index.scss';
  68. </style>