change: change income expence serializer
This commit is contained in:
20
core/apps/finance/migrations/0018_expence_party.py
Normal file
20
core/apps/finance/migrations/0018_expence_party.py
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
# Generated by Django 5.2.4 on 2025-09-10 16:44
|
||||||
|
|
||||||
|
import django.db.models.deletion
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('finance', '0017_alter_expence_project_folder_alter_income_date_and_more'),
|
||||||
|
('orders', '0023_alter_party_orders'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='expence',
|
||||||
|
name='party',
|
||||||
|
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='expences', to='orders.party'),
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
# Generated by Django 5.2.4 on 2025-09-11 14:24
|
||||||
|
|
||||||
|
import django.db.models.deletion
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('finance', '0018_expence_party'),
|
||||||
|
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='expence',
|
||||||
|
name='user',
|
||||||
|
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='expences', to=settings.AUTH_USER_MODEL),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='income',
|
||||||
|
name='user',
|
||||||
|
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='incomes', to=settings.AUTH_USER_MODEL),
|
||||||
|
),
|
||||||
|
]
|
||||||
@@ -3,9 +3,11 @@ from django.db import models
|
|||||||
from core.apps.shared.models import BaseModel
|
from core.apps.shared.models import BaseModel
|
||||||
from core.apps.finance.models import CashTransaction, PaymentType, ExpenceType
|
from core.apps.finance.models import CashTransaction, PaymentType, ExpenceType
|
||||||
from core.apps.counterparty.models import Counterparty
|
from core.apps.counterparty.models import Counterparty
|
||||||
|
from core.apps.accounts.models import User
|
||||||
|
|
||||||
|
|
||||||
class Expence(BaseModel):
|
class Expence(BaseModel):
|
||||||
|
user = models.ForeignKey(User, on_delete=models.CASCADE, related_name='expences', null=True)
|
||||||
cash_transaction = models.ForeignKey(CashTransaction, on_delete=models.CASCADE, related_name='expences')
|
cash_transaction = models.ForeignKey(CashTransaction, on_delete=models.CASCADE, related_name='expences')
|
||||||
payment_type = models.ForeignKey(PaymentType, on_delete=models.CASCADE, related_name='expences')
|
payment_type = models.ForeignKey(PaymentType, on_delete=models.CASCADE, related_name='expences')
|
||||||
project_folder = models.ForeignKey(
|
project_folder = models.ForeignKey(
|
||||||
@@ -20,6 +22,9 @@ class Expence(BaseModel):
|
|||||||
counterparty = models.ForeignKey(
|
counterparty = models.ForeignKey(
|
||||||
Counterparty, on_delete=models.SET_NULL, null=True, blank=True, related_name='expences'
|
Counterparty, on_delete=models.SET_NULL, null=True, blank=True, related_name='expences'
|
||||||
)
|
)
|
||||||
|
party = models.ForeignKey(
|
||||||
|
'orders.Party', on_delete=models.SET_NULL, null=True, blank=True, related_name='expences'
|
||||||
|
)
|
||||||
|
|
||||||
price = models.PositiveBigIntegerField()
|
price = models.PositiveBigIntegerField()
|
||||||
exchange_rate = models.PositiveBigIntegerField(default=0, null=True, blank=True)
|
exchange_rate = models.PositiveBigIntegerField(default=0, null=True, blank=True)
|
||||||
|
|||||||
@@ -3,9 +3,11 @@ from django.db import models
|
|||||||
from core.apps.shared.models import BaseModel
|
from core.apps.shared.models import BaseModel
|
||||||
from core.apps.finance.models import CashTransaction, PaymentType, TypeIncome
|
from core.apps.finance.models import CashTransaction, PaymentType, TypeIncome
|
||||||
from core.apps.counterparty.models import Counterparty
|
from core.apps.counterparty.models import Counterparty
|
||||||
|
from core.apps.accounts.models import User
|
||||||
|
|
||||||
|
|
||||||
class Income(BaseModel):
|
class Income(BaseModel):
|
||||||
|
user = models.ForeignKey(User, on_delete=models.CASCADE, related_name='incomes', null=True)
|
||||||
cash_transaction = models.ForeignKey(
|
cash_transaction = models.ForeignKey(
|
||||||
CashTransaction, on_delete=models.CASCADE, related_name='incomes'
|
CashTransaction, on_delete=models.CASCADE, related_name='incomes'
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ class ExpenceCreateSerializer(serializers.ModelSerializer):
|
|||||||
def create(self, validated_data):
|
def create(self, validated_data):
|
||||||
with transaction.atomic():
|
with transaction.atomic():
|
||||||
expence = Expence.objects.create(
|
expence = Expence.objects.create(
|
||||||
|
user=self.context.get('user'),
|
||||||
cash_transaction=validated_data.get('cash_transaction'),
|
cash_transaction=validated_data.get('cash_transaction'),
|
||||||
payment_type=validated_data.get('payment_type'),
|
payment_type=validated_data.get('payment_type'),
|
||||||
project_folder=validated_data.get('project_folder'),
|
project_folder=validated_data.get('project_folder'),
|
||||||
@@ -81,14 +82,23 @@ class ExpenceListSerializer(serializers.ModelSerializer):
|
|||||||
project = serializers.SerializerMethodField(method_name='get_project')
|
project = serializers.SerializerMethodField(method_name='get_project')
|
||||||
counterparty = serializers.SerializerMethodField(method_name='get_counterparty')
|
counterparty = serializers.SerializerMethodField(method_name='get_counterparty')
|
||||||
expence_type = serializers.SerializerMethodField(method_name='get_expence_type')
|
expence_type = serializers.SerializerMethodField(method_name='get_expence_type')
|
||||||
|
user = serializers.SerializerMethodField(method_name='get_user')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Expence
|
model = Expence
|
||||||
fields = [
|
fields = [
|
||||||
'id', 'cash_transaction', 'payment_type', 'project_folder', 'project', 'expence_type',
|
'id', 'cash_transaction', 'payment_type', 'project_folder', 'project', 'expence_type',
|
||||||
'counterparty', 'price', 'exchange_rate', 'currency', 'date', 'comment', 'audit', 'file'
|
'counterparty', 'price', 'exchange_rate', 'currency', 'date', 'comment', 'audit', 'file'
|
||||||
|
'user'
|
||||||
]
|
]
|
||||||
|
|
||||||
|
def get_user(self, obj):
|
||||||
|
return {
|
||||||
|
'id': obj.user.id,
|
||||||
|
'first_name': obj.user.first_name,
|
||||||
|
'last_name': obj.user.last_name,
|
||||||
|
} if obj.user else None
|
||||||
|
|
||||||
def get_cash_transaction(self, obj):
|
def get_cash_transaction(self, obj):
|
||||||
return {
|
return {
|
||||||
'id': obj.cash_transaction.id,
|
'id': obj.cash_transaction.id,
|
||||||
|
|||||||
@@ -12,13 +12,14 @@ class IncomeListSerializer(serializers.ModelSerializer):
|
|||||||
project = serializers.SerializerMethodField(method_name='get_project')
|
project = serializers.SerializerMethodField(method_name='get_project')
|
||||||
counterparty = serializers.SerializerMethodField(method_name='get_counterparty')
|
counterparty = serializers.SerializerMethodField(method_name='get_counterparty')
|
||||||
type_income = serializers.SerializerMethodField(method_name='get_type_income')
|
type_income = serializers.SerializerMethodField(method_name='get_type_income')
|
||||||
|
user = serializers.SerializerMethodField(method_name='get_user')
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Income
|
model = Income
|
||||||
fields = [
|
fields = [
|
||||||
'id', 'cash_transaction', 'payment_type', 'project_folder', 'project',
|
'id', 'cash_transaction', 'payment_type', 'project_folder', 'project',
|
||||||
'counterparty', 'type_income', 'currency', 'price', 'exchange_rate', 'date',
|
'counterparty', 'type_income', 'currency', 'price', 'exchange_rate', 'date',
|
||||||
'comment', 'file', 'audit'
|
'comment', 'file', 'audit', 'user'
|
||||||
]
|
]
|
||||||
|
|
||||||
def get_cash_transaction(self, obj):
|
def get_cash_transaction(self, obj):
|
||||||
@@ -57,6 +58,13 @@ class IncomeListSerializer(serializers.ModelSerializer):
|
|||||||
'name': obj.type_income.name
|
'name': obj.type_income.name
|
||||||
} if obj.type_income else None
|
} if obj.type_income else None
|
||||||
|
|
||||||
|
def get_user(self, obj):
|
||||||
|
return {
|
||||||
|
'id': obj.user.id,
|
||||||
|
'first_name': obj.user.first_name,
|
||||||
|
'last_name': obj.user.last_name,
|
||||||
|
} if obj.user else None
|
||||||
|
|
||||||
|
|
||||||
class IncomeCreateSerializer(serializers.ModelSerializer):
|
class IncomeCreateSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
@@ -70,6 +78,7 @@ class IncomeCreateSerializer(serializers.ModelSerializer):
|
|||||||
def create(self, validated_data):
|
def create(self, validated_data):
|
||||||
with transaction.atomic():
|
with transaction.atomic():
|
||||||
income = Income.objects.create(
|
income = Income.objects.create(
|
||||||
|
user=self.context.get('user'),
|
||||||
cash_transaction=validated_data['cash_transaction'],
|
cash_transaction=validated_data['cash_transaction'],
|
||||||
payment_type=validated_data['payment_type'],
|
payment_type=validated_data['payment_type'],
|
||||||
project_folder=validated_data.get('project_folder'),
|
project_folder=validated_data.get('project_folder'),
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ class ExpenceCreateApiView(generics.GenericAPIView):
|
|||||||
parser_classes = [parsers.FormParser, parsers.MultiPartParser]
|
parser_classes = [parsers.FormParser, parsers.MultiPartParser]
|
||||||
|
|
||||||
def post(self, request):
|
def post(self, request):
|
||||||
serializer = self.serializer_class(data=request.data)
|
serializer = self.serializer_class(data=request.data, context={'user': request.user})
|
||||||
if serializer.is_valid(raise_exception=True):
|
if serializer.is_valid(raise_exception=True):
|
||||||
serializer.save()
|
serializer.save()
|
||||||
return Response(
|
return Response(
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ class IncomeCreateApiView(generics.GenericAPIView):
|
|||||||
parser_classes = [parsers.FormParser, parsers.MultiPartParser]
|
parser_classes = [parsers.FormParser, parsers.MultiPartParser]
|
||||||
|
|
||||||
def post(self, request):
|
def post(self, request):
|
||||||
ser = self.serializer_class(data=request.data)
|
ser = self.serializer_class(data=request.data, context={'user': request.user})
|
||||||
if ser.is_valid(raise_exception=True):
|
if ser.is_valid(raise_exception=True):
|
||||||
ser.save()
|
ser.save()
|
||||||
return Response(
|
return Response(
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ from core.apps.products.models import Product, Unity
|
|||||||
from core.apps.projects.models import Project, ProjectFolder
|
from core.apps.projects.models import Project, ProjectFolder
|
||||||
from core.apps.wherehouse.models import WhereHouse
|
from core.apps.wherehouse.models import WhereHouse
|
||||||
from core.apps.counterparty.models import Counterparty
|
from core.apps.counterparty.models import Counterparty
|
||||||
|
from core.apps.finance.models import Expence
|
||||||
|
|
||||||
|
|
||||||
class PartyCreateSerializer(serializers.Serializer):
|
class PartyCreateSerializer(serializers.Serializer):
|
||||||
@@ -288,3 +289,76 @@ class PartyUpdateSerializer(serializers.ModelSerializer):
|
|||||||
]
|
]
|
||||||
)
|
)
|
||||||
return instance
|
return instance
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class PartyExpenceCreateSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = Expence
|
||||||
|
fields = [
|
||||||
|
'cash_transaction', 'payment_type', 'project_folder', 'project', 'counterparty',
|
||||||
|
'price', 'exchange_rate', 'currency', 'date', 'comment', 'party'
|
||||||
|
]
|
||||||
|
|
||||||
|
def create(self, validated_data):
|
||||||
|
with transaction.atomic():
|
||||||
|
expence = Expence.objects.create(
|
||||||
|
cash_transaction=validated_data.get('cash_transaction'),
|
||||||
|
payment_type=validated_data.get('payment_type'),
|
||||||
|
project_folder=validated_data.get('project_folder'),
|
||||||
|
project=validated_data.get('project'),
|
||||||
|
counterparty=validated_data.get('counterparty'),
|
||||||
|
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'),
|
||||||
|
currency=validated_data.get('currency'),
|
||||||
|
date=validated_data.get('date'),
|
||||||
|
comment=validated_data.get('comment'),
|
||||||
|
party=validated_data.get('party'),
|
||||||
|
)
|
||||||
|
cash_transaction = expence.cash_transaction
|
||||||
|
payment_type = expence.payment_type
|
||||||
|
|
||||||
|
if validated_data.get('currency') == 'uzs':
|
||||||
|
cash_transaction.expence_balance_uzs += expence.price
|
||||||
|
cash_transaction.total_balance_uzs = cash_transaction.income_balance_uzs - cash_transaction.expence_balance_uzs
|
||||||
|
if payment_type.total_uzs > expence.price:
|
||||||
|
payment_type.total_uzs -= expence.price
|
||||||
|
|
||||||
|
if expence.counterparty:
|
||||||
|
if expence.counterparty.kredit_uzs != 0:
|
||||||
|
expence.counterparty.kredit_uzs -= expence.price
|
||||||
|
expence.counterparty.total_kredit -= expence.price
|
||||||
|
|
||||||
|
expence.counterparty.debit_uzs += expence.counterparty.kredit_uzs - expence.price
|
||||||
|
expence.counterparty.total_debit += expence.price
|
||||||
|
else:
|
||||||
|
expence.counterparty.debit_uzs += expence.price
|
||||||
|
expence.counterparty.total_debit += expence.price
|
||||||
|
expence.counterparty.save()
|
||||||
|
if expence.party.currency == 'uzs':
|
||||||
|
expence.party.party_amount.payment_amount -= expence.price
|
||||||
|
expence.party.party_amount.paid_amount += expence.price
|
||||||
|
expence.party.save()
|
||||||
|
|
||||||
|
elif validated_data.get('currency') == 'usd':
|
||||||
|
cash_transaction.expence_balance_usd += expence.price
|
||||||
|
cash_transaction.total_balance_usd = cash_transaction.income_balance_usd - cash_transaction.expence_balance_usd
|
||||||
|
if payment_type.total_usd > expence.price:
|
||||||
|
payment_type.total_usd -= expence.price
|
||||||
|
|
||||||
|
if expence.counterparty:
|
||||||
|
if expence.counterparty.kredit_usd != 0:
|
||||||
|
expence.counterparty.kredit_usd -= validated_data.get('price')
|
||||||
|
expence.counterparty.total_kredit -= expence.price
|
||||||
|
|
||||||
|
expence.counterparty.debit_usd += expence.counterparty.kredit_usd - validated_data.get('price')
|
||||||
|
expence.counterparty.total_debit += expence.price
|
||||||
|
else:
|
||||||
|
expence.counterparty.debit_usd += validated_data.get('price')
|
||||||
|
expence.counterparty.total_debit += expence.price
|
||||||
|
expence.counterparty.save()
|
||||||
|
|
||||||
|
cash_transaction.save()
|
||||||
|
payment_type.save()
|
||||||
|
return expence
|
||||||
|
|
||||||
Reference in New Issue
Block a user