Candy Theme

Candy is a minimal blogging theme for Cabin.

The theme's source code is located at the Candy GitHub repo.


To use Candy you must have Node.js, Python (for Pygments), and Compass installed.

First install Cabin and Grunt globally with this command:

npm install -g cabin grunt-cli

Then scaffold a static site generator using the Candy theme with this command:

cabin new blog CabinJS/Candy

Now change into the blog directory and run the grunt command:

cd blog && grunt

This will build your site, start a static file server, open a browser tab with the site's homepage, and start a watch process to rebuild your site when source files change.

Try editing a markdown file in the posts folder or CSS in the src/styles folder and upon saving, your site will automatically be rebuilt with the updated content/styles. When you edit markdown, your browser will automatically refresh to view new content, and when editing styles, they will be injected directly into the page for an immediate update.

Note: In the future, you can build your site by running the grunt command in the blog folder.

User Guide

Expected files to edit

There are parts of the Candy theme which you are expected to edit when building your site. Here they are:


You are expected to add your name to the nav home link in the src/layouts/base.jade or src/layouts/_header.ejs file.You are also expected to update the social media links with your GitHub username and Twitter handle in the src/layouts/base.jade or src/layouts/_header.ejs file.

We have also provided social media icons for Google+, Facebook, and Pinterest which you can use out of the box. You can see all the icon font classes in the src/styles/_icon.scss file, and here is an example of how you would add a link to your Pinterest profile:

<a href="" class="icon-pinterest"></a>

To get Disqus setup, you must add your Disqus username to the src/layouts/_social.jade or src/layouts/_social.ejs file. There are also placeholder comments for Google Analytics scripts in the src/layouts/base.jade and src/layouts/_footer.ejs files.


You are expected to edit the src/pages/about.(jade/ejs) and src/pages/projects.(jade/ejs) pages to describe yourself and your projects.


You are expected to edit the default posts and add your own metadata and content.

Authoring Posts

Candy generates pages using markdown posts in the posts folder. It expects markdown posts to contain two required metadata properties:


Type: String

Title of the post which is also used as its url.


Type: String

DateString which is parsed and displayed as the publishing date of the post.

To learn more about post metadata, check out grunt-pages.

Deploying your Site

If you selected a deployment tool during the installation process, you can deploy your site with the grunt deploy command.

Note: for Amazon S3 and FTP deployment, read the Gruntfile.js comment about how to configure your credentials.

If you didn't select a deployment tool during the theme installation, you can add one later by following the installation guide in the wiki.

Deploying to a subdirectory

If you are not deploying to the root of your site, you will need to modify the grunt-pages data.baseUrl property during deployment so that the asset paths and URLs resolve correctly. Here is an example which augments the build and deploy tasks when deploying a site to /blog/:

grunt.registerTask('build', function (target) {
  if (target === 'deploy') {
    grunt.config('', '/blog/');

grunt.registerTask('deploy', ['build:deploy', 'yourChosenDeployTask']);

Changing the main theme color

We provide a number of theme colors out of the box in the src/styles/_base.scss file. To change the color, simply change the value of the $mainTheme Sass variable.

Included libraries/tools


Normalize.css is used to normalize styles across browsers.


jQuery is used to toggle the touch optimized menu in src/scripts/main.js.


Candy uses the IcoMoon App to generate icon fonts. By default it uses icons for social media and comments, but you can easily add and remove icons. To alter the icons, go to this url, and click Import Icons in the top left and upload the src/styles/selection.json file.

After updating the icons simply download them and replace the fonts folder inside the src/styles folder, replace the src/styles/selection.json with the new selection.json and replace the contents of src/styles/_icon.scss with style.css.


If you would like to generate an RSS feed, check out grunt-pages' RSS option and add it to your grunt-pages config in Gruntfile.js.


Cabin supports GitHub flavored Markdown for its static site generation. It has awesome features like:

Syntax highlighted code blocks

function praise (thing) {
  console.log(thing + ' is so great!');


Linked headers(link on the left)

Link into specific sections of your posts.


Markdown Test

Unordered list

Ordered list

  1. First
  2. Second
  3. Third

Horizontal line


Link text is great.

Code block with syntax highlighting

console.log('I am a string');
var MyBackboneView = Backbone.View.extend({});

Inline code

Here is some inline code

Text stlying




Block Quote

The computer is the most remarkable tool that we've ever come up with. It's the equivalent of a bicycle for our minds.

Steve Jobs


Bear Triangimal Bear Triangimal by Pasquale D'Silva