Skip to main content

grafl.io integration for Wagtail CMS

Project description

Wagtail-Grafl

Create charts in Wagtail streamfields using the Grafl.io plotting service.

Installation

Install from PyPI:

pip install wagtail-grafl

Then add the following to your project's INSTALLED_APPS.

'wagtail_grafl',

Out of the box

There are currently three blocks available in wagtail-grafl.

GraflBlock

The primary block used for creating basic Grafl plots.

It consists of a single JSON field for entering Grafl plot data. It inherits from BaseGraflBlock.

JsonBlock

Simple formatted JSON field with basic validation and included in GraflBlock.

BaseGraflBlock

The BaseGraflBlock is provided to make it easy to extend wagtail-grafl and build your own bespoke Grafl blocks.

It provides the get_grafl_data method that needs to be overridden in any blocks that inherit from this.

The get_grafl_data method should return a dictionary of Grafl compatible data.

This make it possible for custom blocks to pull in data from other sources and generate Grafl plots programatically.

Settings

  • WAGTAIL_GRAFL_PLOT_DEFAULTS - a optional dictionary of default parameters that is merged with the blocks grafl data. This is useful for specifying parameters that should be consistent across all Grafl plot blocks.

Example use

Add the StreamBlock to a StreamField on a Wagtail page:

from wagtail.core import blocks
from wagtail_grafl.blocks import GraflBlock

class MyStreamBlock(blocks.StreamBlock):
    grafl_plot = GraflBlock()

Add the StreamBlock to a StreamField on a Wagtail page:

from wagtail.admin.edit_handlers import StreamFieldPanel
from wagtail.core.fields import StreamField
from wagtail.core.models import Page

from .blocks import MyStreamBlock


class MyPage(Page):

    body = StreamField(MyStreamBlock(), null=True)

    content_panels = Page.content_panels + [
        StreamFieldPanel('body'),
    ]

Then in the page template:

{% load static wagtailcore_tags %}

{% include_block page.body %}

About Grafl

Grafl is a plotting service that can be used to generate plots from basic JSON data. It's based on Plotly, free to use and very flexible.

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_grafl-0.0.1.tar.gz (7.0 kB view hashes)

Uploaded Source

Built Distribution

wagtail_grafl-0.0.1-py3-none-any.whl (7.2 kB view hashes)

Uploaded Python 3

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