Jekyll Faces extends the functionality of Jekyll to support a wide variety of use cases. This document attempts to exhaustively list the goals and features of the Jekyll Faces project.
All features of this project shall be implemented such that the sites produced by it may be hosted on GitHub Pages. In short: No custom Jekyll plugins will be used. Only the standard plugins supported by GitHub Pages are allowed.
Jekyll Faces will implement new features using vanilla Liquid script and JavaScript.
The following is a list of planned features. More may follow, but this is the minimum set of features for version 1.0.
Initially inspired by JekyllBootstrap, these features attempt to fill the most common gaps left by a standard installation of Jekyll.
- Blogging
Blogging is what Jekyll does best. Permalinks, categories, pages, posts, ... Everything you would expect of a blogging platform. Jekyll Faces inherits all this functionality, then tries not to get in the way. If you know Jekyll, you'll feel at home with Jekyll Faces. - Posts and Pages
Several pre-built pages are provided by Jekyll Faces, including Archive, Pages, Tags, Categories, RSS, and others. - Bootstrap
Basic support for Twitter's Bootstrap is provided by the project that inspired this one (JekyllBootstrap). Jekyll Faces carries this idea further via support for code-free theme swapping, with built-in support for the free themes at Bootswatch. - Analytics
Capture vaulable metrics to see how visitors are finding, using, and leaving your site. Support for Google Analytics, Gaug.es, and others is provided in a modular way that makes it easy to add new analytics providers in the future. - Comments
Jekyll produces static sites, but that doesn't mean your readers can't interact with you. Several major commenting providers are supported by Jekyll Faces. Among them are Facebook, Disqus, and Intense Debate. The commenting system is implemented in such a way that new providers can easily be supported. - GitHub Pages
Whatever you build with Jekyll Faces can be hosted freely on GitHub Pages. Support for GitHub Pages is a central, driving goal of this project. (See the Prime Directive, at the top of this document.)
The following features are intended to curb the most common frustrations that I've felt when building sites using Jekyll.
- Search
Search functionality is one of the quirkiest things to get right in Jekyll. This project provides search out of the box that's completely configurable. - Font Icons
Bootstrap's icon support has been all over the place. Font Awesome, GLYPHICONS, and now the included Bootstrap Icons. You don't need to choose or lock yourself into the default offering, though. Jekyll Faces provides configurable, built-in support for all the icons you find at GlyphSearch.com. - Custom 404 Pages
The standard 404 page, shown when the specified page cannot be found, is bland and plain. Of course, you can replace the default text with whatever you choose. Jekyll Faces provides a dozen dorky and cute pages that you can specify for your site via the configuration file (no programming needed). - Bootswatch
Jekyll Faces provides support for any of more than 20 free Bootswatch themes via configuration. No custom code required. - Landing Page
Many times, it's easier to snag the domain name than it is to have something that's ready to present to the world. In that case, a landing page makes a lot of sense. - Coming Soon Page
A landing page is better than nothing, but when you want to generate a little buzz surrounding your project, a coming soon page, complete with email registration and a countdown timer, kicks things up a notch.
Now, we get to my whole purpose for creating Jekyll Faces. I have a wide variety of interests, and I like to share my meager progress with others online. Jekyll is a great way to do that, but it takes a fair amout of work to extend the blog-centric model to more specialized site designs.
- Books
Jekyll Faces intends to support showcasing books-in-progress that are written using LeanPub's simple Markdown format. I've written two books using LeanPub and I highly recommend the service. For those who want to have and hold print books, LeanPub can export to formats that are friendly to a service such as Lulu, which provides printing and drop shipping. - Documentation
For my more complex software projects, it helps to have a user manual or developer documentation. Jekyll Faces will provide a simple template for you to publish one or more documentation sections on your site. - Web Apps
I love JavaScript, and I love building single-page applications (SPAs) using the same. Combine that with my passion for game development, and you get my site, GameDevUtils.com. Jekyll Faces will support side-by-side integration of SPAs with its own generated content. - Contributors
Programming can be a lonely art. But, if you're fortunate enough to collaborate with a peer or two, Jekyll Faces will make it easier to tell who's talking when your visitors browse your content. It will also provide a central place to learn more about each of your contributors via their bio pages. - Widgets
Whenever possible (or demanded by Jekyll Faces users), this project will expose the functionality that has been created as stand-alone Liquid and JavaScript widgets. That way, if you think of a use case that we didn't, maybe you can save a little time implementing it for your site. - Performance
One of my pet sites (Fauxcabulary.org) has thousands of blog posts. Performance shall be a focus while developing features for Jekyll Faces. If the site takes too long to generate on the GitHub Pages servers, it will time out, making the whole process useless.
This document attempts to provide an exhaustive list of planned features. It cannot, however, predict all future use cases. Based primarily on user feedback, new features and potential features will be added here as they are identified.
- Manual Builds
Since everything in Jekyll Faces is configurable, you can enable more options than the standard GitHub Pages workflow can support. For those (hopefully) rare cases, this project will likely provide a manual build process where the resulting content is published to agh-pages
branch ordocs/
folder in the GitHub repo. - 1st-Class Windows Support
Jekyll has a bad reputation on Windows. Jekyll Faces will attempt to address any shortcomings via code or documentation. - Chat Providers
Research into JavaScript-based APIs for live chat (e.g. Zoho SalesIQ) and possibly chatbots (e.g. Instabot ??). - Other Integrations
Something useful I set up for my dad's band website was integration with a specific, public Google calendar. He simply adds band gigs to the calendar and they magically appear on the site. I'd like to identify similar JavaScript-only, no-server-code services that might add value to Jekyll Faces.