Skip to main content

No project description provided

Project description

Unit tests codecov

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dash-down-0.0.10.tar.gz (7.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dash_down-0.0.10-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

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

Hashes for dash-down-0.0.10.tar.gz
Algorithm Hash digest
SHA256 aa02da977c15f742a2fba95b6040d0338940c380280e4831b76744d8521c195b
MD5 5cfa23c9d5981918e23ee2904cd0b1db
BLAKE2b-256 2eee89f1f713f5718a58fad029ff51d78518a4dbeaf6758107f9ef539e288d99

See more details on using hashes here.

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

Hashes for dash_down-0.0.10-py3-none-any.whl
Algorithm Hash digest
SHA256 567b811c7e27bca8f7f702f08bd9ae63671496d6ed91d346221bf6c13f58e1d9
MD5 8e2535f9e7d820eb8693c6f9aec7dc85
BLAKE2b-256 5fa13ffc1b2e3f930077a747cc88901a15ad92976808e582adbd66dc9d10c04e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page