related quotas

This commit is contained in:
2025-08-03 11:52:29 +03:30
parent 275b84467e
commit 6ccbadbbdc
4 changed files with 65 additions and 28 deletions

View File

@@ -0,0 +1,19 @@
# Generated by Django 5.0 on 2025-08-03 08:21
import datetime
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('pos_device', '0023_alter_deviceactivationcode_expires_at'),
]
operations = [
migrations.AlterField(
model_name='deviceactivationcode',
name='expires_at',
field=models.DateTimeField(default=datetime.datetime(2025, 8, 3, 11, 51, 14, 712627)),
),
]

View File

@@ -84,25 +84,35 @@ def update_product_stats(instance: Product, distribution: QuotaDistribution = No
)
# number of quotas
quotas_count = instance.quotas.filter(is_closed=False, registerer_organization=organization) # noqa
total_quotas_weight = quotas_count.aggregate( # noqa
quota = Quota.objects.filter(
Q(
distributions_assigned__in=QuotaDistribution.objects.filter(
Q(assigned_organization=organization) |
Q(assigner_organization=organization)
)
) |
Q(registerer_organization=organization),
product=instance
).distinct()
quotas_count = quota.count() # noqa
total_quotas_weight = quota.aggregate( # noqa
total=models.Sum('quota_weight')
)['total'] or 0
quotas_count = quotas_count.count()
# total weight of product that assigned in quota
active_quotas_weight = instance.quotas.filter(is_closed=False, registerer_organization=organization).aggregate(
active_quotas_weight = quota.filter(is_closed=False).aggregate(
total=models.Sum('quota_weight')
)['total'] or 0
closed_quotas_weight = instance.quotas.filter(is_closed=True, registerer_organization=organization).aggregate( # noqa
closed_quotas_weight = quota.filter(is_closed=True).aggregate( # noqa
total=models.Sum('quota_weight')
)['total'] or 0
# total remaining weight of product quotas
total_remaining_quotas_weight = instance.quotas.filter(is_closed=False).aggregate( # noqa
total_remaining_quotas_weight = quota.filter(is_closed=False).aggregate( # noqa
total=models.Sum('remaining_weight')
)['total'] or 0

View File

@@ -1,5 +1,6 @@
import datetime
from apps.product.web.api.v1.serializers import product_serializers as product_serializers
from apps.product.web.api.v1.serializers import quota_serializers
from common.helpers import get_organization_by_user
from rest_framework.exceptions import APIException
from apps.product import models as product_models
@@ -84,6 +85,34 @@ class ProductViewSet(viewsets.ModelViewSet):
serializer = self.get_serializer(queryset, many=True)
return Response(serializer.data)
@action(
methods=['get'],
detail=True,
url_path='related_quotas',
url_name='related_quotas',
name='related_quotas'
)
@transaction.atomic()
def my_related_quotas_by_product(self, request, pk=None):
""" quotas that related to my organization and product """
organization = get_organization_by_user(request.user)
quota = product_models.Quota.objects.filter(
Q(
distributions_assigned__in=product_models.QuotaDistribution.objects.filter(
Q(assigned_organization=organization) |
Q(assigner_organization=organization)
)
) |
Q(registerer_organization=organization),
product=self.get_object()
).distinct()
page = self.paginate_queryset(quota)
if page is not None:
serializer = quota_serializers.QuotaSerializer(page, many=True)
return self.get_paginated_response(serializer.data)
@action(
methods=['put'],
detail=True,

View File

@@ -379,27 +379,6 @@ class QuotaViewSet(viewsets.ModelViewSet, DynamicSearchMixin): # noqa
except Exception as e:
raise APIException("none object", code=403)
@action(
methods=['get'],
detail=False,
url_path='statistics_by_product',
url_name='statistics_by_product',
name='statistics_by_product'
)
@transaction.atomic
def quotas_statistics_by_product(self, request):
""" quota statistics of each product in organization warehouse """
product_data = []
organization = get_organization_by_user(request.user)
products = get_products_in_warehouse(organization.id)
for product in products:
product_data.append(product.quota_information())
return Response(product_data, status=status.HTTP_200_OK)
@action(
methods=['get'],
detail=True,