mirror of
				https://github.com/mermaid-js/mermaid.git
				synced 2025-10-25 00:44:10 +02:00 
			
		
		
		
	 06e44f5da8
			
		
	
	06e44f5da8
	
	
	
		
			
			* fix typos * fix typo * fix typo * fix typo * fix typos * fix typos * fix typos * fix typos * fix typos * fix typo * fix typo * chore: Update docs --------- Co-authored-by: Sidharth Vinod <sidharthv96@gmail.com>
		
			
				
	
	
		
			867 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			867 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| > **Warning**
 | |
| >
 | |
| > ## THIS IS AN AUTOGENERATED FILE. DO NOT EDIT.
 | |
| >
 | |
| > ## Please edit the corresponding file in [/packages/mermaid/src/docs/syntax/sequenceDiagram.md](../../packages/mermaid/src/docs/syntax/sequenceDiagram.md).
 | |
| 
 | |
| # Sequence diagrams
 | |
| 
 | |
| > A Sequence diagram is an interaction diagram that shows how processes operate with one another and in what order.
 | |
| 
 | |
| Mermaid can render sequence diagrams.
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     John-->>Alice: Great!
 | |
|     Alice-)John: See you later!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     John-->>Alice: Great!
 | |
|     Alice-)John: See you later!
 | |
| ```
 | |
| 
 | |
| > **Note**
 | |
| > A note on nodes, the word "end" could potentially break the diagram, due to the way that the mermaid language is scripted.
 | |
| >
 | |
| > If unavoidable, one must use parentheses(), quotation marks "", or brackets {},\[], to enclose the word "end". i.e : (end), \[end], {end}.
 | |
| 
 | |
| ## Syntax
 | |
| 
 | |
| ### Participants
 | |
| 
 | |
| The participants can be defined implicitly as in the first example on this page. The participants or actors are
 | |
| rendered in order of appearance in the diagram source text. Sometimes you might want to show the participants in a
 | |
| different order than how they appear in the first message. It is possible to specify the actor's order of
 | |
| appearance by doing the following:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant Bob
 | |
|     Alice->>Bob: Hi Bob
 | |
|     Bob->>Alice: Hi Alice
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant Bob
 | |
|     Alice->>Bob: Hi Bob
 | |
|     Bob->>Alice: Hi Alice
 | |
| ```
 | |
| 
 | |
| ### Actors
 | |
| 
 | |
| If you specifically want to use the actor symbol instead of a rectangle with text you can do so by using actor statements as per below.
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     actor Alice
 | |
|     actor Bob
 | |
|     Alice->>Bob: Hi Bob
 | |
|     Bob->>Alice: Hi Alice
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     actor Alice
 | |
|     actor Bob
 | |
|     Alice->>Bob: Hi Bob
 | |
|     Bob->>Alice: Hi Alice
 | |
| ```
 | |
| 
 | |
| ### Aliases
 | |
| 
 | |
| The actor can have a convenient identifier and a descriptive label.
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     participant A as Alice
 | |
|     participant J as John
 | |
|     A->>J: Hello John, how are you?
 | |
|     J->>A: Great!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     participant A as Alice
 | |
|     participant J as John
 | |
|     A->>J: Hello John, how are you?
 | |
|     J->>A: Great!
 | |
| ```
 | |
| 
 | |
| ### Actor Creation and Destruction (v10.3.0+)
 | |
| 
 | |
| It is possible to create and destroy actors by messages. To do so, add a create or destroy directive before the message.
 | |
| 
 | |
|     create participant B
 | |
|     A --> B: Hello
 | |
| 
 | |
| Create directives support actor/participant distinction and aliases. The sender or the recipient of a message can be destroyed but only the recipient can be created.
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->>Bob: Hello Bob, how are you ?
 | |
|     Bob->>Alice: Fine, thank you. And you?
 | |
|     create participant Carl
 | |
|     Alice->>Carl: Hi Carl!
 | |
|     create actor D as Donald
 | |
|     Carl->>D: Hi!
 | |
|     destroy Carl
 | |
|     Alice-xCarl: We are too many
 | |
|     destroy Bob
 | |
|     Bob->>Alice: I agree
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->>Bob: Hello Bob, how are you ?
 | |
|     Bob->>Alice: Fine, thank you. And you?
 | |
|     create participant Carl
 | |
|     Alice->>Carl: Hi Carl!
 | |
|     create actor D as Donald
 | |
|     Carl->>D: Hi!
 | |
|     destroy Carl
 | |
|     Alice-xCarl: We are too many
 | |
|     destroy Bob
 | |
|     Bob->>Alice: I agree
 | |
| ```
 | |
| 
 | |
| ### Grouping / Box
 | |
| 
 | |
| The actor(s) can be grouped in vertical boxes. You can define a color (if not, it will be transparent) and/or a descriptive label using the following notation:
 | |
| 
 | |
|     box Aqua Group Description
 | |
|     ... actors ...
 | |
|     end
 | |
|     box Group without description
 | |
|     ... actors ...
 | |
|     end
 | |
|     box rgb(33,66,99)
 | |
|     ... actors ...
 | |
|     end
 | |
| 
 | |
| > **Note**
 | |
| > If your group name is a color you can force the color to be transparent:
 | |
| 
 | |
|     box transparent Aqua
 | |
|     ... actors ...
 | |
|     end
 | |
| 
 | |
| ```mermaid-example
 | |
|     sequenceDiagram
 | |
|     box Purple Alice & John
 | |
|     participant A
 | |
|     participant J
 | |
|     end
 | |
|     box Another Group
 | |
|     participant B
 | |
|     participant C
 | |
|     end
 | |
|     A->>J: Hello John, how are you?
 | |
|     J->>A: Great!
 | |
|     A->>B: Hello Bob, how is Charly?
 | |
|     B->>C: Hello Charly, how are you?
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
|     sequenceDiagram
 | |
|     box Purple Alice & John
 | |
|     participant A
 | |
|     participant J
 | |
|     end
 | |
|     box Another Group
 | |
|     participant B
 | |
|     participant C
 | |
|     end
 | |
|     A->>J: Hello John, how are you?
 | |
|     J->>A: Great!
 | |
|     A->>B: Hello Bob, how is Charly?
 | |
|     B->>C: Hello Charly, how are you?
 | |
| ```
 | |
| 
 | |
| ## Messages
 | |
| 
 | |
| Messages can be of two displayed either solid or with a dotted line.
 | |
| 
 | |
|     [Actor][Arrow][Actor]:Message text
 | |
| 
 | |
| There are six types of arrows currently supported:
 | |
| 
 | |
| | Type   | Description                                      |
 | |
| | ------ | ------------------------------------------------ |
 | |
| | `->`   | Solid line without arrow                         |
 | |
| | `-->`  | Dotted line without arrow                        |
 | |
| | `->>`  | Solid line with arrowhead                        |
 | |
| | `-->>` | Dotted line with arrowhead                       |
 | |
| | `-x`   | Solid line with a cross at the end               |
 | |
| | `--x`  | Dotted line with a cross at the end.             |
 | |
| | `-)`   | Solid line with an open arrow at the end (async) |
 | |
| | `--)`  | Dotted line with a open arrow at the end (async) |
 | |
| 
 | |
| ## Activations
 | |
| 
 | |
| It is possible to activate and deactivate an actor. (de)activation can be dedicated declarations:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     activate John
 | |
|     John-->>Alice: Great!
 | |
|     deactivate John
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     activate John
 | |
|     John-->>Alice: Great!
 | |
|     deactivate John
 | |
| ```
 | |
| 
 | |
| There is also a shortcut notation by appending `+`/`-` suffix to the message arrow:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->>+John: Hello John, how are you?
 | |
|     John-->>-Alice: Great!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->>+John: Hello John, how are you?
 | |
|     John-->>-Alice: Great!
 | |
| ```
 | |
| 
 | |
| Activations can be stacked for same actor:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->>+John: Hello John, how are you?
 | |
|     Alice->>+John: John, can you hear me?
 | |
|     John-->>-Alice: Hi Alice, I can hear you!
 | |
|     John-->>-Alice: I feel great!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->>+John: Hello John, how are you?
 | |
|     Alice->>+John: John, can you hear me?
 | |
|     John-->>-Alice: Hi Alice, I can hear you!
 | |
|     John-->>-Alice: I feel great!
 | |
| ```
 | |
| 
 | |
| ## Notes
 | |
| 
 | |
| It is possible to add notes to a sequence diagram. This is done by the notation
 | |
| Note \[ right of | left of | over ] \[Actor]: Text in note content
 | |
| 
 | |
| See the example below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     participant John
 | |
|     Note right of John: Text in note
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     participant John
 | |
|     Note right of John: Text in note
 | |
| ```
 | |
| 
 | |
| It is also possible to create notes spanning two participants:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->John: Hello John, how are you?
 | |
|     Note over Alice,John: A typical interaction
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->John: Hello John, how are you?
 | |
|     Note over Alice,John: A typical interaction
 | |
| ```
 | |
| 
 | |
| It is also possible to add a line break (applies to text input in general):
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->John: Hello John, how are you?
 | |
|     Note over Alice,John: A typical interaction<br/>But now in two lines
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->John: Hello John, how are you?
 | |
|     Note over Alice,John: A typical interaction<br/>But now in two lines
 | |
| ```
 | |
| 
 | |
| ## Loops
 | |
| 
 | |
| It is possible to express loops in a sequence diagram. This is done by the notation
 | |
| 
 | |
|     loop Loop text
 | |
|     ... statements ...
 | |
|     end
 | |
| 
 | |
| See the example below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->John: Hello John, how are you?
 | |
|     loop Every minute
 | |
|         John-->Alice: Great!
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->John: Hello John, how are you?
 | |
|     loop Every minute
 | |
|         John-->Alice: Great!
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ## Alt
 | |
| 
 | |
| It is possible to express alternative paths in a sequence diagram. This is done by the notation
 | |
| 
 | |
|     alt Describing text
 | |
|     ... statements ...
 | |
|     else
 | |
|     ... statements ...
 | |
|     end
 | |
| 
 | |
| or if there is sequence that is optional (if without else).
 | |
| 
 | |
|     opt Describing text
 | |
|     ... statements ...
 | |
|     end
 | |
| 
 | |
| See the example below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->>Bob: Hello Bob, how are you?
 | |
|     alt is sick
 | |
|         Bob->>Alice: Not so good :(
 | |
|     else is well
 | |
|         Bob->>Alice: Feeling fresh like a daisy
 | |
|     end
 | |
|     opt Extra response
 | |
|         Bob->>Alice: Thanks for asking
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->>Bob: Hello Bob, how are you?
 | |
|     alt is sick
 | |
|         Bob->>Alice: Not so good :(
 | |
|     else is well
 | |
|         Bob->>Alice: Feeling fresh like a daisy
 | |
|     end
 | |
|     opt Extra response
 | |
|         Bob->>Alice: Thanks for asking
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ## Parallel
 | |
| 
 | |
| It is possible to show actions that are happening in parallel.
 | |
| 
 | |
| This is done by the notation
 | |
| 
 | |
|     par [Action 1]
 | |
|     ... statements ...
 | |
|     and [Action 2]
 | |
|     ... statements ...
 | |
|     and [Action N]
 | |
|     ... statements ...
 | |
|     end
 | |
| 
 | |
| See the example below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     par Alice to Bob
 | |
|         Alice->>Bob: Hello guys!
 | |
|     and Alice to John
 | |
|         Alice->>John: Hello guys!
 | |
|     end
 | |
|     Bob-->>Alice: Hi Alice!
 | |
|     John-->>Alice: Hi Alice!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     par Alice to Bob
 | |
|         Alice->>Bob: Hello guys!
 | |
|     and Alice to John
 | |
|         Alice->>John: Hello guys!
 | |
|     end
 | |
|     Bob-->>Alice: Hi Alice!
 | |
|     John-->>Alice: Hi Alice!
 | |
| ```
 | |
| 
 | |
| It is also possible to nest parallel blocks.
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     par Alice to Bob
 | |
|         Alice->>Bob: Go help John
 | |
|     and Alice to John
 | |
|         Alice->>John: I want this done today
 | |
|         par John to Charlie
 | |
|             John->>Charlie: Can we do this today?
 | |
|         and John to Diana
 | |
|             John->>Diana: Can you help us today?
 | |
|         end
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     par Alice to Bob
 | |
|         Alice->>Bob: Go help John
 | |
|     and Alice to John
 | |
|         Alice->>John: I want this done today
 | |
|         par John to Charlie
 | |
|             John->>Charlie: Can we do this today?
 | |
|         and John to Diana
 | |
|             John->>Diana: Can you help us today?
 | |
|         end
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ## Critical Region
 | |
| 
 | |
| It is possible to show actions that must happen automatically with conditional handling of circumstances.
 | |
| 
 | |
| This is done by the notation
 | |
| 
 | |
|     critical [Action that must be performed]
 | |
|     ... statements ...
 | |
|     option [Circumstance A]
 | |
|     ... statements ...
 | |
|     option [Circumstance B]
 | |
|     ... statements ...
 | |
|     end
 | |
| 
 | |
| See the example below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     critical Establish a connection to the DB
 | |
|         Service-->DB: connect
 | |
|     option Network timeout
 | |
|         Service-->Service: Log error
 | |
|     option Credentials rejected
 | |
|         Service-->Service: Log different error
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     critical Establish a connection to the DB
 | |
|         Service-->DB: connect
 | |
|     option Network timeout
 | |
|         Service-->Service: Log error
 | |
|     option Credentials rejected
 | |
|         Service-->Service: Log different error
 | |
|     end
 | |
| ```
 | |
| 
 | |
| It is also possible to have no options at all
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     critical Establish a connection to the DB
 | |
|         Service-->DB: connect
 | |
|     end
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     critical Establish a connection to the DB
 | |
|         Service-->DB: connect
 | |
|     end
 | |
| ```
 | |
| 
 | |
| This critical block can also be nested, equivalently to the `par` statement as seen above.
 | |
| 
 | |
| ## Break
 | |
| 
 | |
| It is possible to indicate a stop of the sequence within the flow (usually used to model exceptions).
 | |
| 
 | |
| This is done by the notation
 | |
| 
 | |
|     break [something happened]
 | |
|     ... statements ...
 | |
|     end
 | |
| 
 | |
| See the example below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Consumer-->API: Book something
 | |
|     API-->BookingService: Start booking process
 | |
|     break when the booking process fails
 | |
|         API-->Consumer: show failure
 | |
|     end
 | |
|     API-->BillingService: Start billing process
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Consumer-->API: Book something
 | |
|     API-->BookingService: Start booking process
 | |
|     break when the booking process fails
 | |
|         API-->Consumer: show failure
 | |
|     end
 | |
|     API-->BillingService: Start billing process
 | |
| ```
 | |
| 
 | |
| ## Background Highlighting
 | |
| 
 | |
| It is possible to highlight flows by providing colored background rects. This is done by the notation
 | |
| 
 | |
| The colors are defined using rgb and rgba syntax.
 | |
| 
 | |
|     rect rgb(0, 255, 0)
 | |
|     ... content ...
 | |
|     end
 | |
| 
 | |
| <!---->
 | |
| 
 | |
|     rect rgba(0, 0, 255, .1)
 | |
|     ... content ...
 | |
|     end
 | |
| 
 | |
| See the examples below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant John
 | |
| 
 | |
|     rect rgb(191, 223, 255)
 | |
|     note right of Alice: Alice calls John.
 | |
|     Alice->>+John: Hello John, how are you?
 | |
|     rect rgb(200, 150, 255)
 | |
|     Alice->>+John: John, can you hear me?
 | |
|     John-->>-Alice: Hi Alice, I can hear you!
 | |
|     end
 | |
|     John-->>-Alice: I feel great!
 | |
|     end
 | |
|     Alice ->>+ John: Did you want to go to the game tonight?
 | |
|     John -->>- Alice: Yeah! See you there.
 | |
| 
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant John
 | |
| 
 | |
|     rect rgb(191, 223, 255)
 | |
|     note right of Alice: Alice calls John.
 | |
|     Alice->>+John: Hello John, how are you?
 | |
|     rect rgb(200, 150, 255)
 | |
|     Alice->>+John: John, can you hear me?
 | |
|     John-->>-Alice: Hi Alice, I can hear you!
 | |
|     end
 | |
|     John-->>-Alice: I feel great!
 | |
|     end
 | |
|     Alice ->>+ John: Did you want to go to the game tonight?
 | |
|     John -->>- Alice: Yeah! See you there.
 | |
| 
 | |
| ```
 | |
| 
 | |
| ## Comments
 | |
| 
 | |
| Comments can be entered within a sequence diagram, which will be ignored by the parser. Comments need to be on their own line, and must be prefaced with `%%` (double percent signs). Any text after the start of the comment to the next newline will be treated as a comment, including any diagram syntax
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     %% this is a comment
 | |
|     John-->>Alice: Great!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     %% this is a comment
 | |
|     John-->>Alice: Great!
 | |
| ```
 | |
| 
 | |
| ## Entity codes to escape characters
 | |
| 
 | |
| It is possible to escape characters using the syntax exemplified here.
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     A->>B: I #9829; you!
 | |
|     B->>A: I #9829; you #infin; times more!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     A->>B: I #9829; you!
 | |
|     B->>A: I #9829; you #infin; times more!
 | |
| ```
 | |
| 
 | |
| Numbers given are base 10, so `#` can be encoded as `#35;`. It is also supported to use HTML character names.
 | |
| 
 | |
| Because semicolons can be used instead of line breaks to define the markup, you need to use `#59;` to include a semicolon in message text.
 | |
| 
 | |
| ## sequenceNumbers
 | |
| 
 | |
| It is possible to get a sequence number attached to each arrow in a sequence diagram. This can be configured when adding mermaid to the website as shown below:
 | |
| 
 | |
| ```html
 | |
| <script>
 | |
|   mermaid.initialize({ sequence: { showSequenceNumbers: true } });
 | |
| </script>
 | |
| ```
 | |
| 
 | |
| It can also be turned on via the diagram code as in the diagram:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     autonumber
 | |
|     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!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     autonumber
 | |
|     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!
 | |
| ```
 | |
| 
 | |
| ## Actor Menus
 | |
| 
 | |
| Actors can have popup-menus containing individualized links to external pages. For example, if an actor represented a web service, useful links might include a link to the service health dashboard, repo containing the code for the service, or a wiki page describing the service.
 | |
| 
 | |
| This can be configured by adding one or more link lines with the format:
 | |
| 
 | |
|     link <actor>: <link-label> @ <link-url>
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant John
 | |
|     link Alice: Dashboard @ https://dashboard.contoso.com/alice
 | |
|     link Alice: Wiki @ https://wiki.contoso.com/alice
 | |
|     link John: Dashboard @ https://dashboard.contoso.com/john
 | |
|     link John: Wiki @ https://wiki.contoso.com/john
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     John-->>Alice: Great!
 | |
|     Alice-)John: See you later!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant John
 | |
|     link Alice: Dashboard @ https://dashboard.contoso.com/alice
 | |
|     link Alice: Wiki @ https://wiki.contoso.com/alice
 | |
|     link John: Dashboard @ https://dashboard.contoso.com/john
 | |
|     link John: Wiki @ https://wiki.contoso.com/john
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     John-->>Alice: Great!
 | |
|     Alice-)John: See you later!
 | |
| ```
 | |
| 
 | |
| #### Advanced Menu Syntax
 | |
| 
 | |
| There is an advanced syntax that relies on JSON formatting. If you are comfortable with JSON format, then this exists as well.
 | |
| 
 | |
| This can be configured by adding the links lines with the format:
 | |
| 
 | |
|     links <actor>: <json-formatted link-name link-url pairs>
 | |
| 
 | |
| An example is below:
 | |
| 
 | |
| ```mermaid-example
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant John
 | |
|     links Alice: {"Dashboard": "https://dashboard.contoso.com/alice", "Wiki": "https://wiki.contoso.com/alice"}
 | |
|     links John: {"Dashboard": "https://dashboard.contoso.com/john", "Wiki": "https://wiki.contoso.com/john"}
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     John-->>Alice: Great!
 | |
|     Alice-)John: See you later!
 | |
| ```
 | |
| 
 | |
| ```mermaid
 | |
| sequenceDiagram
 | |
|     participant Alice
 | |
|     participant John
 | |
|     links Alice: {"Dashboard": "https://dashboard.contoso.com/alice", "Wiki": "https://wiki.contoso.com/alice"}
 | |
|     links John: {"Dashboard": "https://dashboard.contoso.com/john", "Wiki": "https://wiki.contoso.com/john"}
 | |
|     Alice->>John: Hello John, how are you?
 | |
|     John-->>Alice: Great!
 | |
|     Alice-)John: See you later!
 | |
| ```
 | |
| 
 | |
| ## Styling
 | |
| 
 | |
| Styling of a sequence diagram is done by defining a number of css classes. During rendering these classes are extracted from the file located at src/themes/sequence.scss
 | |
| 
 | |
| ### Classes used
 | |
| 
 | |
| | Class        | Description                                                 |
 | |
| | ------------ | ----------------------------------------------------------- |
 | |
| | actor        | Style for the actor box at the top of the diagram.          |
 | |
| | text.actor   | Styles for text in the actor box at the top of the diagram. |
 | |
| | actor-line   | The vertical line for an actor.                             |
 | |
| | messageLine0 | Styles for the solid message line.                          |
 | |
| | messageLine1 | Styles for the dotted message line.                         |
 | |
| | messageText  | Defines styles for the text on the message arrows.          |
 | |
| | labelBox     | Defines styles label to left in a loop.                     |
 | |
| | labelText    | Styles for the text in label for loops.                     |
 | |
| | loopText     | Styles for the text in the loop box.                        |
 | |
| | loopLine     | Defines styles for the lines in the loop box.               |
 | |
| | note         | Styles for the note box.                                    |
 | |
| | noteText     | Styles for the text on in the note boxes.                   |
 | |
| 
 | |
| ### Sample stylesheet
 | |
| 
 | |
| ```css
 | |
| body {
 | |
|   background: white;
 | |
| }
 | |
| 
 | |
| .actor {
 | |
|   stroke: #ccccff;
 | |
|   fill: #ececff;
 | |
| }
 | |
| text.actor {
 | |
|   fill: black;
 | |
|   stroke: none;
 | |
|   font-family: Helvetica;
 | |
| }
 | |
| 
 | |
| .actor-line {
 | |
|   stroke: grey;
 | |
| }
 | |
| 
 | |
| .messageLine0 {
 | |
|   stroke-width: 1.5;
 | |
|   stroke-dasharray: '2 2';
 | |
|   marker-end: 'url(#arrowhead)';
 | |
|   stroke: black;
 | |
| }
 | |
| 
 | |
| .messageLine1 {
 | |
|   stroke-width: 1.5;
 | |
|   stroke-dasharray: '2 2';
 | |
|   stroke: black;
 | |
| }
 | |
| 
 | |
| #arrowhead {
 | |
|   fill: black;
 | |
| }
 | |
| 
 | |
| .messageText {
 | |
|   fill: black;
 | |
|   stroke: none;
 | |
|   font-family: 'trebuchet ms', verdana, arial;
 | |
|   font-size: 14px;
 | |
| }
 | |
| 
 | |
| .labelBox {
 | |
|   stroke: #ccccff;
 | |
|   fill: #ececff;
 | |
| }
 | |
| 
 | |
| .labelText {
 | |
|   fill: black;
 | |
|   stroke: none;
 | |
|   font-family: 'trebuchet ms', verdana, arial;
 | |
| }
 | |
| 
 | |
| .loopText {
 | |
|   fill: black;
 | |
|   stroke: none;
 | |
|   font-family: 'trebuchet ms', verdana, arial;
 | |
| }
 | |
| 
 | |
| .loopLine {
 | |
|   stroke-width: 2;
 | |
|   stroke-dasharray: '2 2';
 | |
|   marker-end: 'url(#arrowhead)';
 | |
|   stroke: #ccccff;
 | |
| }
 | |
| 
 | |
| .note {
 | |
|   stroke: #decc93;
 | |
|   fill: #fff5ad;
 | |
| }
 | |
| 
 | |
| .noteText {
 | |
|   fill: black;
 | |
|   stroke: none;
 | |
|   font-family: 'trebuchet ms', verdana, arial;
 | |
|   font-size: 14px;
 | |
| }
 | |
| ```
 | |
| 
 | |
| ## Configuration
 | |
| 
 | |
| It is possible to adjust the margins for rendering the sequence diagram.
 | |
| 
 | |
| This is done by defining `mermaid.sequenceConfig` or by the CLI to use a json file with the configuration.
 | |
| How to use the CLI is described in the [mermaidCLI](../config/mermaidCLI.md) page.
 | |
| `mermaid.sequenceConfig` can be set to a JSON string with config parameters or the corresponding object.
 | |
| 
 | |
| ```javascript
 | |
| mermaid.sequenceConfig = {
 | |
|   diagramMarginX: 50,
 | |
|   diagramMarginY: 10,
 | |
|   boxTextMargin: 5,
 | |
|   noteMargin: 10,
 | |
|   messageMargin: 35,
 | |
|   mirrorActors: true,
 | |
| };
 | |
| ```
 | |
| 
 | |
| ### Possible configuration parameters:
 | |
| 
 | |
| | Parameter         | Description                                                                                                                                | Default value                  |
 | |
| | ----------------- | ------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------ |
 | |
| | mirrorActors      | Turns on/off the rendering of actors below the diagram as well as above it                                                                 | false                          |
 | |
| | bottomMarginAdj   | Adjusts how far down the graph ended. Wide borders styles with css could generate unwanted clipping which is why this config param exists. | 1                              |
 | |
| | actorFontSize     | Sets the font size for the actor's description                                                                                             | 14                             |
 | |
| | actorFontFamily   | Sets the font family for the actor's description                                                                                           | "Open Sans", sans-serif        |
 | |
| | actorFontWeight   | Sets the font weight for the actor's description                                                                                           | "Open Sans", sans-serif        |
 | |
| | noteFontSize      | Sets the font size for actor-attached notes                                                                                                | 14                             |
 | |
| | noteFontFamily    | Sets the font family for actor-attached notes                                                                                              | "trebuchet ms", verdana, arial |
 | |
| | noteFontWeight    | Sets the font weight for actor-attached notes                                                                                              | "trebuchet ms", verdana, arial |
 | |
| | noteAlign         | Sets the text alignment for text in actor-attached notes                                                                                   | center                         |
 | |
| | messageFontSize   | Sets the font size for actor<->actor messages                                                                                              | 16                             |
 | |
| | messageFontFamily | Sets the font family for actor<->actor messages                                                                                            | "trebuchet ms", verdana, arial |
 | |
| | messageFontWeight | Sets the font weight for actor<->actor messages                                                                                            | "trebuchet ms", verdana, arial |
 |