Metadata-Version: 2.2
Name: django-admin-fast-search
Version: 0.2.4
Summary: Your project description goes here
Home-page: https://github.com/utkbansal/django-admin-fast-search
Author: Utkarsh Bansal
Author-email: ubansal@instawork.com
License: MIT
Keywords: django-admin-fast-search
Classifier: Development Status :: 3 - Alpha
Classifier: Framework :: Django :: 2.1
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: BSD License
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
License-File: LICENSE
License-File: AUTHORS.rst
Requires-Dist: django-filter>=23.5
Dynamic: author
Dynamic: author-email
Dynamic: classifier
Dynamic: description
Dynamic: home-page
Dynamic: keywords
Dynamic: license
Dynamic: requires-dist
Dynamic: summary

=============================
django-admin-fast-search
=============================

.. image:: https://badge.fury.io/py/django-admin-fast-search.svg
    :target: https://badge.fury.io/py/django-admin-fast-search

.. image:: https://travis-ci.org/utkbansal/django-admin-fast-search.svg?branch=master
    :target: https://travis-ci.org/utkbansal/django-admin-fast-search

.. image:: https://codecov.io/gh/utkbansal/django-admin-fast-search/branch/master/graph/badge.svg
    :target: https://codecov.io/gh/utkbansal/django-admin-fast-search

Your project description goes here

Documentation
-------------

The full documentation is at https://django-admin-fast-search.readthedocs.io.

Quickstart
----------

Install django-admin-fast-search::

    pip install django-admin-fast-search

Add it to your `INSTALLED_APPS`:

.. code-block:: python

    INSTALLED_APPS = (
        ...
        'django_admin_fast_search',
        ...
    )

Use it in your Django admin for search fields:

.. code-block:: python

   from django_admin_fast_search.admin import FastSearch

   class MyModelAdmin(FastSearch, admin.ModelAdmin):
       list_display = ['name', 'email']

       search_fields_contains = ("address",)
       search_fields_exact = ("id", "email")
       search_fields_fulltext_index = ("name",)
       search_fields = search_fields_fulltext_index + search_fields_exact + search_fields_contains


Use it for list filters with django_filters_

.. code-block:: python

   from django_filters import BooleanFilter, CharFilter, ModelChoiceFilter, FilterSet
   from django_admin_fast_search.admin import FastSearchFilterMixin

   class MyModelFilter(FastSearchFilterMixin, FilterSet):
       is_verified = BooleanFilter(label="Verified?")

       company_name = CharFilter(field_name="company__name", lookup_expr="icontains")
       company_pincode = CharFilter(field_name="company__location_pincode", lookup_expr="exact")

       company = ModelChoiceFilter()
       # OR
       company = ModelChoiceFilter(queryset=Company.objects.active())

       exclude_industry = CharFilter(field_name="industry", lookup_expr="icontains", label="Exclude Industry", exclude=True)

       status = MultipleChoiceFilter(
           field_name="status",
           lookup_expr="exact",
           label="Status",
           choices=MyModel.STATUS_CHOICES,
       )

       created_at = DateFilter(field_name="created_at", lookup_expr="gt", label="Signed up After")

       class Meta:
           model = MyModel
           fields = [
               "is_verified",
               "company_name",
               "company_pincode",
               "company",
               "exclude_industry",
               "status",
               "created_at",
           ]


   class MyModelAdmin(FastSearch, admin.ModelAdmin):
       list_display = ['name', 'email']

       list_filter = ["company_tier", *MyModelFilter.as_admin_filters()]

       # or only use class-based filters

       list_filter = MyModelFilter.as_admin_filters()


Running Tests
-------------

Does the code actually work?

::

    source <YOURVIRTUALENV>/bin/activate
    (myenv) $ pip install tox
    (myenv) $ tox


Development commands
---------------------

::

    pip install -r requirements_dev.txt
    invoke -l


Credits
-------

Tools used in rendering this package:

*  Cookiecutter_
*  `cookiecutter-djangopackage`_

.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`cookiecutter-djangopackage`: https://github.com/pydanny/cookiecutter-djangopackage
.. _django_filters: https://django-filter.readthedocs.io/en/stable/




History
-------

0.1.2 (2022-05-30)
++++++++++++++++++

* Add classifiers for Python 3.7, 3.8, 3.9, 3.10
* Remove support for Python 2, 2.7, 3.5, 3.6
* Automate publish to PyPi

0.1.0 (2021-05-22)
++++++++++++++++++

* First release on PyPI.
