Skip to main content

Associate RichTextBlock text content to a snippet model.

Project description

wagtail-draftail-snippet

Wagtail has support for adding numerous types of links to RichText content, but there is not a way to tie a link to an arbitrary snippet model currently. wagtail-draftail-snippet provides a way to create either an a href element for a specific snippet model based on a template that can be provided, or a completely free-form piece of HTML for a snippet.

The project provides the following draftail (Wagtail Richtext editor) features:

  1. snippet-link: Allows to create a link using the snippet chooser modal. The link is rendered using the template {app_name}/{model_name}_snippet_link.html.
  2. snippet-embed: Allows to embed a block using the snippet chooser modal. The block is embedded using the template {app_name}/{model_name}_snippet_embed.html.

Unsure whether you want to use a snippet link or embed? Embeds have complete flexibility, but 1) break the flow of text in the Draftail richtext editor and 2) can't be used to link arbitrary text. If you want to render a link to a snippet model inside of body copy, then you probably want to use the snippet link. For anything else, the embed can be used.

Demo of wagtail-draftail-snippet plugin

Install

  1. pip install wagtail-draftail-snippet
  2. Add wagtail_draftail_snippet to INSTALLED_APPS in Django settings
  3. Add "snippet-link" and "snippet-embed" to the features keyword list argument when instantiating a RichTextBlock, e.g. paragraph = RichTextBlock(features=["bold", "italic", "h1", "h2", "h3", "snippet-link", "snippet-embed"])
  4. Create a frontend template to determine how the snippet model will be rendered. Frontend templates are required for a snippet to be selected and are discovered when they match a path like {app_name}/{model_name}_snippet_link.html and {app_name}/{model_name}_snippet_embed.html. For example, if you have an Affiliate snippet model in affiliates/models.py, then a file in affiliates/templates/affiliates/affiliate_snippet_link.html and affiliates/templates/affiliates/affiliate_snippet_embed.html would be required.

Example use-case

Wagtail is used for a content site that will display articles that have affiliate links embedded inside the content. Affiliate links have a snippet data model to store information with a URL, start, and end dates; the urls need to be rendered in such a way that JavaScript can attach an event listener to their clicks for analytics.

When the content gets rendered, it uses the specific affiliate model to get the URL stored in the snippet model. If the affiliate's URL ever changes, the snippet can be changed in the Wagtail admin, and the all of the content will use the correct link when rendered.

An example frontend template in affiliates/templates/affiliates/affiliate_snippet_link.html could be the following.

<a href="{{ object.url }}" data-vars-action="content-cta" data-vars-label="{{ object.slug }}" rel="sponsored">

Requirements

The package requires Wagtail 2.5 or above.

Build the library

  1. poetry build

Push a new version release to PyPI

Travis-CI will build the library and deploy it to PyPI on every commit to master that is tagged with a version.

Run tests

  1. poetry install
  2. poetry run pytest

Contributors

License

BSD

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

wagtail-draftail-snippet-0.4.2.tar.gz (10.6 kB view details)

Uploaded Source

File details

Details for the file wagtail-draftail-snippet-0.4.2.tar.gz.

File metadata

File hashes

Hashes for wagtail-draftail-snippet-0.4.2.tar.gz
Algorithm Hash digest
SHA256 8036b3f57cbd3accfbde2f6606d66079aa75ab1b572e68802d988890ab806be3
MD5 04dd4bcd28f55f99a888920deaa6e7a6
BLAKE2b-256 a5ee20bdb15da83cae0883c475a5e409c86b033862b2c2ddc4d791abb20869cf

See more details on using hashes here.

Supported by

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