Skip to main content

A flexible data composition tool to simplify writing templates.

Project description

django-nifty-layout

PyPI Version Test with tox Code style: black

Version: 0.1.1

A simple but flexible layout tool for composing and transforming data for structured template components. Inspired by crispy-forms Layout, but without the forms.

django-nifty-layout is free software distributed under the MIT License.

Quick Start

  1. Install the django-nifty-layout package from PyPI

    $ pip install django-nifty-layout
    
  2. Go grab a drink, you are all done!

Sample Usage

layout.py

from django.utils.formats import date_format

from nifty_layout.components import (
   DictCompositeNode as Dct,
   FieldNode as Fld,   
   Seq,
)

# ----- Safe Date Formatter ----- #
date_formatter = lambda val: None if val is None else date_format(val, SHORT_DATE_FORMAT)

layout = Dct(
    dict(
        overview=Seq(
             "title",
             Fld("date", formatter=date_formatter),
             report_type",
             "location",
             labeller="Overview",
        ),
        contacts=Seq(
            Dct(
                dict(
                    name="contact_name",
                    contact_methods=Seq("contact_email"),
                ),
                dict(
                    name="reported_by_name",
                    contact_methods=Seq("reported_by_phone_num", "reported_by_email"),
                    ),
                )
            ),
            labeller="Contacts",
        ),
        ...
    )
)

views.py

def report_view(request, pk):
   ...
   obj = Report.objects.get(pk=pk)
   ...
   return render(request, "template.html", dict(report=layout.bind(obj)))

template.html

...
<div class="report>
  <h2>report.overview.label</h2>
  {% for node in report.overview.children %}
      <div class="row">
         <div class="col label">{{ node.label }}</div>
         <div class="col value">{{ node.value|default:"" }}</div>
      {% endfor %}
      </div>
  {% endfor %}
  <div class="row">
    {% for contact in report.contacts.children %}
      <div class="col">
        {% include "contact_card.html" %}
      </div>
    {% endfor %}
  </div>
   ...
</div>   

Get Me Some of That

MIT License

Check Out the Demo App ** coming soon **

  1. pip install -e git+https://github.com/powderflask/django-nifty-layout.git#egg=django-nifty-layout
  2. python django-nifty-layout/manage.py install_demo
  3. python django-nifty-layout/manage.py runserver

Acknowledgments

This project would be impossible to maintain without the help of our generous contributors

Technology Colophon

Without django and the django dev team, the universe would have fewer rainbows and ponies.

This package was originally created with cookiecutter and the cookiecutter-powder-pypackage project template.

For Developers

Install invoke, pip-tools, tox for all the CLI goodness

 pip install invoke pip-tools tox

Initialise the development environment using the invoke task

inv tox.venv

Or create it with tox directly

tox d -e dev .venv

Or build and install the dev requirements with pip

inv deps.compile-dev
pip install -r requirements_dev.txt

Tests

pytest

or

tox r

or run tox environments in parallel using

tox p

Code Style / Linting

$ isort
$ black
$ flake8

Versioning

Build / Deploy Automation

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

django_nifty_layout-0.1.1.tar.gz (13.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_nifty_layout-0.1.1-py3-none-any.whl (13.4 kB view details)

Uploaded Python 3

File details

Details for the file django_nifty_layout-0.1.1.tar.gz.

File metadata

  • Download URL: django_nifty_layout-0.1.1.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for django_nifty_layout-0.1.1.tar.gz
Algorithm Hash digest
SHA256 65bebbfb3665c5e5e4c1427a857266cf37df1e0476b80dee1e07ac06092fddda
MD5 8ced45f4185eea4594a6d70326d019ff
BLAKE2b-256 bf3536202c16604f0e182b4f6e5faa1311bb23ac80ec749d979261721d62ab03

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_nifty_layout-0.1.1.tar.gz:

Publisher: release.yaml on powderflask/django-nifty-layout

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file django_nifty_layout-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for django_nifty_layout-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 52222244728ace59ed2ac297f374a2aee7f8dd57704f1e8d57aeb50718d1c387
MD5 0fe2b13ffbfdf6c8d7d1b3f131189340
BLAKE2b-256 bd5d78145d6856e5887c14863fdbb819fec39c52f7dc2a5395c4aacba833490c

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_nifty_layout-0.1.1-py3-none-any.whl:

Publisher: release.yaml on powderflask/django-nifty-layout

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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