Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/show-docs/remark-kroki
Kroki plugin of remark
https://github.com/show-docs/remark-kroki
code-block diagram doc document documentation docusaurus kroki markdown plantuml remark remark-plugin remarkjs site-generator
Last synced: 3 months ago
JSON representation
Kroki plugin of remark
- Host: GitHub
- URL: https://github.com/show-docs/remark-kroki
- Owner: show-docs
- License: mit
- Created: 2022-03-24T07:48:29.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-07-08T07:13:42.000Z (7 months ago)
- Last Synced: 2024-10-01T16:09:04.545Z (4 months ago)
- Topics: code-block, diagram, doc, document, documentation, docusaurus, kroki, markdown, plantuml, remark, remark-plugin, remarkjs, site-generator
- Language: JavaScript
- Homepage:
- Size: 415 KB
- Stars: 22
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ccamel - show-docs/remark-kroki - Kroki plugin of remark (JavaScript)
README
# remark-kroki
Remark plugin for showing [Kroki] diagram.
[![npm][npm-badge]][npm-url]
[![github][github-badge]][github-url]
![node][node-badge][kroki]: https://kroki.io
[npm-url]: https://www.npmjs.com/package/remark-kroki
[npm-badge]: https://img.shields.io/npm/v/remark-kroki.svg?style=flat-square&logo=npm
[github-url]: https://github.com/show-docs/remark-kroki
[github-badge]: https://img.shields.io/npm/l/remark-kroki.svg?style=flat-square&colorB=blue&logo=github
[node-badge]: https://img.shields.io/node/v/remark-kroki.svg?style=flat-square&colorB=green&logo=node.js## Installation
```sh
npm install remark-kroki --save-dev
```## Usage
```mjs
import readFileSync from 'node:fs';import { remark } from 'remark';
import { remarkKroki } from 'remark-kroki';const markdownText = readFileSync('example.md', 'utf8');
remark()
.use(remarkKroki, {
server: 'http://localhost:8000',
alias: ['plantuml']
})
.process(markdownText)
.then((file) => console.info(file))
.catch((error) => console.warn(error));
```### Docusaurus v3 project
```mjs
// docusaurus.config.mjs
import { remarkKroki } from 'remark-kroki';export default {
presets: [
[
'classic',
{
docs: {
remarkPlugins: [
[
remarkKroki,
{
// ...options here
alias: ['plantuml'],
target: 'mdx3'
}
]
]
}
}
]
]
};
```### Docusaurus v2 project
```cjs
// docusaurus.config.js
module.exports = async function createConfig() {
const { remarkKroki } = await import('remark-kroki');return {
presets: [
[
'classic',
{
docs: {
remarkPlugins: [
[
remarkKroki,
{
// ...options here
alias: ['plantuml']
}
]
]
}
}
]
]
};
};
```## Options
### Options.server
- type: string
- default: http://localhost:8000
- example:Using self host server by default. Set to use free service.
### Options.headers
- type: object
- default: `{}`HTTP headers to send to the server for custom authentication.
### Options.alias
- type: array
- default: `[]`
- example: `['plantuml']`Alias code language name to treat as kroki code block, meta.type will be ignored.
````
```kroki type=plantuml
```
↓```plantuml
```
````### Options.target
- type: string
- default: `'html'`
- enum: `['html', 'mdx3']`Transform HTML tags as MDX 3.0 AST or not. When you using Docusaurus v3, you should use `mdx3`.
### Options.output
- type: string
- default: `'img-base64'`
- enum: `['inline-svg', 'img-base64', 'img-html-base64', 'object-base64']`How to embed SVG as image. See the different and risk on [Best Way To Embed SVG](https://vecta.io/blog/best-way-to-embed-svg).
## Syntax
### Base
````markdown
Turn```kroki type=plantuml
A --> B
```Into
![plantuml]()
````````markdown
Turn```kroki type=plantuml alt=abc
A --> B
```Into
![abc]()
````### Set classnames
````markdown
Turn
```d2 classnames="tw-w-1/2"
A --> B
```Into
````## Troubleshooting
When you using `inline-svg` with `mdx3` mode, You may get following error:
```log
Error: Cannot handle unknown node `raw` when using with `@mdx-js/mdx`
```You need to add `rehype-raw` to the complier, for example:
```mjs
// docusaurus.config.mjs
import rehypeRaw from 'rehype-raw';
import { remarkKroki } from 'remark-kroki';export default {
presets: [
[
'classic',
{
docs: {
remarkPlugins: [
[
remarkKroki,
{
// ...options here
target: 'mdx3',
output: 'inline-svg'
}
]
],
rehypePlugins: [
[
rehypeRaw,
{
passThrough: [
'mdxFlowExpression',
'mdxJsxFlowElement',
'mdxJsxTextElement',
'mdxTextExpression',
'mdxjsEsm'
]
}
]
]
}
}
]
]
};
```## Related
- [markdown-code-block-meta](https://github.com/show-docs/markdown-code-block-meta)
- [rehype-extended-table](https://github.com/show-docs/rehype-extended-table)
- [remark-code-example](https://github.com/show-docs/remark-code-example)
- [remark-docusaurus](https://github.com/show-docs/remark-docusaurus)