Exports mermaid diagrams in Markdown documents as images.
Project description
markdown-mermaid-to-images
A CLI tool for publishing markdown articles to dev.to. The tool will also update articles if they already exist on dev.to. It matches articles based on title in the frontmatter.
> Info: You will need to have pandoc preinstalled <https://pandoc.org/installing.html>_ for this script to work correctly. Or you can use the Docker image instead.
Usage
pip install markdown-mermaid-to-images
markdown_mermaid_to_images --help
Usage: markdown_mermaid_to_images [OPTIONS]
Exports mermaid diagrams in Markdown documents as images.
- Options:
- -m, --file PATH
Path to markdown file, where the mermaid code blocks will be converted to images.
- -f, --folder PATH
Path to folder where we will convert all markdown mermaid code blocks to images.
- -i, --ignore PATH
Path to folder to ignore, markdown files in this folder will not be converted.
- -o, --output PATH
Path to folder where to save the new markdown files. [required]
- -l, --log-level
[DEBUG|INFO|ERROR] Log level for the script.
- --help
Show this message and exit.
$ markdown_mermaid_to_images -f tests/data -o tests/data/output/ -i tests/data/another_folder
Docker Image
You can also use the Docker image that comes with all the dependencies preinstalled. In this example you can find the output in tests/data/output on your host machine.
$ docker run -v ${PWD}/tests/data/another_folder:/data/input -v ${PWD}/tests/data/output:/data/output test
Example Markdown File
Where an example markdown file may look something like this. The meramid code blocks must be surrounded by three ` and have the class mermaid.
## Introduction
Example Document
## Heading
```mermaid
%% Image: image_name
graph LR;
A --> B;
```
> INFO: Info
```mermaid
graph LR;
A --> B
B --> C
subgraph 1;
subgraph 2;
C --> D;
end
end;
```
This will then get converted into a file that looks like
Introduction
------------
Example Document
Heading
-------
![Image](image_name.png)
> INFO: Info
![Image](7d2490309c1c4bf48069dd7399944ff4.png)
GitLab CI
You can use also use this in your CI/CD with the provided Docker image. Below is an example .gitlab-ci.yml file, you may wish to use or include. The advantage of this is you can publish your aritcles using CI/CD.
stages:
- pre-publish
convert-mermaid:markdown:
image: registry.gitlab.com/hmajid2301/markdown-mermaid-to-images
stage: pre-publish
script:
- markdown_mermaid_to_images --folder tests/data --ignore tests/data/another_folder --output tests/data/output
Setup Development Environment
git clone git@gitlab.com:hmajid2301/markdown-mermaid-to-images.git
cd markdown-mermaid-to-images
pip install tox
make install-venv
source .venv/bin/activate
make install-dev
Changelog
You can find the changelog here.
Appendix
Docker Image inspired by sc250024.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file markdown-mermaid-to-images-0.3.0.post1.tar.gz
.
File metadata
- Download URL: markdown-mermaid-to-images-0.3.0.post1.tar.gz
- Upload date:
- Size: 10.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.7.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1ad58638e6379c689108d7f8d7bcd67a2b6cac148a3a17a57742c802136500b3 |
|
MD5 | 97d75a2720e002ecf5c3466cb00229c2 |
|
BLAKE2b-256 | fde8552276e2c7ad0ef9ec35625707999c99442e6a89e5f7ae5ba9d427993bc0 |