2021-01-02 15:55:31 +01:00
|
|
|
---
|
|
|
|
template: overrides/main.html
|
|
|
|
---
|
|
|
|
|
|
|
|
# Diagrams
|
|
|
|
|
|
|
|
Diagrams help to communicate complex relationships and interconnections between
|
|
|
|
different technical components, and are a great addition to project
|
|
|
|
documentation. Material for MkDocs integrates with [Mermaid.js][1], a very
|
|
|
|
popular and flexible solution for drawing diagrams.
|
|
|
|
|
|
|
|
[1]: https://mermaid-js.github.io/mermaid/
|
|
|
|
|
|
|
|
## Configuration
|
|
|
|
|
|
|
|
### SuperFences
|
|
|
|
|
|
|
|
[:octicons-file-code-24: Source][2] ·
|
|
|
|
:octicons-beaker-24: Experimental ·
|
2021-03-13 14:30:29 +01:00
|
|
|
[:octicons-heart-fill-24:{ .mdx-heart } Insiders only][2]{ .mdx-insiders }
|
2021-01-02 15:55:31 +01:00
|
|
|
|
|
|
|
The [SuperFences][3] extension, which is part of [Python Markdown
|
|
|
|
Extensions][4], allows for adding __custom fences__, which can be used to
|
|
|
|
render [Mermaid.js][1] diagrams with zero effort:
|
|
|
|
|
|
|
|
``` yaml
|
|
|
|
markdown_extensions:
|
2021-01-02 16:43:46 +01:00
|
|
|
- pymdownx.superfences:
|
2021-01-02 15:55:31 +01:00
|
|
|
custom_fences:
|
|
|
|
- name: mermaid
|
2021-07-18 17:50:45 +02:00
|
|
|
class: mermaid
|
2021-01-05 18:50:08 +01:00
|
|
|
format: !!python/name:pymdownx.superfences.fence_code_format
|
2021-01-02 15:55:31 +01:00
|
|
|
```
|
|
|
|
|
|
|
|
No further configuration is necessary. Material for MkDocs will automatically
|
|
|
|
load and initialize the [Mermaid.js][1] runtime when a page includes a [fenced
|
|
|
|
`mermaid` block][5]. Furthermore:
|
|
|
|
|
|
|
|
- [x] Works with [instant loading][6] without any additional effort
|
|
|
|
- [x] Diagrams automatically use fonts and colors defined in `mkdocs.yml`[^1]
|
|
|
|
- [x] Fonts and colors can be customized with [additional stylesheets][7]
|
|
|
|
- [x] Support for both, light and dark color schemes
|
|
|
|
|
|
|
|
_While it's also possible to integrate [Mermaid.js][1] using existing
|
2021-02-01 10:11:48 +01:00
|
|
|
third-party plugins[^2], the new native integration is recommended as it
|
2021-01-02 15:55:31 +01:00
|
|
|
ensures interoperability with all Material for MkDocs features._
|
|
|
|
|
|
|
|
[^1]:
|
|
|
|
While all [Mermaid.js][1] features should work out-of-the-box, Material for
|
2021-07-18 17:50:45 +02:00
|
|
|
MkDocs will currently adjust the fonts and colors for flow charts, sequence
|
|
|
|
diagrams, class diagams, state diagrams and entity relationship diagrams.
|
2021-01-02 15:55:31 +01:00
|
|
|
|
|
|
|
[^2]:
|
|
|
|
If you don't want to use the native integration, [mkdocs-mermaid2-plugin][8]
|
|
|
|
might be a good alternative. However, note that this plugin cannot be used
|
2021-01-24 12:34:03 +01:00
|
|
|
in conjunction with the [mkdocs-minify-plugin][9] and doesn't adapt to
|
|
|
|
dark mode.
|
2021-01-02 15:55:31 +01:00
|
|
|
|
2021-03-21 14:04:29 +01:00
|
|
|
[2]: ../insiders/index.md
|
2021-01-02 15:55:31 +01:00
|
|
|
[3]: https://facelessuser.github.io/pymdown-extensions/extensions/superfences/
|
|
|
|
[4]: https://facelessuser.github.io/pymdown-extensions/
|
|
|
|
[5]: #usage
|
|
|
|
[6]: ../setup/setting-up-navigation.md#instant-loading
|
|
|
|
[7]: ../customization.md#additional-css
|
|
|
|
[8]: https://github.com/fralau/mkdocs-mermaid2-plugin
|
|
|
|
[9]: https://github.com/byrnereese/mkdocs-minify-plugin
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
Mermaid diagrams are written as [code blocks][10] with the help of the
|
|
|
|
[SuperFences][11] extension. They must be enclosed with two separate lines
|
2021-07-18 17:50:45 +02:00
|
|
|
containing three backticks.
|
|
|
|
|
|
|
|
[10]: code-blocks.md
|
|
|
|
[11]: #superfences
|
|
|
|
|
|
|
|
### Using flowcharts
|
|
|
|
|
|
|
|
[Flowcharts][12] are diagrams that represent workflows or processes. The steps
|
|
|
|
are rendered as nodes of various kinds and are connected by edges, describing
|
|
|
|
the necessary order of steps.
|
2021-01-02 15:55:31 +01:00
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
|
|
```` markdown
|
|
|
|
``` mermaid
|
|
|
|
graph LR
|
|
|
|
A[Start] --> B{Error?};
|
|
|
|
B -->|Yes| C[Hmm...];
|
|
|
|
C --> D[Debug];
|
|
|
|
D --> B;
|
|
|
|
B ---->|No| E[Yay!];
|
|
|
|
```
|
|
|
|
````
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
2021-06-15 11:03:15 +02:00
|
|
|
``` mermaid
|
|
|
|
graph LR
|
|
|
|
A[Start] --> B{Error?};
|
|
|
|
B -->|Yes| C[Hmm...];
|
|
|
|
C --> D[Debug];
|
|
|
|
D --> B;
|
|
|
|
B ---->|No| E[Yay!];
|
|
|
|
```
|
2021-01-02 15:55:31 +01:00
|
|
|
|
2021-07-18 17:50:45 +02:00
|
|
|
[12]: https://mermaid-js.github.io/mermaid/#/flowchart
|
2021-01-02 15:55:31 +01:00
|
|
|
|
2021-07-18 17:50:45 +02:00
|
|
|
### Using sequence diagrams
|
|
|
|
|
|
|
|
[Sequence diagrams][13] describe a specific scenario as sequential interactions
|
|
|
|
between multiple objects or actors, including the messages that are exchanged
|
|
|
|
between those actors.
|
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
|
|
```` markdown
|
|
|
|
``` mermaid
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>John: Hello John, how are you?
|
|
|
|
loop Healthcheck
|
|
|
|
John->>John: Fight against hypochondria
|
|
|
|
end
|
|
|
|
Note right of John: Rational thoughts!
|
|
|
|
John-->>Alice: Great!
|
|
|
|
John->>Bob: How about you?
|
|
|
|
Bob-->>John: Jolly good!
|
|
|
|
```
|
|
|
|
````
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
|
|
``` mermaid
|
|
|
|
sequenceDiagram
|
|
|
|
Alice->>John: Hello John, how are you?
|
|
|
|
loop Healthcheck
|
|
|
|
John->>John: Fight against hypochondria
|
|
|
|
end
|
|
|
|
Note right of John: Rational thoughts!
|
|
|
|
John-->>Alice: Great!
|
|
|
|
John->>Bob: How about you?
|
|
|
|
Bob-->>John: Jolly good!
|
|
|
|
```
|
|
|
|
|
|
|
|
[13]: https://mermaid-js.github.io/mermaid/#/sequenceDiagram
|
|
|
|
|
|
|
|
### Using state diagrams
|
|
|
|
|
|
|
|
[State diagrams][14] are a great tool to describe the behavior of a system,
|
|
|
|
decomposing it into a finite number of states, and transitions between those
|
|
|
|
states.
|
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
|
|
```` markdown
|
|
|
|
``` mermaid
|
|
|
|
stateDiagram-v2
|
|
|
|
[*] --> Active
|
|
|
|
|
|
|
|
state Active {
|
|
|
|
[*] --> NumLockOff
|
|
|
|
NumLockOff --> NumLockOn : EvNumLockPressed
|
|
|
|
NumLockOn --> NumLockOff : EvNumLockPressed
|
|
|
|
--
|
|
|
|
[*] --> CapsLockOff
|
|
|
|
CapsLockOff --> CapsLockOn : EvCapsLockPressed
|
|
|
|
CapsLockOn --> CapsLockOff : EvCapsLockPressed
|
|
|
|
--
|
|
|
|
[*] --> ScrollLockOff
|
|
|
|
ScrollLockOff --> ScrollLockOn : EvScrollLockPressed
|
|
|
|
ScrollLockOn --> ScrollLockOff : EvScrollLockPressed
|
|
|
|
}
|
|
|
|
```
|
|
|
|
````
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
|
|
``` mermaid
|
|
|
|
stateDiagram-v2
|
|
|
|
[*] --> Active
|
|
|
|
|
|
|
|
state Active {
|
|
|
|
[*] --> NumLockOff
|
|
|
|
NumLockOff --> NumLockOn : EvNumLockPressed
|
|
|
|
NumLockOn --> NumLockOff : EvNumLockPressed
|
|
|
|
--
|
|
|
|
[*] --> CapsLockOff
|
|
|
|
CapsLockOff --> CapsLockOn : EvCapsLockPressed
|
|
|
|
CapsLockOn --> CapsLockOff : EvCapsLockPressed
|
|
|
|
--
|
|
|
|
[*] --> ScrollLockOff
|
|
|
|
ScrollLockOff --> ScrollLockOn : EvScrollLockPressed
|
|
|
|
ScrollLockOn --> ScrollLockOff : EvScrollLockPressed
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
[14]: https://mermaid-js.github.io/mermaid/#/stateDiagram
|
|
|
|
|
|
|
|
### Using class diagrams
|
|
|
|
|
|
|
|
[Class diagrams][15] are central to object oriented programing, describing the
|
|
|
|
structure of a system by modelling entities as classes and relationships between
|
|
|
|
them.
|
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
|
|
```` markdown
|
|
|
|
``` mermaid
|
|
|
|
classDiagram
|
|
|
|
Person <|-- Student
|
|
|
|
Person <|-- Professor
|
|
|
|
Person : +String name
|
|
|
|
Person : +String phoneNumber
|
|
|
|
Person : +String emailAddress
|
|
|
|
Person: +purchaseParkingPass()
|
|
|
|
Address "1" <-- "0..1" Person:lives at
|
|
|
|
class Student{
|
|
|
|
+int studentNumber
|
|
|
|
+int averageMark
|
|
|
|
+isEligibleToEnrol()
|
|
|
|
+getSeminarsTaken()
|
|
|
|
}
|
|
|
|
class Professor{
|
|
|
|
+int salary
|
|
|
|
}
|
|
|
|
class Address{
|
|
|
|
+String street
|
|
|
|
+String city
|
|
|
|
+String state
|
|
|
|
+int postalCode
|
|
|
|
+String country
|
|
|
|
-validate()
|
|
|
|
+outputAsLabel()
|
|
|
|
}
|
|
|
|
```
|
|
|
|
````
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
|
|
``` mermaid
|
|
|
|
classDiagram
|
|
|
|
Person <|-- Student
|
|
|
|
Person <|-- Professor
|
|
|
|
Person : +String name
|
|
|
|
Person : +String phoneNumber
|
|
|
|
Person : +String emailAddress
|
|
|
|
Person: +purchaseParkingPass()
|
|
|
|
Address "1" <-- "0..1" Person:lives at
|
|
|
|
class Student{
|
|
|
|
+int studentNumber
|
|
|
|
+int averageMark
|
|
|
|
+isEligibleToEnrol()
|
|
|
|
+getSeminarsTaken()
|
|
|
|
}
|
|
|
|
class Professor{
|
|
|
|
+int salary
|
|
|
|
}
|
|
|
|
class Address{
|
|
|
|
+String street
|
|
|
|
+String city
|
|
|
|
+String state
|
|
|
|
+int postalCode
|
|
|
|
+String country
|
|
|
|
-validate()
|
|
|
|
+outputAsLabel()
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
[15]: https://mermaid-js.github.io/mermaid/#/classDiagram
|
|
|
|
|
|
|
|
### Using entity-relationship diagrams
|
|
|
|
|
|
|
|
An [entity-relationship diagram][16] is composed of entity types and specifies
|
|
|
|
relationships that exist between entities. It describes inter-related things in
|
|
|
|
a specific domain of knowledge.
|
|
|
|
|
|
|
|
_Example_:
|
|
|
|
|
|
|
|
```` markdown
|
|
|
|
``` mermaid
|
|
|
|
erDiagram
|
|
|
|
CUSTOMER ||--o{ ORDER : places
|
|
|
|
ORDER ||--|{ LINE-ITEM : contains
|
|
|
|
CUSTOMER }|..|{ DELIVERY-ADDRESS : uses
|
|
|
|
```
|
|
|
|
````
|
|
|
|
|
|
|
|
_Result_:
|
|
|
|
|
|
|
|
``` mermaid
|
|
|
|
erDiagram
|
|
|
|
CUSTOMER ||--o{ ORDER : places
|
|
|
|
ORDER ||--|{ LINE-ITEM : contains
|
|
|
|
CUSTOMER }|..|{ DELIVERY-ADDRESS : uses
|
|
|
|
```
|
|
|
|
|
|
|
|
[16]: https://mermaid-js.github.io/mermaid/#/entityRelationshipDiagram
|