Metadata-Version: 2.4
Name: django-admin-advanced-search
Version: 0.1.2
Summary: Advanced search syntax for Django Admin
Author-email: shifenhutu <shifenhutu@example.com>
License: MIT
Project-URL: Homepage, https://github.com/shifenhutu/django-admin-advanced-search
Project-URL: Repository, https://github.com/shifenhutu/django-admin-advanced-search
Project-URL: Documentation, https://github.com/shifenhutu/django-admin-advanced-search/blob/main/README.md
Project-URL: Issues, https://github.com/shifenhutu/django-admin-advanced-search/issues
Keywords: django,admin,search,filter,advanced-search
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Web Environment
Classifier: Framework :: Django
Classifier: Framework :: Django :: 5.1
Classifier: Framework :: Django :: 5.2
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3.12
Requires-Python: >=3.12
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: Django>=5.1
Dynamic: license-file

# Django Admin Advanced Search

[![PyPI](https://img.shields.io/pypi/v/django-admin-advanced-search)](https://pypi.org/project/django-admin-advanced-search/)
[![License](https://img.shields.io/pypi/l/django-admin-advanced-search)](https://github.com/shifenhutu/django-admin-advanced-search/blob/main/LICENSE)
[![Python Version](https://img.shields.io/pypi/pyversions/django-admin-advanced-search)](https://pypi.org/project/django-admin-advanced-search/)

Advanced search syntax for Django Admin that enables powerful filtering capabilities directly from the search bar.

[中文版 说明](README_zh.md)

## Features

- Enhanced search capabilities in Django Admin with advanced syntax
- Support for field-specific searches with various operators
- Case-sensitive and case-insensitive matching options
- Quoted values support for exact phrase matching
- Multiple conditions combination with AND logic
- Seamless integration with existing Django Admin interfaces
- Performance-conscious implementation with database-level filtering
- Automatic field type detection (string, number, date, datetime)
- Type-specific parsing rules for appropriate operators
- Support for comparison operators on number and date fields

## Requirements

- Python >= 3.12
- Django >= 5.1

Note: This package has been tested specifically on Django 5.1, 5.2 with Python 3.12, 3.13, 3.14. While it may work on other versions, compatibility is not guaranteed for versions outside this range.

## Installation

```bash
pip install django-admin-advanced-search
```

## Usage

1. Add `django_admin_advanced_search` to your `INSTALLED_APPS`:

```python
INSTALLED_APPS = [
    ...
    'django_admin_advanced_search',
    ...
]
```

2. Use the advanced search in your admin classes:

```python
from django.contrib import admin
from django_admin_advanced_search.mixins import AdvancedSearchMixin

class MyModelAdmin(AdvancedSearchMixin, admin.ModelAdmin):
    search_fields = ['name', 'description', 'author__name']  # Fields that can be searched
    # Your other admin configuration

admin.site.register(MyModel, MyModelAdmin)
```

## Search Syntax

| Syntax | Description | Example | SQL Equivalent |
|--------|-------------|---------|----------------|
| `field:value` | Case-insensitive contains | `name:john` | `name ILIKE '%john%'` |
| `field:=value` | Case-insensitive exact | `name:=john` | `name ILIKE 'john'` |
| `field:==value` | Case-sensitive exact | `name:==John` | `name = 'John'` |
| `field:!value` | Case-sensitive contains | `name:!john` | `name LIKE '%john%'` |
| `field:*suffix` | Case-insensitive endswith | `name:*son` | `name ILIKE '%son'` |
| `field:!*suffix` | Case-sensitive endswith | `name:!*son` | `name LIKE '%son'` |
| `field:prefix*` | Case-insensitive startswith | `name:john*` | `name ILIKE 'john%'` |
| `field:!prefix*` | Case-sensitive startswith | `name:!john*` | `name LIKE 'john%'` |
| `field:>value` | Greater than (numbers/dates) | `price:>100` | `price > 100` |
| `field:>=value` | Greater than or equal (numbers/dates) | `date:>=2023-01-01` | `date >= '2023-01-01'` |
| `field:<value` | Less than (numbers/dates) | `price:<1000` | `price < 1000` |
| `field:<=value` | Less than or equal (numbers/dates) | `date:<=2023-12-31` | `date <= '2023-12-31'` |
| `field:"quoted value"` | Values with spaces (dates/times) | `created_at:<"2023-12-31 23:59:59"` | `created_at < '2023-12-31 23:59:59'` |
| `"quoted values"` | Exact phrase matching | `name:"John Doe"` | `name ILIKE 'John Doe'` |

## Examples

- `title:django*` - Items with titles starting with "django" (case-insensitive)
- `author__name:*smith` - Items by authors whose names end with "smith" (case-insensitive)
- `title:==Learning Python` - Items with the exact title "Learning Python" (case-sensitive)
- `title:"Python Programming"` - Items with titles containing the exact phrase "Python Programming"
- `title:python author__name:john` - Items with titles containing "python" AND authors whose names contain "john"
- `price:>29.99` - Items with price greater than 29.99
- `publication_date:>=2023-01-01` - Items published on or after January 1, 2023
- `created_at:<"2023-12-31 23:59:59"` - Items created before December 31, 2023 11:59:59 PM (note the quotes around the datetime value with spaces)

## Documentation

- [Usage Guide (English)](docs/usage.md) | [使用指南 (中文)](docs/usage_zh.md)
- [Testing Guide (English)](docs/testing.md) | [测试指南 (中文)](docs/testing_zh.md)

## Database Collation and Performance Notes

- This package generates database-level filters, ensuring optimal performance
- For case-insensitive operations, the package uses the database's native case-insensitive comparison operators when available
- Make sure your database columns have appropriate collation settings for optimal performance
- Complex searches with multiple fields may generate complex SQL queries; consider adding database indexes on frequently searched fields
- When using related field lookups (e.g., `author__name:john`), ensure foreign key relationships are properly indexed
- For number and date fields, the package automatically detects field types and applies appropriate comparison operators
- DateTime values containing spaces must be quoted to be parsed correctly (e.g., `created_at:<"2023-12-31 23:59:59"`)

## Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

1. Fork the repository
2. Create your feature branch (`git checkout -b feature/AmazingFeature`)
3. Commit your changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request

## License

This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.

Project Link: [https://github.com/shifenhutu/django-admin-advanced-search](https://github.com/shifenhutu/django-admin-advanced-search)
