NavigationLinks
This component is useful for lists of links. RFUI uses it for the "Components" section on the left side of this page and for the "On this page" section on the right side of this page.
Source codeimport { NavigationLinks } from "rfui-package";
Basic
<NavigationLinks
linkItems={[{
name: "One",
href: "/one",
}, {
name: "Two",
href: "/two",
}]}
/>
With header
<NavigationLinks
linkItems={[{
name: "Header",
isHeader: true,
}, {
name: "One",
href: "/one",
}, {
name: "Two",
href: "/two",
}]}
/>
Multilevel
To go more levels deep, just keep using
children
.<NavigationLinks
linkItems={[{
name: "Components",
isHeader: true,
}, {
name: "Atoms",
children: [{
name: "Badge",
href: "/components/data-display/badge",
}, {
name: "Blockquote",
href: "/components/typography/blockquote",
}],
}, {
name: "Molecules",
children: [{
name: "Alert",
href: "/components/feedback/alert",
}, {
name: "Card",
href: "/components/data-display/card",
}],
}]}
/>
In page
<NavigationLinks
linkItems={[{
name: "One",
href: "#one",
inPage: true,
}, {
name: "Two",
href: "#two",
inPage: true,
}]}
/>
Sticky
Often times you'll want this component to be sticky, such that it stays in place when you scroll down. To accomplish this you'll want to add something like:
className="sticky top-6 max-h-[90vh] overflow-y-auto"
Note: the example below isn't actually sticky.
<NavigationLinks
className="sticky top-6 max-h-[90vh] overflow-y-auto"
linkItems={[{
name: "One",
href: "/one",
}, {
name: "Two",
href: "/two",
}]}
/>
Props
Prop | Required | Default | Type and notes |
---|---|---|---|
linkItems | ✔ | - |
The type for LinkItemType is below. Note that it is defined recursively.
|
...rest | - | - |
See the docs for rest parameters. For NavigationLinks , you could pass anything you normally would pass to <nav> because the return value looks something like this:
|