Implement breadcrum navigation
This commit is contained in:
30
src/components/Breadcrumbs.astro
Normal file
30
src/components/Breadcrumbs.astro
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
---
|
||||||
|
type BreadcrumbItem = {
|
||||||
|
label: string;
|
||||||
|
href?: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
const { items = [] } = Astro.props as { items?: BreadcrumbItem[] };
|
||||||
|
---
|
||||||
|
|
||||||
|
{
|
||||||
|
items.length > 0 && (
|
||||||
|
<nav aria-label="Breadcrumb">
|
||||||
|
<ol>
|
||||||
|
{items.map((item, index) => {
|
||||||
|
const isCurrent = index === items.length - 1;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<li>
|
||||||
|
{item.href && !isCurrent ? (
|
||||||
|
<a href={item.href}>{item.label}</a>
|
||||||
|
) : (
|
||||||
|
<span aria-current={isCurrent ? "page" : undefined}>{item.label}</span>
|
||||||
|
)}
|
||||||
|
</li>
|
||||||
|
);
|
||||||
|
})}
|
||||||
|
</ol>
|
||||||
|
</nav>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,5 +1,12 @@
|
|||||||
---
|
---
|
||||||
const { title } = Astro.props;
|
import "../styles/global.css";
|
||||||
|
import Breadcrumbs from "../components/Breadcrumbs.astro";
|
||||||
|
import type { BreadcrumbItem } from "../lib/types/breadcrum";
|
||||||
|
|
||||||
|
const { title, breadcrumbs = [] } = Astro.props as {
|
||||||
|
title: string;
|
||||||
|
breadcrumbs?: BreadcrumbItem[];
|
||||||
|
};
|
||||||
---
|
---
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
@@ -10,6 +17,9 @@ const { title } = Astro.props;
|
|||||||
<title>Radium Help - {title}</title>
|
<title>Radium Help - {title}</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<slot />
|
<main class="page-shell">
|
||||||
|
<Breadcrumbs items={breadcrumbs} />
|
||||||
|
<slot />
|
||||||
|
</main>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
4
src/lib/types/breadcrum.ts
Normal file
4
src/lib/types/breadcrum.ts
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
export type BreadcrumbItem = {
|
||||||
|
label: string;
|
||||||
|
href?: string;
|
||||||
|
};
|
||||||
@@ -30,9 +30,24 @@ if (!collection || !isSiteCollection(collection)) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
const { entry } = Astro.props;
|
const { entry } = Astro.props;
|
||||||
|
const entries = await getCollection(collection);
|
||||||
|
const collectionIndex = entries.find((item) => item.id === "index");
|
||||||
|
const entryUrl = entry.id === "index" ? `/${collection}` : `/${collection}/${entry.id}`;
|
||||||
|
const breadcrumbs = [
|
||||||
|
{ label: "Radie Help", href: "/" },
|
||||||
|
{
|
||||||
|
label: collectionIndex?.data.title ?? collection,
|
||||||
|
href: entry.id === "index" ? undefined : `/${collection}`,
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
|
if (entry.id !== "index") {
|
||||||
|
breadcrumbs.push({ label: entry.data.title, href: entryUrl });
|
||||||
|
}
|
||||||
|
|
||||||
const { Content } = await render(entry);
|
const { Content } = await render(entry);
|
||||||
---
|
---
|
||||||
|
|
||||||
<Layout title={entry.data.title}>
|
<Layout title={entry.data.title} breadcrumbs={breadcrumbs}>
|
||||||
<Content />
|
<Content />
|
||||||
</Layout>
|
</Layout>
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
---
|
---
|
||||||
import Layout from "../layouts/Layout.astro";
|
import Layout from "../layouts/Layout.astro";
|
||||||
import TOC from "../components/TOC.astro";
|
import TOC from "../components/TOC.astro";
|
||||||
|
|
||||||
|
const breadcrumbs = [{ label: "Radie Help" }];
|
||||||
---
|
---
|
||||||
|
|
||||||
<Layout title="Home">
|
<Layout title="Home" breadcrumbs={breadcrumbs}>
|
||||||
<TOC />
|
<TOC />
|
||||||
</Layout>
|
</Layout>
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
@import "tailwindcss";
|
/* @import "tailwindcss"; */
|
||||||
Reference in New Issue
Block a user