Organize documentation, playbooks, and other composition with Scrawl
Scrawl is a page-centric theme for Jekyll. Rather than catering to posts like most Jekyll themes, Scrawl focuses on providing categorization and navigation for pages.
The Scrawl theme is based on GitHub's Primer theme and the left navigation is inspired by Steve Smith's Minimal.
Set Jekyll's _config.yml
to pull the theme from the lightster/jekyll-theme-scrawl
remote theme:
remote_theme: lightster/jekyll-theme-scrawl
Scrawl is all about pages.
You will most likely want to create an index.md
in the root of your Jekyll site. This is the page that the browser will load when first arriving at your site.
You can create more pages in the root of your Jekyll site, as well as subdirectories of the Jekyll site. Page URLs match the paths that appear in your site directory structure.
We like our page URLs to leave off the .html
, so we include the following in our _config.yml
:
permalink: pretty
Scrawl provides the following layouts:
base
— Thebase
layout is the base layout used by all other layouts. The base layout has two side-by-side independently scrolling panes. The left pane contains the site title, the site description, and the navigation. The right pane is wider and is used for displaying the content.page
— Thepage
layout is the default layout that pages use. The page layout is similar to the base layout but with a few additions:- The
title
value provided in the page's front matter is displayed as a header above the page content - The calculated estimated reading time. This can be disabled by setting
reading_time
tofalse
in the page front matter. - The
summary
value provided in the page's front matter is displayed below the page title and reading time - A table of contents is displayed below the page title and summary. The table of contents is generated based on the page's level 2, 3, and 4 headers (
<h2>
,<h3>
, and<h4>
tags). This can be disabled by settingtoc
tofalse
in the page front matter.
- The
sitemap
— Thesitemap
layout breaks the navigation into four columns that takes up the width of the layout.
You can set the layout for a page in the page's Jekyll front matter:
---
layout: base
---
For the default
and page
layouts, there is a width
setting for controlling how wide the content pane should be:
fixed
— Thefixed
width is the default. The fixed width layout stays the same width unless the browser window is not wide enough, in which case the navigation is moved into a hamburger menu and the page takes up the width of the browser window.fluid
- Thefluid
width takes up the width of the browser window. If the browser window is not wide enough, the navigation is moved into a hamburger menu.no-nav
– Theno-nav
width behaves like thefixed
width setting, but it removes the navigation, allowing the content pane to take up the entirety of the fixed width.
You can set the width for a page in the page's Jekyll front matter:
---
width: fluid
---
All layouts and widths are mobile-friendly.
The navigation is generated by aggregating all pages' front matter. By default, a page is included in the navigation as long as the page has a non-empty title
value in its front matter.
Pages are sorted in the navigation based on the order
value that you provide in the page front matter. You can set the order
value to the same value as the page's title to order the pages in the navigation alphabetically.
If you do not set an order
value, the ordering of items in the navigation is undefined and may vary between site builds.
The title
that appears in the front matter of the page is used for link text. If you want the link text to be something other than the page title, such as an abbreviated version of the page title, you can set nav_title
in your page front matter.
If you have a page with a title but you do not want the page to appear in the navigation, you can exclude the page by setting hide_in_nav
to true
in your page front matter.
Scrawl allows pages to be organized into categories. These categories are used when displaying the pages in the side navigation and the site map.
Note that categories do not affect a page's URL. As noted in Pages and their URLs, page URLs match the paths that appear in your site directory structure.
Before pages can be placed in categories, you need to define the categories. Categories are defined by creating a _data/scrawl.yml
file and listing categories like so:
categories:
- title: Lunch
order: 1
key: lunch
- title: Dinner
order: 2
key: dinner
- title: Beverages
order: 3
key: beverage
Each category should contain all three keys:
title
— The title appears in the navigation and site map as the title of the category.order
— The order determines the order the category should appear relative to the other categories.key
— The key is the value that is used in page front matter to place the page in the category.
Once the categories are defined, you can place a page in a category by setting the category
value in the page front matter like so:
---
category: beverage
---
If you need to add custom CSS or JavaScript tags, you can create _includes/head.html
and/or _includes/foot.html
files containing the <link>
and/or <script>
tags you need added to your pages.
For custom CSS, you will generally want to place <link>
tags in _includes/head.html
.
For custom JavaScript, you will want to place your <script>
tags in _includes/head.html
if you are using the defer
attribute or otherwise need the <script>
tag to appear in the page's <head>
tags. If you are not using defer
and do not need the JavaScript to load in the <head>
tag, you should place your <script>
tags in _includes/foot.html
so they will be added just above the page's closing </body>
tag.
To set up your environment to develop this theme, fork this repo, clone your fork to your localhost, and run bundle install
.
The theme is setup just like a normal Jekyll site. Run bundle exec jekyll serve
and open your browser to http://localhost:4000
. As you make changes to your clone of the theme, your site will regenerate and you should see the changes in the browser after a refresh, just like normal.
When the theme is released, only the files in _layouts
, _includes
, _sass
and assets
tracked with Git are bundled.
The theme is available as open source under the terms of the MIT License.