![Screenshot](https://github.com/lukasvinclav/django-admin-numeric-filter/raw/master/screenshot.png)
# django-admin-numeric-filter
![](https://img.shields.io/badge/Version-0.1.8-orange.svg?style=flat-square)
![](https://img.shields.io/badge/Django-2.0+-green.svg?style=flat-square)
![](https://img.shields.io/badge/License-MIT-blue.svg?style=flat-square)
django-admin-numeric-filter provides you several filter classes for Django admin which you can use to filter results in change list. It works in **list_filter** when a field name is defined as list where the first value is field name and second one is custom filter class (you can find classes below).
Don't forget to inherit your model admin from **admin_actions.admin.NumericFilterModelAdmin** to load custom CSS styles and JavaScript files declared in inner Media class.
## Getting started
1. Installation
```bash
pip install django-admin-numeric-filter
```
2. Add **admin_numeric_filter** into **INSTALLED_APPS** in your settings file before **django.contrib.admin**.
## Sample admin configuration
```python
from admin_numeric_filter.admin import NumericFilterModelAdmin, SingleNumericFilter, RangeNumericFilter, \
SliderNumericFilter
from .models import YourModel
class CustomSliderNumericFilter(SliderNumericFilter):
MAX_DECIMALS = 2
STEP = 10
@admin.register(YourModel)
class YourModelAdmin(NumericFilterModelAdmin):
list_filter = (
('field_A', SingleNumericFilter), # Single field search, __gte lookup
('field_B', RangeNumericFilter), # Range search, __gte and __lte lookup
('field_C', SliderNumericFilter), # Same as range above but with slider
('field_D', CustomSliderNumericFilter), # Filter with custom attributes
)
```
## Filter classes
| Class name | Description |
|------------------------------------------|----------------------------------------|
| admin_actions.admin.SingleNumericFilter | Single field search, __gte lookup |
| admin_actions.admin.RangeNumericFilter | Range search, __gte and __lte lookup |
| admin_actions.admin.SliderNumericFilter | Same as range above but with slider |
## Slider default options for certain field types
| Django model field | Step | Decimal places |
|------------------------------------------|--------------------------|----------------------------|
| django.db.models.fields.DecimalField() | Based on decimal places | max precision from DB |
| django.db.models.fields.FloatField() | Based on decimal places | field decimal_places attr |
| django.db.models.fields.IntegerField() | 1 | 0 |
Raw data
{
"_id": null,
"home_page": "https://github.com/lukasvinclav/django-admin-numeric-filter",
"name": "django-admin-numeric-filter",
"maintainer": "",
"docs_url": null,
"requires_python": ">=3.6",
"maintainer_email": "",
"keywords": "django,admin,numeric,filter",
"author": "",
"author_email": "",
"download_url": "https://files.pythonhosted.org/packages/b8/38/83cf9211e88960c8538b2ce33a4a7b2106e06ce70948045c8c90f496445a/django_admin_numeric_filter-0.1.8.tar.gz",
"platform": null,
"description": "![Screenshot](https://github.com/lukasvinclav/django-admin-numeric-filter/raw/master/screenshot.png)\n\n# django-admin-numeric-filter\n\n![](https://img.shields.io/badge/Version-0.1.8-orange.svg?style=flat-square)\n![](https://img.shields.io/badge/Django-2.0+-green.svg?style=flat-square)\n![](https://img.shields.io/badge/License-MIT-blue.svg?style=flat-square)\n\ndjango-admin-numeric-filter provides you several filter classes for Django admin which you can use to filter results in change list. It works in **list_filter** when a field name is defined as list where the first value is field name and second one is custom filter class (you can find classes below).\n\nDon't forget to inherit your model admin from **admin_actions.admin.NumericFilterModelAdmin** to load custom CSS styles and JavaScript files declared in inner Media class.\n\n## Getting started\n\n1. Installation\n\n```bash\npip install django-admin-numeric-filter\n```\n\n2. Add **admin_numeric_filter** into **INSTALLED_APPS** in your settings file before **django.contrib.admin**.\n\n## Sample admin configuration\n\n```python\nfrom admin_numeric_filter.admin import NumericFilterModelAdmin, SingleNumericFilter, RangeNumericFilter, \\\n SliderNumericFilter\n\nfrom .models import YourModel\n\n\nclass CustomSliderNumericFilter(SliderNumericFilter):\n MAX_DECIMALS = 2\n STEP = 10\n\n\n@admin.register(YourModel)\nclass YourModelAdmin(NumericFilterModelAdmin):\n list_filter = (\n ('field_A', SingleNumericFilter), # Single field search, __gte lookup\n ('field_B', RangeNumericFilter), # Range search, __gte and __lte lookup\n ('field_C', SliderNumericFilter), # Same as range above but with slider\n ('field_D', CustomSliderNumericFilter), # Filter with custom attributes\n )\n```\n\n## Filter classes\n\n| Class name | Description |\n|------------------------------------------|----------------------------------------|\n| admin_actions.admin.SingleNumericFilter | Single field search, __gte lookup |\n| admin_actions.admin.RangeNumericFilter | Range search, __gte and __lte lookup |\n| admin_actions.admin.SliderNumericFilter | Same as range above but with slider |\n\n\n## Slider default options for certain field types\n\n| Django model field | Step | Decimal places |\n|------------------------------------------|--------------------------|----------------------------|\n| django.db.models.fields.DecimalField() | Based on decimal places | max precision from DB |\n| django.db.models.fields.FloatField() | Based on decimal places | field decimal_places attr |\n| django.db.models.fields.IntegerField() | 1 | 0 |",
"bugtrack_url": null,
"license": "MIT",
"summary": "Numeric filters for Django admin",
"version": "0.1.8",
"split_keywords": [
"django",
"admin",
"numeric",
"filter"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "e8f759f62aab3029fdd1ce091537f925a9099bf0090c7b31870a394161ddcdab",
"md5": "a8a14449e4b19329f18979b1949c5671",
"sha256": "89052324989d2c6a9bb060c13e1f159800ec9ca8b7f40d2160d710f89c7453d3"
},
"downloads": -1,
"filename": "django_admin_numeric_filter-0.1.8-py3-none-any.whl",
"has_sig": false,
"md5_digest": "a8a14449e4b19329f18979b1949c5671",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.6",
"size": 19190,
"upload_time": "2023-01-13T08:03:18",
"upload_time_iso_8601": "2023-01-13T08:03:18.124636Z",
"url": "https://files.pythonhosted.org/packages/e8/f7/59f62aab3029fdd1ce091537f925a9099bf0090c7b31870a394161ddcdab/django_admin_numeric_filter-0.1.8-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "b83883cf9211e88960c8538b2ce33a4a7b2106e06ce70948045c8c90f496445a",
"md5": "c3b9c78aff297fcbc3b1a495b6839bdf",
"sha256": "26edf7d9fc16cd3f8630aa5f4ae84df4253786bcf86d2254185b93cc9fca65ed"
},
"downloads": -1,
"filename": "django_admin_numeric_filter-0.1.8.tar.gz",
"has_sig": false,
"md5_digest": "c3b9c78aff297fcbc3b1a495b6839bdf",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.6",
"size": 16922,
"upload_time": "2023-01-13T08:03:19",
"upload_time_iso_8601": "2023-01-13T08:03:19.999204Z",
"url": "https://files.pythonhosted.org/packages/b8/38/83cf9211e88960c8538b2ce33a4a7b2106e06ce70948045c8c90f496445a/django_admin_numeric_filter-0.1.8.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-01-13 08:03:19",
"github": true,
"gitlab": false,
"bitbucket": false,
"github_user": "lukasvinclav",
"github_project": "django-admin-numeric-filter",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"lcname": "django-admin-numeric-filter"
}