add: add new two api
This commit is contained in:
@@ -7,5 +7,5 @@ class ExpenceFilter(django_filters.FilterSet):
|
||||
class Meta:
|
||||
model = Expence
|
||||
fields = [
|
||||
'w'
|
||||
'payment_type', 'project_folder', 'project', 'user', 'expence_type'
|
||||
]
|
||||
@@ -47,6 +47,7 @@ urlpatterns = [
|
||||
[
|
||||
path('list/', income_views.IncomeListApiView.as_view()),
|
||||
path('create/', income_views.IncomeCreateApiView.as_view()),
|
||||
path('<uuid:counterparty_id>/list/', income_views.CounterpartyIncomeListApiView.as_view()),
|
||||
]
|
||||
)),
|
||||
path('expence_type/', include(
|
||||
@@ -61,6 +62,7 @@ urlpatterns = [
|
||||
[
|
||||
path('list/', expence_views.ExpenceListApiView.as_view()),
|
||||
path('create/', expence_views.ExpenceCreateApiView.as_view()),
|
||||
path('<uuid:counterparty_id>/list/', expence_views.CounterpartyExpenceListApiView.as_view()),
|
||||
]
|
||||
))
|
||||
]
|
||||
@@ -1,3 +1,5 @@
|
||||
from django.shortcuts import get_object_or_404
|
||||
|
||||
from rest_framework import generics, views, parsers, filters
|
||||
from rest_framework.response import Response
|
||||
|
||||
@@ -7,6 +9,7 @@ from core.apps.accounts.permissions.permissions import HasRolePermission
|
||||
from core.apps.finance.models import Expence
|
||||
from core.apps.finance.serializers import expence as serializers
|
||||
from core.apps.finance.filters.expence import ExpenceFilter
|
||||
from core.apps.counterparty.models import Counterparty
|
||||
|
||||
|
||||
class ExpenceCreateApiView(generics.GenericAPIView):
|
||||
@@ -61,3 +64,20 @@ class ExpenceListApiView(generics.GenericAPIView):
|
||||
serializer = self.serializer_class(page, many=True)
|
||||
return self.get_paginated_response(serializer.data)
|
||||
|
||||
|
||||
|
||||
class CounterpartyExpenceListApiView(generics.GenericAPIView):
|
||||
permission_classes = [HasRolePermission]
|
||||
queryset = Expence.objects.select_related(
|
||||
'cash_transaction', 'payment_type', 'project_folder', 'project', 'counterparty', 'expence_type',
|
||||
'user'
|
||||
).exclude(counterparty__isnull=True)
|
||||
serializer_class = serializers.ExpenceListSerializer
|
||||
|
||||
def get(self, request, counterparty_id):
|
||||
counterparty = get_object_or_404(Counterparty, id=counterparty_id)
|
||||
page = self.paginate_queryset(self.queryset.filter(counterparty=counterparty))
|
||||
if page is not None:
|
||||
ser = self.serializer_class(page, many=True)
|
||||
return self.get_paginated_response(ser.data)
|
||||
|
||||
@@ -9,6 +9,7 @@ from core.apps.finance.models import Income
|
||||
from core.apps.finance.serializers import income as serializers
|
||||
from core.apps.accounts.permissions.permissions import HasRolePermission
|
||||
from core.apps.finance.filters.income import IncomeFilter
|
||||
from core.apps.counterparty.models import Counterparty
|
||||
|
||||
|
||||
class IncomeListApiView(generics.GenericAPIView):
|
||||
@@ -60,3 +61,19 @@ class IncomeCreateApiView(generics.GenericAPIView):
|
||||
status=400
|
||||
)
|
||||
|
||||
|
||||
class CounterpartyIncomeListApiView(generics.GenericAPIView):
|
||||
permission_classes = [HasRolePermission]
|
||||
queryset = Income.objects.select_related(
|
||||
'cash_transaction', 'payment_type', 'project_folder', 'project', 'counterparty', 'type_income',
|
||||
'user'
|
||||
).exclude(counterparty__isnull=True)
|
||||
serializer_class = serializers.IncomeListSerializer
|
||||
|
||||
def get(self, request, counterparty_id):
|
||||
counterparty = get_object_or_404(Counterparty, id=counterparty_id)
|
||||
page = self.paginate_queryset(self.queryset.filter(counterparty=counterparty))
|
||||
if page is not None:
|
||||
ser = self.serializer_class(page, many=True)
|
||||
return self.get_paginated_response(ser.data)
|
||||
|
||||
Reference in New Issue
Block a user