add: add cash_transaction statistics api

This commit is contained in:
behruz-dev
2025-09-10 15:32:28 +05:00
parent 06c22fa686
commit e128d0a92c
2 changed files with 21 additions and 0 deletions

View File

@@ -16,6 +16,7 @@ urlpatterns = [
path('create/', cash_views.CashTransactionCreateApiView.as_view()),
path('<uuid:id>/delete/', cash_views.CashTransactionDeleteApiView.as_view()),
path('<uuid:id>/update/', cash_views.CashTransactionUpdateApiView.as_view()),
path('statistics/', cash_views.CashTransactionStatisticsApiView.as_view()),
]
)),
path('cash_transaction_folder/', include(

View File

@@ -1,4 +1,5 @@
from django.shortcuts import get_object_or_404
from django.db.models import Sum
from rest_framework import generics, views
from rest_framework.response import Response
@@ -65,3 +66,22 @@ class CashTransactionDeleteApiView(views.APIView):
)
class CashTransactionStatisticsApiView(views.APIView):
permission_classes = [HasRolePermission]
def get(self, request):
cash_transaction_ids = request.query_params.getlist('cash_transaction')
if cash_transaction_ids:
queryset = CashTransaction.objects.filter(id__in=cash_transaction_ids)
queryset = CashTransaction.objects.all()
res = queryset.aggregate(
total_balance_usd=Sum('total_balance_usd'),
income_balance_usd=Sum('income_balance_usd'),
expence_balance_usd=Sum('expence_balance_usd'),
total_balance_uzs=Sum('total_balance_uzs'),
income_balance_uzs=Sum('income_balance_uzs'),
expence_balance_uzs=Sum('expence_balance_uzs')
)
return Response(res)