etl/DOCUMENTATION.md
2026-03-25 19:47:59 +00:00

145 lines
5.5 KiB
Markdown

# Viewing the documentation locally
The documentation for this project is built using [Hugo](https://gohugo.io/), a static site generator.
This guide will walk you through installing Hugo and running the documentation site on your machine.
---
## Prerequisites
- You must have already cloned this repository, including its submodules (the Hugo themes are stored as submodules).
- If you cloned without submodules, run this first:
```bash
git submodule update --init --recursive
```
---
## Step 1: Install Hugo Extended
This project requires the **extended** version of Hugo, which includes support for additional features such as SCSS/Sass processing.
Make sure you install the extended version, not the standard one.
### Windows
1. The easiest way to install Hugo on Windows is via [Chocolatey](https://chocolatey.org/). If you have it installed, open a command prompt as Administrator and run:
```bash
choco install hugo-extended -y
```
2. If you don't have Chocolatey, you can download Hugo Extended directly from the [Hugo releases page](https://github.com/gohugoio/hugo/releases).
Download the file named `hugo_extended_x.x.x_windows-amd64.zip`, extract it, and add the folder to your system PATH.
3. Verify the installation by opening a new command prompt and running:
```bash
hugo version
```
You should see the word **extended** in the output, for example: `hugo v0.x.x+extended`.
### macOS
1. The easiest way to install Hugo Extended on macOS is via [Homebrew](https://brew.sh/). Homebrew installs the extended version by default. If you have it installed, open a terminal and run:
```bash
brew install hugo
```
2. If you don't have Homebrew, you can install it first by following the instructions at [brew.sh](https://brew.sh/), then run the command above.
3. Verify the installation by running:
```bash
hugo version
```
You should see the word **extended** in the output, for example: `hugo v0.x.x+extended`.
### Linux
1. Package managers often provide an older or non-extended version of Hugo, so the recommended approach is to download the latest extended release directly from the [Hugo releases page](https://github.com/gohugoio/hugo/releases).
Download the file named `hugo_extended_x.x.x_linux-amd64.tar.gz`, then run:
```bash
tar -xzf hugo_extended_x.x.x_linux-amd64.tar.gz
sudo mv hugo /usr/local/bin/
```
2. Verify the installation by running:
```bash
hugo version
```
You should see the word **extended** in the output, for example: `hugo v0.x.x+extended`.
---
## Step 2: Run the documentation site
1. Open a terminal (or command prompt on Windows) and navigate to the `hugo` directory inside the project:
```bash
cd hugo
```
2. Start the Hugo development server:
```bash
hugo server
```
3. Hugo will start a local web server. You will see output similar to:
```
Web Server is available at http://localhost:1313/
```
4. Open your browser and go to **http://localhost:1313/** to view the documentation.
---
## Stopping the server
To stop the Hugo server, go back to your terminal and press **Ctrl+C**.
---
## Editing the Documentation
The documentation source files are located in the `/docs` directory at the root of the repository —
**not** inside the `hugo` directory. Hugo is configured to mount this directory automatically via
`hugo.toml`, so any changes you make to files in `/docs` will be picked up by the Hugo development
server straight away.
Here is a quick overview of where things live:
```
hugo/
├── layouts/ # HTML templates (you probably won't need to touch these)
├── themes/ # The Hugo theme (managed as a git submodule)
└── hugo.toml # Hugo configuration file (includes the /docs content mount)
docs/
└── section-name/ # Each subdirectory becomes a section in the documentation
├── _index.md # The landing page for that section
└── my-page.md # Individual pages within the section
```
### Adding or Editing a Page
All documentation pages are written in **Markdown** (`.md` files). To edit an existing page, open
the relevant `.md` file in the `/docs` directory and make your changes.
The documentation is written in [Goldmark](https://github.com/teekennedy/goldmark-markdown) markdown.
Hugo uses [Goldmark](https://github.com/teekennedy/goldmark-markdown) as its default Markdown processor for versions 0.60.0 and newer.
It is built into Hugo, providing high-performance and fully [CommonMark](https://commonmark.org/)-compliant rendering, along with support for [GitHub](https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax) Markdown.
### Starting a New Page
A template file is provided at `docs/page-template.md` to use as a starting point. Copy it to the
appropriate section directory, rename it, and edit the front matter, in particular, change the
`title` and remove the `draft: true` line, otherwise Hugo will not include your page in the
documentation.
### Previewing Your Changes
If you have the Hugo development server running (see [Step 2](#step-2--run-the-documentation-site)),
your changes will appear in the browser automatically as soon as you save the file. There is no need
to restart the server.
### Images and Other Assets
If you need to include images in your documentation, place them in the `hugo/static/` directory and
reference them in your Markdown like so:
```markdown
![Alt text](/my-image.png)
```
The site will automatically refresh in your browser whenever you save changes to the documentation files.