Note: The theme uses the jekyll-include-cache plugin which will need to be installed in your Gemfile
and added to the plugins
array of _config.yml
. Otherwise you'll throw Unknown tag 'include_cached'
errors at build.
- Bundled as a "theme gem" for easier installation/upgrading.
- Compatible with GitHub Pages.
- Support for Jekyll's built-in Sass/SCSS preprocessor.
- Nine different skins (color variations).
- Several responsive layout options (single, archive index, search, splash, and paginated home page).
- Optimized for search engines with support for Twitter Cards and Open Graph data.
- Optional header images, custom sidebars, table of contents, galleries, related posts, breadcrumb links, navigation lists, and more.
- Commenting support (powered by Disqus, Facebook, Google+, Discourse, static-based via Staticman, and utterances).
- Google Analytics support.
- UI localized text in English (default), Brazilian Portuguese (Português brasileiro), Chinese, Danish, Dutch, French (Français), German (Deutsch), Greek, Hindi (हिंदी), Hungarian, Indonesian, Italian (Italiano), Japanese, Korean, Malayalam, Nepali (Nepalese), Persian (فارسی), Polish, Punjabi (ਪੰਜਾਬੀ), Romanian, Russian, Slovak, Spanish (Español), Swedish, Turkish (Türkçe), and Vietnamese.
Name | Description |
---|---|
Post with Header Image | A post with a large header image. |
HTML Tags and Formatting Post | A variety of common markup showing how the theme styles them. |
Syntax Highlighting Post | Post displaying highlighted code. |
Post with a Gallery | A post showing several images wrapped in <figure> elements. |
Sample Collection Page | Single page from a collection. |
Categories Archive | Posts grouped by category. |
Tags Archive | Posts grouped by tag. |
Additional sample posts are available under posts archive on the demo site. Source files for these (and the entire demo site) can be found in /docs
.
There are three ways to install: as a gem-based theme, as a remote theme (GitHub Pages compatible), or forking/directly copying all of the theme files into your project.
Remote themes are similar to Gem-based themes, but do not require Gemfile
changes or whitelisting making them ideal for sites hosted with GitHub Pages.
To install:
-
Create/replace the contents of your
Gemfile
with the following:source "https://rubygems.org" gem "github-pages", group: :jekyll_plugins
-
Add
jekyll-include-cache
to theplugins
array of your_config.yml
. -
Fetch and update bundled gems by running the following Bundler command:
bundle
-
Add
remote_theme: "mmistakes/[email protected]"
to your_config.yml
file. Remove any othertheme:
orremote_theme:
entry.
For detailed instructions on how to configure, customize, add/migrate content, and more read the theme's documentation.
Having trouble working with the theme? Found a typo in the documentation? Interested in adding a feature or fixing a bug? Then by all means submit an issue or pull request. If this is your first pull request, it may be helpful to read up on the GitHub Flow first.
Minimal Mistakes has been designed as a base for you to customize and fit your site's unique needs. Please keep this in mind when requesting features and/or submitting pull requests. If it's not something that most people will use, I probably won't consider it. When in doubt ask.
This goes for author sidebar links and "share button" additions -- I have no intention of merging in every possibly option, the essentials are there to get you started 😄.
When submitting a pull request:
- Clone the repo.
- Create a branch off of
master
and give it a meaningful name (e.g.my-awesome-new-feature
). - Open a pull request on GitHub and describe the feature or fix.
Theme documentation and demo pages can be found in the /docs
if submitting improvements, typo corrections, etc.
To set up your environment to develop this theme, run bundle install
.
To test the theme, run bundle exec rake preview
and open your browser at http://localhost:4000/test/
. This starts a Jekyll server using content in the test/
directory. As modifications are made to the theme and test site, it will regenerate and you should see the changes in the browser after a refresh.