83 lines
2.5 KiB
Vue
83 lines
2.5 KiB
Vue
<template>
|
|
<template v-if="!item.hidden">
|
|
<template v-if="!item.alwaysShow && hasOneShowingChild(item.children, item)">
|
|
<app-link v-if="onlyOneChild.meta" :to="resolvePath(onlyOneChild.path)">
|
|
<!-- <el-menu-item :index="resolvePath(onlyOneChild.path)">-->
|
|
<!-- <el-icon :size="20">-->
|
|
<!-- <component :is="onlyOneChild?.meta.icon"></component>-->
|
|
<!-- </el-icon>-->
|
|
<!-- <template #title>{{ onlyOneChild.meta && onlyOneChild.meta.title }}</template>-->
|
|
<!-- </el-menu-item>-->
|
|
</app-link>
|
|
</template>
|
|
<!-- <el-sub-menu :index="resolvePath(item.path)" v-else popper-append-to-body>-->
|
|
<!-- <template #title>-->
|
|
<!-- <el-icon :size="20"> <component :is="item.meta?.icon"></component></el-icon>-->
|
|
<!-- <span>{{ item.meta && item.meta.title }}</span>-->
|
|
<!-- </template>-->
|
|
<!-- <sub-item-->
|
|
<!-- v-for="child in item.children"-->
|
|
<!-- :key="child.path"-->
|
|
<!-- :item="child"-->
|
|
<!-- :base-path="resolvePath(child.path)"-->
|
|
<!-- />-->
|
|
<!-- </el-sub-menu>-->
|
|
</template>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { isExternal } from '@/utils/validate.js'
|
|
import AppLink from './Link.vue'
|
|
import path from 'path-browserify'
|
|
import { ref, computed } from 'vue'
|
|
const props = defineProps({
|
|
item: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
basePath: {
|
|
type: String,
|
|
default: '',
|
|
},
|
|
})
|
|
|
|
const onlyOneChild = ref(null)
|
|
const hasOneShowingChild = (children = [], parent) => {
|
|
|
|
const showingChildren = children.filter((item) => {
|
|
// 过滤掉需要隐藏的菜单
|
|
if (item.hidden) {
|
|
return false
|
|
} else {
|
|
// 临时设置(如果只有一个显示子项,则将使用)
|
|
onlyOneChild.value = item
|
|
return true
|
|
}
|
|
})
|
|
// 当只有一个子路由器时,默认情况下会显示该子路由器
|
|
if (showingChildren.length === 1) {
|
|
return true
|
|
}
|
|
// 如果没有要显示的子路由器,则显示父路由器
|
|
if (showingChildren.length === 0) {
|
|
onlyOneChild.value = { ...parent, path: '', noShowingChildren: true }
|
|
// onlyOneChild.value = { ...parent, noShowingChildren: true }
|
|
return true
|
|
}
|
|
|
|
return false
|
|
}
|
|
|
|
const resolvePath = (routePath) => {
|
|
if (isExternal(routePath)) {
|
|
return routePath
|
|
}
|
|
if (isExternal(props.basePath)) {
|
|
return props.basePath
|
|
}
|
|
let path2 = path.resolve(props.basePath, routePath)
|
|
console.log('======path======',props.basePath)
|
|
return path2
|
|
}
|
|
</script>
|