The Next.js generator scaffolds components for server-side rendered (SSR) applications using Next.js.
The easiest way to get started is to install the API Platform distribution. It contains a Next.js skeleton generated with Create Next App, a development Docker container to serve the webapp, and all the API Platform components you may need, including an API server supporting Hydra and OpenAPI.
If you use API Platform, jump to the next section!
Alternatively, create a Next.js application by executing:
# using pnpm (recommended)
pnpm create next-app --typescript
# or using npm
npm init next-app --typescript
# or using yarn
yarn create next-app --typescript
Install the required dependencies:
# using pnpm
pnpm install isomorphic-unfetch formik react-query
# or using npm
npm install isomorphic-unfetch formik react-query
# or using yarn
yarn add isomorphic-unfetch formik react-query
The generated HTML will contain Tailwind CSS classes. Optionnaly, follow the Tailwind installation guide for NextJS projects (Tailwind is preinstalled in the API Platform distribution)
If you use the API Platform distribution, generating all the code you need for a given resource is as simple as running the following command:
docker compose exec pwa \
pnpm create @api-platform/client --resource book -g next
Omit the resource flag to generate files for all resource types exposed by the API.
If you don’t use the standalone installation, run the following command instead:
# using pnpm
pnpm create @api-platform/client https://demo.api-platform.com . --generator next --resource book
# or using npm
npm init @api-platform/client https://demo.api-platform.com . -- --generator next --resource book
# or using yarn
yarn create @api-platform/client https://demo.api-platform.com . --generator next --resource book
Replace the URL by the entrypoint of your Hydra-enabled API.
You can also use an OpenAPI documentation with -f openapi3
.
The code has been generated, and is ready to be executed!
Add the layout to the app:
import type { AppProps } from "next/app";
import type { DehydratedState } from "react-query";
import Layout from "../components/common/Layout";
const App = ({ Component, pageProps }: AppProps<{dehydratedState: DehydratedState}>) => (
<Layout dehydratedState={pageProps.dehydratedState}>
<Component {...pageProps} />
</Layout>
);
export default App;
You can launch the server with
# using pnpm
pnpm dev
# or using npm
npm run dev
# or using yarn
yarn dev
Go to http://localhost:3000/books/
to start using your app.
Made with love by
Les-Tilleuls.coop can help you design and develop your APIs and web projects, and train your teams in API Platform, Symfony, Next.js, Kubernetes and a wide range of other technologies.
Learn more