No project description provided
Project description
The dash-down module provides tools to convert markdown files into Plotly Dash applications.
Getting started
Make sure that you have setup poetry. Then run
poetry install
to install dependencies.
Running the example
poetry run python example.py
Running the tests
poetry run pytest
Custom content
Custom content is rendered the markdown directive syntax extension. A directive has the following syntax,
.. directive-name:: directive value
:option-key: option value
:option-key: option value
full featured markdown text here
where the directive-name is mandatory, while the value, the options (specified as key value pairs), and the text are optional.
What directives are bundled?
Currently, the bundled directives are
- api-doc - a directive for rendering api documentation for a component
- dash-proxy - a block for rendering dash apps (including interactivity)
How to create custom directives?
To create a new directive, simply make a subclass of DashDirective and implement the render_directive function. Say you want to make a new directive that yields a plot of the iris dataset. The code would be along the lines of,
import plotly.express as px
from dash_down.directives import DashDirective
from dash_extensions.enrich import dcc
class GraphDirective(DashDirective):
def render_directive(self, value, text, options, blueprint):
df = getattr(px.data, options.dataset)()
fig = px.scatter(df, x=options.x, y=options.y)
return dcc.Graph(figure=fig)
The directive name is derived from the class name by dropping Directive, and converting to kebab-case (or you can override the get_directive_name function). With this directive defined, you can now create a graph similar to the one in the Dash docs with the following syntax,
.. graph::
:dataset: iris
:x: sepal_width
:y: sepal_length
To render a markdown file using your new, shiny directive, the syntax would be,
from dash_extensions.enrich import DashProxy
from dash_down.express import md_to_blueprint_dmc
path_to_your_md_file = "..."
blueprint = md_to_blueprint_dmc(path_to_your_md_file, plugins=[GraphDirective()])
if __name__ == '__main__':
DashProxy(blueprint=blueprint).run_server()
A working example is bundled in the repo (see example_custom_directive.py).
How to customize the layout of the rendered blueprint?
The layout of the blueprint returned by the renderer can be customized by passing a custom layout function to the PluginBlueprint. A working example is bundled in the repo (see example_code_renderer.py).
How to customize the markdown rendering itself?
Make a subclass of DashMantineRenderer (or DashHtmlRenderer, if you prefer to start from raw HTML) and override the render function(s) for any element that you want to change.
How to customize the way code is rendered with the DashProxyDirective?
The DashProxyDirective takes optional arguments to customize code rendering. A working example is bundled in the repo (see example_code_renderer.py).
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dash-down-0.0.10.tar.gz.
File metadata
- Download URL: dash-down-0.0.10.tar.gz
- Upload date:
- Size: 7.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.9.1 Darwin/21.3.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
aa02da977c15f742a2fba95b6040d0338940c380280e4831b76744d8521c195b
|
|
| MD5 |
5cfa23c9d5981918e23ee2904cd0b1db
|
|
| BLAKE2b-256 |
2eee89f1f713f5718a58fad029ff51d78518a4dbeaf6758107f9ef539e288d99
|
File details
Details for the file dash_down-0.0.10-py3-none-any.whl.
File metadata
- Download URL: dash_down-0.0.10-py3-none-any.whl
- Upload date:
- Size: 8.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.9.1 Darwin/21.3.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
567b811c7e27bca8f7f702f08bd9ae63671496d6ed91d346221bf6c13f58e1d9
|
|
| MD5 |
8e2535f9e7d820eb8693c6f9aec7dc85
|
|
| BLAKE2b-256 |
5fa13ffc1b2e3f930077a747cc88901a15ad92976808e582adbd66dc9d10c04e
|