Get Started with CB-Essay
This guide walks you through creating your first CB-Essay project from scratch. You’ll have a working essay site in about 10 minutes.
Philosophy: Copy and Replace
This entire demo site is designed to teach through demonstration. Every feature you see can be copied directly into your own essays. See a blockquote you like? Copy the code, replace the content with yours. Find a useful margin note? Same approach.
You don’t need to understand the technical details - just copy what works and replace the content.
Prerequisites
You’ll need:
- A GitHub account (free) – Sign up now!
- A willingness to learn
Step 1: Use This Template
CB-Essay is a GitHub template repository. This means you can create your own copy with one click:
- Navigate to github.com/CollectionBuilder/cb-essay
- Click the green “Use this template” button
- Name your repository (e.g.,
my-essay-project)Tip: Use a descriptive repository name. It will become part of your site’s URL:username.github.io/repository-name - Choose Public or Private (If you’d like to publish the site on GitHub’s free GitHub Pages web hosting, it will need to be Public)
- Click “Create repository”
That’s it! You now have your own CB-Essay repository.
Step 2: Choose Your Editing Workflow
You have several options for working with your essays. Most CB-Essay users work directly on GitHub without installing anything locally.
Option A: Edit on GitHub.com (Easiest!)
Work entirely in your browser - no local installation needed:
- Navigate to your repository on GitHub
- Click into the
_essay/folder - Open
01-welcome.mdand replace it’s content with your own! - Do the same with the other
.mdfiles in the folder, renaming the filenames and replacing the “frontmatter” Frontmatter is the information at the top of each.mdfile that includes information liketitleandorder; it’s separated by---lines at the top and bottom. with your own info.- See Step 3 below for more information on how to edit these files.
- Edit the
_config.ymlfile and the_data/theme.ymlfile to change the site’s title, theme, featured image, and typography - Click “Commit changes”
That’s it!
Bonus: Use the Project Gutenberg extractor (Actions tab) to populate your _essay/ folder with a complete book automatically!
Option B: GitHub.dev (VS Code in Browser)
Get a full VS Code editor without leaving your browser:
- Go to your repository on GitHub
- Press the
.(period) key OR change the URL fromgithub.comtogithub.dev - Edit files in a full-featured code editor
- Replace the content in the
_essayfolder with your own - Edit the
_config.ymlfile and the_data/theme.ymlfile to change the site’s title, theme, featured image, and typography
- Replace the content in the
- Use Source Control panel (third option from the top on the far right) to stage and commit changes
Perfect for: Multiple file edits, search/replace, file management
Option C: GitHub Codespaces (Cloud Development)
Get a complete development environment in the cloud:
- Click Code → Codespaces → Create codespace
- Wait for environment to load (includes Jekyll!)
- Edit files in VS Code interface
- Preview with
bundle exec jekyll s - Use terminal, extensions, and full IDE features
Perfect for: Testing features, previewing locally, advanced work
Option D: Local Development (Advanced)
For local development with Git and Jekyll installed on your computer, follow the CollectionBuilder-CSV walkthrough. CB-Essay uses the same setup process.
Perfect for: Offline work, full control, fastest preview cycle
Step 3: Add Content (Two Options)
Option A: Use the Gutenberg Extractor (Quickest!)
Want to start with a complete book? Extract one from Project Gutenberg:
- Go to your repository’s Actions tab
- Click “Extract Gutenberg Book” workflow
- Click “Run workflow”
- Enter a book ID (e.g.,
84for Frankenstein,1342for Pride and Prejudice) - Click “Run workflow” button
Wait a minute - your _essay/ folder will be populated with chapter files automatically! And your config files (_config.yml and _data/theme.yml) will be updated with the title, author, and cover image from Project Gutenberg.
Find books: Browse gutenberg.org and get the ID from the URL.
Option B: Write Your Own Essay
No matter which editing method you chose in Step 2, essays use the same format.
Create a file in _essay/ named my-first-essay.md with this content:
---
title: My First Essay
order: 1
---
## Introduction
This is my first essay using CB-Essay. I can write in **Markdown** with _formatting_.
Here's a paragraph with a [link](https://example.com).
## Another Section
- Bullet points work
- As expected<svg xmlns="http://www.w3.org/2000/svg" width="8" height="8" fill="currentColor" class="bi bi-asterisk small" viewBox="0 0 16 16" style="vertical-align: super;"><path d="M8 0a1 1 0 0 1 1 1v5.268l4.562-2.634a1 1 0 1 1 1 1.732L10 8l4.562 2.634a1 1 0 1 1-1 1.732L9 9.732V15a1 1 0 1 1-2 0V9.732l-4.562 2.634a1 1 0 1 1-1-1.732L6 8 1.438 5.366a1 1 0 0 1 1-1.732L7 6.268V1a1 1 0 0 1 1-1"/></svg><span class="aside">So do asides!</span>
### Subsections too
I can add blockquotes:
{% include essay/feature/blockquote.html
quote="This is a quotation"
speaker="Someone Important" %}
Notice the front matter (between --- lines):
title: Your essay’s titleorder: Controls navigation sequence (1, 2, 3…)
Step 4: Customize Configuration
Edit two main configuration files:
_config.yml - Site Settings
These settings control what appears on your homepage cover page:
title: "Your Essay Title"
author: "Your Name" # Displays as "by Your Name" on cover page
tagline: "A brief description" # Only shows if author is empty
description: "Longer description for search engines (160 chars)"
Cover Page Display:
- title: Your main title (always displays)
- author: Shows as “by [Author Name]” beneath the title
- If you provide an author, it displays instead of the tagline
- You can use HTML for multiple lines:
author: "Author Name<br>Edited by Editor Name"
- tagline: Only displays if author field is empty
- Use for subtitle or project description
- Can also use HTML:
tagline: "A Digital Edition<br>Published 2024"
_data/theme.yml - Appearance
base-theme: essay # or monograph for book-style
# Homepage image
image-style: full-image # full-image, half-image, or no-image
featured-image: /assets/img/your-image.jpg
# Typography
base-font-size: 1.3em
base-font-family: Georgia
You can edit these files directly on GitHub or in any of the editors mentioned in Step 2.
Step 5: Add More Essays
Create additional essay files in _essay/:
_essay/
├── 01-introduction.md (order: 1)
├── 02-chapter-one.md (order: 2)
└── 03-conclusion.md (order: 3)
Essays will appear in navigation based on their order value, not the filename.
Pro tip: Use order values like 10, 20, 30 instead of 1, 2, 3. This makes it easy to insert essays later without renumbering everything.
Step 6: Deploy to GitHub Pages
When you’re ready to publish your site, you have several options, as detailed here on our CollectionBuilder’s Deployment Documentation. You can build and publish these sites wherever you have access to a web server.
Set Up GitHub Pages with Jekyll Action
The most common way to publish these sites is using GitHub Pages. CB-Essay requires a GitHub Action to build properly. Follow these steps to set up deployment:
- Go to your repository and click the Settings menu item at the end of the second row on the page
- Click on the Pages section on the left-hand side
- Under Source, select GitHub Actions
- GitHub will display a Jekyll workflow option - click Configure on that option
- In the workflow file that opens, find line 40 where it says
ruby-version: '3.1' - Change the version from
3.1to3.4 - Click Commit changes to save the workflow file
That’s it! Every time you commit changes from there on out, GitHub Actions will automatically build and deploy your site.
View Your Live Site
After the GitHub Action completes (usually 2-3 minutes), visit:
https://YOUR-USERNAME.github.io/YOUR-REPO-NAME/
Your essay is live! 🎉
Tip: Watch the Actions tab to see the build progress. A green checkmark means your site deployed successfully!
Next Steps
Now that your site is running, explore what you can do:
- Essay Features - Learn all available features with copy-paste examples
- Collection Integration - Add collection items to your essays
Or dive into the documentation.
You’re ready to write! The next essay will show you every available feature with working examples you can copy.