mermaid/docs/directives.md

85 lines
3.3 KiB
Markdown
Raw Normal View History

2020-10-25 00:30:20 -07:00
# Directives
2020-10-28 00:37:33 -07:00
**Edit this Page** [![N|Solid](img/GitHub-Mark-32px.png)](https://github.com/mermaid-js/mermaid/blob/develop/docs/directives.md)
## Directives
2022-01-18 23:02:16 +01:00
Directives gives a diagram author the capability to alter the appearance of a diagram before rendering by changing the applied configuration.
2020-11-08 18:58:46 -08:00
2021-01-21 23:29:22 -08:00
Directives are divided into two sets or orders, by priority in parsing. The first set, containing 'init' or 'initialize' directives are loaded ahead of any other directive. While the other set, containing all other kinds of directives are parsed and factored into the rendering, only after 'init' and the desired graph-type are declared.
2021-01-21 23:29:22 -08:00
### Init
2020-07-17 20:00:24 -07:00
| Parameter | Description |Type | Required | Values|
| --- | --- | --- | --- | --- |
| init | modifies configurations| Directive| Optional | Any parameters not included in the secure array|
**Notes:**
init would be an argument-directive: %%{init: { **insert argument here**}}%%
2020-11-08 18:58:46 -08:00
The json object that is passed as {**argument** } must be valid key value pairs and encased in quotation marks or it will be ignored.
2022-01-18 23:02:16 +01:00
Valid Key Value pairs can be found in config.
2020-11-08 18:58:46 -08:00
The init/initialize directive is parsed earlier in the flow, this allows the incorporation of `%%init%%` directives into the mermaid diagram that is being rendered. Example:
2021-11-10 18:04:40 -08:00
```mmd
%%{init: { 'logLevel': 'debug', 'theme': 'dark' } }%%
graph >
A-->B
```
2022-01-18 23:02:16 +01:00
will set the `logLevel` to `debug` and the `theme` to `dark` for a flowchart diagram, changing the appearance of the diagram itself.
2020-11-08 18:58:46 -08:00
Note: 'init' or 'initialize' are both acceptable as init directives. Also note that `%%init%%` and `%%initialize%%` directives will be grouped together after they are parsed. This means:
2022-01-18 23:02:16 +01:00
```mmd2
%%{init: { 'logLevel': 'debug', 'theme': 'forest' } }%%
%%{initialize: { 'logLevel': 'fatal', "theme":'dark', 'startOnLoad': true } }%%
...
```
2020-11-08 18:58:46 -08:00
parsing the above generates the `%%init%%` object below, combining the two directives and carrying over the last value given for `loglevel`:
```json5
{
logLevel: 'fatal',
theme: 'dark',
startOnLoad: true
}
```
2020-11-08 18:58:46 -08:00
This will then be sent to `mermaid.initialize(...)` for rendering.
2021-01-21 23:29:22 -08:00
### Other directives
2021-01-21 23:29:22 -08:00
In this category are any directives that come after the graph type declaration. Essentially, these directives will only be processed after the init directive. Each individual graph type will handle these directives. As an example:
2022-01-18 08:00:06 +01:00
```
%%{init: { 'logLevel': 'debug', 'theme': 'dark' } }%%
sequenceDiagram
%%{config: { 'fontFamily': 'Menlo', 'fontSize': 18, 'fontWeight': 400} }%%
Alice->>Bob: Hi Bob
Bob->>Alice: Hi Alice
```
## Chronology
This will set the `logLevel` to `debug` and `theme` to `dark` for a sequence diagram. Then, during processing, the config for the sequence diagram is set by the `config` directive. This directive is handled in the `sequenceDb.js`. In this example, the fontFamily, fontSize, and fontWeight are all set for this sequence diagram.
2021-01-21 23:29:22 -08:00
### Wrapping
## Wrap
| Parameter | Description |Type | Required | Values|
| --- | --- | --- | --- | --- |
| wrap | a callable text-wrap function| Directive| Optional | %%{wrap}%%|
#### Backwards Compatibility
2020-07-17 20:00:24 -07:00
Init directives and any other non-multiline directives should be backwards compatible, because they will be treated as comments in prior versions of mermaid-js.
Multiline directives, however, will pose an issue and will render an error. This is unavoidable.
2022-01-18 23:02:16 +01:00
# example
2021-04-17 23:05:12 -07:00