UnisKB/ui/src/layout/components/sidebar/SidebarItem.vue

51 lines
1.2 KiB
Vue
Raw Normal View History

2023-10-16 10:58:51 +00:00
<template>
2023-10-18 11:06:22 +00:00
<div v-if="!menu.meta || !menu.meta.hidden" class="sidebar-item">
2023-10-16 10:58:51 +00:00
<el-menu-item ref="subMenu" :index="menu.path" popper-class="sidebar-popper">
<template #title>
2023-12-01 03:36:04 +00:00
<AppIcon v-if="menu.meta && menu.meta.icon" :iconName="menuIcon" class="sidebar-icon" />
2023-10-16 10:58:51 +00:00
<span v-if="menu.meta && menu.meta.title">{{ menu.meta.title }}</span>
</template>
</el-menu-item>
</div>
</template>
<script setup lang="ts">
2023-12-01 03:36:04 +00:00
import { computed } from 'vue'
2023-10-18 11:06:22 +00:00
import { type RouteRecordRaw } from 'vue-router'
2023-10-16 10:58:51 +00:00
2023-12-01 03:36:04 +00:00
const props = defineProps<{
2023-10-16 10:58:51 +00:00
menu: RouteRecordRaw
2023-12-01 03:36:04 +00:00
activeMenu: any
2023-10-16 10:58:51 +00:00
}>()
2023-12-01 03:36:04 +00:00
const menuIcon = computed(() => {
if (props.activeMenu === props.menu.path) {
return props.menu.meta?.iconActive || props.menu?.meta?.icon
} else {
return props.menu?.meta?.icon
}
})
2023-10-16 10:58:51 +00:00
</script>
2023-10-18 11:06:22 +00:00
<style scoped lang="scss">
.sidebar-item {
2023-11-02 10:25:09 +00:00
.sidebar-icon {
font-size: 20px;
margin-top: -2px;
}
2023-10-18 11:06:22 +00:00
.el-menu-item {
2023-11-02 10:25:09 +00:00
padding: 13px 12px 13px 16px !important;
2023-10-18 11:06:22 +00:00
font-weight: 500;
2023-11-02 10:25:09 +00:00
border-radius: 4px;
2023-11-07 07:30:15 +00:00
&:hover {
background: none;
color: var(--el-menu-active-color);
}
2023-10-18 11:06:22 +00:00
}
.el-menu-item.is-active {
color: var(--el-menu-active-color);
2023-11-06 11:06:02 +00:00
background: var(--el-color-primary-light-9);
2023-10-18 11:06:22 +00:00
}
}
</style>