Skip to main content

Pragmatic tools and utilities for Django projects

Project description

django-pragmatic

Build Status

Pragmatic tools and utilities for Django projects.

Requirements

Optional dependencies are required only for the modules that use them (see Installation).

Installation

pip install django-pragmatic

Add pragmatic to INSTALLED_APPS:

INSTALLED_APPS = [
    ...
    'pragmatic',
]

Run migrations (needed only if you use deleted-object tracking):

python manage.py migrate pragmatic

What's included

Module Description
Models DeletedObject — audit trail for deleted instances
Mixins CBV/form mixins: permissions, delete, pagination, sorting, display modes, PDF, slugs
Decorators permissions_required, permission_required, PostgreSQL lock, Cached
Template tags {% load pragmatic_tags %} — filter display, sorting, pagination, URL tools
Fields RangeField, SliderField, MultiSelectField, ChoiceArrayField
Filters SliderFilter, OneFieldRangeFilter, ArrayFilter and more
Widgets GroupedCheckboxSelectMultiple, SliderWidget, map widgets
Middleware MaintenanceModeMiddleware — serve 503 during downtime
Managers EmailManager — template-based email with optional RQ queue
Context processors Date formats, installed apps, URL identifier, settings
Signals SignalsHelper, apm_custom_context, disable_signals
Utils build_absolute_uri, get_task_decorator, zip compression
Jobs Background email via RQ, ConnectionClosingWorker
REST Framework ContentTypeSerializer, HybridRouter, BearerAuthentication
Management commands clean_migrations, rqscheduler

Quick examples

Maintenance mode:

# settings.py
MAINTENANCE_MODE = True
MAINTENANCE_MODE_BYPASS_USERS = [1]  # superuser can still log in

Send an email from a template:

from pragmatic.managers import EmailManager

EmailManager.send_mail(
    to=user,
    template_prefix='emails/welcome',
    subject='Welcome!',
    data={'activation_link': url},
    request=request,
)

List view with display modes and sorting:

from pragmatic.mixins import DisplayListViewMixin, SortingListViewMixin

class ArticleListView(SortingListViewMixin, DisplayListViewMixin, ListView):
    model = Article
    displays = ['list', 'table']
    paginate_by_display = {'list': [10, 25], 'table': 100}
    sorting_options = {'-created': 'Newest', 'title': 'Title A–Z'}

Template filter values display:

{% load pragmatic_tags %}
{% filter_values filter %}
{% num_applied_filters filter request.GET as n %}
{{ n }} active filter{{ n|pluralize }}

Background task decorator:

# settings.py
PRAGMATIC_TASK_DECORATOR = 'django_rq.job'  # or 'celery.shared_task'
from pragmatic.utils import get_task_decorator

task = get_task_decorator(queue='default')

@task
def process_export(export_id):
    ...

Documentation

Full documentation is at django-pragmatic.readthedocs.io.

License

BSD License — see LICENSE for details.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django_pragmatic-7.1.0.tar.gz (48.5 kB view details)

Uploaded Source

File details

Details for the file django_pragmatic-7.1.0.tar.gz.

File metadata

  • Download URL: django_pragmatic-7.1.0.tar.gz
  • Upload date:
  • Size: 48.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for django_pragmatic-7.1.0.tar.gz
Algorithm Hash digest
SHA256 eb646c066b6c13a31ddc64defe07cd399b6bc0ad592e5c1af724dc474744e7d7
MD5 74139809ac15f52fc324a749b20da14e
BLAKE2b-256 51446934a32b577d3599263db53fc1adea8e2c9b923fc3ab8d46e5a0799b27e9

See more details on using hashes here.

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