Note
sphinxcontrib-mermaid is actively seeking new maintainers.
As the original creator, I'm no longer able to dedicate the time and
attention needed. If you're interested in contributing and helping to
drive this project forward, please see this
issue.
This extension allows you to embed Mermaid graphs in your documents, including general flowcharts, sequence diagrams, gantt diagrams and more.
It adds a directive to embed mermaid markup. For example:
.. mermaid::
sequenceDiagram
participant Alice
participant Bob
Alice->John: Hello John, how are you?
loop Healthcheck
John->John: Fight against hypochondria
end
Note right of John: Rational thoughts <br/>prevail...
John-->Alice: Great!
John->Bob: How about you?
Bob-->John: Jolly good!By default, the HTML builder will simply render this as a div tag with
class="mermaid", injecting the external javascript, css and
initialization code to make mermaid works.
For other builders (or if mermaid_output_format config variable is set
differently), the extension will use
mermaid-cli to render as to
a PNG or SVG image, and then used in the proper code.
sequenceDiagram
participant Alice
participant Bob
Alice->John: Hello John, how are you?
loop Healthcheck
John->John: Fight against hypochondria
end
Note right of John: Rational thoughts <br/>prevail...
John-->Alice: Great!
John->Bob: How about you?
Bob-->John: Jolly good!
You can also embed external mermaid files, by giving the file name as an argument to the directive and no additional content:
.. mermaid:: path/to/mermaid-gantt-code.mmdAs for all file references in Sphinx, if the filename is not absolute, it is taken as relative to the source directory.
In addition, you can use mermaid to automatically generate a diagram to
show the class inheritance using the directive autoclasstree. It
accepts one or more fully qualified names to a class or a module. In the
case of a module, all the class found will be included.
Of course, these objects need to be importable to make its diagram.
If an optional attribute :full: is given, it will show the complete
hierarchy of each class.
The option :namespace: <value> limits to the base classes that belongs
to this namespace. Meanwhile, the flag :strict: only process the
classes that are strictly defined in the given module (ignoring classes
imported from other modules).
For example:
.. autoclasstree:: sphinx.util.DownloadFiles sphinx.util.ExtensionError
:full:.. autoclasstree:: sphinx.util.DownloadFiles sphinx.util.ExtensionError
:full:
Or directly the module:
.. autoclasstree:: sphinx.util.. autoclasstree:: sphinx.util
You can install it using pip
pip install sphinxcontrib-mermaidThen add sphinxcontrib.mermaid in extensions list of your project's
conf.py:
extensions = [
...,
'sphinxcontrib.mermaid'
]sphinxcontrib-mermaid mermaid diagrams can be configured by rst/md frontmatter:
.. mermaid::
:name: test
<diagram>```mermaid
---
name: test
---
<diagram>name: determines the image's name for HTML output. NOTE: mermaid will use this as theidof the generatedsvgelement, which can be useful for styling with custom css:#mydiagram > svg { height: 1000px }alt: determines the image's alternate text for HTML output. If not given, the alternate text defaults to the mermaid code.align: determines the image's position. Valid options are'left','center','right'caption: can be used to give a caption to the diagram.zoom: can be used to enable zooming the diagram. For a global config seemermaid_d3_zoombellow.
fullscreen: can be used to enable fullscreen modal viewing of the diagram. For a global config seemermaid_fullscreenbelow.config: JSON to pass through to the mermaid configuration. NOTE: The mermaid documentation uses YAML, but we must use JSON because Markdown processing of frontmatter will interfere.title: Title to pass through to the mermaid configuration
The output format for Mermaid when building HTML files. This must be
either 'raw' 'png' or 'svg'; the default is 'raw'.
mermaid-cli is required if it's not raw
The command name with which to invoke mermaid-cli program. The
default is 'mmdc'; you may need to set this to a full path if it's
not in the executable search path. If a string is specified, it is
split using [shlex.split]{.title-ref} to support multi-word commands.
To avoid splitting, a list of strings can be specified. Examples:
mermaid_cmd = 'npx mmdc'
mermeid_cmd = ['npx', '--no-install', 'mmdc']When set to true, the shell=True argument will be passed the process
execution command. This allows commands other than binary executables
to be executed on Windows. The default is false.
For individual parameters, a list of parameters can be added. Refer to Examples:
mermaid_params = ['--theme', 'forest', '--width', '600', '--backgroundColor', 'transparent']This will render the mermaid diagram with theme forest, 600px width and transparent background.
Allows overriding the sequence diagram configuration. It could be useful to increase the width between actors. It needs to be a json file Check options in the documentation
Use the verbose mode when call mermaid-cli, and show its output in the building process.
If using latex output, it might be useful to crop the pdf just to the
needed space. For this, pdfcrop can be used. State binary name to
use this extra function.
Optional override of arguments to mermaid.initialize(), passed in as
a JSON. Defaults to { "startOnLoad": True}.
The version of mermaid that will be used to parse raw output in HTML
files. This should match a version available on
https://www.jsdelivr.com/package/npm/mermaid.
The default is "11.12.1".
Optional path to a local installation of mermaid.esm.min.mjs. By
default, we will pull from jsdelivr.
Whether to download and load the ELK JavaScript extensions. Defaults to False.
Whether to download and load the ZenuML JavaScript extensions. Defaults to False.
The version of mermaid ELK renderer that will be used. The default is
"0.2.0".
The version of mermaid ZenuML renderer that will be used. The default
is "0.2.2".
Optional path to a local installation of
mermaid-layout-elk.esm.min.mjs. By default, we will pull from
jsdelivr.
Optional path to a local installation of mermaid-zenuml.esm.min.mjs.
By default, we will pull from jsdelivr.
Optional path to a local installation of d3.min.js. By default, we
will pull from jsdelivr.
The version of d3 that will be used to provide zoom functionality on
mermaid graphs. The default is "7.9.0".
Enables zooming in all the generated Mermaid diagrams.
Sets the default diagram width within its container. Default to 100%.
Sets the default diagram height within its container. Default to 500px.
Enables fullscreen modal viewing for all Mermaid diagrams. When enabled, a fullscreen button appears in the top-right corner of each diagram. Clicking it opens the diagram in a fullscreen modal overlay. The modal can be closed by pressing ESC, clicking outside the diagram, or clicking the close button. This feature is theme-agnostic and works with any Sphinx theme.
Customizes the fullscreen button icon/text. Default is "⛶". You can
use any Unicode character or emoji, for example "🔍" or "⛶".
Customizes the fullscreen button opacity, to avoid fully obscuring
important chart content. Default is 50 (percent). You can use any
value from 0 to 100. Button becomes fully opaque on hover.
You can include Mermaid diagrams in your Markdown documents in Sphinx. You just need to setup the markdown support in Sphinx via myst-parser . See a minimal configuration from the tests.
Then in your .md documents include a code block as in
reStructuredTexts:
```{mermaid}
sequenceDiagram
participant Alice
participant Bob
Alice->John: Hello John, how are you?
```For GitHub cross-support, you can omit the curly braces and configure myst to use the [mermaid]{.title-ref} code block as a myst directive. For example, in `conf.py`:
myst_fence_as_directive = ["mermaid"]In order to have Mermaid diagrams build properly in PDFs generated on readthedocs.io, you will need a few extra configurations.
- In your
.readthedocs.yamlfile (which should be in the root of your repository) include apost-installcommand to the Mermaid CLI:
build:
os: ubuntu-20.04
tools:
python: "3.8"
nodejs: "16"
jobs:
post_install:
- npm install -g @mermaid-js/mermaid-cliNote that if you previously did not have a .readthedocs.yaml file,
you will also need to specify all targets you wish to build and other
basic configuration options. A minimal example of a complete file is:
# .readthedocs.yaml
# Read the Docs configuration file
# See https://docs.readthedocs.io/en/stable/config-file/v2.html for details
# Required
version: 2
# Set the version of Python and other tools you might need
build:
os: ubuntu-24.04
apt_packages:
- libasound2t64
tools:
python: "3.11"
nodejs: "20"
jobs:
post_install:
- npm install -g @mermaid-js/mermaid-cli
# Build documentation in the docs/ directory with Sphinx
sphinx:
configuration: docs/conf.py
# If using Sphinx, optionally build your docs in additional formats such as PDF
formats:
- epub
- pdf
python:
install:
- requirements: docs/requirements.txt- In your documentation directory add file
puppeteer-config.jsonwith contents: :
{
"args": ["--no-sandbox"]
}- In your documentation
conf.pyfile, add: :
mermaid_params = ['-p', 'puppeteer-config.json']