Skip to content

Latest commit

 

History

History

website

Weave GitOps Product Website

This website is built using Docusaurus 2, a modern static website generator. It requires Node.js installed on your system. Install or Update your current setup for Node.js from here Install yarn from here

The website is live here.

Developing the docs

Start a local development server

  1. Change into the website directory: cd website.

  2. Install dependencies: yarn install.

  3. Set a fake Google Analytics API key to pass validation errors: export GA_KEY=fakekey

  4. Start the docs server.

    If you are using newer version of Node (17+):

    export NODE_OPTIONS=--openssl-legacy-provider
    yarn start

    This will open a browser window. Your changes will be automatically loaded by the server.

Making changes to the docs

Below are some things to be aware of when adding content, such as where we store things and how we manage the sidebar. For general info on how to build a Docusaurus site, check their docs.

Directory layout

  • The docs are kept in docs/
  • Any images or assets are kept in static/
  • Custom CSS is kept in src/css
  • Non-versioned (ie non-product) docs are kept in src/pages
  • Older versions of docs are kept in versioned_docs
  • React components used by files under docs/ are kept in docs/components

General notes on style and content

Not all the below will apply, take them as hints.

  • An intro explaining why they would want this thing
  • A summary of what the tutorial will acheive
  • Prerequisites
  • Notes on assumed knowledge
  • Screenshots (ones you can actually read)
  • Emojis
  • Colourful admonitions
  • Short paragraphs (no big wall of text)
  • Bullet points
  • Getting too long? Break down into multiple pages
  • Enterprise tags (if required)

How to add a new page to a sidebar

All our sidebars (2 at the time of writing) are managed in the sidebars.js file. When you want to add a new file, simply slot it in where it fits best. Do not add sidebar_position at the top of files.

How to do internal links

Because we version our docs, all links refering to another doc must be relative paths. For example if in docs/intro.mdx you want to link to docs/releases.mdx, you would write this as [link to releases](../releases).

If paths are absolute (eg [link to release](/docs/releases)), then the links are not prepended with their version information. This means they will link to the latest instance of the page, which in some cases may not exist. Relative paths ensure that they point to the version and location of the page which existed at that moment in time.

Making changes to older versions

Most of the time you will not need to touch the contents of versioned_docs/ but occasionally you may need to backfill fixes or missing feature documentation. In that case, once you have made the changes to the main docs under docs/, copy the changes over to the correct version in versioned_docs/. If you need to change the sidebar at that point, change the correct version in versioned_sidebars.

How to change the navbar

The navbar is controlled in docusaurus.config.js. It is important to note that this is not (and cannot be) versioned, meaning that if you change the navbar that change will be present for all versions.

How to add yaml/json/console output without making it painful

Our product comes with a lot of yaml, and we need to document that. However, too much can saturate a page and make it hard to read. It can also be easy to miss bits of text lying in between large chunks of yaml. The solution is to collapse large yaml, json or console output sections with <details> tags.

Smaller chunks are usually fine. But for anything more that 10 lines it is neater to wrap it.

<details><summary>Expand to see this awesome HelmRepository</summary>

Don't forget to leave a line break below the opening tag...
```yaml
---
woohoo:
  such: yaml
```
and before the closing one.

</details>
Expand to see this awesome HelmRepository

Don't forget to leave a line break below the opening tag...

---
woohoo:
  such: yaml

and before the closing one.

How to add screenshots

Please, please, zoom in before you take the shot. I promise they don't need to see the whole page, just the bit you are talking about is fine.

After you have finished your changes

Check that the docs build with GA_KEY=fakekey yarn build.

The build will also be run on the PR, but it is convenient to run it before you open one.

Deploying the docs

Do not attempt to deploy the docs manually.

Deployment happens automatically (once the tests pass) upon merging to the main branch: see .github/workflows/docs.yaml for config.

Terminology

This section lists commonly used terms in the docs in an effort to promote consistency.

  • Leaf clusters: used in Weave GitOps Enterprise to describe any CAPI or non-CAPI clusters that appear in the Clusters section of the UI. Typically, these clusters are running application workloads.