orchid-diagrams-feature
Create flowcharts and sequence diagrams using the PlantUML markup language.
About
This plugin adds support for UML diagrams to be created from text, using PlantUML syntax. Text diagrams will be converted to SVG and embedded directly in your page content. Having diagrams described in text makes them easy to create and maintain, and enables them to be tracked with Git, ideal for managing diagrams for project documentation.
Note that some diagram types require GraphViz to be installed on your local machine to work properly.
Installation
dependencies {
    orchidRuntime("io.github.copper-leaf.orchid:orchid-diagrams-feature:0.21.1")
}
<dependency>
    <groupId>io.github.copper-leaf.orchid</groupId>
    <artifactId>orchid-diagrams-feature</artifactId>
    <version>0.21.1</version>
    <type>pom</type>
</dependency>
libraryDependencies += "io.github.copper-leaf.orchid" % "orchid-diagrams-feature" % "0.21.1"
@file:DependsOn("io.github.copper-leaf.orchid:orchid-diagrams-feature:0.21.1")
Demo
Examples
The following examples are taken directly from the official PlantUML docs
Sequence Diagram
Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response
Alice -> Bob: Another authentication Request
Alice <-- Bob: another authentication Response
Class Description
class Dummy {
 -field1
 #field2
 ~method1()
 +method2()
}
Activity Diagram
start
if (condition A) then (yes)
  :Text 1;
elseif (condition B) then (yes)
  :Text 2;
  stop
elseif (condition C) then (yes)
  :Text 3;
elseif (condition D) then (yes)
  :Text 4;
else (nothing)
  :Text else;
endif
stop
State Diagram
scale 350 width
[*] --> NotShooting
state NotShooting {
  [*] --> Idle
  Idle --> Configuring : EvConfig
  Configuring --> Idle : EvConfig
}
state Configuring {
  [*] --> NewValueSelection
  NewValueSelection --> NewValuePreview : EvNewValue
  NewValuePreview --> NewValueSelection : EvNewValueRejected
  NewValuePreview --> NewValueSelection : EvNewValueSaved
  
  state NewValuePreview {
    State1 -> State2
  }  
}
Timing Diagram
robust "Web Browser" as WB
concise "Web User" as WU
WB is Initializing
WU is Absent
@WB
0 is idle
+200 is Processing
+100 is Waiting
WB@0 <-> @50 : {50 ms lag}
@WU
0 is Waiting
+500 is ok
@200 <-> @+150 : {150 ms}
Usage
Basic Usage
Using this plugin adds support for the .uml and .puml file extension to be recognized by Orchid. Any file that
Orchid reads, such as blogs, static pages, or changelog versions, can use the .uml extension and be compiled as a
PlantUML diagram.
. / (resources root)
├── homepage.md
├── config.yml
└── pages/
    └── registration-flow.puml <-- page content will be compiled to an SVG diagram
Alternatively, you may wish to embed diagrams within the content of another page. You can do this inline with the
compileAs() template function.
// homepage.md
---
---
{% filter compileAs('md') %}
Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response
Alice -> Bob: Another authentication Request
Alice <-- Bob: another authentication Response
{% endfilter %}
You may also use the load() function to embed it from another file.
// diagram.uml
Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response
Alice -> Bob: Another authentication Request
Alice <-- Bob: another authentication Response
// homepage.md
---
---
{{ load('diagram.uml') | raw }} # loads content of `diagram.uml`, compiles it as PlantUML, and embeds the result 
 
Compiling Multiple Diagrams At Once
By default, Orchid does not need the @startuml...@enduml tags to compile diagram content; it will add them if they do
not exist. However, if you include multiple diagrams in a single file, each with their own @startuml...@enduml tags,
they will each be compiled as diagrams separately and embedded as separate SVG diagrams.
// diagram.uml
@startuml
Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response
Alice -> Bob: Another authentication Request
Alice <-- Bob: another authentication Response
@enduml
@startuml
Charlie -> Dennis: Authentication Request
Dennis --> Charlie: Authentication Response
Charlie -> Dennis: Another authentication Request
Charlie <-- Dennis: another authentication Response
@enduml
Other Diagram Types
If you omit the start/end tags from your diagram source, Orchid will assume it is a "UML" diagram and add
@startuml...@enduml for you. However, PlantUML supports a variety of diagram formats, using differing start/end tags.
The following tags are supported by Orchid and PlantUML:
- @startuml/@enduml
- @startsalt/@endsalt
- @startmath/@endmath
- @startlatex/@endlatex
- @startgantt/@endgantt
Mermaid JS
In addition to prerendered diagrams with PlantUML, you can add Mermaid JS diagrams to be rendered directly in the
browser. Add the mermaid meta-component to your theme to add the necessary scripts to your site. By default, Markdown
code snippets with the mermaid language are converted to Mermaid diagrams, but you can customize the selector.
# config.yml
theme:
    metaComponents:
        - type: mermaid
          selector: '.mermaid' # optional