This is a theme for Ghost. It's based on the default Source theme, with some changes, listed in the first section Changes. Most of the information from there now on are therefore about Source.
The following changes have been made from the Source theme:
- Browser Javascript plugins are loaded through yarn, and packaged automatically. This should make adding new dependencies and keeping them up to date easier...
- Visibility: posts that are members-only are generally not listed when somebody is not logged in.
- Tag Styling: tags are styled with a light instead of font, in lowercase. All tags are shown on posts, not just the primary tag.
- Footnotes: writing
[[N]]
whereN
is an (arbitray) number will create a footnote button that will pop-up the footnote text defined in a paragraph starting with the same-numbered[[N]]:
. Note: this is done with littlefoot, which also rewrites the numbers to be sequential. - Bible References: Standard references to chapters and verses in the Christian Bible are automatically linked and will show a pop-up with the NIV text for that verse. Note: this is done with bibleup.
- Menu Styling: menus are adjusted to handle more and wider items
- Copyright Notice: rather than saying "Powered by Ghost", a customizable copyright text appears.
- Pagination fix: a fix to a strange pagination bug in Source.
- A separate feed was made for photos...
The default theme for Ghost. This is the latest development version of Source! If you're just looking to download the latest release, head over to the releases page.
Ghost uses a simple templating language called Handlebars for its themes.
This theme has lots of code comments to help explain what's going on just by reading the code. Once you feel comfortable with how everything works, we also have full theme API documentation which explains every possible Handlebars helper and template.
The main files are:
default.hbs
- The parent template file, which includes your global header/footerhome.hbs
- The homepageindex.hbs
- The main template to generate a list of postspost.hbs
- The template used to render individual postspage.hbs
- Used for individual pagestag.hbs
- Used for tag archives, eg. "all posts tagged withnews
"author.hbs
- Used for author archives, eg. "all posts written by Jamie"
One neat trick is that you can also create custom one-off templates by adding the slug of a page to a template file. For example:
page-about.hbs
- Custom template for an/about/
pagetag-news.hbs
- Custom template for/tag/news/
archiveauthor-ali.hbs
- Custom template for/author/ali/
archive
Source styles are compiled using Gulp/PostCSS to polyfill future CSS spec. You'll need Node, Yarn and Gulp installed globally. After that, from the theme's root directory:
# install dependencies
yarn install
# run development server
yarn dev
Now you can edit /assets/css/
files, which will be compiled to /assets/built/
automatically.
The zip
Gulp task packages the theme files into dist/<theme-name>.zip
, which you can then upload to your site.
# create .zip file
yarn zip
- Autoprefixer - Don't worry about writing browser prefixes of any kind, it's all done automatically with support for the latest 2 major versions of every browser.
Source uses inline SVG icons, included via Handlebars partials. You can find all icons inside /partials/icons
. To use an icon just include the name of the relevant file, eg. To include the SVG icon in /partials/icons/rss.hbs
- use {{> "icons/rss"}}
.
You can add your own SVG icons in the same manner.
Copyright (c) 2013-2025 Ghost Foundation - Released under the MIT license.