| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- import django_filters
- from django.db.models import Q
- from extras.filters import CustomFieldFilterSet, CreatedUpdatedFilterSet
- from utilities.filters import BaseFilterSet, NameSlugSearchFilterSet, NumericInFilter, TagFilter
- from .models import Tenant, TenantGroup
- __all__ = (
- 'TenancyFilterSet',
- 'TenantFilterSet',
- 'TenantGroupFilterSet',
- )
- class TenantGroupFilterSet(BaseFilterSet, NameSlugSearchFilterSet):
- class Meta:
- model = TenantGroup
- fields = ['id', 'name', 'slug']
- class TenantFilterSet(BaseFilterSet, CustomFieldFilterSet, CreatedUpdatedFilterSet):
- id__in = NumericInFilter(
- field_name='id',
- lookup_expr='in'
- )
- q = django_filters.CharFilter(
- method='search',
- label='Search',
- )
- group_id = django_filters.ModelMultipleChoiceFilter(
- queryset=TenantGroup.objects.all(),
- label='Group (ID)',
- )
- group = django_filters.ModelMultipleChoiceFilter(
- field_name='group__slug',
- queryset=TenantGroup.objects.all(),
- to_field_name='slug',
- label='Group (slug)',
- )
- tag = TagFilter()
- class Meta:
- model = Tenant
- fields = ['name', 'slug']
- def search(self, queryset, name, value):
- if not value.strip():
- return queryset
- return queryset.filter(
- Q(name__icontains=value) |
- Q(slug__icontains=value) |
- Q(description__icontains=value) |
- Q(comments__icontains=value)
- )
- class TenancyFilterSet(django_filters.FilterSet):
- """
- An inheritable FilterSet for models which support Tenant assignment.
- """
- tenant_group_id = django_filters.ModelMultipleChoiceFilter(
- field_name='tenant__group__id',
- queryset=TenantGroup.objects.all(),
- to_field_name='id',
- label='Tenant Group (ID)',
- )
- tenant_group = django_filters.ModelMultipleChoiceFilter(
- field_name='tenant__group__slug',
- queryset=TenantGroup.objects.all(),
- to_field_name='slug',
- label='Tenant Group (slug)',
- )
- tenant_id = django_filters.ModelMultipleChoiceFilter(
- queryset=Tenant.objects.all(),
- label='Tenant (ID)',
- )
- tenant = django_filters.ModelMultipleChoiceFilter(
- field_name='tenant__slug',
- queryset=Tenant.objects.all(),
- to_field_name='slug',
- label='Tenant (slug)',
- )
|