Skip to content

Widgets Specification

Peter Siemens edited this page May 15, 2017 · 9 revisions

Dispatch Widgets

Widgets are modular components that can be used throughout different parts of a Dispatch website.

Zones

A zone is a pre-defined portion of the website that can support one or more widget types. Zones allow us to configure the placement of widgets throughout the site. A widget can be compatible with one or more zones.

Defining zones in your theme

# zones.py

from dispatch.themes import zones

# Register your zones with dispatch
zones.register('Zone 1', 'zone-1')
zones.register('Zone 2', 'zone-2')

Using zones in templates

A zone can be rendered in any template using the zone template tag like so:

{% load zones %}

... 

<div>
{% zone 'zone-1' %}
</div>

Zones API Spec

Zones only have two methods: GET and PUT. Since zones and widgets are defined in the theme code, they do not support the standard CRUD operations. The zone PUT route only allows the user to manipulate the dynamic data stored for that zone.

GET '/api/zones/'

# JSON
[
  {
    'id': 'zone-1',
    'name': 'Zone 1',
    'widget': {
      'id': 'widget-1',
      'data': {
        'title': 'test title 1',
      }
    }
  },
  {
    'id': 'zone-2',
    'name': 'Zone 2',
    'widget': {
      'id': 'widget-2',
      'data': {
        'title': 'test title 2',
      }
    }
  }
]

GET '/api/zones/{id}'

# JSON
{
  'id': 'zone-2',
  'name': 'Zone 2'
  'widget': {
    'id': 'widget-2',
    'data': {
      'title': 'test title 2',
    }
  }
}

PATCH '/api/zones/{id}'

# JSON
{
  'widget': {
    'id': 'widget-1',
    'data': {
      'title': 'test title 1',
    }
  }
}

Widgets

Defining widgets in your theme

# widgets.py

from dispatch.theme.widgets import widgets, Widget, CharField

class CustomWidget(Widget):
  id = 'custom-widget'
  name = 'Custom Widget'
  template = 'widgets/custom-widget.html'

  fields = [
    ('title', CharField
  ]
  

Widgets API Spec

GET '/api/widgets/'

# JSON

[
  {
    'id': 'widget-1',
    'name': 'Widget 1',
    'fields': [
      {
        'type': 'text'
      },
       {
        'type': 'image',
        'many': True
      }
    }]
  }
]
Clone this wiki locally