Skip to main content

Allows users to filter Django models

Project description

Django Filtering UI

A Django app for providing a user interface (UI) to the django-filtering package.

The original usecase for the project's UI required the following:

  • Does not disrupt existing backend rendered model listings
  • provides the ability to filter on a field more than once
  • provides the ability to toggle the filtering operation (i.e. AND, OR and NOT filters operators)
  • provides the grouping of filters by operator (TODO)
  • serializes UI filter data to JSON
  • pre-validates UI filter data before sending to backend (TODO)

The UI is implemented in VueJS as a progressive web app (PWA). VueJS was used because of it's small footprint, ease of use, and progressive usage.

The UI implementation here in django-filtering-ui is separate from django-filtering because there are multiple paths to implementing a frontend behavior. I've choosen to create a PWA in VueJS, but there is nothing stopping someone from developing a solution in htmx, React, JQuery, etc.

Installation

Install via pip or the preferred package manager:

pip install django-filtering-ui

Add this package to the installed apps list in your settings.

INSTALLED_APPS=[
    #...
    'django_filtering_ui',
]

See Usage for how to integrate into your frontend.

Usage

TODO

State of development

This package is very much a work-in-progress. All APIs are completely unstable.

Testing & development

Note, I'm testing within a docker container, because I never run anything locally. There are two containers, one for each language; Python for the backend and Node for the frontend. For the moment the containers is simply run with:

docker run -d --rm --name django-filtering-ui--frontend --workdir /code -v $PWD:/code -p 5173:5173 -p 9223:9223 node:latest sleep infinity
docker run -d --rm --name django-filtering-ui--backend --workdir /code -v $PWD:/code python:3.12 sleep infinity

Testing the frontend

Execute testing commands:

docker exec django-filtering-ui--frontend npm install
docker exec django-filtering-ui--frontend npm run test

Testing the backend

Execute testing commands:

docker exec django-filtering-ui--backend pip install -e ".[tests]"
docker exec django-filtering-ui--backend pytest

Using the debugger when testing the frontend

To use the chrome debugger use the following:

npm exec -- vitest --inspect-brk 0.0.0.0:9223 --no-file-parallelism -t $TEST_FILE

Then open chrome://inspect and 0.0.0.0:9223 as a network target.

Building for release

At this time the package is built as follows:

# Builds the js source and outputs it into src/django_filtering_ui/static
npm run build
# Build the python package files
hatchling build

License

GPL v3 (see LICENSE file)

Copyright

© 2025 The Shadowserver Foundation

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_filtering_ui-0.0.4.tar.gz (105.9 kB view details)

Uploaded Source

Built Distribution

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

django_filtering_ui-0.0.4-py3-none-any.whl (77.5 kB view details)

Uploaded Python 3

File details

Details for the file django_filtering_ui-0.0.4.tar.gz.

File metadata

  • Download URL: django_filtering_ui-0.0.4.tar.gz
  • Upload date:
  • Size: 105.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for django_filtering_ui-0.0.4.tar.gz
Algorithm Hash digest
SHA256 40e76d78091681e1411f4e660a04ffaa9ca49ed467b98e76043839231804bcca
MD5 54599ea1ce9fcc7c74cf3326bde12aca
BLAKE2b-256 3b2d584ac3b492845a146a8bd592827cab445f957de678ca6f5edbb2d8e60ce1

See more details on using hashes here.

File details

Details for the file django_filtering_ui-0.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for django_filtering_ui-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 8a2623306791d1c70583328abc7132a4129c4d983a29eff54a22f11f373ab37d
MD5 cf8f8a2bb0957cccf26b103d556f2e40
BLAKE2b-256 f06c094740e2bb114f861355ffcf9a3b53c1365976321b9f48a6c5f9e70343d5

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