A MkDocs plugin that injects the mkdocs.yml extra variables into the markdown template
Project description
mkdocs-markdownextradata-plugin
A MkDocs plugin that injects the mkdocs.yml extra variables into the markdown template
usecase
As a user with variables that need to be inserted at the markdown level, not the template level.
I need a mkdocs plugin that will inject my `extras` variables into the markdown template before it gets rendered to html.
So that I can build my markdown pages with different values for images, urls, client_names, etc.
Installation
Note: This package requires MkDocs version 0.17 or higher.
Install the package with pip:
pip install mkdocs-markdownextradata-plugin
Enable the plugin in your mkdocs.yml
:
plugins:
- search
- markdownextradata: {}
You are then able to use the mkdocs extra: {}
hash to pass context data into your files
Note: If you have no
plugins
entry in your config file yet, you'll likely also want to add thesearch
plugin. MkDocs enables it by default if there is noplugins
entry set, but now you have to enable it explicitly.
Features
Use Extra Variables in your markdown files
The variables you define in the mkdown.yml extra:
slot will become available in your templates
site_name: My fantastic site
plugins:
- search
- markdownextradata
extra:
customer:
name: Your name here
web: www.example.com
salt: salt.example.com
and then in your *.md
files
{{ customer.name }}
<a href="{{ customer.web }}">{{ customer.web }}</a>
Using external data files
If the extra: {}
hash is not enough for your data then you are able to make use of external yaml files to provide that context data
plugins:
- search
- markdownextradata:
data: path/to/datafiles
or if you have multiple locations provide a comma (,) separated list of locations
plugins:
- search
- markdownextradata:
data: path/to/datafiles, another/path/to/datafiles
if you leave markdownextradata.data
empty
plugins:
- search
- markdownextradata
by default it will search in the folder where your mkdocs.yml is kept
and in the docs folder for another folder called _data
i.e. ./docs/_data/site.yaml
- available as '{{ site.whatever_variable_in_the_yaml}}'
If this path is found, the plugin will read all .yml|.yaml
and .json
files inside it and add the data in them, to the template context.
If inside your data folder you have a directory and a file file
called [path/to/datafiles/]sections/captions.yaml
- where [path/to/datafiles/]
is the path in your configuration -
the data inside that file will be available in your templates as sections.captions.whatever_variable_in_the_yaml
.
Testing
virtualenv venv -p python3.7
source venv/bin/activate
python setup.py test
pytest test
Contributing
From reporting a bug to submitting a pull request: every contribution is appreciated and welcome. Report bugs, ask questions and request features using Github issues. If you want to contribute to the code of this project, please read the Contribution Guidelines.
Contributors
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
Built Distribution
File details
Details for the file mkdocs-markdownextradata-plugin-0.1.3.tar.gz
.
File metadata
- Download URL: mkdocs-markdownextradata-plugin-0.1.3.tar.gz
- Upload date:
- Size: 5.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c010a44e317a9bb36f7d9b51b1b09aab1004320b8813db18805ffdf62353391c |
|
MD5 | 5d03a5ca50a044922fbf38d31c1a8213 |
|
BLAKE2b-256 | b588e1efd6a4e1f83fc923fe617b662c42892ba1637f8e69293970049be17526 |
Provenance
File details
Details for the file mkdocs_markdownextradata_plugin-0.1.3-py3-none-any.whl
.
File metadata
- Download URL: mkdocs_markdownextradata_plugin-0.1.3-py3-none-any.whl
- Upload date:
- Size: 5.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e55db0f3c8ea0a2aeff4f9054a7dd8e7186ad8bd440302f2a4cad8b081f3808e |
|
MD5 | 08a233b14acd10524c3b2949f2c86788 |
|
BLAKE2b-256 | 6d522a74925deaa9e74508017ad9b87023d93778e13ef06917f6be291162e9d0 |