Skip to content

Latest commit

 

History

History
129 lines (78 loc) · 6.83 KB

github-pages-pipeline.md

File metadata and controls

129 lines (78 loc) · 6.83 KB

GitHub Pages Pipeline – Challenge

The Challenge

The challenge we have is to automate the conversion of an HTML/XHTML book source into a GitHub Pages website. We have the example sources and current website that we want to replicate.

The preference is for our option 2 solution as this will allow for a W3C HTML complaint GitHub Pages workflow.

Completion of this challenge would mean the ADA Pipeline can fully automate its output to GitHub.

NB: The next challenge will be to implement WebBook Level 1 Unofficial Proposal Draft, 2 February 2018, Daniel Glazman.

About ADA Pipeline software

Mission

An infrastructural open-source software project to support workflows for open science digital objects and improving open standards in multi-format book publishing.

Software

The ADA Pipeline is an open-source collaborative book authoring workflow that generates publication ready outputs as multi-format.

ADA uses automatic typesetting, and versioning. The output formats targets are: website, paginated web, screen PDF, print-on-demand PDF, eBook, and source.

ADA chains together different tools in as an extensible pipeline, currently including the following key applications: Fidus Writer, Vivliostyle, and GitHub.

Over 20 books have been made with over 100 authors using ADA.

Example book websites

Here are two example books, one using Jekyll and the other Hugo for website display.

If you would like to try out the system email or DM Simon Worthington, [email protected] – Twitter: @mrchristian99

The problem that needs to solve

Our problem is producing Markdown that will work with GitHub Pages.

The pipeline outputs a variety of file formats and any of these could be used for a tranformation to Markdown.

It important to look at these new output file examples ( > 4 Nov 21) as output file markup has been changed over time.

Example sources

See files here: https://github.com/TIBHannover/ADA-Reference-Publication

Other respositories will have older file types with outdated markup.

Output formats include:

  • HTML as a unified file
  • Multifile HTML
  • Unzipped EPUB
  • EPUB
  • LaTeX

Ideas for options to solve the problem

For both options the ADA Pipeline is designed in a way that the user forks a template repository from our master repository and then writes their book source file automatically to the forked repository. This template repository still need to be made, but can quickly be put together.

  1. Better Markdown conversion with CI on GitHub
  2. Use a source file, e.g., the unified single HTML files and render this is GitHub Pages

Options explained

Option 1. Better Markdown conversion with CI on GitHub

We have used a variety of tools to generate markdown but each options has problems. One eample was with R, 'fidus2GitHub' https://github.com/akademie-oeffentliches-gesundheitswesen/fidus2github

What we need is a process to take one of our output files and and convert it to Markdown and make it work with this framework / theme – Docsify https://docsify.js.org/#/

The idea would be that we find a library for Markdown transformation, have a CI process running on GitHub, then process files and output on for GitHub Pages to serve the files.

If the user adds new source files to GitHub pages then the CI would be processed and new Markdown files generated.

For the Docsify theme files need to be placed in a specific directory. For some settings of the theme some additional field content needs inputting, this could be done by direct file editing on GitHub.

Option 2. Use a source file, e.g., the unified single HTML files and render this is GitHub Pages

A more elegant option is to use the unified HTML output as Markdown only gets rendered back to HTML for display.

The idea would be that a piece of JavaScript would need to be written to make the navigation menu similar to how the different Markdown frameworks to. And we need and a few other features.

This option also does away with a CI process being needed.

The process could also use some standard web CSS framework.

What we need the system to do

Our current semi-automatic process has following features that we need to replace in this new solution to our problem.

  1. Present the book in the same way the current Docsity setup does - https://health-sprints.github.io/Should-Schools-Reopen/#/report/chapter_0
  2. Produce a navigation menu from the document headers
  3. Add title at top of navigation
  4. Be mobile first
  5. Have a previous, next at the bottom of chapters, which are defined as H2 by Fidus Writer. The 'previous, next' might not be needed in the unified HTML files, as opposed to other source versions which are multi-document types.
  6. Have a fixed header set of menus that link to files on GitHub for the different versions: webbook, PDF, eBook, print-on-demand page, GitHub source, verion history, release history and publisher. These links can mostly be static links as we have a set directory structure for the book.
  7. Adding GitHub Release number and GitHub Version number added to the site somehow as showing version histories is important to our publishing project. A simple approach here is only to Releases and that way these can be added in book info and metadata by the author.

Current workflow

ADA workflow

Diagram source

Applications used