Success Building CMS-less Production Sites with Jekyll

As an organization that works primarily with nonprofits, ThinkShout is no stranger to the “small organization, big impact” problem. The problem is that small organizations have budgets commensurate with their size and goals, for which the sky is the limit.

Resolving this problem requires acute awareness of how to build what is necessary to allow an organization to meet their goals. In other words, “how can we build everything this organization needs and nothing more?”

When Feeding Texas approached us to redesign their site, it became clear we could leverage both their small size and their large ambitions as “pros” for using Jekyll. Feeding Texas works to provide food security to all Texans by coordinating a statewide network of food banks, initiating scalable public action that empowers Texans to solve their hunger problems collaboratively, and guiding the public conversation surrounding hunger in Texas. The site is designed to advance this work by first engaging visitors at a local level before leading them to connect with Feeding Texas in their state-wide effort to end hunger. By generating interest about hunger next door, Feeding Texas is able to motivate its constituents to do their part in resolving the larger issue at the heart of its mission.

Why Jekyll Works for Small Organizations That Need to Make a Big Impact

Feeding Texas has two characteristics shared by many small organizations:

  1. Limited capacity to generate and update content
  2. Need to appear as big as a BIG organization

Jekyll is the glass slipper for this dilemma for two reasons:

  1. Large budget savings by not implementing an in-site CMS – a small content management team means relatively simple content management needs. There’s no reason to use a full-blown CMS like WordPress or Drupal.
  2. Rapid development and excellent DOM control allowed the funds saved to be reinvested in the site’s visual presentation with maximum returns

However, this left us with one big engineering question…

Jekyll Has No CMS. How Do We Allow Non-Technical End Users to Manage Content!?

Our solution to this problem is multi-faceted…

GitHub for Content Management

Since all content for a Jekyll site is stored in text files (markdown, csv, HTML, etc.) all content can be managed from the GitHub interface. Alternatively, there are tools like Prose that are well-integrated with Jekyll and allow for a more robust content editing experience.

Complex Content Management with Simple CSV Inputs

Tools like Github allow for simple updates like changing text on a page, but can also allow for complex content management as is the case with Feeding Texas’ zip-code detail pages. These pages are generated from a CSV input that holds data for each zip code in Texas. The CSV file is processed when the site is built by a custom Ruby plugin that creates a page for each zip code. From a content management standpoint, this means Feeding Texas can update hundreds of pages in three simple steps:

  1. Edit the CSV file with the preferred tool (Excel, etc.)
  2. Copy and paste the contents of the file into the GitHub interface
  3. Commit the updated file

This commit then triggers a re-build of the site wherein each zip code detail page will contain the updated CSV data.

Reusable Content Blocks

Another popular content management concept that was difficult to implement in Jekyll until the 2.0.0 release was blocks of content that could be stored in a single place and used in multiple places around the site. Collections made this much easier. On the Feeding Texas site, we created collections for several things ranging from calls to action (scroll to page bottom) to staff profiles that can be placed anywhere on the site by specifying their index (where the index could be any YAML frontmatter variable). So, for example, if a Feeding Texas content manager wanted to create and use a new call to action block, they would do two things:

  1. Create a markdown file for the block and include a frontmatter variable like this: index: 1.
  2. Then to apply the new block to a page, they’d specify the block’s index as a frontmatter variable in the page’s markdown file like this:
calls_to_action:
  - 1
  - 2

…and our templates do the rest.

Challenges of Using GitHub as a Content Management Tool

One difficulty of using GitHub for content management is there is no way to add image or video files through the GitHub interface. This is problematic because it is something content managers expect to be able to do, and we cannot simply add the files to the (compiled) live site directory (via FTP for example) because each commit triggers a wipe and a rebuild of said directory. To work around this problem, we created an Amazon S3 bucket dedicated to storing assets (images, videos, etc.) and reference the assets statically anywhere they need to be used on the site.

As a side note, the site is also hosted on an S3 bucket and we did consider putting both S3 buckets behind a CDN, but ultimately decided this was not necessary. That said, it’d be a trivial way to increase site performance if we ever wanted a boost.

Since assets are stored on a server that will persist, management of them becomes very straightforward. Feeding Texas uses S3’s built in file management UI (pictured below), but you could just as easily use Transmit or any other FTP client.
S3 file management UI

Travis CI for Deployment

Travis is a continuous integration platform that is tightly integrated with GitHub. With a single configuration file, we were able to set up a fully functional deployment workflow that includes a staging and a production site. A commit to a particular branch in GitHub triggers Travis to build and deploy the site automatically to a specified endpoint. So, for example, editing and committing a file in the staging branch triggers a deployment to the staging site whereas a commit to the live branch triggers a deployment to the live site. For a more in depth look at how to configure a deployment workflow like this, check out Lev’s post on how we’re doing it for the ThinkShout site.

As an added bonus, we can leverage GitHub’s pull request feature as a content management tool. For example, a staff writer could create several pieces of content in the staging branch, and then bundle those commits into a pull request for their editor to approve and merge into the live branch.

Our Travis configuration file also specifies tests to run before deploying a new build of the site, which prevents a bad commit from generating a broken site. Travis has several testing frameworks baked in, but if those aren’t enough, you can also install tools via your Travis configuration file. We, for example, install CasperJS for our tests.

We Did it! A CMS-Less Site Ready for Production Use!

Having thought our way around using a full-blown CMS, like WordPress or Drupal provide, we got two big wins:

  1. A lightning-fast site – because Jekyll sites are static, all of the “heavy lifting” is done when the site is being generated; no database calls or logic layer to slow things down. Also, no in-site CMS!
  2. More time to spend making the site look like a million dollar project – because we spared ourselves the time it would have taken to configure a CMS, we were able to spend it integrating neat JavaScript like the maps and charts you see on zip code detail pages.

I’m looking forward to building more Jekyll sites and am personally thrilled we devised a way to leverage its strengths to work in cooperation with the needs of our nonprofit client base.