Skip to content

Latest commit

 

History

History
316 lines (208 loc) · 15.2 KB

README.md

File metadata and controls

316 lines (208 loc) · 15.2 KB

eSSIF-Lab Framework

This repo contains files that are used to generate the eSSIF-Lab framework website.

This README file describes

  • how contributions can be made.
  • how to test such contributions for the correct structure/syntax.
  • how the repo is setup so that it automatically updates the website.

It helps to know that your contributions will consist of texts that have a simple structure that is a bit peculiar and you'll need to get acquainted with that. When your contribution is complete, these texts are then further processed by some tools that will turn it into a nice (static) website. For this repo, the tools we use are Docusaurus 2, and a custom plugin (developed by GRNET) that we call Terminolovy Engine v1 (or TEv1) that allows you to enhance the terms in your text that have been properly defined (this is what makes the terms stand out on the website, and produces the popups when readers hover over them).

How To Contribute

In order to contribute, you need to

Contributions can be made by creating new, or modifying existing files in the repo

  • to the body of the framework. That's where contributions to the vision, objectives, principles etc. can be made. The corresponding files live in the /docs directory of the framework repo;
  • to the terminology (and mental models) of the framework. That's where contributions can be made to (definitions and descriptions of) terms that we use, as well as the mental models. The corresponding files live in the /docs/terms directory of the repo.

The easiest way to start is to look at existing files so that you get an idea of how things are done. You'll quickly find out that they are markdown files that consist of two parts:

  • a 'header', i.e. a block of text at the top of the file that starts with three dashes (---), then has multiple lines that consists of fields (keywords and associated values (texts)), and concludes with another three dashes (---). Headers like this are not usual in markdown files, but they are in this repo.
  • a 'body', i.e. all the text that follows the header, which uses the typical basic markdown syntax. However, you can also use additional markdown features.

The Header (or Front Matter)

The header serves two purposes:

  1. it contains fields that are necessary to turn the files into a nice website. This is done by Docusaurus 2. Docusaurus calls this header data 'markdown front matter'.
  2. it also contains fields that are used by the TEv1. that allows you to enhance the terms in your text that have been properly defined (this is what makes the terms stand out on the website, and produces the popups when readers hover over them).

The easiest way to go about header fields is to look at existing files as examples that work.

Header fields that are used by Docusaurus are documented here.

Header fields that are specific for the Terminology Engine

The Body

Writing Docusaurus Documents

Docusaurus requires documentation content to appear in .md files inside the docs folder. Each file defines the following attributes at its very beginning:

  • id, by which the file is referred to across the project
  • title, appearing at the top of the file's display
  • sidebar_label, the file's name appearing in the sidebar

Documentation on these and other header fields can be found here.

The Terminology Engine plugin of GRNET uses additional header fields. These are (or will be) defined here.

The sidebars.js file contains the basic mechanism for distributing content among sections and is self-explanatory (compare with the sidebar appearing here). Subsections within the .md file (that is, tagged with ##) will appear at the right part of the page (see for example here).

Inserting Images in docs

If you want to add an image, say example.png, here is what you do:

  • first, add the image to the /static/images directory (or /static/images/subdir-path/)
  • then, in your document, add a line behind the docusaurus header that says: import useBaseUrl from '@docusaurus/useBaseUrl';
  • next, in your document, at the place where you want the image to be presented, insert the following snippet:
<img
  alt="text-that-shows-if-the-image-cannot-be-found"
  src={useBaseUrl('images/example.png')}
/>

(or src={useBaseUrl('images/subdir-path/example.png')} if you added the image file there).

Installation

You must be able to use yarn in order to run the local development server. If you face an error similar to ERROR: There are no scenarios; must have at least one, refer here for a correct re-installation of yarn.

Local Development

$ yarn
$ yarn start

The first command is for linking dependencies. The second starts a local development server and opens up a browser window. Note that not all browsers work with this - for example, Microsoft Edge doesn't work. Chrome and FireFox however do. When developing, most changes are reflected live without having to restart the server.

Build

$ yarn build

This command generates static content into the build directory and can be served using any static contents hosting service.

Deployment via Github Pages

GitHub Pages provides hosting that comes for free with every GitHub repository.

The master branch has the latest changes to the content of the website.

❗ Avoid pushing changes directly to master. The best practice is to create a new branch, apply your changes and then merge the new branch to master once you make sure that it won't break the deployment of the website.

Workflow

The workflow in the framework repository, has the following jobs:

  • checks job: runs some checks, to make sure that the merged changes will not break the deployment

    These checks run on all the branches but master

  • gh-release job: takes care of the deployment

    The release job runs only when another branch gets merged to master and the changes affect the artifact of the deployment

❗ The branch that the website will be deployed to, defaults to gh-pages. The result of the release job (build directory) is stored in the gh-pages branch, so the developer should not apply changes directly to gh-pages branch. All changes must be merge to the master branch, and then the release job will start running automatically.

In order to deploy a new version of the website, follow the procedure below:
  1. Create locally a new branch from master (ex. feature-gh-branch branch)

  2. Add and commit your changes locally

  3. Push your changes to the remote feature-gh-branch branch

  4. To create a Pull Request to master, go to the repository's page on Github, in the Pull requests tab, and click New pull request

  5. In the compare: dropdown list, choose the branch you want to merge with master (in this case with feature-gh-branch), and review the changes

Github compare branches

Then, click Create Pull Request button to proceed

  1. You will get prompted to the pull request page, where the checks of the PR are launched automatically, as part of the workflow

Github PR checks

When the PR passes all the checks and it has no conflicts with the master branch, you can click the Merge pull request button, to merge the changes

Github PR page

Once the merging is over, the PR will change status from Open to Merged

Github PR merged

  1. In the Actions page you can review all the running workflows.

Github PR merged

Now that the feature-gh-branch got merged to master, the release job started running, to update the website.

Github PR merged

Once the job is completed, the new version of the website will be available here: https://essif-lab.github.io/framework/

The Activity log of the deployments is available here: https://github.com/essif-lab/framework/deployments/activity_log

Terminology/Glossary plugin usage

This project has a plugin integrated that can generate terms in a useful way so contributors can write a special syntax to reference terms and generate a glossary based on those terms.

This plugin is designed to work in the pre-build stage.dc up This means, it is strongly suggested that you do not run manually the script in your local computer (or at least do not commit changes). In order to view the final result, you can instead use Docker and/or Docker Compose, as follows.

Docker

You can run the following commands to see the output of the website, just as it will look like when deployed to a production environment:

docker build -t essif-lab-framework:latest .
docker run -ti -p 5000:5000 essif-lab-framework:latest

You can then visit http://localhost:5000 to view the website

To stop docker from running, you can just hit ctrl+c in the terminal window.

Docker Compose

Docker Compose is a wrapper of docker, so you can run less commands to do the same job as you would do with docker commands. You only need to run:

docker-compose up --force-recreate --build

and then visit http://localhost:5000 to view the website.

To stop docker-compose, just like docker, hit ctrl+c in the terminal window.

Terminology/Glossary plugin explanation

How it works

This plugin parses docs in two ways:

  1. Parses all *.mdx files under docs/ and replaces each pattern with an appropriate React component supporting a tooltip functionality (see below)
  2. Generates a glossary with all terms corresponding to the *.md files under docs/terms/.

Parses all markdown files and generates a glossary page with all the pattern terms found in the .md files

Replace patterns with dynamical elements

When writing docs, in order to refer to a term, you may use the following syntax:

%%term_text|term_name%%

where:

  • term_text: The terminology text you want it to be visible in the documentation page
  • term_name: The filename of the term file, which resides under ./docs/terms directory.

inside docs/*.mdx files. After successfully running the script, the above occurrence will be replaced by a React component, which will render term_text as a link to the corresponding term page, which is in turn generated from the term_name attribute; furthermore, hovering over term_text displays a term summary, as extracted from the corresponding term page.

Example usage

Say you want to reference a term that exists under the ./docs/terms/ directory, e.g. ./docs/terms/party.md. You can use the following syntax to reference this term in your documentation page:

Some content that wants to reference the %%party|party%% term

When the script runs, this will be replaced as follows:

Some content that wants to reference the <Term reference="party" popup="hovertext provided in the party.md file">Party</Term> term

which supports the functionality explained above.

How to correctly write a term

This plugin assumes that you follow the structure, as explained below:

Each term should have its own .md file, inside the ./docs/terms directory. For example, you can define the term term in file term.md, which would then exist as ./docs/terms/term.md.

These files must have the following structure:

---
id: term
title: Term page
hoverText: "This text will appear as a popup when the term is referenced in a documentation page."
glossaryText: "This text will appear as a description of the term in the glossary that is generated."
date: 20210601
---

### Term explanation

content here

Pay attention to the hoverText attribute, as it's important to provide this attribute (along with the default docusaurus attributes), so the plugin can fetch the correct popup text to show when referencing a term. The hoverText MUST NOT contain %%-references!

The glossaryText attribute may contain references to (other) terms, but, for technical reasons, the syntax is slightly different: You should write %%term text^term-name%% (i.e. not use the | character as in %%term text|term-name%%

Running the script

When you are finished referencing terms and have written corresponding term pages, you can test this locally by running the following command:

$ yarn parse
yarn run v1.22.5
 docusaurus parse
Replacing patterns with <Term />
Done in 1.41s.

This will replace all %%term_text|term_name%% occurrences with the React component supporting the required functionality.

Generate the glossary page

If everything works well with the above procedure, you can then generate a glossary page, by running the following command:

$ yarn glossary
yarn run v1.22.5
 docusaurus glossary
Alphabetical list of terms
Done in 1.53s.

This will generate a file in ./docs/glossary.md where every term that has been mentioned above, will be populated in the glossary.md page.