Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Decathlon/slate-builder-action

GitHub Action to build Slate Documentation
https://github.com/Decathlon/slate-builder-action

actions documentation-tool github-actions

Last synced: 3 months ago
JSON representation

GitHub Action to build Slate Documentation

Awesome Lists containing this project

README

        

# Slate Documenation Builder Action
GitHub action to build repositories Markdown files using the [slate framework](https://github.com/lord/slate)

**Table of Contents**

- [Slate Documenation Builder Action](#slate-documenation-builder-action)
- [Getting Started](#getting-started)
- [Using as GitHub Action](#using-as-github-action)
- [Settings for v2.0.0+ release](#settings-for-v200-release)
- [Advanced configuration](#advanced-configuration)
- [Get the Result](#get-the-result)
- [Complete Workflow Example](#complete-workflow-example)

## Getting Started
The docker image can be used to locally build your markdown files. For this you need, first of all, to build the docker image:

```bash
docker build -t decathlon/slate-builder .
```

Once built run the container using the following command:

```bash
docker run -it --rm -v :/usr/src/doc decathlon/slate-builder
```

The slate build result will be stored into the build subdir of ``.

## Using as GitHub Action

### Settings for v2.0.0+ release

Create a file into your root project directory: .github/workflows/slate-builder-action.yml:

```
on: push
name: Create Slate Documentation on Push
jobs:
slate-documentation:
runs-on: ubuntu-18.04
steps:
- uses: actions/checkout@master
- name: Build documentation
uses: docker://decathlon/slate-builder-action:2.0.0
env:
DOC_BASE_FOLDER = "."
```

The `DOC_BASE_FOLDER` environement variable is the path, in your gitHub repository, containing the Markdown files you want to build as Slate website.

#### Advanced configuration
You can override the default Slate template, providing a repository containing your custom slate template.

```
on: push
name: Create Slate Documentation on Push
jobs:
slate-documentation:
runs-on: ubuntu-18.04
steps:
- uses: actions/checkout@master
- name: Build documentation
uses: docker://decathlon/slate-builder-action:2.0.0
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
DOC_BASE_FOLDER = "."
TEMPLATE_REPO = "decathlon/custom-slate"
```

The `GITHUB_TOKEN` secrets variable contains the [Private Access Token](https://help.github.com/en/articles/creating-a-personal-access-token-for-the-command-line). This secret is mandatory if you want to access to a private repository but you can leave it empty if the template you want to use is opensource.

##### Get the Result
The result is built into `DOC_BASE_FOLDER/build` folder. You have to chain this action with one taking care about deployment, delivery, or whatever you want to do with your built documentation.
To simplify the export, the result is zipped into `DOC_BASE_FOLDER/documentation.zip`. You can disable the zipping function providing `ZIP_BUILD=false` as environment variable.

```
on: push
name: Create Slate Documentation on Push
jobs:
slate-documentation:
runs-on: ubuntu-18.04
steps:
- uses: actions/checkout@master
- name: Build documentation
uses: docker://decathlon/slate-builder-action:2.0.0
env:
DOC_BASE_FOLDER = "."
ZIP_BUILD = "false"
```

## Complete Workflow Example

Ih this example the workflow is started if we are on the `master` branch and an `md` file is delivered. In this case:
* the documention is built
* the new version is deployed as GitHub Pages

```
on: push
name: Create Slate Documentation on Push
jobs:
action-filter:
runs-on: ubuntu-18.04
steps:
- uses: actions/checkout@master
- name: action-filter
uses: actions/bin/filter@master
with:
args: branch master
- name: files-filter
uses: wcchristian/gh-pattern-filter-action@master
with:
args: .*\\.md$
- name: Build documentation
uses: docker://decathlon/slate-builder-action:2.0.0
env:
DOC_BASE_FOLDER: .
ZIP_BUILD: false
- name: Deploy to GitHub Pages
uses: docker://maxheld83/[email protected]
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
BUILD_DIR: test-documentation/build/
```