{"id":28026008,"url":"https://github.com/codercatdev/datocms-next-js-blog-demo-967","last_synced_at":"2025-10-14T13:03:06.244Z","repository":{"id":78374449,"uuid":"306901286","full_name":"codercatdev/datocms-next-js-blog-demo-967","owner":"codercatdev","description":null,"archived":false,"fork":false,"pushed_at":"2020-10-24T14:28:23.000Z","size":844,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"master","last_synced_at":"2025-05-11T04:55:26.150Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"datocms-next-js-blog-demo-967.ajonp.vercel.app","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/codercatdev.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2020-10-24T14:28:14.000Z","updated_at":"2020-10-24T14:29:11.000Z","dependencies_parsed_at":"2023-05-26T20:30:32.538Z","dependency_job_id":null,"html_url":"https://github.com/codercatdev/datocms-next-js-blog-demo-967","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/codercatdev/datocms-next-js-blog-demo-967","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fdatocms-next-js-blog-demo-967","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fdatocms-next-js-blog-demo-967/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fdatocms-next-js-blog-demo-967/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fdatocms-next-js-blog-demo-967/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/codercatdev","download_url":"https://codeload.github.com/codercatdev/datocms-next-js-blog-demo-967/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/codercatdev%2Fdatocms-next-js-blog-demo-967/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279018556,"owners_count":26086583,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-14T02:00:06.444Z","response_time":60,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-05-11T04:55:24.989Z","updated_at":"2025-10-14T13:03:06.237Z","avatar_url":"https://github.com/codercatdev.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# A statically generated blog example using Next.js and DatoCMS\n\nThis example showcases Next.js's [Static Generation](/docs/basic-features/pages.md) feature using [DatoCMS](https://www.datocms.com/) as the data source.\n\nThe author of this example is [chibicode](https://github.com/chibicode) and you can find the latest version of this example in the official [Next.js repo](https://github.com/zeit/next.js/tree/canary/examples/cms-datocms).\n\nThe purpose of this repo is to have a quick start reference that can be set up with the \"one-click\" button below.\n\n## Demo\n\nHave a look at the end result live:\n\n### [https://next-blog-datocms.now.sh/](https://next-blog-datocms.now.sh/)\n\n## How to use\n\n### Quick start\n\n1. [Create an account on DatoCMS](https://datocms.com).\n\n2. Make sure that you have set up the [Github integration on ZEIT](https://zeit.co/docs/v2/git-integrations/zeit-now-for-github).\n\n3. Let DatoCMS set everything up for you clicking this button:\n\n[![Deploy with DatoCMS](https://dashboard.datocms.com/deploy/button.svg)](https://dashboard.datocms.com/deploy?repo=datocms/nextjs-demo)\n\n### Local setup\n\nOnce the setup of the project and repo is done, clone the repo locally.\n\n#### Set up environment variables\n\nIn your DatoCMS' project, go to the **Settings** menu at the top and click **API tokens**.\n\nThen click **Read-only API token** and copy the token.\n\nNext, copy the `.env.example` file in this directory to `.env` (which will be ignored by Git):\n\n```bash\ncp .env.example .env\n```\n\nThen set each variable on `.env`:\n\n- `NEXT_EXAMPLE_CMS_DATOCMS_API_TOKEN` should be the API token you just copied.\n- `NEXT_EXAMPLE_CMS_DATOCMS_PREVIEW_SECRET` can be any random string (but avoid spaces), like `MY_SECRET` - this is used for [the Preview Mode](/docs/advanced-features/preview-mode.md).\n\nYour `.env` file should look like this:\n\n```bash\nNEXT_EXAMPLE_CMS_DATOCMS_API_TOKEN=...\nNEXT_EXAMPLE_CMS_DATOCMS_PREVIEW_SECRET=...\n```\n\n#### Run your project locally\n\n```bash\nnpm install\nnpm run dev\n```\n\nYour blog should be up and running on [http://localhost:3000](http://localhost:3000)!\n\n#### Try preview mode\n\nOn DatoCMS, go to one of the posts you've created and:\n\n- **Update the title**. For example, you can add `[Draft]` in front of the title.\n- Click **Save**, but **DO NOT** click **Publish**. By doing this, the post will be in the draft state.\n\n(If it doesn't become draft, you need to go to the model settings for `Post`, go to **Additional Settings**, and turn on **Enable draft/published system**.)\n\nNow, if you go to the post page on localhost, you won't see the updated title. However, if you use the **Preview Mode**, you'll be able to see the change ([Documentation](/docs/advanced-features/preview-mode.md)).\n\nTo enable the Preview Mode, go to this URL:\n\n```\nhttp://localhost:3000/api/preview?secret=\u003csecret\u003e\u0026slug=\u003cslug\u003e\n```\n\n- `\u003csecret\u003e` should be the string you entered for `NEXT_EXAMPLE_CMS_DATOCMS_PREVIEW_SECRET`.\n- `\u003cslug\u003e` should be the post's `slug` attribute (you can check on DatoCMS).\n\nYou should now be able to see the updated title. To exit the preview mode, you can click **Click here to exit preview mode** at the top.\n\n#### Full guide\n\nTo read all the details and a long form guide, please check the original example on the [Next.js repo](https://github.com/zeit/next.js/tree/canary/examples/cms-datocms)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcodercatdev%2Fdatocms-next-js-blog-demo-967","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fcodercatdev%2Fdatocms-next-js-blog-demo-967","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fcodercatdev%2Fdatocms-next-js-blog-demo-967/lists"}