Skip to content

Commit

Permalink
docs: revise developer guide documentation BM-1081 (#3368)
Browse files Browse the repository at this point in the history
### Motivation

As a Basemaps developer, when I run Basemaps locally using the
[developer guide][docs/dev-guide], assets (glyphs and sprites) don't
load when enabling the labels feature or viewing the Topographic layer.

- This pull request updates the [developer guide][docs/dev-guide]
documentation to include details about the additional parameters
required to serve vector tile imagery with assets.

- This pull request also includes some minor cleanup and re-formatting
of the existing [developer guide][docs/dev-guide] documentation.

### Modifications

#### Additions

1. Adds a [call-out][ref/call-out] to the [**How to run `basemaps`
locally**][docs/run-basemaps-locally] page describing how to build
Basemaps in _watch mode_. [[commit]][commit/watch-mode]

2. Adds a new page titled **"Bundle the `basemaps` assets archive"** to
the [CLI methods][docs/dev-guide] section. The new page describes how to
generate the **basemaps** bundled assets archive using the
**basemaps/cli** package. [[commit]][commit/assets-usage-wip-1]

3. Adds details to the [Server methods][docs/dev-guide] section's
[**Serve `basemaps` using a bundled config
file**][docs/bundled-config-file] page describing the value of the
assets archive and why you may need to use it.
[[commit]][commit/assets-usage-wip-2]

4. Adds details to the new **"Bundle the `basemaps` assets archive"**
page describing how to generate the asset files (glyph files and sprite
sheets) required to bundle the assets archive.
[[commit]][commit/assets-usage]

#### Revisions

1. Removes unused internal links from various documentation pages.
[[commit]][commit/internal-links]

2. Updates code example commands to reference `build` directories
instead of `bin` directories. [[commit]][commit/build-bin]

3. Corrects the description and usage of the `--output` parameter when
running the **basemaps/cli** package. [[commit]][commit/output-desc]

4. Fixes minor spelling errors and formatting inconsistencies for
various documentation pages. [[commit]][commit/formatting]

### Verification

You can view the updated [developer guide][docs/dev-guide] documentation
by following these steps.

1. Switch to this branch (`docs/dev-guide-revison`).

2. Run the following command from the root of the repository:

```bash
# serve the Basemaps docs locally
docker run --rm \
    -v $PWD:/docs \
    -p 8000:8000 \
    ghcr.io/linz/basemaps-mkdocs:v1 serve -a 0.0.0.0:8000
```

<!-- internal links -->

[commit/watch-mode]:
3df0686
[commit/assets-usage-wip-1]:
c118d83#diff-a3ddf2f482248ee60c9134a7a95c6e6de6023c852c9873b9a6d234671abb6fd1
[commit/assets-usage-wip-2]: 

c118d83#diff-4e24348b01ae8e99d94927c006a6fc7f52a762f519bd9876ccb3126b83ef542a
[commit/assets-usage]:
03b5a3e

[commit/internal-links]:
7f7c9a6
[commit/build-bin]:
ec967f0
[commit/output-desc]:

b30435d
[commit/formatting]:

1e769da

<!-- external links -->

[docs/dev-guide]: https://basemaps.linz.govt.nz/docs/developer-guide/
[docs/run-basemaps-locally]:
https://basemaps.linz.govt.nz/docs/developer-guide/run-basemaps-locally/
[docs/bundled-config-file]:
https://basemaps.linz.govt.nz/docs/developer-guide/server-methods/serve-basemaps-with-bundled-config-file/

[ref/call-out]:
https://squidfunk.github.io/mkdocs-material/reference/admonitions/
  • Loading branch information
tawera-manaena authored Nov 27, 2024
1 parent 3b1a6fa commit c3c795b
Show file tree
Hide file tree
Showing 5 changed files with 265 additions and 59 deletions.
158 changes: 158 additions & 0 deletions docs/developer-guide/cli-methods/bundle-the-basemaps-assets-archive.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,158 @@
# Bundle the `basemaps` assets archive

This guide explains how to generate the `basemaps` bundled assets archive using the **basemaps/cli** package.

## Get started

Clone the [**linz/basemaps-config**][bm_config_repo] repository to your machine.

=== "HTTPS"

```bash
git clone https://github.com/linz/basemaps-config.git
```

=== "SSH"

```bash
git clone [email protected]:linz/basemaps-config.git
```

=== "GitHub CLI"

```bash
gh repo clone linz/basemaps-config
```

!!! abstract "Paths"

This guide uses variables as shorthand to reference key directories and files. On your machine, note the following paths:

=== "`BM_CONFIG_REPO`"

The path to the **basemaps-config** repository folder on your machine.

```bash
$BM_CONFIG_REPO = {path_to}/basemaps-config
```

=== "`BM_CLI_BUILD`"

The **basemaps/cli** package provides a **bundle-assets** function we can use to generate a bundled assets archive.

The path to the **build** folder of the **basemaps/cli** package.

```bash
$BM_CLI_BUILD = $BM_REPO/packages/cli/build/cli
```

=== "`BM_SPRITES_BIN`"

The **basemaps/sprites** package provides a default function we can use to generate sprite sheets from a collection of sprite images.

The path to the **bin** folder of the **basemaps/sprites** package.

```bash
$BM_SPRITES_BIN = $BM_REPO/packages/sprites/bin
```

## Generate the `basemaps` assets

### 1. Create local directory

To prepare for bundling the `basemaps` assets archive, create a local directory on your machine with the following subdirectory structure:

```md
- assets
- fonts
- sprites
```

You can specify a location and directory name of your choice.

!!! abstract "Path"

On your machine, consider the following path:

=== "`ASSETS_DIR`"

The path to the created directory on your machine.

```bash
$ASSETS_DIR = {path_to_directory}
```

### 2. Convert fonts into `.pbf` (protobuf-encoded glyphs) files

To generate the `basemaps` `.pbf` files, follow the instructions described in this [README.md][fonts_readme] file. Alternatively, there is a [repository][pbf_fonts_repo] containing various fonts that have already been converted into the `.pbf` format.

Move the generated and/or downloaded collections of `.pbf` files **into** the following directory:

```
$ASSETS_DIR/assets/fonts
```

The contents of your `$ASSETS_DIR/assets/fonts` directory should look similar to the following:

```md
- $ASSETS_DIR/assets/fonts
- Noto Sans Bold
- 0-255.pbf
- ...
- Open Sans Bold
- 0-255.pbf
- ...
```

### 3. Convert sprite files into sprite sheets

Use the following command to generate the `basemaps` sprite sheets from the collection of topographic sprite files:

```bash
node $BM_SPRITES_BIN/basemaps-sprites.mjs \
$BM_CONFIG_REPO/config/sprites/topographic
```

The above command will output the resulting sprite sheets to the location from which you executed the command. Move the outputted files **into** the following directory:

```md
$ASSETS_DIR/assets/sprites
```

The contents of your `$ASSETS_DIR/assets/sprites` directory should look similar to the following:

```md
- $ASSETS_DIR/assets/sprites
- topographic.json
- topographic.png
- [email protected]
- [email protected]
```

## Run the `basemaps/cli` package

### Command

Use the following command to bundle the `basemaps` assets archive:

```bash
node $BM_CLI_BUILD/bin.js bundle-assets \
--assets $ASSETS_DIR \
--output assets.bundle.tar.co \
```

### Parameters

=== "`--assets`"

Specifies the location of the assets folder to use. This folder refers to that which contains the `.pbf` files and sprite sheets on your local machine.

=== "`--output`"

Specifies where to save the bundled assets archive, relative to the location from which you execute the command. You can specify a location and filename of your choice.

<!-- external links -->

[bm_config_repo]: https://github.com/linz/basemaps-config
[fonts_readme]: https://github.com/linz/basemaps-config/tree/master/config/fonts
[pbf_fonts_repo]: https://github.com/korywka/fonts.pbf
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,10 @@ Clone the [**linz/basemaps-config**][bm_config_repo] repository to your machine.
gh repo clone linz/basemaps-config
```

!!! abstract "Path"
!!! abstract "Paths"

This guide uses variables as shorthand to reference key directories and files. On your machine, note the following paths:

=== "`BM_CONFIG_REPO`"

The path to the **basemaps-config** repository folder on your machine.
Expand All @@ -44,14 +44,14 @@ Clone the [**linz/basemaps-config**][bm_config_repo] repository to your machine.
$BM_CONFIG_REPO = {path_to}/basemaps-config
```

=== "`BM_CLI_BIN`"
=== "`BM_CLI_BUILD`"

The **basemaps/cli** package provides a **bundle** function we can use to generate a bundled config file.

The path to the **bin** folder of the **basemaps/cli** package.
The path to the **build** folder of the **basemaps/cli** package.

```bash
$BM_CLI_BIN = $BM_REPO/packages/cli/bin
$BM_CLI_BUILD = $BM_REPO/packages/cli/build/cli
```

## Run the `basemaps/cli` package
Expand All @@ -61,9 +61,9 @@ Clone the [**linz/basemaps-config**][bm_config_repo] repository to your machine.
Use the following command to bundle the `basemaps` config file:

```bash
node $BM_CLI_BIN/bmc.js bundle \
node $BM_CLI_BUILD/bin.js bundle \
--config $BM_CONFIG_REPO/config \
--output $BM_REPO/config/config.bundle.json \
--output config.bundle.json \
--cache s3://linz-basemaps-staging/basemaps-config/cache/
```

Expand All @@ -75,18 +75,12 @@ node $BM_CLI_BIN/bmc.js bundle \

=== "`--output`"

Specifies where to save the bundled config file. You can specify a location of your choice. This guide specifies the `basemaps` repository for convenience.
Specifies where to save the bundled config file, relative to the location from which you execute the command. You can specify a location and filename of your choice.

=== "`--cache`"

Specifies the location of the cache directory. This parameter is optional but recommended to reduce the time needed to construct the config file.

<!-- internal links -->

[running-basemaps-locally]: ../running-basemaps-locally.md
[configuring-the-basemapsserver-package]: ../running-basemaps-locally.md#2-configuring-the-basemapsserver-package
[path-to-json-config-file]: ../Server%20Methods/json-config-file.md

<!-- external links -->

[bm_config_repo]: https://github.com/linz/basemaps-config
[bm_config_repo]: https://github.com/linz/basemaps-config
10 changes: 10 additions & 0 deletions docs/developer-guide/run-basemaps-locally.md
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,15 @@ npm run build
npm run test
```

!!! tip

You can build the `basemaps` packages in [watch mode][tsc_watch] so that they recompile anytime you modify the source code. In a terminal, navigate to `BM_REPO` and run the following command:

```bash
# Generate the <package_name>/build for each package (watch mode)
npm run build -- --watch
```

## Configure the `basemaps/server` package

There are two main ways you can configure and run the **basemaps/server** package:
Expand All @@ -103,3 +112,4 @@ There are two main ways you can configure and run the **basemaps/server** packag
[configuration]: https://github.com/linz/basemaps/blob/master/docs/configuration.md
[contributing]: https://github.com/linz/basemaps/blob/master/CONTRIBUTING.md
[stac]: https://github.com/radiantearth/stac-spec/blob/master/overview.md
[tsc_watch]: https://www.typescriptlang.org/docs/handbook/project-references.html#tsc--b-commandline
Loading

0 comments on commit c3c795b

Please sign in to comment.