add: add income model and income create and list apig

This commit is contained in:
behruz-dev
2025-09-08 17:32:39 +05:00
parent d84612af13
commit ffe9215892
9 changed files with 256 additions and 9 deletions

View File

@@ -39,16 +39,22 @@ class CashTransactionUpdateSerializer(serializers.ModelSerializer):
'name', 'payment_type', 'employees', 'status', 'folder',
]
class CashTransactionCreateSerializer(serializers.Serializer):
payment_type_id = serializers.UUIDField()
employee_ids = serializers.ListSerializer(child=serializers.UUIDField())
employee_ids = serializers.ListSerializer(child=serializers.UUIDField(), write_only=True)
name = serializers.CharField()
status = serializers.BooleanField()
folder_id = serializers.UUIDField(required=False)
def validate_name(self, value):
if CashTransaction.objects.filter(name=value).exists():
raise serializers.ValidationError('cash transaction with this name already exists')
return value
def validate(self, data):
payment_type = PaymentType.objects.filter(id=data['id']).first()
if payment_type:
payment_type = PaymentType.objects.filter(id=data['payment_type_id']).first()
if not payment_type:
raise serializers.ValidationError("Payment Type not found")
if data.get('folder_id'):
folder = CashTransactionFolder.objects.filter(id=data.get('folder_id')).first()
@@ -60,7 +66,7 @@ class CashTransactionCreateSerializer(serializers.Serializer):
def create(self, validated_data):
with transaction.atomic():
employee_ids = validated_data.pop('employee_ids')
employee_ids = validated_data.pop('employee_ids', [])
cash_transaction = CashTransaction.objects.create(
name=validated_data.get('name'),
payment_type=validated_data.get('payment_type'),

View File

@@ -0,0 +1,97 @@
from django.db import transaction
from rest_framework import serializers
from core.apps.finance.models import Income
class IncomeListSerializer(serializers.ModelSerializer):
cash_transaction = serializers.SerializerMethodField(method_name='get_cash_transaction')
payment_type = serializers.SerializerMethodField(method_name='get_payment_type')
project_folder = serializers.SerializerMethodField(method_name='get_project_folder')
project = serializers.SerializerMethodField(method_name='get_project')
counterparty = serializers.SerializerMethodField(method_name='get_counterparty')
type_income = serializers.SerializerMethodField(method_name='get_type_income')
class Meta:
model = Income
fields = [
'id', 'cash_transaction', 'payment_type', 'project_folder', 'project',
'counterparty', 'type_income', 'currency', 'price', 'exchange_rate', 'date',
'comment', 'file', 'audit'
]
def get_cash_transaction(self, obj):
return {
'id': obj.cash_transaction.id,
'name': obj.cash_transaction.name
}
def get_payment_type(self, obj):
return {
'id': obj.payment_type.id,
'name': obj.payment_type.name
}
def get_project_folder(self, obj):
return {
'id': obj.project_folder.id,
'name': obj.project_folder.name
}
def get_project(self, obj):
return {
'id': obj.project.id,
'name': obj.project.name
} if obj.project else None
def get_counterparty(self, obj):
return {
'id': obj.counterparty.id,
'name': obj.counterparty.name
} if obj.counterparty else None
def get_type_income(self, obj):
return {
'id': obj.type_income.id,
'name': obj.type_income.name
} if obj.type_income else None
class IncomeCreateSerializer(serializers.ModelSerializer):
class Meta:
model = Income
fields = [
'cash_transaction', 'payment_type', 'project_folder', 'project',
'counterparty', 'type_income', 'currency', 'price', 'exchange_rate', 'date',
'comment', 'file', 'audit'
]
def create(self, validated_data):
with transaction.atomic():
income = Income.objects.create(
cash_transaction=validated_data['cash_transaction'],
payment_type=validated_data['payment_type'],
project_folder=validated_data['project_folder'],
project=validated_data.get('project'),
counterparty=validated_data.get('counterparty'),
type_income=validated_data.get('type_income'),
currency=validated_data.get('currency'),
price=validated_data.get('price') * validated_data.get('exchange_rate') if validated_data.get('exchange_rate') else validated_data.get('price'),
exchange_rate=validated_data.get('exchange_rate'),
date=validated_data.get('date'),
comment=validated_data.get('comment'),
file=validated_data.get('file'),
audit=validated_data.get('audit')
)
cash_transaction = income.cash_transaction
if validated_data.get('currency') == 'uzs':
cash_transaction.income_balance_uzs += income.price
cash_transaction.total_balance_uzs = cash_transaction.income_balance_uzs - cash_transaction.expence_balance_uzs
elif validated_data.get('currency') == 'usd':
cash_transaction.income_balance_usd += income.price
cash_transaction.total_balance_usd = cash_transaction.income_balance_usd - cash_transaction.expence_balance_usd
cash_transaction.save()
return income