Skip to content

Latest commit

 

History

History
220 lines (127 loc) · 12.2 KB

README.md

File metadata and controls

220 lines (127 loc) · 12.2 KB

Your Website

This folder, called the "web root" or sometimes "document root," contains the whole of your Website. Everything needed to publish your site's HTML pages, blog posts, events, gallery, images, and more are somewhere within this folder structure. Not all of these files are Web pages. Some are configuration files, data files, or snippets of templates.

The software used to publish your Website is called Jekyll. It is the program responsible for processing the files in this folder structure and transforming them into the HTML pages, RSS feeds, iCalendar feeds, and other machine-readable formats that your Web browser, news reader, calendaring application, and other client software downloads. Much of the documentation provided by the Jekyll project is therefor very useful in understanding both the folder hierarchy contained herein and the contents of each file in these folders.

The rest of this document offers a basic overview of these files, what they do, and how to edit them.

Folder structure

All Jekyll projects share a similar folder structure. (In Jekyll's documentation, the term "folder" and "directory" are interchangable.) The most important folders for your website are:

  • _posts - Blog posts are saved here.
  • _data - Site-specific content, such as navigation menus and calendar events, are saved here.
  • static/images - Upload images for your blog posts, gallery, etcetera into this folder.

There are other folders as well, but these are the ones you will need to open and edit most often.

Site configuration

Settings that affect the whole of your website are written to the main configuration file, called _config.yml, located in the document root (this folder). The configuration file itself is written in a highly structured format called YAML. If you edit this file to update a site setting, be sure to change only the setting you intend, and not the structure of the file (i.e., don't change the indentation or remove any punctuation).

One exception to this rule is the human-language text contained in the file. These sections are always prepended with the octothorpe (#) character. The octothrope signifies the start of a comment. Such comments are intended to make remembering how to edit the file a little easier. Feel free to edit these comments as you wish.

The remainder of this section describes the individual site settings in greater detail.

Site settings

Some settings affect almost every page on your website. These settings are documented next.

title

The title of your website. This is shown in the Web browser's title bar, set as the default name for a bookmark, and in numerous places on your site's published web page(s).

description

Your website's description should be a one or two sentence explanation of what your site is for and what a visitor might find useful about it. The description field is sometimes shown in the detail view of search engine result pages, and when someone shares your website address on social media.

timezone

The default timezone for your website. This setting will affect things like the publication dates of blog posts and the specific times of published events. Jekyll uses the tz database for understanding timezone information. Set this to the closest city listed in the tz list.

For example, for a website whose authors and events are primarily or only located in New York City, New York, United States:

timezone: "America/New_York"

main_logo

The filename of your website's main logo. To be useful, there must be a file of the same name in your website's static/images folder. For example:

main_logo: my-site-logo.jpg

Build settings

These settings affect the way Jekyll processes your site's source files. You probably shouldn't change any of these. :)

markdown

This setting instructs Jekyll which Gem to use to parse and transform Markdown files. The default, kramdown, is the best option in most cases.

exclude

This setting instructs Jekyll to ignore specific files or folders when processing your website. Any path listed in this setting will not become a published Web page.

The following example will prevent the file or folder named vendor and the file named README.md from appearing as a Web page on your published site:

exclude:
    - vendor
    - README.md

Blog settings

These settings affect your blog post listing pages and the blog posts themselves.

paginate

How many posts per page should appear on blog listing pages, such as the main blog page, category pages, tag pages, archive pages, and so on.

See also Jekyll's documentation about pagination.

paginate_path

This setting determines the URL structure ("pretty permalinks") for paginated pages.

See also Jekyll's documentation about pagination.

date_format

A representation of the default way to print dates, specified in strftime format. For example, to print dates as the day of the week, a comma and a space, then an abbreviated month name, followed by the number of the day of the month, another comma and space, and then the four-digit year, like "Tuesday, Apr 30, 2019" use the following format string:

date_format: "%A, %b %e, %Y"

time_format

A representation of the default way to print times, specified in strftime format. This is identical to date_format but formats times-of-day instead of dates.

Collections settings

Collections are a Jekyll feature that takes structured data and can render a page for each item in that data structure. For example, you can make a collection of baking recipes and then, for each recipe in the collection, you can make a page with its own Web address to show the recipe on your Web site.

Each collection is described as its own object in the top-level collections object. The primary feature of your Web site that uses collections is events. This means that there is a collections.events object, and the items of this object are the individual settings for the events collection. These settings are collectively referred to as "collection metadata."

In YAML, this is written as follows:

collections:
    events:
        output: true

When discussing the output setting of the events collection, we refer to it as the collections.events.output setting. Since the events part of the setting is dependent on the name of the collection, this is replaced with :collection.

All collection settings are optional. Refer to the Jekyll documentation on Collections details about the available settings.

For example, to define two collections, menu_items and events, where the events collection has a custom permalink structure and individual pages for each item (event) in the collection, write a collections object as follows:

collections:
    menu_items:
    events:
        output: true
        permalink: /:collection/:title

RSS feed settings

An RSS ("Really Simple Syndication") feed allows visitors to subscribe to your blog posts in news reader applications. This means they can include your site in personalized news feeds (a digital equivalent of a "morning newspaper"). The same technology also allows other websites to automatically syndicate your posts on their own websites. This is often used for automatically sharing event announcements or other news from one site to another.

The RSS feed settings are all contained inside an rss object. So, for instance, the rss.items setting is written as an indented item in YAML like this:

rss:
    items: 5

rss.items

This setting controls how many of your most recent blog posts to publish in your syndicated news feed. This is similar to the paginate setting, but only applies to news feeds.

rss.update_period

This setting is a request to any subscribers of your news feeds to please fetch an update in the specified period. The valid values are:

  • hourly
  • daily
  • weekly
  • monthly
  • yearly

The default value is daily.

This setting works in tandem with the rss.update_frequency setting, described next.

rss.update_frequency

This setting is a request to any subscribers of your news feeds to please fetch an update a certain number of times within the aforementioned rss.update_period. For instance, if this setting is set to 2 and the rss.update_period setting is set to weekly, your site is asking subscribers to "please fetch an update two times every week."

The default value is 1.

rss.ttl

Short for "Time To Live," this setting tells subscribers how many minutes the content in the news feed should be considered fresh for. After the ttl number of minutes, subscribers should feel free to re-fetch the news feed. Well-behaved subscribers will not refresh the feed before the time to live has expired.

The default value is 60 minutes.

rss.editor_email

The email address of the person responsible for editorial content on the blog. This may or may not not be the same as a blog post's author. You should ordinarily set this to the "admin name" email address in your domain name registration.

rss.webmaster_email

The email address of the person responsible for any technical issues with the news feed. You should ordinarily set this to be the same as your website's "technical contact" email address in your domain name registration.

rss.image

The path to a picture representing your blog content, such as your site logo or a larger version of your website's favicon. This must be an image uploaded to your website.

Page defaults

The defaults object in your site configuration controls the default values of certain metadata that accompany your pages.

TK-TODO: Document some of these? It's not likely going to be changed.

iCalendar settings

Your site has built-in support for iCalendar, a digital calendaring and event scheduling format. Using iCalendar, visitors can subscribe to upcoming and recurring event notifications. These notifications will then show up right alongside their own alarms and alerts in their phones or other mobile devices. This feature is often used by performance venues to help remind visitors of an upcoming show, presentation, or class.

The iCalendar settings are similar in structure to the RSS feed settings in that they are all contained within one iCalendar object in YAML.

iCalendar defaults

The iCalendar.defaults object sets the default values for various event metadata.

iCalendar.defaults.location

The physical location for events that are missing this field. This should usually be set to the physical location of the event venue itself.

For example:

iCalendar:
    defaults:
        location: "123 Main Street, Pleasanthill Neighborhood, Anytown, 12345, United States"

iCalendar.defaults.status

The planning stage for events that are missing this field. The values are the same as for the STATUS field in the iCalendar specification (RFC 5545). The default is CONFIRMED.

iCalendar.defaults.image

The file name of the image to use as an event image's placeholder for events that are missing this field. To be useful, there must be an image with the same filename in your site's static/images folder.