A static Jekyll site for doaj.org
Ruby is required.
gem install jekyll
git clone https://github.com/DOAJ/doaj-static.gitcd doaj-staticjekyll s- Navigate to
http://127.0.0.1:4000in your browser - You must make changes locally (and not via Github) to see them.
git clone https://github.com/DOAJ/doaj-static.gitcd doaj-staticjekyll build- Compiled static HTML, CSS, & JS will be found in
_site/
Each static page is represented by a single .md file.
Most of the content of doaj.org’s pages can be edited in either Markdown (.md) or input into a database-like YAML file (.yml).
Static content is usually long-form, unstructured texts, as seen in the Data documentation and About pages.
This content is found in the following directories (each representing a section of the site):
about/index.md: the main About section page (Mission, History)advisory-board-council.mdfaq.mdteam-ambassadors.mdvolunteers.md
apply/guide.mdseal.mdtransparency.mdwhy-index.md
data/openurl.mdpublic-data-dump.mdwidgets.mdxml.md
support/index.md: the main Support section page (Support DOAJ)publisher-supporters.mdsponsors.mdsupporters.md
Each static Markdown page includes YAML front matter at the top of the document which indicates:
layout:- the layout to be used for that page
- for now, we only have
sidenav,data,two-col-data: TO BE RENAMED
title:- the page title displayed in
<h1>and<title>tags
- the page title displayed in
toc(trueorfalse):- whether or not we want a table of contents on the side, for in-page navigation
highlight(trueorfalse):- whether or not the page should start with a highlight section (slightly darker background, as seen in the homepage’s search box)
Whenever we have structured content that could be stored in a database (e.g. records of people or organisations with metadata), we use Jekyll’s data files.
Data files can be in CSV, YAML, or JSON and are uploaded in the _data/ directory (not to be confused with the data/ section).
We are currently using the YAML (.yml) format, but are not restricted to it.
The following information is represented in data files:
- About section
- Advisory Board:
advisory-board.yml - Council:
council.yml - Team:
team.yml - Ambassadors:
ambassadors.yml - Volunteers:
volunteers.yml
- Advisory Board:
- Support section
- Publisher supporters:
publisher-supporters.yml - Sponsors:
sponsors.yml - Supporters:
supporters.yml
- Publisher supporters:
- Other
- Promotional snippet (in page sidebar):
promo.yml
- Promotional snippet (in page sidebar):
Make sure to follow the indentation and line breaks of already-existing records when adding a new line or entry.
Advanced tools:
- StackEdit, an in-browser Markdown editor (might be useful for much longer text and helps with the creation of UML diagrams)
- Typora, a downloadable Markdown editor app
- Rename and harmonise base templates (
sidenav,data) - Add a promo post category so we can target content for specific pages
- Finish inputting data in
volunteers.yml - Add & style bio photos for
team.yml+team-ambassadors.md - Add appropriate Paypal forms for each page of the Support section
- Make menu responsive
- Create Footer content pages (legal / admin pages)
- Create Thank you pages (application form, Paypal support form)
- Check content for broken or missing links, typos
- Review all content with the team with Hypothesis & update text
- Run HTML5 validator on all pages & fix errors
- Run Lighthouse’s automated a11y tests on all pages & fix errors