fix
This commit is contained in:
@@ -1,6 +1,6 @@
|
|||||||
from django.shortcuts import get_object_or_404
|
from django.shortcuts import get_object_or_404
|
||||||
|
|
||||||
from rest_framework import generics, views, status, parsers
|
from rest_framework import generics, views, status, parsers, filters
|
||||||
from rest_framework.permissions import IsAdminUser
|
from rest_framework.permissions import IsAdminUser
|
||||||
|
|
||||||
from core.apps.admin_panel.serializers import product as serializers
|
from core.apps.admin_panel.serializers import product as serializers
|
||||||
@@ -12,9 +12,11 @@ class ProductListApiView(generics.GenericAPIView):
|
|||||||
serializer_class = serializers.AdminProductListSerializer
|
serializer_class = serializers.AdminProductListSerializer
|
||||||
queryset = Product.objects.select_related('category', 'unity').order_by('name')
|
queryset = Product.objects.select_related('category', 'unity').order_by('name')
|
||||||
permission_classes = [IsAdminUser]
|
permission_classes = [IsAdminUser]
|
||||||
|
filter_backends = [filters.SearchFilter]
|
||||||
|
search_fields = ['name']
|
||||||
|
|
||||||
def get(self, request):
|
def get(self, request):
|
||||||
page = self.paginate_queryset(self.queryset)
|
page = self.paginate_queryset(self.filter_queryset(self.queryset))
|
||||||
if page is not None:
|
if page is not None:
|
||||||
serializer = self.serializer_class(page, many=True)
|
serializer = self.serializer_class(page, many=True)
|
||||||
return self.get_paginated_response(serializer.data)
|
return self.get_paginated_response(serializer.data)
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
from django.shortcuts import get_object_or_404
|
from django.shortcuts import get_object_or_404
|
||||||
|
|
||||||
from rest_framework import generics, views
|
from rest_framework import generics, views, filters
|
||||||
from rest_framework.response import Response
|
from rest_framework.response import Response
|
||||||
|
|
||||||
from core.apps.products.models import Product, Category
|
from core.apps.products.models import Product, Category
|
||||||
@@ -11,11 +11,13 @@ class ProductListApiView(generics.GenericAPIView):
|
|||||||
serializer_class = serializers.ProductListSerializer
|
serializer_class = serializers.ProductListSerializer
|
||||||
queryset = Product.objects.select_related('unity')
|
queryset = Product.objects.select_related('unity')
|
||||||
permission_classes = []
|
permission_classes = []
|
||||||
|
filter_backends = [filters.SearchFilter]
|
||||||
|
search_fields = ['name']
|
||||||
|
|
||||||
def get(self, request, category_id):
|
def get(self, request, category_id):
|
||||||
category = get_object_or_404(Category, id=category_id)
|
category = get_object_or_404(Category, id=category_id)
|
||||||
products = Product.objects.filter(category=category).select_related('unity')
|
products = Product.objects.filter(category=category).select_related('unity')
|
||||||
page = self.paginate_queryset(products)
|
page = self.paginate_queryset(self.filter_queryset(products))
|
||||||
if page is not None:
|
if page is not None:
|
||||||
serializer = self.serializer_class(page, many=True, context={'user': request.user})
|
serializer = self.serializer_class(page, many=True, context={'user': request.user})
|
||||||
return self.get_paginated_response(serializer.data)
|
return self.get_paginated_response(serializer.data)
|
||||||
|
|||||||
Reference in New Issue
Block a user