maxkb/ui/src/layout/components/sidebar/SidebarItem.vue
wangdan-fit2cloud ab46d7ab61 feat: layout
2025-04-28 18:15:41 +08:00

108 lines
2.6 KiB
Vue

<template>
<div v-if="(!menu.meta || !menu.meta.hidden) && showMenu()" class="sidebar-item">
<el-sub-menu
v-if="menu?.children && menu?.children.length > 0"
:index="menu.path"
popper-class="sidebar-container-popper"
>
<template #title>
<el-icon>
<AppIcon v-if="menu.meta && menu.meta.icon" :iconName="menuIcon" class="sidebar-icon" />
</el-icon>
<span>{{ $t(menu.meta?.title as string) }}</span>
</template>
<sidebar-item
v-hasPermission="child.meta?.permission"
v-for="(child, index) in menu?.children"
:key="index"
:menu="child"
:activeMenu="activeMenu"
>
</sidebar-item>
</el-sub-menu>
<el-menu-item
v-else
ref="subMenu"
:index="menu.path"
popper-class="sidebar-popper"
@click="clickHandle(menu)"
>
<template #title>
<AppIcon v-if="menu.meta && menu.meta.icon" :iconName="menuIcon" class="sidebar-icon" />
<span v-if="menu.meta && menu.meta.title">{{ $t(menu.meta?.title as string) }}</span>
</template>
</el-menu-item>
</div>
</template>
<script setup lang="ts">
import { computed } from 'vue'
import { useRouter, useRoute, type RouteRecordRaw } from 'vue-router'
import { isWorkFlow } from '@/utils/application'
const props = defineProps<{
menu: RouteRecordRaw
activeMenu: any
}>()
const router = useRouter()
const route = useRoute()
const {
params: { id, type }
} = route as any
function showMenu() {
if (isWorkFlow(type)) {
return props.menu.name !== 'AppHitTest'
} else {
return true
}
}
function clickHandle(item?: any) {
if (isWorkFlow(type) && item?.name === 'AppSetting') {
router.push({ path: `/application/${id}/workflow` })
}
}
const menuIcon = computed(() => {
if (props.activeMenu === props.menu.path) {
return props.menu.meta?.iconActive || props.menu?.meta?.icon
} else {
return props.menu?.meta?.icon
}
})
</script>
<style scoped lang="scss">
.sidebar-item {
.sidebar-icon {
font-size: 20px;
margin-top: -2px;
}
.el-menu-item {
padding: 13px 12px 13px 16px !important;
font-weight: 500;
border-radius: 4px;
&:hover {
background: none;
color: var(--el-color-primary);
}
}
:deep(.el-sub-menu__title) {
padding: 13px 12px 13px 16px !important;
&:hover {
background: none;
color: var(--el-color-primary);
}
}
.el-sub-menu {
.el-menu-item {
padding-left: 43px !important;
}
}
.el-menu-item.is-active {
color: var(--el-color-primary);
background: var(--el-color-primary-light-9);
}
}
</style>