Next.js Quick start guide
Estimated duration: 10 minutes
This guide shows you how to connect Prepr to a Next.js project to get data from Prepr CMS. You'll learn how to make a simple blog with Next.js and Prepr CMS. By the end of this guide, you'll have a working app that looks like the image below.
If you want to skip ahead, try out the zero installation demo on Stackblitz (opens in a new tab) or clone the repository on GitHub (opens in a new tab) to run the demo locally. These resources and the steps below are based on the latest version of Next.js including the App router.
You can also watch the video for step-by-step instructions that are detailed in the guide below.
This video was created using AI avatars and voices to ensure a consistent look and feel. The use of AI matches our culture of using innovative technologies.
Prerequisites
You need to have the following setup before you connect your Next.js project to Prepr.
- A free Prepr account (opens in a new tab)
- An environment with demo data in Prepr
- The latest version of Node.js (opens in a new tab)
Create a simple Blog website with Next.js and Prepr CMS
Create a new Next.js project
The instructions below show you how to create an empty Next.js project for your blog app.
We're currently evaluating the latest versions of Next.js. In the meantime, we've chosen to base this guide on Next.js version 14. Don't hesitate to contact us (opens in a new tab) about using newer Next.js releases with this guide.
Install Next.js
You can skip this step if you have an existing Next.js project.
- Open a terminal and execute the following command to create a new Next.js project called
prepr-next
:
npx create-next-app@14 prepr-next
Mark the options as shown in the image below to create the same project structure used in this guide.
- Now that the project is successfully created, go to the
prepr-next
folder, the root directory of the project, and run the project with the following commands in the terminal:
cd prepr-next
npm run dev
-
You should now be able to view your app on your localhost, for example,
http://localhost:3000/
. -
Open your project with your preferred code editor.
-
Go to the
src/app
folder and replace the code in thepage.js
file with the following code to display your blog:
export default async function Home() {
return (
<div>
<h1>My blog site</h1>
</div>
);
}
- Go to the
layout.js
file in thesrc/app
folder and replace the default code with the simplified layout below.
export const metadata = {
title: 'My blog site',
description: 'A simple blog app project',
}
export default function RootLayout({ children }) {
return (
<html lang="en">
<body>{children}</body>
</html>
)
}
- Empty the
globals.css
file in theapp
folder to remove the existing formatting.
You should now see something like the image below on your localhost.
Install the Apollo client
The Apollo client is an integration tool that helps to retrieve CMS data with GraphQL. The instructions below show you how to install the Apollo client so that you can add GraphQL queries to request data from the Prepr API.
- Stop the server you started in the above step (
CTRL-C
) and execute the following command in the terminal:
npm install @apollo/client graphql
- In the
src
directory of the project, create a file calledapollo-client.js
. Copy the following code to this file to import and initialize the Apollo client:
import { ApolloClient, InMemoryCache } from "@apollo/client";
const client = new ApolloClient({
uri: `https://graphql.prepr.io/${process.env.PREPR_ACCESS_TOKEN}`,
cache: new InMemoryCache(),
});
export default client;
This client will be used to make API requests to endpoints provided by the Prepr CMS across your Next application.
- We recommend using environment variables to store sensitive information like access tokens. To add environment variables, create a
.env
file in the root directory of your project and add the access token like this:
PREPR_ACCESS_TOKEN=<YOUR-ACCESS-TOKEN>
- Replace the placeholder value
<YOUR-ACCESS-TOKEN>
with an access token from Prepr. Get an access token by logging into your Prepr account:
a. Go to Settings → Access tokens to view all the access tokens.
b. Click to open the GraphQL Production access token and use this value to only retrieve published content items on your site.
Use the GraphQL Production access token to request published content items for your live app and use the GraphQL Preview token to make a preview of unpublished content items for your content editors.
- Execute the following command to restart the server and to make sure that the Apollo client is installed correctly:
npm run dev
If your app runs without errors, then the setup above was done correctly. The next step is to fetch content from Prepr using the installed Apollo client.
Troubleshooting
Build error: Failed to compile
- Module not found: Can't resolve '@apollo-client'
Cause: The path to the src
folder has not been defined.
Solution: Make sure your jsconfig.json
has the following path defined:
{
"compilerOptions": {
"paths": {
"@/*": ["./src/*"]
}
}
}
Once done, go back to the beginning of this step and reinstall the Apollo client
Fetch multiple articles
Now that your Apollo client is installed and connected to Prepr, fetch the blog articles from Prepr.
Add a GraphQL query
-
Create a
queries
folder in thesrc
directory of your project and create a file namedget-articles.js
. -
Add the following query to this file to retrieve all articles:
import { gql } from "@apollo/client";
export const GetArticles = gql`
query {
Articles {
items {
_id
_slug
title
}
}
}
`
You can create and test GraphQL queries using the Apollo explorer (opens in a new tab) from Prepr. Open the API Explorer from the Article content item page in Prepr or the access token page.
If you’re using preloaded demo data in your Prepr CMS environment as mentioned above in the Prerequisites section, you should have a few published articles as shown in the below image. The query will retrieve the ID, Slug, and Title of each article.
In the next step, we'll fetch and process the query response.
Fetch data
Now that the query has been added, fetch the articles from Prepr and display them in the app.
- Open the
page.js
file in theapp
folder and replace the content with the code below to display the data retrieved from the query.
For different rendering and caching options, check out the Next.js docs (opens in a new tab) for more details.
import { GetArticles } from "@/queries/get-articles";
import client from "@/apollo-client";
import Link from "next/link";
export const revalidate = 0;
async function getData() {
const {data} = await client.query({
query: GetArticles,
});
return data.Articles.items;
}
export default async function Home() {
const articles = await getData();
return (
<div>
<h1>My blog site</h1>
<ul>
{articles.map((article) => (
//List the fetched articles
<li key={article._id}>
{article.title}
</li>
))}
</ul>
</div>
);
}
Now when you view the website on your localhost, you'll see something like the image below.
Fetch individual articles
Now that you have the list of articles, add links to them. When a visitor clicks an article link, your app should open a detailed article page automatically. The instructions below show you how to set up the routing from the main page to the detailed page and how to fetch the article details based on the slug of the article that was clicked.
Add links
First add links to the articles.
- Update the
page.js
file to include a link tag on each article title as shown in the code below.
import { GetArticles } from "@/queries/get-articles";
import client from "@/apollo-client";
import Link from "next/link";
export const revalidate = 0;
async function getData() {
const {data} = await client.query({
query: GetArticles,
});
return data.Articles.items;
}
export default async function Home() {
const articles = await getData();
return (
<div>
<h1>My blog site</h1>
<ul>
{articles.map((article) => (
//List the fetched articles
<li key={article._id}>
<Link href={article._slug}>{article.title}</Link>
</li>
))}
</ul>
</div>
);
}
Now when you view the app, each article has its own link. When you click the link, a new page opens with the slug in the URL, but a Page 404 error is displayed. Continue with the next step to fetch the article details and resolve this error.
Fetch article details
Add another query to fetch a specific article by its slug and make this page visible when a visitor clicks to view an article.
- Create a file called
get-article-by-slug.js
in thequeries
folder and add the following to query a specific article by its slug:
import { gql } from "@apollo/client";
export const GetArticleBySlug = gql`
query ($slug: String) {
Article (slug: $slug) {
_id
title
content {
__typename
... on Text {
_id
body
text
}
... on Assets {
items {
_id
url
}
}
}
}
}`
Now that the query is added, fetch the individual article by its slug. Fetch the article title and the article content.
The Article content is stored in a Dynamic content field. Check out the GraphQL docs for more details on how to fetch the data within this field.
- Go to the the
src/app
folder and create a new folder called[slug]
. Create a newpage.js
in this folder and add the code below to fetch an article by its slug and display the article details.
import client from "@/apollo-client";
import {GetArticleBySlug} from "@/queries/get-article-by-slug";
export const revalidate = 0;
async function getData(slug) {
const {data} = await client.query({
query: GetArticleBySlug,
variables: {
slug
}
})
return data.Article
}
export default async function ArticlePage(props) {
const params = await props.params;
const {slug} = params;
const article = await getData(slug);
return (
<>
<h1>
{ article?.title }
</h1>
{/* Loop through content types in article content */}
{article?.content.map((contentType) => {
//Display image if it exists
if (contentType.__typename === 'Assets' && contentType.items.length) {
return (
<div className="my-10" key={contentType.items[0]?._id}>
<img
src={contentType.items[0]?.url}
width="300"
height="250"
/>
</div>
)
}
//Display text as HTML
if (contentType.__typename === 'Text') {
return (
<div key={contentType._id} dangerouslySetInnerHTML={{ __html: contentType.body }}></div>
)
}
})}
</>
)
}
Now, when you view your site, you can click an article which will direct you to that specific article like in the image below.
All done
Congratulations! You have successfully connected a Next project to Prepr for a simple Blog app.
Next steps
To learn more on how to expand your project, check out the following resources:
Was this article helpful?
We’d love to learn from your feedback