👉 Visit the DatoCMS homepage or see What is DatoCMS?
This example showcases a TypeScript Next.js 13 website with App Router (app) — using DatoCMS as the data source.
It uses the awesome @graphql-codegen/client-preset package to offer typed GraphQL queries.
The purpose of this repo is to have a quick start reference that can be set up with the "one-click" button below.
Have a look at the end result live:
-
Make sure that you have set up the Github integration on Vercel.
-
Let DatoCMS set everything up for you clicking this button below:
- Signup to https://formspark.io/
- Create a new form - the first 250 form submissions are free!
- Go to Settings, and copy the Form ID
- Paste the same ID in your DatoCMS project, under the "Contact Page" > "FormSpark Form ID" field.
Once the setup of the project and repo is done, clone the repo locally.
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):
cp .env.local.sample .env.local
and set the NEXT_DATOCMS_API_TOKEN
variable as the API token you just copied.
npm install
npm run dev
Your blog should be up and running on http://localhost:3000!
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.
If you're replicating this setup on DatoCMS projects created before January 1st, 2023, you might get a "Duplicate identifier" error when generating the graphql.ts
(see product changelog). You can solve it by adding a namingConvention
configuration in the graphql.config.js
file:
config: {
namingConvention: {
enumValues: 'keep',
},
}
DatoCMS is the REST & GraphQL Headless CMS for the modern web.
Trusted by over 25,000 enterprise businesses, agency partners, and individuals across the world, DatoCMS users create online content at scale from a central hub and distribute it via API. We ❤️ our developers, content editors and marketers!
Quick links:
- ⚡️ Get started with a free DatoCMS account
- 🔖 Go through the docs
- ⚙️ Get support from us and the community
- 🆕 Stay up to date on new features and fixes on the changelog
Our featured repos:
- datocms/react-datocms: React helper components for images, Structured Text rendering, and more
- datocms/js-rest-api-clients: Node and browser JavaScript clients for updating and administering your content. For frontend fetches, we recommend using our GraphQL Content Delivery API instead.
- datocms/cli: Command-line interface that includes our Contentful importer and Wordpress importer
- datocms/plugins: Example plugins we've made that extend the editor/admin dashboard
- datocms/gatsby-source-datocms: Our Gatsby source plugin to pull data from DatoCMS
- Frontend examples in different frameworks: Next.js, Vue and Nuxt, Svelte and SvelteKit, Astro, Remix. See all our starter templates.
Or see all our public repos