1
mirror of https://github.com/jakejarvis/jarv.is.git synced 2025-04-26 08:25:21 -04:00
jarv.is/app/sitemap.ts
2025-04-15 12:27:09 -04:00

52 lines
1.4 KiB
TypeScript

import { env } from "../lib/env";
import path from "path";
import glob from "fast-glob";
import { getFrontMatter } from "../lib/helpers/posts";
import type { MetadataRoute } from "next";
const sitemap = async (): Promise<MetadataRoute.Sitemap> => {
// start with manual routes
const routes: MetadataRoute.Sitemap = [
{
// homepage
url: `${env.NEXT_PUBLIC_BASE_URL}`,
priority: 1.0,
lastModified: new Date(),
},
];
// add each directory in the app folder as a route (excluding special routes)
(
await glob("**/page.{tsx,mdx}", {
cwd: path.join(process.cwd(), "app"),
ignore: [
// homepage is already included manually above
"./page.tsx",
// don't include dynamic routes
"**/\\[*\\]/page.tsx",
],
})
).forEach((route) => {
routes.push({
// remove matching page.(tsx|mdx) file and make all URLs absolute
url: `${env.NEXT_PUBLIC_BASE_URL}/${route.replace(/\/page\.(tsx|mdx)$/, "")}`,
});
});
const frontmatter = await getFrontMatter();
frontmatter.forEach((post) => {
routes.push({
url: post.permalink,
// pull lastModified from front matter date
lastModified: new Date(post.date),
});
});
// sort alphabetically by URL, sometimes fast-glob returns results in a different order
routes.sort((a, b) => (a.url < b.url ? -1 : 1));
return [...routes];
};
export default sitemap;