You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
192 lines
6.9 KiB
192 lines
6.9 KiB
from django.contrib.admin.utils import lookup_field
|
|
from django.db.models import Prefetch, Q
|
|
from rest_framework.generics import ListAPIView , RetrieveAPIView
|
|
from rest_framework.response import Response
|
|
|
|
from utils.pagination import StandardResultsSetPagination
|
|
from ..models import Transmitters , TransmitterOpinion, TransmitterOriginalText
|
|
from ..serializers import TransmitterSerializer , TransmitterDetailSerializer, TransmitterSyncSerializer,TransmitterOpinionSerializer, TransmitterOriginalTextSerializer
|
|
from ..docs import transmitter_filters_swagger,transmitter_list_swagger, transmitter_detail_swagger, transmitter_sync_swagger, transmitter_opinion_swagger, transmitter_original_text_swagger
|
|
from utils.pagination import NoPagination
|
|
from .category import get_localized_text
|
|
|
|
class TransmitterFliterView(ListAPIView):
|
|
pass
|
|
|
|
class TransmitterView(ListAPIView):
|
|
queryset = Transmitters.objects.all()
|
|
serializer_class = TransmitterSerializer
|
|
pagination_class = StandardResultsSetPagination
|
|
|
|
@transmitter_list_swagger
|
|
def get(self, request, *args, **kwargs):
|
|
return super().get(request, *args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
queryset = Transmitters.objects.all()
|
|
|
|
# Get query parameters
|
|
search_query = self.request.query_params.get('search', None)
|
|
status_filter = self.request.query_params.get('status', None)
|
|
madhhab_filter = self.request.query_params.get('madhhab', None)
|
|
generation_filter = self.request.query_params.get('generation', None)
|
|
|
|
# 1. Apply search filter (Searching across name-related JSONFields)
|
|
if search_query:
|
|
queryset = queryset.filter(
|
|
Q(full_name__icontains=search_query) |
|
|
Q(kunya__icontains=search_query) |
|
|
Q(known_as__icontains=search_query) |
|
|
Q(nickname__icontains=search_query)
|
|
)
|
|
|
|
# 2. Apply categorical filters
|
|
if status_filter:
|
|
queryset = queryset.filter(reliability__slug=status_filter)
|
|
|
|
if madhhab_filter:
|
|
queryset = queryset.filter(madhhab=madhhab_filter)
|
|
|
|
if generation_filter:
|
|
queryset = queryset.filter(generation=generation_filter)
|
|
|
|
return queryset
|
|
|
|
class TransmitterDetailView(RetrieveAPIView):
|
|
serializer_class = TransmitterDetailSerializer
|
|
lookup_field = 'slug'
|
|
lookup_url_kwarg = 'narrator_slug'
|
|
|
|
@transmitter_detail_swagger
|
|
def get(self, request, *args, **kwargs):
|
|
return super().get(request, *args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
input = self.kwargs.get('narrator_slug')
|
|
return Transmitters.objects.filter(slug=input)
|
|
|
|
class TransmitterOpinionView(ListAPIView):
|
|
serializer_class = TransmitterOpinionSerializer
|
|
pagination_class = StandardResultsSetPagination
|
|
|
|
@transmitter_opinion_swagger
|
|
def get(self, request, *args, **kwargs):
|
|
return self.list(request, *args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
narrator_slug = self.kwargs.get('narrator_slug')
|
|
return TransmitterOpinion.objects.filter(
|
|
transmitter__slug=narrator_slug
|
|
).select_related(
|
|
'transmitter', # Essential if serializer includes transmitter data
|
|
'status' # Added for the new OpinionStatus ForeignKey
|
|
).prefetch_related(
|
|
# Add any nested relations from TransmitterOriginalTextSerializer
|
|
# 'translations',
|
|
# 'manuscript_references',
|
|
)
|
|
|
|
|
|
class TransmitterOriginalTextView(ListAPIView):
|
|
serializer_class = TransmitterOriginalTextSerializer
|
|
pagination_class = StandardResultsSetPagination
|
|
|
|
@transmitter_original_text_swagger
|
|
def get(self, request, *args, **kwargs):
|
|
return self.list(request, *args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
narrator_slug = self.kwargs.get('narrator_slug')
|
|
|
|
return TransmitterOriginalText.objects.filter(
|
|
transmitter__slug=narrator_slug
|
|
).select_related(
|
|
'transmitter' # Essential if serializer includes transmitter data
|
|
).prefetch_related(
|
|
# Add any nested relations from TransmitterOriginalTextSerializer
|
|
# 'translations',
|
|
# 'manuscript_references',
|
|
)
|
|
|
|
|
|
|
|
class TransmitterSyncView(ListAPIView):
|
|
"""
|
|
API view to sync all transmitter data for offline mode
|
|
Returns all transmitters with biographical data and scholarly opinions
|
|
"""
|
|
serializer_class = TransmitterSyncSerializer
|
|
pagination_class = NoPagination
|
|
|
|
@transmitter_sync_swagger
|
|
def get(self, request, *args, **kwargs):
|
|
return self.list(request, *args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
"""
|
|
Prefetch ALL related data at once
|
|
"""
|
|
return (
|
|
Transmitters.objects
|
|
.prefetch_related(
|
|
Prefetch('opinions', queryset=TransmitterOpinion.objects.select_related('status')),
|
|
Prefetch('originaltexts', queryset=TransmitterOriginalText.objects.all())
|
|
)
|
|
.order_by('id')
|
|
)
|
|
|
|
def list(self, request, *args, **kwargs):
|
|
queryset = self.get_queryset()
|
|
serializer = self.get_serializer(queryset, many=True, context={'request': request})
|
|
|
|
response_data = {
|
|
'count': len(serializer.data), # ← No extra query!
|
|
'results': serializer.data
|
|
}
|
|
|
|
return Response(response_data)
|
|
|
|
|
|
class TransmitterFiltersView(ListAPIView):
|
|
"""
|
|
API view to return filter data for transmitters
|
|
Returns generations, madhabs, and reliabilities for filtering
|
|
"""
|
|
pagination_class = NoPagination
|
|
|
|
@transmitter_filters_swagger
|
|
def get(self, request, *args, **kwargs):
|
|
return self.list(request, *args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
# This view doesn't need a queryset, it returns computed data
|
|
return Transmitters.objects.none()
|
|
|
|
def list(self, request, *args, **kwargs):
|
|
# Get all unique generations
|
|
generations = Transmitters.objects.exclude(generation__isnull=True).values_list('generation', flat=True).distinct().order_by('generation')
|
|
|
|
# Get madhhab choices
|
|
madhabs = []
|
|
for choice in Transmitters.MadhhabChoices:
|
|
madhabs.append(choice.value)
|
|
|
|
# Get reliabilities from TransmitterReliability model
|
|
from ..models.transmitter import TransmitterReliability
|
|
reliabilities = []
|
|
for reliability in TransmitterReliability.objects.all().order_by('id'):
|
|
# Get the English title for the slug
|
|
if reliability.title:
|
|
reliabilities.append({
|
|
'text': get_localized_text(reliability.title,request),
|
|
'slug': reliability.slug
|
|
})
|
|
|
|
response_data = {
|
|
'generations': list(generations),
|
|
'madhabs': madhabs,
|
|
'reliabilities': reliabilities
|
|
}
|
|
|
|
return Response(response_data)
|
|
|