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.3 KiB
TypeScript
45 lines
1.3 KiB
TypeScript
import Head from "next/head";
|
|
import { GetStaticProps } from "next";
|
|
import Container from "../components/container";
|
|
import MoreStories from "../components/more-stories";
|
|
import HeroPost from "../components/hero-post";
|
|
import Intro from "../components/intro";
|
|
import Layout from "../components/layout";
|
|
import { getAllPostsForHome } from "../lib/api";
|
|
import { CMS_NAME } from "../lib/constants";
|
|
|
|
export default function Index({ allPosts: { edges }, preview }) {
|
|
const heroPost = edges[0]?.node;
|
|
const morePosts = edges.slice(1);
|
|
|
|
return (
|
|
<Layout preview={preview}>
|
|
<Head>
|
|
<title>{`Next.js Blog Example with ${CMS_NAME}`}</title>
|
|
</Head>
|
|
<Container>
|
|
<Intro />
|
|
{heroPost && (
|
|
<HeroPost
|
|
title={heroPost.title}
|
|
coverImage={heroPost.featuredImage}
|
|
date={heroPost.date}
|
|
author={heroPost.author}
|
|
slug={heroPost.slug}
|
|
excerpt={heroPost.excerpt}
|
|
/>
|
|
)}
|
|
{morePosts.length > 0 && <MoreStories posts={morePosts} />}
|
|
</Container>
|
|
</Layout>
|
|
);
|
|
}
|
|
|
|
export const getStaticProps: GetStaticProps = async ({ preview = false }) => {
|
|
const allPosts = await getAllPostsForHome(preview);
|
|
|
|
return {
|
|
props: { allPosts, preview },
|
|
revalidate: 10,
|
|
};
|
|
};
|