10 changed files with 276 additions and 33 deletions
@ -0,0 +1,106 @@ |
|||||
|
<template> |
||||
|
<el-menu class="topbar-menu" :ellipsis="false" :default-active="activeMenu" :active-text-color="theme" mode="horizontal"> |
||||
|
<sidebar-item :key="route.path + index" v-for="(route, index) in topMenus" :item="route" :base-path="route.path" /> |
||||
|
|
||||
|
<el-sub-menu index="more" class="el-sub-menu__hide-arrow" v-if="moreRoutes.length > 0"> |
||||
|
<template #title> |
||||
|
<span>更多菜单</span> |
||||
|
</template> |
||||
|
<sidebar-item :key="route.path + index" v-for="(route, index) in moreRoutes" :item="route" :base-path="route.path" /> |
||||
|
</el-sub-menu> |
||||
|
</el-menu> |
||||
|
</template> |
||||
|
|
||||
|
<script setup> |
||||
|
import SidebarItem from '../Sidebar/SidebarItem' |
||||
|
import useAppStore from '@/store/modules/app' |
||||
|
import useSettingsStore from '@/store/modules/settings' |
||||
|
import usePermissionStore from '@/store/modules/permission' |
||||
|
|
||||
|
const route = useRoute() |
||||
|
const appStore = useAppStore() |
||||
|
const settingsStore = useSettingsStore() |
||||
|
const permissionStore = usePermissionStore() |
||||
|
|
||||
|
const sidebarRouters = computed(() => permissionStore.sidebarRouters) |
||||
|
const theme = computed(() => settingsStore.theme) |
||||
|
const device = computed(() => appStore.device) |
||||
|
const activeMenu = computed(() => { |
||||
|
const { meta, path } = route |
||||
|
if (meta.activeMenu) { |
||||
|
return meta.activeMenu |
||||
|
} |
||||
|
return path |
||||
|
}) |
||||
|
|
||||
|
const visibleNumber = ref(5) |
||||
|
const topMenus = computed(() => { |
||||
|
return permissionStore.sidebarRouters.filter((f) => !f.hidden).slice(0, visibleNumber.value) |
||||
|
}) |
||||
|
const moreRoutes = computed(() => { |
||||
|
return permissionStore.sidebarRouters.filter((f) => !f.hidden).slice(visibleNumber.value, sidebarRouters.value.length - visibleNumber.value) |
||||
|
}) |
||||
|
function setVisibleNumber() { |
||||
|
const width = document.body.getBoundingClientRect().width / 3 |
||||
|
visibleNumber.value = parseInt(width / 85) |
||||
|
} |
||||
|
|
||||
|
onMounted(() => { |
||||
|
window.addEventListener('resize', setVisibleNumber) |
||||
|
}) |
||||
|
onBeforeUnmount(() => { |
||||
|
window.removeEventListener('resize', setVisibleNumber) |
||||
|
}) |
||||
|
|
||||
|
onMounted(() => { |
||||
|
setVisibleNumber() |
||||
|
}) |
||||
|
</script> |
||||
|
|
||||
|
<style lang="scss"> |
||||
|
.topbar-menu.el-menu--horizontal > .el-menu-item { |
||||
|
float: left; |
||||
|
height: 50px !important; |
||||
|
line-height: 50px !important; |
||||
|
color: #303133 !important; |
||||
|
padding: 0 5px !important; |
||||
|
margin: 0 10px !important; |
||||
|
} |
||||
|
|
||||
|
.el-sub-menu.is-active .svg-icon, .el-menu-item.is-active .svg-icon + span, .el-sub-menu.is-active .svg-icon + span, .el-sub-menu.is-active .el-sub-menu__title span { |
||||
|
color: v-bind(theme); |
||||
|
} |
||||
|
|
||||
|
/* sub-menu item */ |
||||
|
.topbar-menu.el-menu--horizontal > .el-sub-menu .el-sub-menu__title { |
||||
|
float: left; |
||||
|
height: 62px !important; |
||||
|
line-height: 50px !important; |
||||
|
color: #303133 !important; |
||||
|
padding: 0 5px !important; |
||||
|
margin: 0 20px -4px!important; |
||||
|
} |
||||
|
|
||||
|
/* 背景色隐藏 */ |
||||
|
.topbar-menu.el-menu--horizontal>.el-menu-item:not(.is-disabled):focus, .topbar-menu.el-menu--horizontal>.el-menu-item:not(.is-disabled):hover, .topbar-menu.el-menu--horizontal>.el-submenu .el-submenu__title:hover { |
||||
|
background-color: #ffffff; |
||||
|
} |
||||
|
|
||||
|
/* 图标右间距 */ |
||||
|
.topbar-menu .svg-icon { |
||||
|
margin-right: 4px; |
||||
|
} |
||||
|
|
||||
|
/* topbar more arrow */ |
||||
|
.topbar-menu .el-sub-menu .el-sub-menu__icon-arrow { |
||||
|
position: static; |
||||
|
margin-left: 8px; |
||||
|
margin-top: 0px; |
||||
|
display: block !important; |
||||
|
} |
||||
|
|
||||
|
/* menu__title el-menu-item */ |
||||
|
.topbar-menu.el-menu--horizontal .el-sub-menu__title, .topbar-menu.el-menu--horizontal .el-menu-item { |
||||
|
height: 60px; |
||||
|
} |
||||
|
</style> |
||||
Loading…
Reference in new issue