4466ba436b
## Description This PR ensures that the default prettier config is used for examples and templates. This config is compatible with `prettier@3` as well (upgrading prettier is bigger change that can be a future PR). ## Changes - Updated `.prettierrc.json` in root with `"trailingComma": "es5"` (will be needed upgrading to prettier@3) - Added `examples/.prettierrc.json` with default config (this will change every example) - Added `packages/create-next-app/templates/.prettierrc.json` with default config (this will change every template) ## Related - Fixes #54402 - Closes #54409
45 lines
1 KiB
JavaScript
45 lines
1 KiB
JavaScript
import fs from "fs";
|
|
import matter from "gray-matter";
|
|
import Link from "next/link";
|
|
import path from "path";
|
|
import Layout from "../components/Layout";
|
|
import { postFilePaths, POSTS_PATH } from "../utils/mdxUtils";
|
|
|
|
export default function Index({ posts }) {
|
|
return (
|
|
<Layout>
|
|
<h1>Home Page</h1>
|
|
<p>
|
|
Click the link below to navigate to a page generated by{" "}
|
|
<code>next-mdx-remote</code>.
|
|
</p>
|
|
<ul>
|
|
{posts.map((post) => (
|
|
<li key={post.filePath}>
|
|
<Link
|
|
as={`/posts/${post.filePath.replace(/\.mdx?$/, "")}`}
|
|
href={`/posts/[slug]`}
|
|
>
|
|
{post.data.title}
|
|
</Link>
|
|
</li>
|
|
))}
|
|
</ul>
|
|
</Layout>
|
|
);
|
|
}
|
|
|
|
export function getStaticProps() {
|
|
const posts = postFilePaths.map((filePath) => {
|
|
const source = fs.readFileSync(path.join(POSTS_PATH, filePath));
|
|
const { content, data } = matter(source);
|
|
|
|
return {
|
|
content,
|
|
data,
|
|
filePath,
|
|
};
|
|
});
|
|
|
|
return { props: { posts } };
|
|
}
|