|
|
@@ -2,7 +2,7 @@ import django_filters
|
|
|
from django.db.models import Q
|
|
|
|
|
|
from extras.filters import CustomFieldFilterSet, CreatedUpdatedFilterSet
|
|
|
-from utilities.filters import BaseFilterSet, NameSlugSearchFilterSet, TagFilter
|
|
|
+from utilities.filters import BaseFilterSet, NameSlugSearchFilterSet, TagFilter, TreeNodeMultipleChoiceFilter
|
|
|
from .models import Tenant, TenantGroup
|
|
|
|
|
|
|
|
|
@@ -14,6 +14,16 @@ __all__ = (
|
|
|
|
|
|
|
|
|
class TenantGroupFilterSet(BaseFilterSet, NameSlugSearchFilterSet):
|
|
|
+ parent_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
+ queryset=TenantGroup.objects.all(),
|
|
|
+ label='Tenant group (ID)',
|
|
|
+ )
|
|
|
+ parent = django_filters.ModelMultipleChoiceFilter(
|
|
|
+ field_name='parent__slug',
|
|
|
+ queryset=TenantGroup.objects.all(),
|
|
|
+ to_field_name='slug',
|
|
|
+ label='Tenant group group (slug)',
|
|
|
+ )
|
|
|
|
|
|
class Meta:
|
|
|
model = TenantGroup
|
|
|
@@ -25,15 +35,18 @@ class TenantFilterSet(BaseFilterSet, CustomFieldFilterSet, CreatedUpdatedFilterS
|
|
|
method='search',
|
|
|
label='Search',
|
|
|
)
|
|
|
- group_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
+ group_id = TreeNodeMultipleChoiceFilter(
|
|
|
queryset=TenantGroup.objects.all(),
|
|
|
- label='Group (ID)',
|
|
|
+ field_name='group',
|
|
|
+ lookup_expr='in',
|
|
|
+ label='Tenant group (ID)',
|
|
|
)
|
|
|
- group = django_filters.ModelMultipleChoiceFilter(
|
|
|
- field_name='group__slug',
|
|
|
+ group = TreeNodeMultipleChoiceFilter(
|
|
|
queryset=TenantGroup.objects.all(),
|
|
|
+ field_name='group',
|
|
|
+ lookup_expr='in',
|
|
|
to_field_name='slug',
|
|
|
- label='Group (slug)',
|
|
|
+ label='Tenant group (slug)',
|
|
|
)
|
|
|
tag = TagFilter()
|
|
|
|
|
|
@@ -56,16 +69,17 @@ 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',
|
|
|
+ tenant_group_id = TreeNodeMultipleChoiceFilter(
|
|
|
queryset=TenantGroup.objects.all(),
|
|
|
- to_field_name='id',
|
|
|
+ field_name='tenant__group',
|
|
|
+ lookup_expr='in',
|
|
|
label='Tenant Group (ID)',
|
|
|
)
|
|
|
- tenant_group = django_filters.ModelMultipleChoiceFilter(
|
|
|
- field_name='tenant__group__slug',
|
|
|
+ tenant_group = TreeNodeMultipleChoiceFilter(
|
|
|
queryset=TenantGroup.objects.all(),
|
|
|
+ field_name='tenant__group',
|
|
|
to_field_name='slug',
|
|
|
+ lookup_expr='in',
|
|
|
label='Tenant Group (slug)',
|
|
|
)
|
|
|
tenant_id = django_filters.ModelMultipleChoiceFilter(
|
|
|
@@ -73,8 +87,8 @@ class TenancyFilterSet(django_filters.FilterSet):
|
|
|
label='Tenant (ID)',
|
|
|
)
|
|
|
tenant = django_filters.ModelMultipleChoiceFilter(
|
|
|
- field_name='tenant__slug',
|
|
|
queryset=Tenant.objects.all(),
|
|
|
+ field_name='tenant__slug',
|
|
|
to_field_name='slug',
|
|
|
label='Tenant (slug)',
|
|
|
)
|