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_NAME" $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
docker exec django-filtering-ui--frontend npm run build
# Build the python package files
docker exec django-filtering-ui--backend pip install hatchling
docker exec django-filtering-ui--backend hatchling build

License

GPL v3 (see LICENSE file)

Copyright

© 2026 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.10.tar.gz (101.5 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.10-py3-none-any.whl (51.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: django_filtering_ui-0.0.10.tar.gz
  • Upload date:
  • Size: 101.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for django_filtering_ui-0.0.10.tar.gz
Algorithm Hash digest
SHA256 897e1f24897a648cac9c246f265415eea256acba09185140ad1e31a7f190986d
MD5 9cbf7171e3116ea345af9fcdbfe1dccc
BLAKE2b-256 607c847c9a1528dcbe96b433dc94338499fcc425c4e51597a3c6e573304bc411

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_filtering_ui-0.0.10-py3-none-any.whl
Algorithm Hash digest
SHA256 bc49c825f6cf63371b94df03a9c4fa20833abec973636098ef8d7f40d8d477db
MD5 a188602b5246e7ad5aafafe9bea248a6
BLAKE2b-256 e0e186a24a7ce4dd71d3d485c167b349af0d42dfa3d79deda0954166add9e898

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