Skip to main content

Slippers is a lightweight library for Django that makes your HTML components available as template tags.

Project description

Slippers

Slippers is a lightweight library for Django that makes your HTML components available as template tags.

{% card variant="small" %}
  <h1>Slippers is cool</h1>

  {% button %}Super cool{% endbutton %}
  {% button variant="secondary" %}Lit af{% endbutton %}
{% endcard %}

Why?

I want to be able to make reusable components, but the syntax for {% include %} is too verbose. Plus it doesn't allow me to specify child elements.

Show me how it works

First create your template. Wherever you would normally put it is fine.

{# myapp/templates/myapp/card.html #}
<div class="card">
  <h1 class="card__header">{{ heading }}</h1>
  <div class="card__body">
    {# Child elements are rendered by `{{ children }}` #}
    {{ children }}
  </div>
</div>

Next, create a components.yaml file. By default, Slippers looks for this file in the root template folder.

# myapp/templates/components.yaml
# Components that have child elements
block_components:
  card: "myapp/card.html"
 
# Components that don't have child elements
inline_components: 
  avatar: "myapp/avatar.html"

You can now use the components like so:

{% load slippers %}

{% card heading="Slippers is awesome" %}
  <span>Hello {{ request.user.full_name }}!</span>
{% endcard %}

And the output:

<div class="card">
  <h1 class="card__header">Slippers is awesome</h1>
  <div class="card__body">
    <span>Hello Ryland Grace!</span>
  </div>
</div>

Installation

pip install slippers

Add it to your INSTALLED_APPS:

INSTALLED_APPS = [
    ...
    'slippers',
    ...
]

Documentation

The components.yaml file

This file should be placed at the root template directory. E.g. myapp/templates/components.yaml.

The structure of the file is as follows:

# Components that have child elements are called "block" components
block_components:
  # The key determines the name of the template tag. So `card` would generate
  # `{% card %}{% endcard %}`
  # The value is the path to the template file as it would be if used with {% include %}
  card: "myapp/card.html"
 
# Components that don't have child elements are called "inline" components
inline_components: 
  avatar: "myapp/avatar.html"

This file also doubles as an index of available components which is handy.

Context

Unlike {% include %}, using the component template tag will not pass the current context to the child component. This is a design decision. If you need something from the parent context, you have to explicitly pass it in via keyword arguments, or use {% include %} instead.

{% with not_passed_in="Lorem ipsum" %}
  {% button is_passed_in="Dolor amet" %}Hello{% endbutton %}
{% endwith %}

License

MIT

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

slippers-0.1.3.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

slippers-0.1.3-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file slippers-0.1.3.tar.gz.

File metadata

  • Download URL: slippers-0.1.3.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.0 CPython/3.8.6 Darwin/20.5.0

File hashes

Hashes for slippers-0.1.3.tar.gz
Algorithm Hash digest
SHA256 edc69e3660c9bec3ac4d7f03bf1ea7e648b362b00c311c5518720b2aa9f70c79
MD5 35e2a051cf282d586ce5ffbbb0d4d66e
BLAKE2b-256 743b37a111b3ec4be966c01249ab2ae54d402a1117bc07c14f3d082d19126e8d

See more details on using hashes here.

File details

Details for the file slippers-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: slippers-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 5.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.0 CPython/3.8.6 Darwin/20.5.0

File hashes

Hashes for slippers-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 376dcabc7ce63bcf8a66b8c93e3ff1cc27c1eb4b2d6705287dca0d022792a955
MD5 29cd00db7cdd756a308232ca93c5833d
BLAKE2b-256 9acb9c827b2a3fb2981cb35689eb1d3451caae5c5b2d76eab7cab1cde39c1a9c

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