mirror of
https://github.com/netbirdio/docs.git
synced 2026-04-16 15:36:36 +00:00
139 lines
6.3 KiB
JavaScript
139 lines
6.3 KiB
JavaScript
import { useRouter } from 'next/router'
|
|
import clsx from 'clsx'
|
|
import {ActivePageMarker, NavLink, TopLevelNavItem, VisibleSectionHighlight} from "@/components/NavigationAPI";
|
|
import {AnimatePresence, motion} from "framer-motion";
|
|
|
|
export const docsNavigation = [
|
|
{
|
|
title: 'About NetBird',
|
|
links: [
|
|
{ title: 'Why Wireguard with NetBird?', href: '/docs/about-netbird/why-wireguard-with-netbird' },
|
|
{ title: 'How Netbird Works', href: '/docs/about-netbird/how-netbird-works' },
|
|
{ title: 'NetBird vs. Traditional VPN', href: '/docs/about-netbird/netbird-vs-traditional-vpn' },
|
|
{ title: 'Other', href: '/docs/about-netbird/other' },
|
|
{ title: 'FAQ', href: '/docs/about-netbird/faq' },
|
|
],
|
|
},
|
|
{
|
|
title: 'How-to',
|
|
links: [
|
|
{ title: 'Getting Started', href: '/docs/how-to/getting-started' },
|
|
{ title: 'Peers', href: '/docs/how-to/peers' },
|
|
{ title: 'Setup Keys', href: '/docs/how-to/setup-keys' },
|
|
{ title: 'Access Control', href: '/docs/how-to/access-control' },
|
|
{ title: 'Network Routes', href: '/docs/how-to/network-routes' },
|
|
{ title: 'DNS', href: '/docs/how-to/dns' },
|
|
{ title: 'Users', href: '/docs/how-to/users' },
|
|
{ title: 'Activity', href: '/docs/how-to/activity' },
|
|
{ title: 'Settings', href: '/docs/how-to/settings' },
|
|
{ title: 'Examples', href: '/docs/how-to/examples' },
|
|
{ title: 'CLI', href: '/docs/how-to/cli' },
|
|
],
|
|
},
|
|
{
|
|
title: 'Self-Hosted',
|
|
links: [
|
|
{ title: 'Installation Guide', href: '/docs/selfhosted/selfhosted-guide' },
|
|
{ title: 'Identity Providers', href: '/docs/selfhosted/identity-providers' },
|
|
],
|
|
},
|
|
|
|
]
|
|
|
|
export function NavigationDocs(props) {
|
|
return (
|
|
<nav {...props}>
|
|
<ul role="list">
|
|
<TopLevelNavItem href="https://netbird.io/">Home</TopLevelNavItem>
|
|
<TopLevelNavItem href="/docs/introductions">Docs</TopLevelNavItem>
|
|
<TopLevelNavItem href="/ipa/introductions">API</TopLevelNavItem>
|
|
<TopLevelNavItem href="https://netbird.io/blog/">Blog</TopLevelNavItem>
|
|
<TopLevelNavItem href="https://github.com/netbirdio/netbird">Github</TopLevelNavItem>
|
|
<TopLevelNavItem href="https://join.slack.com/t/netbirdio/shared_invite/zt-vrahf41g-ik1v7fV8du6t0RwxSrJ96A">Support</TopLevelNavItem>
|
|
{docsNavigation.map((group, groupIndex) => (
|
|
<NavigationGroup
|
|
key={group.title}
|
|
group={group}
|
|
className={groupIndex === 0 && 'md:mt-0'}
|
|
/>
|
|
))}
|
|
</ul>
|
|
</nav>
|
|
)
|
|
}
|
|
|
|
function NavigationGroup({ group, className }) {
|
|
// If this is the mobile navigation then we always render the initial
|
|
// state, so that the state does not change during the close animation.
|
|
// The state will still update when we re-open (re-render) the navigation.
|
|
let router = useRouter()
|
|
|
|
let isActiveGroup =
|
|
group.links.findIndex((link) => link.href === router.pathname) !== -1
|
|
|
|
|
|
return (
|
|
<li className={clsx('relative mt-6', className)}>
|
|
<motion.h2
|
|
layout="position"
|
|
className="text-xs font-semibold text-zinc-900 dark:text-white"
|
|
>
|
|
{group.title}
|
|
</motion.h2>
|
|
<div className="relative mt-3 pl-2">
|
|
<AnimatePresence >
|
|
{isActiveGroup && (
|
|
<VisibleSectionHighlight group={group} pathname={router.pathname} />
|
|
)}
|
|
</AnimatePresence>
|
|
<motion.div
|
|
layout
|
|
className="absolute inset-y-0 left-2 w-px bg-zinc-900/10 dark:bg-white/5"
|
|
/>
|
|
<AnimatePresence initial={false}>
|
|
{isActiveGroup && (
|
|
<ActivePageMarker group={group} pathname={router.pathname} />
|
|
)}
|
|
</AnimatePresence>
|
|
<ul role="list" className="border-l border-transparent">
|
|
{group.links.map((link) => (
|
|
<motion.li key={link.href} layout="position" className="relative">
|
|
<NavLink href={link.href} active={link.href === router.pathname}>
|
|
{link.title}
|
|
</NavLink>
|
|
{/*<AnimatePresence mode="popLayout" initial={false}>*/}
|
|
{/* {link.href === router.pathname && sections.length > 0 && (*/}
|
|
{/* <motion.ul*/}
|
|
{/* role="list"*/}
|
|
{/* initial={{ opacity: 0 }}*/}
|
|
{/* animate={{*/}
|
|
{/* opacity: 1,*/}
|
|
{/* transition: { delay: 0.1 },*/}
|
|
{/* }}*/}
|
|
{/* exit={{*/}
|
|
{/* opacity: 0,*/}
|
|
{/* transition: { duration: 0.15 },*/}
|
|
{/* }}*/}
|
|
{/* >*/}
|
|
{/* {sections.map((section) => (*/}
|
|
{/* <li key={section.id}>*/}
|
|
{/* <NavLink*/}
|
|
{/* href={`${link.href}#${section.id}`}*/}
|
|
{/* tag={section.tag}*/}
|
|
{/* isAnchorLink*/}
|
|
{/* >*/}
|
|
{/* {section.title}*/}
|
|
{/* </NavLink>*/}
|
|
{/* </li>*/}
|
|
{/* ))}*/}
|
|
{/* </motion.ul>*/}
|
|
{/* )}*/}
|
|
{/*</AnimatePresence>*/}
|
|
</motion.li>
|
|
))}
|
|
</ul>
|
|
</div>
|
|
</li>
|
|
)
|
|
}
|