mirror of
https://github.com/ArthurDanjou/ui.git
synced 2026-01-14 20:19:34 +01:00
41 lines
1.3 KiB
TypeScript
41 lines
1.3 KiB
TypeScript
import type { ContentNavigationItem } from '@nuxt/content'
|
|
|
|
function processNavigationItem(item: ContentNavigationItem, parent?: ContentNavigationItem): any {
|
|
if (item.shadow) {
|
|
return item.children?.flatMap(child => processNavigationItem(child, item))
|
|
}
|
|
|
|
return {
|
|
...item,
|
|
title: parent?.title && parent.title !== 'Pro' ? parent.title : item.title,
|
|
badge: parent?.badge || item.badge,
|
|
class: [item.framework && `${item.framework}-only`, item.module && `${item.module}-only`].filter(Boolean),
|
|
children: item.children?.length ? item.children?.flatMap(child => processNavigationItem(child)) : undefined
|
|
}
|
|
}
|
|
|
|
export const useContentNavigation = (navigation: Ref<ContentNavigationItem[] | undefined>) => {
|
|
const { framework, module } = useSharedData()
|
|
|
|
const mappedNavigation = computed(() => navigation.value?.map(item => processNavigationItem(item)))
|
|
const filteredNavigation = computed(() => mappedNavigation.value?.map((item) => {
|
|
return {
|
|
...item,
|
|
children: item.children?.filter((child: any) => {
|
|
if (child.framework && child.framework !== framework.value) {
|
|
return false
|
|
}
|
|
if (child.module && child.module !== module.value) {
|
|
return false
|
|
}
|
|
return true
|
|
})
|
|
}
|
|
}))
|
|
|
|
return {
|
|
mappedNavigation,
|
|
filteredNavigation
|
|
}
|
|
}
|