Creating a blog with Bridgetown and Netlify CMS

This is a quick tutorial to showcase how you can quickly integrate Netlify CMS into your Bridgetown site.

The code for this tutorial can be found at:

{% github andrewmcodes/bridgetown-netlify-cms-starter no-readme %}

Let’s get started!


For detailed instructions on getting Bridgetown set up on your local machine, take a look at the Bridgetown Getting Started Documentation and the Bridgetown Installation Guides.

The TL;DR is you need Ruby >= 2.5, Bundler, Node >= 10.13, Yarn, and the Bridgetown gem installed.

You can install the gem by running the following command in your terminal:

gem install bridgetown

As far as the other dependencies go, you don’t have to use the same versions that I am as long as you meet the minimum requirements above, but this is what I am currently using:

  • Ruby 2.7.1
    • Bundler 2.4.1
  • Node 13.11.0
    • Yarn 1.22.4

Creating a new Bridgetown site

The first thing we are going to do is generate a new Bridgetown site.

Run the following command in your terminal:

bridgetown new bridgetown-netlify-cms-starter
cd bridgetown-netlify-cms-starter

Our new site has been generated! :tada:

Let’s take a look! Run yarn start in your terminal and open http://localhost:4000 in your browser.

Alt Text

Optional Styling

Just to make this a little prettier, I am going to add new.css, which just adds styles to your default HTML. If you’d like to do the same, add the following in your head component at src/_components/head.liquid:

<!-- src/_components/head.liquid -->
<link rel="stylesheet" href="" />
<link rel="stylesheet" href="" />

And remove the contents of frontend/styles/index.scss.

Adding Netlify CMS to your site

I won’t be going in great depth about the specific features of Netlify CMS, I encourage taking a looking at the Netlify CMS Documentation to learn more.

We are going to create an admin folder with two files: index.html and config.yml:

mkdir src/admin
touch src/admin/index.html
touch src/admin/config.yml

Paste the following inside of src/admin/index.html:

<!DOCTYPE html>
<meta charset="utf-8" />
<meta http-equiv="x-ua-compatible" content="ie=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no" />
<title>Netlify CMS</title>
<script src="" type="text/javascript"></script>
<script src="^2.0.0/dist/netlify-cms.js" type="text/javascript"></script>

And in src/admin/config.yml

name: git-gateway # required for using Github
branch: main # the default branch you want CMS changes merged to
commit_messages: # Optional: configure the commit messages Netlify CMS will use when publishing changes
create: "feat({{collection}}): :sparkles: Create {{slug}}"
update: "chore({{collection}}): :recycle: Update {{slug}}"
delete: "chore({{collection}}): :recycle: Delete {{slug}}"
uploadMedia: "feat(assets): :bento: Upload {{path}}"
deleteMedia: "chore(assets): :wastebasket: Delete {{path}}"
local_backend: true # Enable the CMS locally
media_folder: src/images/uploads # location of where we want images uploaded via the CMS put
- name: blog # collection name
label: Blog # label in the CMS
folder: src/_posts/ # location of the files that make up the collection
extension: .md # extension of those files
format: frontmatter # format to use
create: true # allow creation of new items in this collection
slug: "{{year}}-{{month}}-{{day}}-{{title}}" # the slug to use when creating new items
preview: false # According to the documentation, this won't work with our setup, but I didn't try
fields: # Fields for the collection
- { label: Layout, name: layout, widget: hidden, default: post }
- { label: Title, name: title, widget: string }
- { label: Publish Date, name: date, widget: datetime }
- { label: Body, name: body, widget: markdown }
- name: pages
label: Pages
preview: false
- label: Index Page
name: index
file: src/
- { label: Layout, name: title, widget: hidden, default: home }
- { label: Body, name: body, widget: markdown }
- label: About Page
name: about
file: src/
- { label: Title, name: title, widget: hidden, default: About }
- { label: Layout, name: layout, widget: hidden, default: page }
- { label: Permalink, name: permalink, widget: string, default: "/about/" }
- { label: Body, name: body, widget: markdown }

For more information on these config options, checkout the Netlify CMS Configuration Options Documentation

I decided what fields needed to be used by looking at the frontmatter in the example pages that Bridgetown created with the new site.

For our posts, this looks like:

title: "Your First Post on Bridgetown"
category: updates

and in our config for Netlify CMS:

- { label: Layout, name: layout, widget: hidden, default: post }
- { label: Title, name: title, widget: string }
- { label: Publish Date, name: date, widget: datetime }
- { label: Body, name: body, widget: markdown }

I neglected to add category, which would be a great contribution to this repository if you are interested!

You should now be able to navigate to http://localhost:4000/admin in your browser and see this page:

Netlify CMS Admin Page

In order to use the CMS locally, run npx netlify-cms-proxy-server in a separate terminal window or run yarn add -D netlify-cms-proxy-server and modify start.js:

{ command: "yarn webpack-dev", name: "Webpack", prefixColor: "yellow"},
{ command: "sleep 4; yarn serve --port " + port, name: "Bridgetown", prefixColor: "green"},
- { command: "sleep 8; yarn sync", name: "Live", prefixColor: "blue"}
+ { command: "sleep 8; yarn sync", name: "Live", prefixColor: "blue"},
+ { command: "sleep 12; yarn netlify-cms-proxy-server", name: "CMS", prefixColor: "red"}
], {
restartTries: 3,
killOthers: ['failure', 'success'],
}).then(() => { console.log("Done.");console.log('\033[0G'); }, () => {});

Now the CMS will start with the rest of your server. You can play with it locally and check for errors, but the real power is once we get this live!

Create GitHub repo

Create a new GitHub repository and push this code to your default branch. If you have the GitHub CLI, that process would look something like:

# I am using main as my default branch
gco -b main
git add .
git commit -m "feat: :tada: Initial" -m "Initial commit"
gh repo create bridgetown-netlify-cms-starter --public
git push --set-upstream origin main

Create Netlify site

  1. Log in to Netlify
  2. Press the ‘New site from Git’ button
  3. Choose your repository
  4. Set your build command to yarn deploy
  5. Set the publish directory to output
  6. Deploy site

Alt Text

Netlify Identity

In order to log in to our CMS, we need to enable Netlify Identity on the Identity tab for our new site.

Registration preferences

Before setting this, make sure you have created your first user to make your life easier (next section) I would recommend setting this to invite only vs open once you have a configured user.

External providers

I find it is way easier to use an external provider (like GitHub) and highly suggest doing the same. There is a weird bug with the invitation links that I haven’t solved yet for normal signups and this will remove that headache.


Enable the Git Gateway to allow Netlify to connect your site to GitHub’s API, which is required for using Netlify CMS.

Using the CMS

Navigate to your deployed site and go to the /admin route. For example, the admin page for this starter is located at

Your page should look like:

Netlify CMS login

Click the Continue with GitHub button. After you authenticate with GitHub, you should be redirected to your CMS!

Netlify CMS

Note: At this point, I would go back to your site settings and set the registration preferences to invite only!


From here you should be all set! You can create a new blog post, edit content on your pages, upload images, and more!

After changing the index page for example, hit the publish button at the top of the page and publish now.

What this will do is add a commit to your GitHub repo with the changes and if Netlify is set to deploy your default branch (this is default behavior), the Netlify will automatically redeploy the site with the changes.

To go back to your site, change your url to the root, or click the user icon in the top right of the CMS and log out.

Note: there is some weird bug that pops up after it logs you out. Either refresh the page or just change the url back to your root url.

After the deploy finishes (it is very quick if you followed along), the content you changed or added should be reflected! I updated the index page, and my site now looks like:

Alt Text

Wrap up

From this point, you can continue changing your Bridgetown site, and configure the CMS config file as needed. Hopefully this gives you all the excuse you need to try Bridgetown! If you encounter any issues or find a bug, feel free to report it on the repository.

You can find the demo for this project here.

Happy coding!

Andrew Mason's profile image

Hey, I'm Andrew 👋

I'm a senior product engineer at Podia, co-host of Remote Ruby and Ruby for All, and co-editor of Ruby Radar. You can explore my writing, learn more about me, or subscribe to my RSS feed.

Page Info

11 July 2020
29 January 2022
Reading Time:
6 min read