Skip to content

Commit

Permalink
Docs: Add minimal hugo build, update docs README (grafana#20905)
Browse files Browse the repository at this point in the history
* initial commit

* remove menu and submenu

* improve layout templates, improve README

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* fix typo

* remove layouts

* update readme, makefile

* update docs command

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>

* Update docs/README.md

Co-Authored-By: Diana Payton <52059945+oddlittlebird@users.noreply.github.com>
  • Loading branch information
robbymilo and oddlittlebird authored Dec 13, 2019
1 parent 096b820 commit e5695b1
Show file tree
Hide file tree
Showing 10 changed files with 23 additions and 226 deletions.
1 change: 1 addition & 0 deletions docs/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
data/menu.yaml
14 changes: 0 additions & 14 deletions docs/Dockerfile

This file was deleted.

40 changes: 2 additions & 38 deletions docs/Makefile
Original file line number Diff line number Diff line change
@@ -1,38 +1,2 @@
.PHONY: all default docs docs-build docs-shell shell checkvars

# to allow `make DOCSPORT=9000 docs`
DOCSPORT := 3004

DOCKER_DOCS_IMAGE := grafana/grafana-docs
SOURCES_HOST_DIR := "$(shell pwd)/sources"

# assuming grafana and grafana.org-repo to be checked out in the same folder
DEFAULT_LAYOUTS_DIR := "$(shell pwd)/../../../../../../grafana.org/layouts"

# to allow `make DOCSDIR=docs docs-shell` (to create a bind mount in docs)
LAYOUTS_MOUNT := $(if $(LAYOUTS),-v $(DEFAULT_LAYOUTS_DIR):/site/layouts)
DOCS_MOUNT := -v $(SOURCES_HOST_DIR):/site/content

DOCKER_RUN_DOCS := docker run --rm -it $(DOCS_MOUNT) $(LAYOUTS_MOUNT) -e NOCACHE -p 3004:3004 -p 3005:3005

VERSION := $(shell head -n 1 VERSION)

default: docs

checkvars:
ifndef ENV
$(error ENV is undefined set via ENV=staging or ENV=prod as argument to make)
endif

docs: docs-build
$(DOCKER_RUN_DOCS) $(DOCS_MOUNT) -e DOCKERHOST "$(DOCKER_DOCS_IMAGE)" /bin/bash -c "grunt --env=dev-docs && grunt connect --port=3004"

watch: docs-build
$(DOCKER_RUN_DOCS) $(DOCS_MOUNT) $(LAYOUTS_MOUNT) -e DOCKERHOST "$(DOCKER_DOCS_IMAGE)" /bin/bash -c "grunt --env=dev-docs && grunt connect --port=3004 & grunt watch --port=3004 --env=dev-docs"

publish: checkvars docs-build
$(info Publishing ENV=${ENV} and VERSION=${VERSION})
$(DOCKER_RUN_DOCS) $(DOCS_MOUNT) -e DOCKERHOST "$(DOCKER_DOCS_IMAGE)" /bin/bash -c "./publish.sh ${ENV}-docs ${VERSION}"

docs-build:
docker build -t "$(DOCKER_DOCS_IMAGE)" --no-cache .
docs:
docker run -v $(PWD)/sources:/hugo/content/docs/grafana/latest -p 3002:3002 --rm -it grafana/docs-base:latest
92 changes: 20 additions & 72 deletions docs/README.md
Original file line number Diff line number Diff line change
@@ -1,90 +1,38 @@
### Note for external contributors
# Building the docs locally

We are currently working on migrating the docs to a new static website. The `grafana/website` repository will be private during this migration, which unfortunately means the docs site can't be built without access.
When you contribute to documentation, it is a good practice to build the docs on your local machine to make sure your changes appear as you expect. This README explains the process for doing that.

The Markdown content however, is still public in this repository. We still encourage pull requests to make the docs better, and we will make sure the changed content works well on the current docs site. Include any images in your pull request, and we will move them to the `grafana/website` repository.
## Requirements

# Building the docs
Docker >= 2.1.0.3

To build the docs locally, you need to have Docker installed. The docs are built using [Hugo](http://gohugo.io/) - a static site generator.
## Build the doc site

**Prepare the Docker image**:
1. In the command line, make sure you are in the docs folder: `cd docs`.
2. Run `make docs`. This launches a preview of the docs website at `http://localhost:3002/docs/grafana/latest/` which will refresh automatically when changes to content in the `sources` directory are made.

> Due to migration to new static site, the Docker image needs to be built from `old-docs` branch.
---

Git clone `grafana/website` repo. Run these commands in the root of that repo. **Note** that you may require `sudo`
when running `make docs-build` depending on how your system's Docker
service is configured):
## Content guidelines

```
git clone https://github.com/grafana/website
cd website
make docs-build
```
Edit content in the `sources` directory.

**Build the Documentation**:
### Using `relref` for internal links

Now that the Docker image has been prepared we can build the
grafana docs and start a docs server.
Use the Hugo shortcode [relref](https://gohugo.io/content-management/cross-references/#use-ref-and-relref) anytime you are linking to other internal docs pages.

If you have not cloned the Grafana repository already then:
### Edit the side menu

```
cd ..
git clone https://github.com/grafana/grafana
```
Edit [sources/menu.yaml](sources/menu.yaml) to make changes to the sidebar. Restart the `make run` command for changes to take effect.

Switch your working directory to the directory this file
(README.md) is in.
### Add images

```
cd grafana/docs
```
Images are currently hosted in the grafana/website repo.

An AWS config file is required to build the docs Docker image and to publish the site to AWS. If you are building locally only and do not have any AWS credentials for docs.grafana.org then create an empty file named `awsconfig` in the current directory.
---

```
touch awsconfig
```
## Deploy changes to grafana.com

Then run (possibly with `sudo`):
When a PR is merged to master with changes in the `docs` directory, those changes are automatically synched to the grafana/website repo on the `docs-grafana` branch.

```
make watch
```

This command will not return control of the shell to the user. Instead
the command is now running a new Docker container built from the image
we created in the previous step.

Open [localhost:3004](http://localhost:3004) to view the docs.

### Images and Content

All markdown files are part of [this repository](https://github.com/grafana/grafana). However, all images are added to the [website repository](https://github.com/grafana/website). Therefore, the process of adding images is not as straightforward. These are the steps:

1. Ensure you create a feature branch within the [website repository](https://github.com/grafana/website) to make the change. This branch needs to be based on the `old-docs` branch.
1. Ensure the image(s) are compressed and optimised e.g. Using [tinypng](https://tinypng.com/).
1. Add the image(s) to the `/static/img/docs` directory.
1. Then, make a commit that adds the image(s).
1. The Pull Request you create needs to target where you branched off, the branch `old-docs`.

Finally, run:

```
make docs-build
```

This will rebuild the docs Docker image.

To be able to use your image(s) you have to quit (Ctrl+C) the `make watch` command (that you run in the same directory as this README). Then simply rerun `make watch`, it will restart the docs server but now with access to your image(s).

### Editing content

Changes to the markdown files should automatically cause a docs rebuild and live reload should reload the page in your browser.

### Troubleshooting

#### Running `make watch` errors out with `Warning: Task "default" not found.`

Ensure that the Docker image from the [website repository](https://github.com/grafana/website) is built using the `old-docs` branch.
In order to make those changes live, open a PR in the website repo that merges the `docs-grafana` branch into `master`. Then follow the publishing guidelines in that repo.
20 changes: 0 additions & 20 deletions docs/config.toml

This file was deleted.

Binary file removed docs/logo-horizontal.png
Binary file not shown.
64 changes: 0 additions & 64 deletions docs/logo-swirl.svg

This file was deleted.

3 changes: 0 additions & 3 deletions docs/publish.sh

This file was deleted.

11 changes: 0 additions & 11 deletions docs/s3_website.json

This file was deleted.

4 changes: 0 additions & 4 deletions docs/yarn.lock

This file was deleted.

0 comments on commit e5695b1

Please sign in to comment.