91 lines
2.4 KiB
Vue
Raw Normal View History

2023-11-09 09:26:37 +08:00
<template>
<template v-if="!route.meta?.hidden">
2023-11-09 17:48:23 +08:00
<!-- {{ routePath }} -->
2023-11-09 09:26:37 +08:00
<app-link v-if="!hasShowChild" :to="`${routePath}?${queryStr}`">
<el-menu-item :index="routePath">
<icon
class="menu-item-icon"
:size="16"
v-if="routeMeta?.icon"
:name="routeMeta?.icon"
/>
<template #title>
<span>{{ routeMeta?.title }}</span>
</template>
</el-menu-item>
</app-link>
<el-sub-menu v-else :index="routePath" :popper-class="popperClass">
<template #title>
<icon
class="menu-item-icon"
:size="16"
v-if="routeMeta?.icon"
:name="routeMeta?.icon"
/>
<span>{{ routeMeta?.title }}</span>
</template>
<menu-item
v-for="item in route?.children"
:key="resolvePath(item.path)"
:route="item"
:route-path="resolvePath(item.path)"
:popper-class="popperClass"
/>
</el-sub-menu>
</template>
</template>
<script lang="ts" setup>
import { getNormalPath, objectToQuery } from '@/utils/util'
import { isExternal } from '@/utils/validate'
import type { RouteRecordRaw } from 'vue-router'
interface Props {
route: RouteRecordRaw
routePath: string
popperClass: string
}
const props = defineProps<Props>()
const hasShowChild = computed(() => {
const children: RouteRecordRaw[] = props.route.children ?? []
return !!children.filter((item) => !item.meta?.hidden).length
})
const routeMeta = computed(() => {
return props.route.meta
})
const resolvePath = (path: string) => {
if (isExternal(path)) {
return path
}
const newPath = getNormalPath(`${props.routePath}/${path}`)
return newPath
}
const queryStr = computed<string>(() => {
const query = props.route.meta?.query as string
try {
const queryObj = JSON.parse(query)
return objectToQuery(queryObj)
} catch (error) {
// console.log(error)
return query
}
})
</script>
<style lang="scss" scoped>
.el-menu-item,
.el-sub-menu__title {
.menu-item-icon {
margin-right: 8px;
width: var(--el-menu-icon-width);
text-align: center;
vertical-align: middle;
}
}
</style>