Complex filtering for parts

- Allow filtering against child categories
- Could potentially be slooow
This commit is contained in:
Oliver Walters 2019-04-14 11:59:07 +10:00
parent a465e990b9
commit 9d98c429d6
2 changed files with 29 additions and 2 deletions

View File

@ -5,7 +5,9 @@ from django_filters.rest_framework import DjangoFilterBackend
from rest_framework import filters from rest_framework import filters
from rest_framework import generics, permissions from rest_framework import generics, permissions
from django.db.models import Q
from django.conf.urls import url, include from django.conf.urls import url, include
from django.shortcuts import get_object_or_404
from .models import Part, PartCategory, BomItem from .models import Part, PartCategory, BomItem
from .models import SupplierPart from .models import SupplierPart
@ -65,9 +67,33 @@ class PartDetail(DraftRUDView):
class PartList(generics.ListCreateAPIView): class PartList(generics.ListCreateAPIView):
queryset = Part.objects.all() #queryset = Part.objects.all()
serializer_class = PartSerializer serializer_class = PartSerializer
def get_queryset(self):
print("Get queryset")
# Does the user wish to filter by category?
cat_id = self.request.query_params.get('category', None)
if cat_id:
print("Getting category:", cat_id)
category = get_object_or_404(PartCategory, pk=cat_id)
# Filter by the supplied category
flt = Q(category=cat_id)
if self.request.query_params.get('include_child_categories', None):
childs = category.getUniqueChildren()
for child in childs:
if child == cat_id: continue
flt |= Q(category=child)
return Part.objects.filter(flt)
# Default - return all parts
return Part.objects.all()
permission_classes = [ permission_classes = [
permissions.IsAuthenticatedOrReadOnly, permissions.IsAuthenticatedOrReadOnly,
] ]
@ -79,7 +105,7 @@ class PartList(generics.ListCreateAPIView):
] ]
filter_fields = [ filter_fields = [
'category', #'category',
] ]
ordering_fields = [ ordering_fields = [

View File

@ -120,6 +120,7 @@
return { return {
{% if category %} {% if category %}
category: {{ category.id }}, category: {{ category.id }},
include_child_categories: true,
{% endif %} {% endif %}
} }
}, },