MDX
TL;DR
In order to use MDX files with Content Collections, we have to transform the collected content. We have a special package to simplify this process. Let's see how we can use it.
First we have to install the package @content-collections/mdx
package.
pnpm add @content-collections/mdx
After installing the package, we can use the compileMDX
function to compile the content of our document.
import { defineCollection, defineConfig } from "@content-collections/core";
import { compileMDX } from "@content-collections/mdx";
const posts = defineCollection({
name: "posts",
directory: "content",
include: "*.mdx",
schema: (z) => ({
title: z.string()
}),
transform: async (document, context) => {
const body = await compileMDX(context, document);
return {
...document,
body,
};
},
});
export default defineConfig({
collections: [posts],
});
Now we can use the MDXContent
component to render the compiled MDX.
import { allPosts } from "content-collections";
import { MDXContent } from "@content-collections/mdx/react";
export default function App() {
return (
<main>
<h1>Posts</h1>
<ul>
{allPosts.map((post) => (
<li key={post._meta.path}>
<h2>{post.title}</h2>
<MDXContent code={post.body} />
</li>
))}
</ul>
</main>
);
}
And that's it! Now we can use MDX files with Content Collections.