Add min_start_date filter to Tournament summary view

mailing
Razmig Sarkissian 2 months ago
parent 754c1d5796
commit ac76622995
  1. 2
      api/serializers.py
  2. 16
      api/views.py

@ -143,7 +143,7 @@ class TournamentSummarySerializer(serializers.ModelSerializer):
fields = ['id', 'name', 'start_date', 'day_duration', 'team_count', 'federal_category', 'federal_level_category', 'federal_age_category', 'registration_count']
def get_registration_count(self, obj):
return len(obj.teams(True))
return len(obj.teams(False))
class EventSerializer(serializers.ModelSerializer):
class Meta:

@ -40,6 +40,7 @@ import pandas as pd
import os
import logging
from datetime import datetime
logger = logging.getLogger(__name__)
@ -83,10 +84,23 @@ class TournamentSummaryViewSet(SoftDeleteViewSet):
if self.request.user.is_anonymous:
return Tournament.objects.none()
return self.queryset.filter(
queryset = self.queryset.filter(
Q(event__creator=self.request.user) | Q(related_user=self.request.user)
).distinct()
# Add min_start_date filtering
min_start_date = self.request.query_params.get('min_start_date')
if min_start_date:
try:
# Parse the date string (assumes ISO format: YYYY-MM-DD)
min_date = datetime.fromisoformat(min_start_date).date()
print(min_date)
queryset = queryset.filter(start_date__gte=min_date)
except (ValueError, TypeError):
# If date parsing fails, ignore the filter
pass
return queryset
class TournamentViewSet(SoftDeleteViewSet):
queryset = Tournament.objects.all()

Loading…
Cancel
Save