Supply, an e-commerce Jekyll theme with Gumroad integration

Supply is an e-commerce template for Jekyll + Gumroad, designed with Tachyons CSS.

If you are a Gumroad creator, you can use Supply with Jekyll to display and sell products on your site or blog.

Demo Site with documentation

Browse through a live demo:

Supply is designed by alternatyves.

Find more templates, themes, and Jekyll tutorials.


  • List & display products, thanks to Jekyll's collections
  • Take payment online using Gumroad
  • Contact form with formcarry
  • Map with Leaflet thanks to the jekyll-leaflet plugin
  • jekyll-archives to build and sort through categories & tags pages
  • Custom variables
  • RSS/Atom feed
  • SEO tags
  • Microdata markup
  • Jekyll livereload + NPM for fast development
  • Built-in site search


  1. Install Jekyll
  2. Add your site and author details in _config.yml.
  3. Get a workflow going to see your site's output with Jekyll locally.

Supply was built with Jekyll version 4.0.0 and should support newer versions as well.

Install the dependencies with Bundler:

$ bundle install

Run jekyll commands through Bundler to ensure you're using the right versions:

$ bundle exec jekyll serve


Add your custom configuration in the _config file.

  • Exposed as a data file to give clients better access
  • Set in the Data / Navigation section, look for navigation.yml in _data.

Look for footer.html in _includes to add and change your footer links.

Contact Page

To add you formcarry endpoint URL to _config.yml, you'll need a fromcarry account, please refer to formcarry documentation

Add your map coordinates if you want to display a map. Please refer to the jekyll-leaflet plugin and [Leaflet]( m) documentation for customizing your map(s).

Product Pages

If you have products on Gumroad, you can start adding product pages right away. Within the Supply theme, you'll find a sample of a product page with free products, free-products.html, located in _pages.


Building front-end assets: styles and scripts

  1. Install Node module dependencies:
npm install


You can change the site styling using Tachyons, look for the CSS in the sup-theme file, located in the src folder.

Tachyons is a CSS toolkit and design system based on using components. Please refer to Tachyons documentation, you can also start with

Once you are done with your style changes, run:

Run the npm run


That will process all your CSS files in one readable file located in assets/css/sup-tachyons.css.

to minify your css you can run

npm run minify-css


npm run start

to minify and build the site locally.

npm commands with browser reload

Supply uses a couple of custom Postcss npm scripts. Make sure your dependencies are installed: npm install. Type npm outdated to see if you have outdated versions, then install any outdated dependencies.

Once that is done, to build your site & concatenate your CSS (in assets -> CSS), simply run:

npm run start

This command builds the site locally on port 4000, you can quickly revise design changes thanks to livereload.



  • Add, update, or remove a post in the Posts collection.
  • Change the defaults when new posts are created in _posts/


To display products, Supply uses a collection called product You will find a series of product samples in the _products collection folder. By design, all the products are on display on the home page, in Supply, that is ìndex.html. You can manually create pages based on this index to sort your products or any other collection by custom variable.

You can also add your products in regular posts, using the Gumroad overlay, embed, and hyperlinks method, thanks to an include snippet.

Write something like:

{% raw %}<a href=" class="no-underline pv2 grow db"><img class="w-100" src="/images/screenshot.png"></a>

{% include gumroad-overlay.html id="supply" %}{% endraw %}

to get a product display like this:

Supply is designed by alternatyves and licensed under the MIT license.

Please use and contribute to Supply .

Buy Me A Coffee

Who is using this?

Are you using Supply? Let me know!