mermaid/docs/mindmap.md

252 lines
6.9 KiB
Markdown
Raw Normal View History

# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT. Please edit the corresponding file in packages/mermaid/src/docs.
2022-09-05 20:40:12 +02:00
2022-08-30 21:38:34 +02:00
# Mindmap
2022-10-08 12:17:26 +08:00
> Mindmap: This is an experimental diagram for now. The syntax and properties can change in future releases. The syntax is stable except for the icon integration which is the experimental part.
2022-08-30 21:38:34 +02:00
2022-09-05 15:47:17 +02:00
"A mind map is a diagram used to visually organize information into a hierarchy, showing relationships among pieces of the whole. It is often created around a single concept, drawn as an image in the center of a blank page, to which associated representations of ideas such as images, words and parts of words are added. Major ideas are connected directly to the central concept, and other ideas branch out from those major ideas." Wikipedia
2022-08-30 21:38:34 +02:00
### An example of a mindmap.
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid-example
mindmap
root((mindmap))
Origins
Long history
::icon(fa fa-book)
Popularisation
British popular psychology author Tony Buzan
Research
On effectivness<br/>and eatures
On Automatic creation
Uses
Creative techniques
Strategic planning
Argument mapping
Tools
Pen and paper
Mermaid
```
2022-08-30 21:38:34 +02:00
```mermaid
mindmap
root((mindmap))
Origins
Long history
::icon(fa fa-book)
Popularisation
British popular psychology author Tony Buzan
Research
On effectivness<br/>and eatures
On Automatic creation
Uses
Creative techniques
Strategic planning
Argument mapping
Tools
Pen and paper
Mermaid
```
2022-09-05 15:47:17 +02:00
2022-08-30 21:38:34 +02:00
## Syntax
The syntax for creating Mindmaps is simple and relies on indentation for setting the levels in the hierarchy.
2022-10-14 10:01:32 +02:00
In the following example you can see how there are 3 different levels of indentation. The leftmost indentation is the root of the mindmap. There can only be one root and if you by misstake add two of them on the same level there will be a syntax error. Rows with larger indentation will be connected as children to the previous row with lower indentation. Based on that you can see in the example how the nodes B and C both are children to node A whci in turn is a child of the node Root.
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
mindmap
Root
A
B
C
2022-08-30 21:38:34 +02:00
2022-10-14 10:01:32 +02:00
In the diagram below you can see the example rendered as a mindmap.
2022-08-30 21:38:34 +02:00
2022-09-05 20:40:12 +02:00
```mermaid-example
mindmap
Root
A
B
C
```
2022-08-30 21:38:34 +02:00
```mermaid
mindmap
Root
A
B
C
```
In this way we can use a text outline to generate a hierarchical mindmap.
## Different shapes
2022-09-05 15:47:17 +02:00
2022-09-02 11:08:26 +02:00
Mermaids mindmaps can show node using different shapes. When specifying a shape for a node the syntax for the is similar to flowchart nodes, with an id followed by the shape definition and with the text within the shape delimiters. Where possible we try/will try to keep the same shapes as for flowcharts even though they are not all supported from the start.
2022-08-30 21:38:34 +02:00
Mindmap can show the following shapes:
### Square
```mermaid-example
mindmap
id[I am a square]
```
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
id[I am a square]
```
2022-08-30 21:38:34 +02:00
### Rounded square
```mermaid-example
mindmap
id(I am a rounded square)
```
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
id(I am a rounded square)
```
2022-08-30 21:38:34 +02:00
### Circle
```mermaid-example
mindmap
2022-08-30 22:08:05 +02:00
id((I am a circle))
2022-08-30 21:38:34 +02:00
```
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
id((I am a circle))
```
2022-09-05 09:53:04 +02:00
### Bang
```mermaid-example
mindmap
id))I am a bang((
```
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
id))I am a bang((
```
2022-09-05 09:53:04 +02:00
### Cloud
2022-08-30 21:38:34 +02:00
2022-09-05 09:53:04 +02:00
```mermaid-example
mindmap
id)I am a cloud(
```
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
id)I am a cloud(
```
2022-08-30 22:08:05 +02:00
### Default
```mermaid-example
mindmap
I am the default shape
```
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
I am the default shape
```
2022-08-30 22:08:05 +02:00
More shapes will be added, beginning with the shapes available in flowcharts.
# Icons and classes
## icons
2022-09-05 15:47:17 +02:00
As with flowcharts you can add icons to your nodes but with an updated syntax. The styling for the font based icons are added during the integration so that they are available for the web page. _This is not something a diagram author can do but has to be done with the site administrator or the integrator_. Once the icon fonts are in place you add them to the mind map nodes using the `::icon()` syntax. You place the classes for the icon within the parenthesis like in the following example where icons for material design and fontawesome 4 are displayed. The intention is that this approach should be used for all diagrams supporting icons. **Experimental feature:** This wider scope is also the reason Mindmaps are experimental as this syntax and approach could change.
2022-08-30 22:08:05 +02:00
```mermaid-example
mindmap
Root
A
::icon(fa fa-book)
B(B)
::icon(mdi mdi-skull-outline)
```
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
Root
A
::icon(fa fa-book)
B(B)
::icon(mdi mdi-skull-outline)
```
2022-08-30 22:08:05 +02:00
## Classes
Again the syntax for adding classes is similar to flowcharts. You can add classes using a triple colon following a number of css classes separated by space. In the following example one of the nodes has two custom classes attached urgent turning the background red and the text white and large increasing the font size:
2022-09-05 15:47:17 +02:00
2022-08-30 22:08:05 +02:00
```mermaid-example
mindmap
Root
A[A]
:::urgent large
B(B)
C
```
2022-09-05 15:47:17 +02:00
2022-09-05 20:40:12 +02:00
```mermaid
mindmap
Root
A[A]
:::urgent large
B(B)
C
```
2022-09-05 15:47:17 +02:00
_These classes needs top be supplied by the site administrator._
2022-08-30 22:08:05 +02:00
2022-08-30 21:38:34 +02:00
## Unclear indentation
2022-09-05 15:47:17 +02:00
2022-08-30 21:38:34 +02:00
The actual indentation does not really matter only compared with the previous rows. If we take the previous example and disrupt it a little we can se how the calculations are performed. Let us start with placing C with a smaller indentation than `B`but larger then `A`.
2022-09-05 20:40:12 +02:00
mindmap
Root
A
B
C
2022-08-30 21:38:34 +02:00
2022-10-14 10:01:32 +02:00
This outline is unclear as `B` clearly is a child of `A` but when we move on to `C` the clarity is lost. `C` is not a child of `B` with a higher indentation nor does it have the same indentation as `B`. The only thing that is clear is that the first node with smaller indentation, indicating a parent, is A. Mermaid will rely on this known truth and compensates for the unclear indentation and selects `A` as a parent of `C` leading till the same diagram with `B` and `C` as siblings.
2022-08-30 21:38:34 +02:00
2022-09-05 20:40:12 +02:00
```mermaid-example
mindmap
Root
A
B
C
```
2022-08-30 21:38:34 +02:00
```mermaid
mindmap
Root
A
B
C
```
2022-11-18 11:28:29 +05:30
## Integrating with your library/website.
Mindmap uses the experimental lazy loading & async rendering features which could change in the future.
```html
<script type="module">
import mermaid from 'https://unpkg.com/mermaid@9/dist/mermaid.esm.min.mjs';
import mindmap from 'https://unpkg.com/@mermaid-js/mermaid-mindmap@9/dist/mermaid-mindmap.esm.min.mjs';
await mermaid.registerExternalDiagrams([mindmap]);
</script>
```
You can also refer the implementation in the live editor [here](https://github.com/mermaid-js/mermaid-live-editor/blob/fcf53c98c25604c90a218104268c339be53035a6/src/lib/util/mermaid.ts) to see how the async loading is done.