Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/forgeworks/quill-delta-python

Python port of the Quill-JS Delta library - Has support for HTML Rendering
https://github.com/forgeworks/quill-delta-python

operational-transformation python quilljs

Last synced: about 1 month ago
JSON representation

Python port of the Quill-JS Delta library - Has support for HTML Rendering

Awesome Lists containing this project

README

        

# Delta (Python Port)

Python port of the javascript Delta library for QuillJS: https://github.com/quilljs/delta

Some basic pythonizing has been done, but mostly it works exactly like the above library.

There is no other python specific documentation at this time, sorry. Please see the tests
for reference examples.

## Install with [Poetry](https://poetry.eustace.io/docs/#installation)

With HTML rendering:

> poetry add -E html quill-delta

Without HTML rendering:

> poetry add quill-delta

## Install with pip

Note: If you're using `zsh`, see below.

With HTML rendering:

> pip install quill-delta[html]

With HTML rendering (zsh):

> pip install quill-delta"[html]"

Without HTML rendering:

> pip install quill-delta

# Rendering HTML in Python

This library includes a module `delta.html` that renders html from an operation list,
allowing you to render Quill Delta operations in full from a Python server.

For example:

from delta import html

ops = [
{ "insert":"Quill\nEditor\n\n" },
{ "insert": "bold",
"attributes": {"bold": True}},
{ "insert":" and the " },
{ "insert":"italic",
"attributes": { "italic": True }},
{ "insert":"\n\nNormal\n" },
]

html.render(ops)

Result (line formatting added for readability):

Quill


Editor




bold and the italic




Normal

[See test_html.py](tests/test_html.py) for more examples.

# Developing

## Setup
If you'd to contribute to quill-delta-python, get started setting your development environment by running:

Checkout the repository

> git clone https://github.com/forgeworks/quill-delta-python.git

Make sure you have python 3 installed, e.g.,

> python --version

From inside your new quill-delta-python directory:

> python3 -m venv env
> source env/bin/activate
> pip install poetry
> poetry install -E html

## Tests
To run tests do:

> py.test