0.0.3 • Published 1 year ago

@beoe/rehype-graphviz v0.0.3

Weekly downloads
-
License
MIT
Repository
github
Last release
1 year ago

@beoe/rehype-graphviz

Rehype plugin to generate Graphviz diagrams (as inline SVGs) in place of code fences. This

```dot
digraph G { Hello -> World }
```

will be converted to

<figure class="beoe graphviz">
  <svg>...</svg>
</figure>

which can look like this:

TODO: add screenshot

Usage

import rehypeGraphviz from "@beoe/rehype-graphviz";

const html = await unified()
  .use(remarkParse)
  .use(remarkRehype)
  .use(rehypeGraphviz)
  .use(rehypeStringify)
  .process(`markdown`);

It support caching the same way as @beoe/rehype-code-hook does.

Tips

Styling and dark mode

You can add dark mode with something like this:

:root {
  --color-variable: #000;
}
@media (prefers-color-scheme: dark) {
  :root {
    --color-variable: #fff;
  }
}
.graphviz {
  text {
    fill: var(--color-variable);
  }
  [fill="black"] {
    fill: var(--color-variable);
  }
  [stroke="black"] {
    stroke: var(--color-variable);
  }
}

Plus you can pass class to Edges and Nodes to implement advanced styling.

Transparent background

To remove background use:

digraph G {
 bgcolor="transparent"
}

To remove title

To remove title (which shows as tooltip when you hover mouse) use:

digraph G {
 node[tooltip=" "]
}

You can add links

Inline SVG can contain HTML links:

digraph G {
 node[URL="https://example.com"]
}

TODO