fix
This commit is contained in:
18
core/apps/orders/migrations/0036_offer_is_deleted.py
Normal file
18
core/apps/orders/migrations/0036_offer_is_deleted.py
Normal file
@@ -0,0 +1,18 @@
|
||||
# Generated by Django 5.2.4 on 2025-11-10 16:25
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('orders', '0035_order_completion_percentage_order_received_count_and_more'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name='offer',
|
||||
name='is_deleted',
|
||||
field=models.BooleanField(default=False),
|
||||
),
|
||||
]
|
||||
@@ -27,6 +27,7 @@ class Offer(BaseModel):
|
||||
qqs = models.BooleanField(default=False, null=True, blank=True)
|
||||
number = models.PositiveIntegerField(default=1)
|
||||
status = models.CharField(max_length=20, choices=STATUS, default='PENDING', null=True, blank=True)
|
||||
is_deleted = models.BooleanField(default=False)
|
||||
|
||||
def __str__(self):
|
||||
return str(self.number)
|
||||
|
||||
@@ -22,6 +22,7 @@ urlpatterns = [
|
||||
[
|
||||
path('create/', offer_views.OffersCreateApiView.as_view()),
|
||||
path('list/', offer_views.OfferListApiView.as_view()),
|
||||
path('deleted_list/', offer_views.DeletedOfferListApiView.as_view()),
|
||||
path('<uuid:id>/delete/', offer_views.OfferDeleteApiView.as_view()),
|
||||
path('<uuid:id>/update/', offer_views.OfferUpdateApiView.as_view()),
|
||||
path('bulk-delete/', offer_views.DeleteMultipleOfferApiView.as_view()),
|
||||
|
||||
@@ -33,7 +33,31 @@ class OffersCreateApiView(generics.GenericAPIView):
|
||||
class OfferListApiView(generics.GenericAPIView):
|
||||
permission_classes = [HasRolePermission]
|
||||
queryset = Order.objects.select_related('product', 'unity').prefetch_related('offers').filter(
|
||||
offers__isnull=False
|
||||
offers__isnull=False, offers__is_deleted=False
|
||||
).distinct()
|
||||
serializer_class = serializers.OrderListForOfferSerializer
|
||||
filter_backends = [DjangoFilterBackend]
|
||||
filterset_class = OrderFilter
|
||||
|
||||
def get(self, request):
|
||||
offer_status = request.query_params.get('status', None)
|
||||
orders = self.filter_queryset(self.get_queryset())
|
||||
page = self.paginate_queryset(orders)
|
||||
if page is not None:
|
||||
if offer_status:
|
||||
serializer = self.serializer_class(page, many=True, context={'status': offer_status})
|
||||
else:
|
||||
serializer = self.serializer_class(page, many=True)
|
||||
return self.get_paginated_response(serializer.data)
|
||||
serializer = self.serializer_class(offers, many=True)
|
||||
return Response(serializer.data, status=200)
|
||||
|
||||
|
||||
|
||||
class DeletedOfferListApiView(generics.GenericAPIView):
|
||||
permission_classes = [HasRolePermission]
|
||||
queryset = Order.objects.select_related('product', 'unity').prefetch_related('offers').filter(
|
||||
offers__isnull=False, offers__is_deleted=True
|
||||
).distinct()
|
||||
serializer_class = serializers.OrderListForOfferSerializer
|
||||
filter_backends = [DjangoFilterBackend]
|
||||
@@ -91,7 +115,8 @@ class OfferDeleteApiView(views.APIView):
|
||||
|
||||
def delete(self, request, id):
|
||||
offer = get_object_or_404(Offer, id=id)
|
||||
offer.delete()
|
||||
offer.is_deleted = True
|
||||
offer.save()
|
||||
return Response({'success': True}, status=204)
|
||||
|
||||
|
||||
@@ -103,8 +128,12 @@ class DeleteMultipleOfferApiView(views.APIView):
|
||||
if not ids:
|
||||
return Response({"detail": "offer_ids kerak"}, status=400)
|
||||
|
||||
deleted_count, _ = Offer.objects.filter(id__in=ids).delete()
|
||||
return Response({"deleted": deleted_count}, status=200)
|
||||
count = 0
|
||||
for offer in Offer.objects.filter(id__in=ids):
|
||||
offer.is_deleted = True
|
||||
offer.save()
|
||||
count += 1
|
||||
return Response({"deleted": count}, status=200)
|
||||
|
||||
|
||||
class ChangeOfferStatusApiView(views.APIView):
|
||||
|
||||
Reference in New Issue
Block a user