Skip to main content

A wrapper of mistletoe to output Markdown as dash components

Project description

dash_mistletoe

An extension of mistletoe that converts markdown into dash components.

Purpose

While other Markdown parsers exist, they lack the ability to customize items at the component level. This creates a barrier when we want to change styles or add ids to elements. dash_mistletoe fixes this problem by providing a baseline framework for extending Markdown using dash.

We build an extension of mistletoe; a fast, spec-compliant, and customizable Markdown parser; for dash components. mistletoe parses to an Abstract Syntax Tree allowing us to extend easily.

Install

To install and use, run

pip install dash-mistletoe

To clone and run locally, run

git clone https://github.com/bradley-erickson/dash-mistletoe
pip install -r requirements.txt
python usage.py

Usage

First, mistletoe will parse markdown_to_render using the dashRenderer. The output will contain all contents of the markdown wrapped in a Div.

from dash import html
from dash_mistletoe.dash_renderer import dashRenderer
import mistletoe

markdown_to_render = """
# Heading level 1

I like markdown
"""

component = mistletoe.markdown(markdown_to_render, dashRenderer)
component
# html.Div([html.H1('Heading level 1'), html.P('I like markdown')])

Extending Components

To extend a component, we will first make a sub class of dashRenderer to inherit all methods. Next, we just need overwrite the methods we want to customize. The possible methods to overwrite can be referenced in the code.

class MydashRenderer(dashRenderer):

    def render_heading(self, token):

Depending on what we need done with the content, we can create the component with the super class first. Then, we change an attribute about it. In the heading example, I add an id to each heading element. Doing this allows for automatic scroll when changing the hash of the URL. This is great for adding a table of contents to a blog post.

class MydashRenderer(dashRenderer):

    def render_heading(self, token):
        # fetch the super class heading first i.e. an html.Hx component
        heading = super().render_heading(token)
        # render the child (token) to as text (plain)
        id = self.render_to_plain(token).lower().replace(' ', '')
        # set the id and return
        heading.id = id
        return heading

You can also completely ignore the super class method and return something brand new. For example, we can return a P element with a specific className instead of Strong one. This allows us to handle how the Strong text looks with CSS instead.

class MydashRenderer(dashRenderer):

    def render_strong(self, token):
        # render the children (token)
        children = self.render_inner(token)
        return html.P(children, className='strong-text')

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_mistletoe-0.2.0.tar.gz (4.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_mistletoe-0.2.0-py3-none-any.whl (3.2 kB view details)

Uploaded Python 3

File details

Details for the file dash_mistletoe-0.2.0.tar.gz.

File metadata

  • Download URL: dash_mistletoe-0.2.0.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.10

File hashes

Hashes for dash_mistletoe-0.2.0.tar.gz
Algorithm Hash digest
SHA256 18ba12fef1081f7b05d6476c3e6f91ae9e3dae116d8d9bb497e36a43f0a7caa1
MD5 41c5ede5ff79b84bfb9ba06627750a02
BLAKE2b-256 56a9c319db03a86f8fa5e662334d761ad307446c35c6222037e97a72ee4e2165

See more details on using hashes here.

File details

Details for the file dash_mistletoe-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: dash_mistletoe-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 3.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.8.10

File hashes

Hashes for dash_mistletoe-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 88055acdbeb6a7f582728fc06b78213e4caca58f5a1893d614666ae28961dcc4
MD5 e9cd2197991350d8fb078f180c7346a2
BLAKE2b-256 cf0c98366a6ebb698bdb7076f602004eb31051e1e47e996a53650fd0bf9bd6c8

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