forked from grafana/grafana
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Docs: Add minimal hugo build, update docs README (grafana#20905)
* initial commit * remove menu and submenu * improve layout templates, improve README * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * fix typo * remove layouts * update readme, makefile * update docs command * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]> * Update docs/README.md Co-Authored-By: Diana Payton <[email protected]>
- Loading branch information
1 parent
096b820
commit e5695b1
Showing
10 changed files
with
23 additions
and
226 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
data/menu.yaml |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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. |
This file was deleted.
Oops, something went wrong.
Binary file not shown.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.