Skip to content

The-Shadowserver-Foundation/django-filtering-ui

Repository files navigation

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

Then I execute commands on the shell within it:

docker exec -it django-filtering-ui--frontend bash

From here you can install and run the frontend code tests using:

npm install
npm run test

Test debugging

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