Remix has built-in support for setting up meta tags on a per-route basis which
you can read about
in the Remix Metadata docs.
The Epic Stack also has built-in support for /robots.txt and /sitemap.xml
via resource routes
using @nasa-gcn/remix-seo. By
default, all routes are included in the sitemap.xml file, but you can
configure which routes are included using the handle export in the route. Only
public-facing pages should be included in the sitemap.xml file.
Here are two quick examples of how to customize the sitemap on a per-route basis
from the @nasa-gcn/remix-seo docs:
// routes/blog/$blogslug.tsx
export const handle: SEOHandle = {
	getSitemapEntries: async request => {
		const blogs = await db.blog.findMany()
		return blogs.map(blog => {
			return { route: `/blog/${blog.slug}`, priority: 0.7 }
		})
	},
}
// in your routes/url-that-doesnt-need-sitemap
import { SEOHandle } from '@nasa-gcn/remix-seo'
export let loader: LoaderFunction = ({ request }) => {
	/**/
}
export const handle: SEOHandle = {
	getSitemapEntries: () => null,
}
Edit this page on