Skip to content

Site builder for the Fortunoff Critical Editions software

Notifications You must be signed in to change notification settings

jakekara/essay-formatter

Repository files navigation

essay-formatter

Build Critical Editions sites around your data

About

This site builder is used to generate https://editions.fortunoff.library.yale.edu.

It works by converting your configuration files into structured data designed to be read by the Critical Editions Viewer app and then stuffing them into a new copy of the production build of that app. It is also being used to power two forthcoming Fortunoff publishing projects.

Quickstart

$ pip install git+https://github.com/jakekara/essay-formatter
$ essay-formatter init my-project

Initiating Critical Editions site
=================================
 📂 Created directory my-project
 📄 Copied start content

 ✨ Finished building project in my-project!

To start hacking, type: 
	cd "my-project"

To build with start content, run:
	 essay-formatter build content

To view the site run:
	essay-formatter serve build

Hosting your site

Now that you have a skeleton of a site up and running locally, you'll want to think about how you're going to make it accessible over the Web. There are two basic approaches — putting your "build" folder on a static web hosting service, like AWS s3, or through a version-controlled, continuous integration approach.

Static site hosting (s3 example)

This is the simplest option from a technical standpoint. All you need is a place you can store your static files, such as Amazon's AWS s3 bucket service.

Because this application is based on React, your web host needs to be set up to redirect all traffic to "index.html" so that page routing will work. In s3 this can be done by specifying index.html as both the error document and the default index.

Once the host is configured, you can copy the contents of your build folder over to it each time you rebuild with the essay-formatter build command described above.

Continuous integration hosting (netlify example)

A better way to deploy your site is with a service like netlify, which can monitor your content repository and build a new version of the site every time you push a commit. It can even make different sites for each branch, so you can make a branch for edits, and then a main branch that is used for the production version of your site.

To configure your netlify site for this repo, you need to have a _redirects file in your public directory that contains the following:

/*    /index.html   200

This file is included in the starter site that you get when you run essay-formatter init

You also have to change your build command in the Netlify dashboard.

Here's the command:

    python setup.py install && essay-formatter build {YOUR_CONTENT_FOLDER}

Make sure to replace YOUR_CONTENT_FOLDER with the name of your content folder.

Finally, change the publish directory to build, which is the folder that gets generated by the essay-formatter build command.

Customizing site data

The essay-formatter init command above creates a project folder and seed it with content in the content subdfolder. This is where all of the data for your site lives, and each time you rebuild the site with essay-formatter build, the files in the content folder are formatted and bundled into the new build.

The content folder looks like this:

my-project/content
├── chapter-1.md
├── public
│   └── img
│       ├── ImpactHeaderBackground.jpg
│       ├── header-logo.svg
│       ├── impact-header-background.jpg
│       ├── org-logo.svg
│       └── parent-logo.svg
└── settings.yaml

Let's go through the contents:

  • chapter-1.md - This and any Markdown file will be converted into an "essay" or "chapter" within your critical edition app. Each Markdown file corresponds to one link on the home page. These markdown files must contain certain metadata at the top for the build to be successful, but many fields may be omitted. The exact formatting for these files is discussed below.
  • settings.yaml - This contents site-wide settings, like the name of the project. The exact formatting for this file is discussed below.
  • public - Anything in the public directory will be copied into the build, overwriting any files that are already there each time the build subcommand is run. You should replace these files with images and logos that are appropriate for your project.

settings.yaml

This file contains project-level metadata, as well as a list specifying the order in which essays (or "chapters" if you prefer) should appear on the index page.

Here's an example of settings.yaml.

title: A book
subtitle: A book by an author
introCopy: This is where you can put a paragraph describing your project. Keep it short.
homeLink: https://google.com
callToAction: true
impactImageCaption: "Photo: Here's where to put your image caption"
organizationName: Your Org
parentOrganizationName: Your University
parentOrganizationURL: https://google.com
textOnlyIndexPage: false
showBylinesOnIndexPage: true
showSupertitlesOnIndexPage: true
essayOrder:
  - chapter-1
  - chapter-2

Each item in essayOrder corresponds to a slug specified in the essay's markdown file.

Essay Markdown files

All of the .md files in the content directory must begin with a code block of type yaml:meta containing certain metadata properties. For example, check out chapter-1.md, or see below:

supertitle: Chapter 1
title: Actual chapter name
author: John Doe
publicationDate: Feb. 2021
slug: chapter-1

Supported Markdown features

The current version of this software supports a limited subset of Markdown features. It supports basic paragraphs, headings, blockquotes, as well as the extended markdown syntax for footnotes. Here's an example of a plain footnote:

This is a sentence with a footnote.[^1]

[^1]: Footnotes are a great feature, and very import in academic content.

In addition to these Markdown features, you may add embedded content to footnotes like so:

This is a sentence with a footnote.[^1]

[^1]: Footnotes are a great feature, and very import in academic content.

```yaml:embed
footnote: 1
code: '<...>'
```

In addition to numerically labeled footnotes, essay-formatter also supports footnotes that are given arbitrary string labels. They can even be non-unique, if you provide a unique id for each footnote. The syntax is:

this is a labeled footnote[^10=Doe, 1998].

[^10=Doe, 1998]: foo

In the above example, "10" is the unique ID for the footnote and "Doe, 1998" is the footnote label that willbe rendered. Implementing this feature led to development of this open source Marko extension for labeled footnotes.

Images are added like this:

```yaml:block
type: "image"
data:
    src: "https://example.com/path/to/img.jpg"
    caption: 'Caption for the image goes here'
```

Aviary embeds are added like this:

```yaml:aviary
ead_id: mssa.hvt.0237
tape: 2
start_time: 600
end_time: 620
caption: Test video embed from 00:10:00 to 00:10:20
```

"2" subcommands

The above documentation describes the most common uses of essay-formatter — the init, build, and serve subcommands.

essay-formatter also has tools to convert individual files from html to Markdown (html2markdown), from markdown to html (markdown2html), and from html to json (html2json) — the "2" subcommands.

These tools may be helpful for initilally preparing your data, if you have it in one form or another. (The particular flavor of JSON is a format used by editor.js and used by the underlying critical edition client software).

The all follow the same basic usage pattern, taking an input file and producing an output file. The help for the markdown2html subcommand is listed below:

usage: essay-formatter markdown2html [-h] [-i INFILE] [-o OUTFILE]

optional arguments:
  -h, --help            show this help message and exit
  -i INFILE, --infile INFILE
                        input Markdown file
  -o OUTFILE, --outfile OUTFILE
                        output HTML file

Updating the core template

This site builder is meant to be a turnkey solution for building Critical Editions sites. It uses a core template that was built with the Fortunoff Video Archive's needs in mind. If the configuration options aren't enough customization for you, then you will need to modify the core template. That resides in a different repository from this site builder.

About

Site builder for the Fortunoff Critical Editions software

Resources

Stars

Watchers

Forks

Packages

No packages published