2020-12-31 11:47:52 +08:00
|
|
|
<template>
|
2021-01-10 23:59:43 +08:00
|
|
|
<el-aside :class="setCollapseWidth">
|
|
|
|
<Logo v-if="setShowLogo" />
|
2021-01-05 23:58:16 +08:00
|
|
|
<el-scrollbar class="flex-auto" ref="layoutAsideScrollbarRef">
|
2020-12-31 11:47:52 +08:00
|
|
|
<Vertical :menuList="menuList" />
|
|
|
|
</el-scrollbar>
|
|
|
|
</el-aside>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts">
|
2021-01-10 23:59:43 +08:00
|
|
|
import {
|
|
|
|
toRefs,
|
|
|
|
reactive,
|
|
|
|
computed,
|
|
|
|
watch,
|
|
|
|
getCurrentInstance,
|
|
|
|
ref,
|
|
|
|
} from "vue";
|
2021-01-05 18:11:13 +08:00
|
|
|
import { useStore } from "/@/store/index.ts";
|
2021-01-06 18:41:05 +08:00
|
|
|
import Logo from "/@/views/layout/logo/index.vue";
|
|
|
|
import Vertical from "/@/views/layout/navMenu/vertical.vue";
|
2020-12-31 11:47:52 +08:00
|
|
|
export default {
|
|
|
|
name: "layoutAside",
|
2021-01-05 23:58:16 +08:00
|
|
|
components: { Logo, Vertical },
|
2020-12-31 11:47:52 +08:00
|
|
|
setup() {
|
2021-01-05 23:58:16 +08:00
|
|
|
const { proxy } = getCurrentInstance();
|
2021-01-05 18:11:13 +08:00
|
|
|
const store = useStore();
|
2020-12-31 11:47:52 +08:00
|
|
|
const state = reactive({
|
|
|
|
menuList: [
|
|
|
|
{
|
|
|
|
path: "/home",
|
|
|
|
meta: {
|
|
|
|
title: "首页",
|
|
|
|
icon: "el-icon-s-home",
|
|
|
|
},
|
|
|
|
children: [
|
|
|
|
{
|
2021-01-03 22:43:07 +08:00
|
|
|
path: "/home",
|
2020-12-31 11:47:52 +08:00
|
|
|
meta: {
|
2021-01-03 22:43:07 +08:00
|
|
|
title: "微软",
|
2020-12-31 11:47:52 +08:00
|
|
|
icon: "el-icon-s-flag",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-01-03 22:43:07 +08:00
|
|
|
path: "/docs",
|
2020-12-31 11:47:52 +08:00
|
|
|
meta: {
|
2021-01-03 22:43:07 +08:00
|
|
|
title: "文档",
|
2020-12-31 11:47:52 +08:00
|
|
|
icon: "el-icon-s-flag",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-01-03 22:43:07 +08:00
|
|
|
path: "/docs1",
|
2020-12-31 11:47:52 +08:00
|
|
|
meta: {
|
2021-01-03 22:43:07 +08:00
|
|
|
title: "文档1",
|
2020-12-31 11:47:52 +08:00
|
|
|
icon: "el-icon-s-flag",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
2021-01-03 22:43:07 +08:00
|
|
|
path: "/docs2",
|
2020-12-31 11:47:52 +08:00
|
|
|
meta: {
|
2021-01-03 22:43:07 +08:00
|
|
|
title: "文档2",
|
2020-12-31 11:47:52 +08:00
|
|
|
icon: "el-icon-s-management",
|
|
|
|
isLink: "https://www.ele.me",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2021-01-03 22:43:07 +08:00
|
|
|
path: "/docs3",
|
2020-12-31 11:47:52 +08:00
|
|
|
meta: {
|
2021-01-03 22:43:07 +08:00
|
|
|
title: "文档3",
|
2020-12-31 11:47:52 +08:00
|
|
|
icon: "el-icon-s-management",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
2021-01-10 23:59:43 +08:00
|
|
|
// 设置菜单展开/收起时的宽度
|
|
|
|
const setCollapseWidth = computed(() => {
|
|
|
|
let { layout, isCollapse, menuBar } = store.state.themeConfig;
|
|
|
|
let asideBrColor =
|
|
|
|
menuBar === "#FFFFFF" ||
|
|
|
|
menuBar === "#FFF" ||
|
|
|
|
menuBar === "#fff" ||
|
|
|
|
menuBar === "#ffffff"
|
|
|
|
? "layout-el-aside-br-color"
|
|
|
|
: "";
|
|
|
|
if (layout === "columns") {
|
|
|
|
// 分栏布局,菜单收起时宽度给 1px
|
|
|
|
if (isCollapse) {
|
|
|
|
return ["layout-aside-width1", asideBrColor];
|
|
|
|
} else {
|
|
|
|
return ["layout-aside-width-default", asideBrColor];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// 其它布局给 64px
|
|
|
|
if (isCollapse) {
|
|
|
|
return ["layout-aside-width64", asideBrColor];
|
|
|
|
} else {
|
|
|
|
return ["layout-aside-width-default", asideBrColor];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
// 设置显示/隐藏 logo
|
|
|
|
const setShowLogo = computed(() => {
|
|
|
|
let { layout, isShowLogo } = store.state.themeConfig;
|
|
|
|
return (
|
|
|
|
(isShowLogo && layout === "defaults") ||
|
|
|
|
(isShowLogo && layout === "columns")
|
|
|
|
);
|
2021-01-05 23:58:16 +08:00
|
|
|
});
|
2021-01-10 23:59:43 +08:00
|
|
|
// 监听 themeConfig 配置文件的变化,更新菜单 el-scrollbar 的高度
|
2021-01-05 23:58:16 +08:00
|
|
|
watch(store.state.themeConfig, (val) => {
|
2021-01-06 13:30:53 +08:00
|
|
|
if (val.isShowLogoChange !== val.isShowLogo) {
|
2021-01-10 23:59:43 +08:00
|
|
|
if (!proxy.$refs.layoutAsideScrollbarRef) return false;
|
2021-01-06 13:30:53 +08:00
|
|
|
proxy.$refs.layoutAsideScrollbarRef.update();
|
|
|
|
}
|
2021-01-05 18:11:13 +08:00
|
|
|
});
|
2020-12-31 11:47:52 +08:00
|
|
|
return {
|
2021-01-10 23:59:43 +08:00
|
|
|
setCollapseWidth,
|
|
|
|
setShowLogo,
|
2020-12-31 11:47:52 +08:00
|
|
|
...toRefs(state),
|
|
|
|
};
|
|
|
|
},
|
|
|
|
};
|
|
|
|
</script>
|