Skip to content

Template For Using GhostCMS as a headless CMS with NextJS

Notifications You must be signed in to change notification settings

Wayne-Jones/ghost-cms-nextjs

Repository files navigation

This repo was made with create-next-app using the latest version of NextJS/TypeScript and connects using the v3 of the Content API from GhostCMS.

This serves as a starting template to fetch and retieve all posts and single posts as a Statically Generated Site. I might update this repo in the future to use other parts of the GhostCMS Content API, but this is just a proof of concept.

Getting Started

First, create your own .env file using the .env-example file and replace the values of your BLOG_URL and CONTENT_API_KEY with the values that you get from GhostCMS. If you currently don't have a Content API Key, you can create one by going to the GhostCMS Admin panel and adding a Custom Integration.

Second, run the development server:

npm run dev
# or
yarn dev
# or
pnpm dev

Open http://localhost:3000 with your browser to see the result.

You can start editing the page by modifying pages/index.tsx. The page auto-updates as you edit the file.

API routes can be accessed on http://localhost:3000/api/hello. This endpoint can be edited in pages/api/hello.ts.

The pages/api directory is mapped to /api/*. Files in this directory are treated as API routes instead of React pages.

This project uses next/font to automatically optimize and load Inter, a custom Google Font.

Learn More

To learn more about Next.js, take a look at the following resources:

You can check out the Next.js GitHub repository - your feedback and contributions are welcome!

Deploy on Vercel

The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.

Check out our Next.js deployment documentation for more details.