Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
42 changes: 38 additions & 4 deletions lego/apps/companies/filters.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,46 @@
from django.db.models import Q
from django_filters import BooleanFilter, CharFilter, FilterSet
from django.db.models import Q, Func, IntegerField, Subquery, OuterRef, Value
from django.db.models.functions import Coalesce
from django_filters import BooleanFilter, CharFilter, FilterSet, OrderingFilter

from lego.apps.companies.models import Company, CompanyInterest, Semester, SemesterStatus

class StatusOrderingFilter(OrderingFilter):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.extra['choices'] += [
('status', 'Status'),
('-status', 'Status (descending)')
]

from lego.apps.companies.models import Company, CompanyInterest, Semester
def filter(self, queryset, value):
if not value:
return queryset

semester_id = self.parent.request.query_params.get("semester_id")

class ArrayLength(Func):
function = 'CARDINALITY'
output_field = IntegerField()

return queryset.annotate(
status=Coalesce(
Subquery(
SemesterStatus.objects.filter(
company=OuterRef('pk'),
semester_id=semester_id
).annotate(
contact_count=ArrayLength('contacted_status')
).values('contact_count')[:1]
),
Value(0, output_field=IntegerField())
)
).order_by('-status')

class AdminCompanyFilterSet(FilterSet):

search = CharFilter(method="filter_search")
status = CharFilter(method="filter_semester_status")
ordering = StatusOrderingFilter()

def filter_semester_status(self, queryset, name, value):
if not value:
Expand Down Expand Up @@ -42,7 +75,8 @@ def filter_search(self, queryset, name, value):

class Meta:
model = Company
fields = ["search", "status"]
fields = ["search", "status", "ordering"]



class CompanyFilterSet(FilterSet):
Expand Down
1 change: 0 additions & 1 deletion lego/apps/companies/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,6 @@ class Company(BasisModel):

class Meta:
permission_handler = CompanyPermissionHandler()
ordering = ["name"]

@property
def content_target(self) -> str:
Expand Down
2 changes: 0 additions & 2 deletions lego/apps/companies/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,8 +53,6 @@ class AdminCompanyViewSet(AllowedPermissionsMixin, viewsets.ModelViewSet):
queryset = Company.objects.all().prefetch_related("semester_statuses", "files")
filterset_class = AdminCompanyFilterSet
permission_handler = CompanyAdminPermissionHandler()
ordering_fields = ["name", "created_at"]
ordering = "name"

def get_serializer_context(self):
context = super().get_serializer_context()
Expand Down