gatsby-remark-plantuml
Gatsby Remark plugin to transform PlantUML code blocks into SVG images.
Install
npm install --save gatsby-transformer-remark gatsby-remark-plantuml
Prerequisites
This plugin bundles plantuml-jar-mit-1.2019.9
but must have the other prerequisites for a local PlantUML v1.2019.10
installation:
- Java
- Graphviz (this is not optional as the plugin can’t tell if you plan to only create sequence or activity (beta) diagrams)
How to use
with gatsby-transformer-remark
// In your gatsby-config.js
plugins: [
{
resolve: `gatsby-transformer-remark`,
options: {
plugins: [
{
// its order in the `gatsby-transformer-remark` plugins list is important.
// * before `gatsby-remark-prismjs` so the code block has been transformed
// and `gatsby-remark-prismjs` will never see it as a code block
// * after `gatsby-remark-code-titles` so the title block will be generated
resolve: `gatsby-remark-plantuml`,
},
],
},
},
]
with gatsby-plugin-mdx
// In your gatsby-config.js
{
resolve: `gatsby-plugin-mdx`,
options: {
gatsbyRemarkPlugins: [
{
// NOTE: As this plugin replaces the `plantuml` code blocks with an svg
// its order in the `gatsby-transformer-remark` plugins list is important.
// * before `gatsby-remark-prismjs` so the code block has been transformed
// and `gatsby-remark-prismjs` will never see it as a code block
// * after `gatsby-remark-code-titles` so the title block will be generated
resolve: `gatsby-remark-plantuml`,
},
],
},
},
Options
Name | Default | Description |
---|---|---|
maxWidth |
undefined |
The maxWidth value to apply to the width attribute of the generated svg.When undefined the svg will default to the plantuml width and height which is the entire diagram.Otherwise set the width attribute of the svg to the provided value, use any valid values include vh and % s. Additionally sets the height attribute of the svg to auto to ensure the svg sizes correctly |
attributes |
undefined |
String of custom attributes that will be added to the generated svg element. See Custom Attributes |
plantumljar |
use embedded jar | Path to an alternative PlantUML Jar file |
JAVA_OPTS |
[] | Additional options to pass to java executable. Will always include DEFAULT_JAVA_OPTS = ["-Djava.awt.headless=true"] |
PLANTUML_OPTS |
[] | Additional options to pass as options to plantuml. WARNING use at own risk. Passing an incompatible option will cause this plugin to stop working and probably with no reasonable error messages generated. Will always include DEFAULT_PLANTUML_OPTS=["-charset", "UTF-8", "-Dfile.encoding=utf8", "-pipe", "-pipeNoStderr", "-tsvg"] |
You can specify these options in your gatsby-config.js
file as follows:
// In your gatsby-config.js
plugins: [
{
resolve: `gatsby-transformer-remark`,
// or resolve: `gatsby-plugin-mdx`,
options: {
plugins: [
{
resolve: 'gatsby-remark-plantuml',
options: {
maxWidth: '960',
attributes: 'max-width: 960;',
plantumljar: '/path/to/plantuml.jar'
}
},
],
},
},
]
Usage in Markdown
See PlantUML and select any of the diagram types from the top navigation bar for examples of how to write PlantUML diagrams.
Then in a code block specify the language type of plantuml
and in the code
block write your PlantUML diagram.
For example:
```plantuml
@startuml
Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response
Alice -> Bob: Another authentication Request
Alice <-- Bob: Another authentication Response
@enduml
```
Custom Attributes
By default, the following inline style is applied to all rendered SVGs in order to make them responsive:
max-width: 100%;
height: auto;
This can be overwritten by using the custom attributes feature:
```plantuml
@startuml style=""
Alice -> Bob: Authentication Request
Bob --> Alice: Authentication Response
Alice -> Bob: Another authentication Request
Alice <-- Bob: Another authentication Response
@enduml
```