#mdbook #mermaid #book #js

bin+lib mdbook-mermaid

mdbook preprocessor to add mermaid support

38 releases

0.17.0 Nov 18, 2025
0.16.0 Sep 16, 2025
0.15.0 Mar 28, 2025
0.14.0 Sep 11, 2024
0.2.2 Jul 16, 2019

#291 in Text processing

Download history 4577/week @ 2025-09-22 4743/week @ 2025-09-29 4281/week @ 2025-10-06 3660/week @ 2025-10-13 5402/week @ 2025-10-20 6208/week @ 2025-10-27 3594/week @ 2025-11-03 2835/week @ 2025-11-10 3210/week @ 2025-11-17 3957/week @ 2025-11-24 5099/week @ 2025-12-01 3296/week @ 2025-12-08 3865/week @ 2025-12-15 2008/week @ 2025-12-22 2323/week @ 2025-12-29 3914/week @ 2026-01-05

12,309 downloads per month
Used in 3 crates

MPL-2.0 license

2.5MB
3K SLoC

JavaScript 2.5K SLoC // 0.0% comments Rust 479 SLoC // 0.0% comments

mdbook-mermaid

A preprocessor for mdbook to add mermaid.js support.

It turns this:

```mermaid
graph TD;
    A-->B;
    A-->C;
    B-->D;
    C-->D;
```

into this:

Simple Graph

in your book. (Graph provided by Mermaid Live Editor)

Installation

From source

To install it from source:

cargo install mdbook-mermaid

This will build mdbook-mermaid from source.

Using cargo-binstall

If you have cargo-binstall already:

cargo binstall mdbook-mermaid

This will download and install the pre-built binary for your system.

Manually

Binary releases are available on the Releases page. Download the relevant package for your system, unpack it, and move the mdbook-mermaid executable into $HOME/.cargo/bin:

Configure your mdBook to use mdbook-mermaid

When adding mdbook-mermaid for the first time, let it add the required files and configuration:

mdbook-mermaid install path/to/your/book

This will add the following configuration to your book.toml:

[preprocessor.mermaid]
command = "mdbook-mermaid"

[output.html]
additional-js = ["mermaid.min.js", "mermaid-init.js"]

It will skip any unnecessary changes and detect if mdbook-mermaid was already configured.

Additionally it copies the files mermaid.min.js and mermaid-init.js into your book's directory. You find these files in the src/bin/assets directory. You can modify mermaid-init.js to configure Mermaid, see the Mermaid documentation for all options.

Finally, build your book:

mdbook path/to/book

Development

Update the bundled mermaid.js

Find the latest version of mermaid on https://github.com/mermaid-js/mermaid/releases. Then run:

cargo xtask <version>

This will fetch the minified mermaid.js file and commit it.

Note: mdbook-mermaid does NOT automatically update the mermaid.min.js file in your book. For that rerun

mdbook-mermaid install path/to/your/book

or manually replace the file.

License

MPL. See LICENSE.
Copyright (c) 2018-2024 Jan-Erik Rediger janerik@fnordig.de

Mermaid is MIT licensed. The bundled assets (mermaid.min.js) are MIT licensed.

Dependencies

~12–16MB
~226K SLoC