44 lines
1.6 KiB
Vue
Raw Normal View History

2023-03-04 09:16:33 +08:00
<template>
<template v-for="subItem in menuList" :key="subItem.path">
<el-sub-menu v-if="subItem.children && subItem.children.length > 0" :index="subItem.path">
<template #title>
2023-03-27 14:17:30 +08:00
<img :src="activeMenu == subItem.path ? `${subItem.meta.icon}` : `${'un' + subItem.meta.icon}`" />
<span style="margin-left: 8px">{{ subItem.meta.title }}</span>
2023-03-04 09:16:33 +08:00
</template>
<SubMenu :menuList="subItem.children" />
</el-sub-menu>
<el-menu-item v-else :index="subItem.path" @click="handleClickMenu(subItem)">
2023-03-24 19:36:11 +08:00
<!-- <img :src="`${subItem.meta.icon}`" /> -->
<img :src="getImageUrl(activeMenu == subItem.path ? subItem.meta.icon : 'un' + subItem.meta.icon)" />
2023-03-04 09:16:33 +08:00
<template #title>
2023-03-27 14:17:30 +08:00
<span style="margin-left: 8px">{{ subItem.meta.title }}</span>
2023-03-04 09:16:33 +08:00
</template>
</el-menu-item>
</template>
</template>
<script setup lang="ts">
2023-03-27 14:17:30 +08:00
import { ref, computed } from "vue";
import { useRouter, useRoute } from "vue-router";
const route = useRoute();
const activeMenu = computed(() => (route.meta.activeMenu ? route.meta.activeMenu : route.path));
2023-03-04 09:16:33 +08:00
function getImageUrl(name: string) {
return new URL(`../../../assets/images/leftTab/${name}`, import.meta.url).href;
}
2023-03-04 09:16:33 +08:00
defineProps<{ menuList: Menu.MenuOptions[] }>();
const router = useRouter();
// const imgUrl = "/src/assets/images/leftTab/";
2023-03-24 19:36:11 +08:00
const imgUrl = "/src/assets/images/leftTab/";
const baseImgURl = import.meta.env.VITE_BASE_IMAGE_URL;
// const imgUrl = "@/assets/images/leftTab/";
2023-03-04 09:16:33 +08:00
const handleClickMenu = (subItem: Menu.MenuOptions) => {
if (subItem.meta.isLink) return window.open(subItem.meta.isLink, "_blank");
router.push(subItem.path);
};
</script>