change offer apis
This commit is contained in:
11
core/apps/orders/filters/offer.py
Normal file
11
core/apps/orders/filters/offer.py
Normal file
@@ -0,0 +1,11 @@
|
||||
import django_filters
|
||||
|
||||
from core.apps.orders.models import Order, Offer
|
||||
|
||||
|
||||
class OfferFilter(django_filters.FilterSet):
|
||||
class Meta:
|
||||
model = Offer
|
||||
fields = [
|
||||
'order__wherehouse', 'order__project', 'order__project_folder', 'order__date'
|
||||
]
|
||||
@@ -87,3 +87,11 @@ class OfferUpdateSerializer(serializers.ModelSerializer):
|
||||
instance.price_type = validated_data.get('price_type', instance.price_type)
|
||||
instance.save()
|
||||
return instance
|
||||
|
||||
|
||||
class OffersSerializer(serializers.ModelSerializer):
|
||||
class Meta:
|
||||
model = Offer
|
||||
fields = [
|
||||
'id', 'number', 'price', 'price_type', 'phone', 'comment', 'qqs',
|
||||
]
|
||||
@@ -13,6 +13,7 @@ urlpatterns = [
|
||||
path('<uuid:order_id>/cancel/', order_views.OrderChangeStatusCancelledApiView.as_view()),
|
||||
path("<uuid:order_id>/accept/", order_views.OrderChangeStatusAcceptedApiView.as_view()),
|
||||
path("accepted/list/", order_views.OrderAcceptApiView.as_view()),
|
||||
path('<uuid:order_id>/offers/', order_views.OrderOfferListApiView.as_view()),
|
||||
]
|
||||
)),
|
||||
path('offer/', include(
|
||||
|
||||
@@ -3,10 +3,13 @@ from django.shortcuts import get_object_or_404
|
||||
from rest_framework import generics, views
|
||||
from rest_framework.response import Response
|
||||
|
||||
from django_filters.rest_framework.backends import DjangoFilterBackend
|
||||
|
||||
from core.apps.shared.paginations.custom import PageNumberPagination
|
||||
from core.apps.accounts.permissions.permissions import HasRolePermission
|
||||
from core.apps.orders.serializers import offer as serializers
|
||||
from core.apps.orders.models import Offer
|
||||
from core.apps.orders.filters.offer import OfferFilter
|
||||
|
||||
|
||||
class OffersCreateApiView(generics.GenericAPIView):
|
||||
@@ -33,9 +36,11 @@ class OfferListApiView(generics.GenericAPIView):
|
||||
queryset = Offer.objects.select_related('order')
|
||||
required_permissions = ['offer']
|
||||
serializer_class = serializers.OfferListSerializer
|
||||
filter_backends = [DjangoFilterBackend]
|
||||
filterset_class = OfferFilter
|
||||
|
||||
def get(self, request):
|
||||
offers = Offer.objects.all()
|
||||
offers = self.filter_queryset(self.get_queryset())
|
||||
page = self.paginate_queryset(offers)
|
||||
if page is not None:
|
||||
serializer = self.serializer_class(page, many=True)
|
||||
|
||||
@@ -6,8 +6,9 @@ from rest_framework.response import Response
|
||||
from django_filters.rest_framework import DjangoFilterBackend
|
||||
|
||||
from core.apps.orders.serializers import order as serializers
|
||||
from core.apps.orders.models import Order
|
||||
from core.apps.orders.models import Order, Offer
|
||||
from core.apps.orders.filters.order import OrderFilter
|
||||
from core.apps.orders.serializers.offer import OffersSerializer
|
||||
from core.apps.accounts.permissions.permissions import HasRolePermission
|
||||
from core.apps.shared.paginations.custom import CustomPageNumberPagination
|
||||
|
||||
@@ -94,3 +95,16 @@ class OrderAcceptApiView(generics.ListAPIView):
|
||||
permission_classes = [HasRolePermission]
|
||||
required_permissions = ['order']
|
||||
pagination_class = CustomPageNumberPagination
|
||||
|
||||
|
||||
class OrderOfferListApiView(generics.GenericAPIView):
|
||||
serializer_class = OffersSerializer
|
||||
permission_classes = [HasRolePermission]
|
||||
required_permissions = ['order']
|
||||
queryset = Offer.objects.select_related('order')
|
||||
pagination_class = None
|
||||
|
||||
def get(self, request, order_id):
|
||||
offers = self.get_queryset().select_related("order").filter(order_id=order_id)
|
||||
serializer = self.serializer_class(offers, many=True)
|
||||
return Response(serializer.data, status=200)
|
||||
2161
resources/logs/django.log.2025-08-20
Normal file
2161
resources/logs/django.log.2025-08-20
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user