fix offer api
This commit is contained in:
@@ -19,6 +19,8 @@ class Command(BaseCommand):
|
|||||||
{'code': 'product_folder', 'name': 'all access to product folder'},
|
{'code': 'product_folder', 'name': 'all access to product folder'},
|
||||||
{'code': 'product', 'name': 'all access to product'},
|
{'code': 'product', 'name': 'all access to product'},
|
||||||
{'code': 'order', 'name': 'all access to orders'},
|
{'code': 'order', 'name': 'all access to orders'},
|
||||||
|
{'code': 'offer', 'name': 'all access to offers'},
|
||||||
|
|
||||||
]
|
]
|
||||||
|
|
||||||
for perm in permissions:
|
for perm in permissions:
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ class Offer(BaseModel):
|
|||||||
number = models.PositiveIntegerField(default=1)
|
number = models.PositiveIntegerField(default=1)
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.name
|
return str(self.number)
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
def save(self, *args, **kwargs):
|
||||||
if not self.pk:
|
if not self.pk:
|
||||||
|
|||||||
@@ -11,20 +11,20 @@ class OfferCreateSerializer(serializers.Serializer):
|
|||||||
price = serializers.IntegerField()
|
price = serializers.IntegerField()
|
||||||
phone = serializers.CharField(required=False)
|
phone = serializers.CharField(required=False)
|
||||||
comment = serializers.CharField(required=False)
|
comment = serializers.CharField(required=False)
|
||||||
qqs = serializers.CharField(required=False)
|
qqs = serializers.BooleanField(required=False)
|
||||||
price_type = serializers.ChoiceField(Offer.PRICE_TYPE)
|
price_type = serializers.ChoiceField(Offer.PRICE_TYPE)
|
||||||
|
|
||||||
def validate(self, data):
|
def validate(self, data):
|
||||||
counterparty = Counterparty.objects.filter(id=data['counterparty_id']).first()
|
counterparty = Counterparty.objects.filter(id=data['counterparty_id']).first()
|
||||||
if not counterparty:
|
if not counterparty:
|
||||||
raise serializers.ValidationError("Counterparty not found")
|
raise serializers.ValidationError("Counterparty not found")
|
||||||
data['counterparty']
|
data['counterparty'] = counterparty
|
||||||
return data
|
return data
|
||||||
|
|
||||||
|
|
||||||
class MultipleOfferCreateSerializer(serializers.Serializer):
|
class MultipleOfferCreateSerializer(serializers.Serializer):
|
||||||
order_id = serializers.UUIDField()
|
order_id = serializers.UUIDField()
|
||||||
offers = serializers.ListSerializer(child=OfferCreateSerializer())
|
offers = OfferCreateSerializer(many=True)
|
||||||
|
|
||||||
def validate(self, data):
|
def validate(self, data):
|
||||||
order = Order.objects.filter(id=data['order_id']).first()
|
order = Order.objects.filter(id=data['order_id']).first()
|
||||||
@@ -37,8 +37,9 @@ class MultipleOfferCreateSerializer(serializers.Serializer):
|
|||||||
with transaction.atomic():
|
with transaction.atomic():
|
||||||
offers = []
|
offers = []
|
||||||
for offer in validated_data.pop('offers'):
|
for offer in validated_data.pop('offers'):
|
||||||
offer.append(
|
offers.append(
|
||||||
Offer(
|
Offer(
|
||||||
|
order=validated_data.get('order'),
|
||||||
counterparty=offer['counterparty'],
|
counterparty=offer['counterparty'],
|
||||||
price=offer['price'],
|
price=offer['price'],
|
||||||
phone=offer.get('phone'),
|
phone=offer.get('phone'),
|
||||||
@@ -48,8 +49,8 @@ class MultipleOfferCreateSerializer(serializers.Serializer):
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
return Offer.objects.bulk_update(offers)
|
created_offers = Offer.objects.bulk_create(offers)
|
||||||
|
return created_offers
|
||||||
|
|
||||||
class OfferListSerializer(serializers.ModelSerializer):
|
class OfferListSerializer(serializers.ModelSerializer):
|
||||||
counterparty = serializers.SerializerMethodField(method_name='get_counterparty')
|
counterparty = serializers.SerializerMethodField(method_name='get_counterparty')
|
||||||
|
|||||||
@@ -36,9 +36,12 @@ class OfferListApiView(generics.GenericAPIView):
|
|||||||
|
|
||||||
def get(self, request):
|
def get(self, request):
|
||||||
offers = Offer.objects.all()
|
offers = Offer.objects.all()
|
||||||
|
page = self.paginate_queryset(offers)
|
||||||
|
if page is not None:
|
||||||
|
serializer = self.serializer_class(page, many=True)
|
||||||
|
return self.get_paginated_response(serializer.data)
|
||||||
serializer = self.serializer_class(offers, many=True)
|
serializer = self.serializer_class(offers, many=True)
|
||||||
self.paginate_queryset(serializer)
|
return Response(serializer.data, status=200)
|
||||||
return self.get_paginated_response
|
|
||||||
|
|
||||||
|
|
||||||
class OfferUpdateApiView(generics.GenericAPIView):
|
class OfferUpdateApiView(generics.GenericAPIView):
|
||||||
|
|||||||
Reference in New Issue
Block a user