🎈 Welcome to the Marketplace — Explore and discover the ecosystem around DatoCMS, and share your own work with the community!

Next.js 14 Landing Page Demonstration

Marketing Website

Offers typed GraphQL queries, Tailwind, multi-language, Web Previews, real-time updates in Preview Mode, SEO/Readability analysis, and much more

website template next.js
Want to create your own starter project? Learn how to do that in our documentation!

A Marketing Website Demo using Next.js 14 and DatoCMS

This example showcases a TypeScript Next.js 14 website with App Router (app) — using DatoCMS as the data source.

It uses GraphQL CodeGen to type all of the requests coming from DatoCMS automatically: See how it works here

Demo

Have a look at the end result live:

https://company-website-demo-preview.vercel.app/

How to use

Quick start

  1. Create an account on DatoCMS.

  2. Make sure that you have set up the Github integration on Vercel.

  3. Let DatoCMS set everything up for you clicking this button below:

Deploy with DatoCMS

Local setup

Once the setup of the project and repo is done, clone the repo locally.

Set up environment variables

In your DatoCMS' project, go to the Settings menu at the top and click API tokens.

Then click Read-only API token and copy the token.

Next, copy the .env.example file in this directory to .env (which will be ignored by Git):

Terminal window
cp .env.local.sample .env.local

and set the DATOCMS_READONLY_API_TOKEN variable as the API token you just copied.

Also then set a secret token that is being used for WebPreviews, SEO Previews and Cache invalidation:

URL=http://localhost:3000
SEO_SECRET_TOKEN=superSecretToken
DRAFT_SECRET_TOKEN=superSecretToken
CACHE_INVALIDATION_SECRET_TOKEN=superSecretToken

Run your project locally

Terminal window
npm install
npm run dev

Your blog should be up and running on http://localhost:3000

VS Code

It's strongly suggested to install the GraphQL: Language Feature Support extension, to get autocomplete suggestions, validation against schema, and many more niceties when working with your GraphQL queries.

Subscribe to our newsletter! 📥
One update per month. All the latest news and sneak peeks directly in your inbox.
support@datocms.com ©2025 Dato srl, all rights reserved P.IVA 06969620480