Based on the Metalsmith blog starter. This starter is setup for content editing with the Netlify CMS and ready to deploy to Netlify with a couple of clicks. Check out a demo of this starter.
- Pages and a blog
- Netlify CMS with editor previews
- Minifies HTML
- Uses Markdown files for content
- Uses Nunjucks templates for layout
Simply deploy a copy of the demo website to your Netlify account by clicking the button. If you don't have an account, you can create one during this process. Netlify has a generous free tier, no credit card needed.
Once you have clicked the button a new repository will be created in your GitHub account with this code and the Netlify account will be linked to this Github repo. Now, every time you commit a change to your Github repo, your site will be rebuild and deployed to Netlify's global CDN network.
All content may now be managed with the Netlify CMS and you may invite other contributors/editors as well. Netlify Identity is used to control access to the CMS admin console.
After deploying this project, Netlify Identity will add you as a CMS user and will email you an invite. It is not necessary to accept this invite if you wish to use an OAuth provider (e.g. Github) to manage authentication for your CMS. It is recommended to use this method of authentication as it removes the need for an email & password to log in to the CMS and is generally more secure. You will need to add an OAuth provider in your Netlify app settings under Settings > Identity > External providers
.
Once you've added an OAuth provider, navigate to /admin
on your site and log into your CMS.
Follow these steps to build a local development environment:
-
Create the Metalsmith starter.
Clone the starter repository to create a new site.
git clone https://github.com/wernerglinka/metalsmith-netlify-starter.git my-site
-
Start developing.
Navigate to the my-site directory and start it up.
cd my-site/ npm install npm start
Your site is now running at
http://localhost:3000
! -
Open the source code and start editing!
Open the
my-site
directory in your code editor of choice and editsrc/content/index.md
. Save your changes and the browser will update in real time! -
Use the Netlify CMS locally to edit content
You have to setup Netlify Identiy as described above before you can use the CMS locally.
Inside
my-site
runnpx netlify-cms-proxy-server ... npm run edit
Click the
Login with Netlify Identity
button and you'll see the CMS dashboard.
A quick look at the top-level files and directories you'll see in this Metalsmith project.
.
├── node_modules
├── src
├── templates
├── .eslintrc.yml
├── .gitignore
├── .prettierignore
├── .prettierrc
├── LICENSE
├── metalsmith.js
├── package-lock.json
├── package.json
└── README.md
-
node_modules
: This directory contains all the node modules that your project depends on. -
src
: This directory will contain all the content that makes up your site. -
layouts
: This directory will contain all the layout templates and template partials that will be used to render your site. -
.eslintrc.yml
: This file contains all rules foir eslint. -
.gitignore
: This file tells git which files it should not track / not maintain a version history for. -
.prettierignore
: This file tells prettier what files it should ignore. -
.prettierrc
: This is a configuration file for Prettier. Prettier is a tool to help keep the formatting of your code consistent. -
LICENSE
: This Metalsmith starter is licensed under the MIT license. -
metalsmith.js
: This is the Metalsmith build file. -
package-lock.json
(Seepackage.json
below, first). This is an automatically generated file based on the exact versions of your npm dependencies that were installed for your project. (You won’t change this file directly). -
package.json
: A manifest file for Node.js projects, which includes things like metadata (the project’s name, author, etc). This manifest is how npm knows which packages to install for your project. -
README.md
: A text file containing useful reference information about your project.
Looking for more guidance? Full documentation for Metalsmith can be found on the website.
Deploy and Host on any static hosting service. For example Netlify, Vercel or Cloudflare Pages.
Here is an article about how to deploy Metalsmith on Netlify.
For getting help with setting up Netlify CMS, you may want to reach out to the Netlify team.
To discuss all-things Metalsmith, please join the Metalsmith community at