2024-04-13 22:09:14 +08:00
|
|
|
|
<template>
|
2024-04-20 16:54:12 +08:00
|
|
|
|
<a-menu
|
2024-05-20 13:03:51 +08:00
|
|
|
|
:breakpoint="layoutType != 'layoutHead' ? 'xl' : undefined"
|
2024-05-06 00:20:09 +08:00
|
|
|
|
:mode="'vertical'"
|
2024-05-06 16:36:10 +08:00
|
|
|
|
:theme="asideDark ? 'dark' : 'light'"
|
2024-04-20 16:54:12 +08:00
|
|
|
|
:collapsed="collapsed"
|
2024-05-04 23:36:38 +08:00
|
|
|
|
:auto-scroll-into-view="true"
|
2024-04-20 16:54:12 +08:00
|
|
|
|
:auto-open-selected="true"
|
2024-05-04 23:36:38 +08:00
|
|
|
|
:accordion="isAccordion"
|
2024-04-20 16:54:12 +08:00
|
|
|
|
:selected-keys="[currentRoute.name]"
|
|
|
|
|
|
@menu-item-click="onMenuItem"
|
|
|
|
|
|
>
|
2024-05-14 13:05:02 +08:00
|
|
|
|
<MenuItem :route-tree="props.routeTree" />
|
2024-04-13 22:09:14 +08:00
|
|
|
|
</a-menu>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
|
|
|
import MenuItem from "@/layout/components/Menu/menu-item.vue";
|
|
|
|
|
|
import { storeToRefs } from "pinia";
|
2024-04-28 13:38:12 +08:00
|
|
|
|
import { useThemeConfig } from "@/store/modules/theme-config";
|
|
|
|
|
|
import { useRoutesListStore } from "@/store/modules/route-list";
|
2024-04-20 16:54:12 +08:00
|
|
|
|
import { useRoutingMethod } from "@/hooks/useRoutingMethod";
|
2024-04-18 00:24:07 +08:00
|
|
|
|
const router = useRouter();
|
2024-04-13 22:09:14 +08:00
|
|
|
|
const routerStore = useRoutesListStore();
|
2024-05-14 13:05:02 +08:00
|
|
|
|
const { currentRoute } = storeToRefs(routerStore);
|
2024-04-13 22:09:14 +08:00
|
|
|
|
const themeStore = useThemeConfig();
|
2024-05-06 16:36:10 +08:00
|
|
|
|
const { collapsed, isAccordion, layoutType, asideDark } = storeToRefs(themeStore);
|
2024-04-13 22:09:14 +08:00
|
|
|
|
|
2024-05-14 13:05:02 +08:00
|
|
|
|
interface Props {
|
|
|
|
|
|
routeTree: Menu.MenuOptions[];
|
|
|
|
|
|
}
|
|
|
|
|
|
// props的数据类型
|
|
|
|
|
|
// type类型参考:https://cn.vuejs.org/guide/typescript/composition-api.html#typing-component-props
|
|
|
|
|
|
const props = withDefaults(defineProps<Props>(), {
|
|
|
|
|
|
routeTree: () => []
|
|
|
|
|
|
});
|
|
|
|
|
|
|
2024-04-21 00:26:49 +08:00
|
|
|
|
/**
|
|
|
|
|
|
* @description 菜单点击事件
|
|
|
|
|
|
* @param {String} key
|
|
|
|
|
|
*/
|
2024-04-18 00:24:07 +08:00
|
|
|
|
const onMenuItem = (key: string) => {
|
2024-04-20 16:54:12 +08:00
|
|
|
|
const { findLinearArray } = useRoutingMethod();
|
|
|
|
|
|
const find = findLinearArray(key);
|
2024-04-21 00:26:49 +08:00
|
|
|
|
// 路由存在则存入并跳转,不存在则跳404
|
2024-04-18 00:24:07 +08:00
|
|
|
|
if (find) {
|
|
|
|
|
|
router.push(find.path);
|
|
|
|
|
|
} else {
|
|
|
|
|
|
router.push("/404");
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
2024-04-13 22:09:14 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
2024-05-06 00:20:09 +08:00
|
|
|
|
<style lang="scss" scoped></style>
|