mirror of
https://github.com/lemeow125/Borrowing-TrackerBackend.git
synced 2024-11-17 06:19:26 +08:00
Improved transaction and breakage report serializers when handling breakages
This commit is contained in:
parent
d0ca68149a
commit
0b1c065a80
4 changed files with 47 additions and 40 deletions
|
@ -14,33 +14,3 @@ class BreakageReport(models.Model):
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return f"Breakage report for transaction #{self.transaction.id} by {self.transaction.borrower} under {self.transaction.teacher}"
|
return f"Breakage report for transaction #{self.transaction.id} by {self.transaction.borrower} under {self.transaction.teacher}"
|
||||||
|
|
||||||
def save(self, *args, **kwargs):
|
|
||||||
# Check if the instance is being updated
|
|
||||||
if not self._state.adding:
|
|
||||||
# Check if all associated equipment instances have status "Working"
|
|
||||||
all_working = all(
|
|
||||||
eq.status == 'Working' for eq in self.equipments.all())
|
|
||||||
|
|
||||||
# If all equipment instances are working
|
|
||||||
if all_working:
|
|
||||||
# set resolved field to True
|
|
||||||
self.resolved = True
|
|
||||||
# set the status of the associated transaction to "Finalized"
|
|
||||||
self.transaction.status = 'Finalized'
|
|
||||||
self.transaction.save()
|
|
||||||
|
|
||||||
# Then save the instance again to reflect the changes
|
|
||||||
super().save(*args, **kwargs)
|
|
||||||
# If not, set the resolved field to False
|
|
||||||
else:
|
|
||||||
if (self.resolved != False or self.transaction.status != 'With Breakages: Pending Resolution'):
|
|
||||||
# set resolved field to False
|
|
||||||
self.resolved = False
|
|
||||||
# set the status of the associated transaction to still be pending
|
|
||||||
self.transaction.status = 'With Breakages: Pending Resolution'
|
|
||||||
self.transaction.save()
|
|
||||||
# Then save the instance again to reflect the changes
|
|
||||||
super().save(*args, **kwargs)
|
|
||||||
else:
|
|
||||||
super().save(*args, **kwargs)
|
|
||||||
|
|
|
@ -4,6 +4,7 @@ from drf_spectacular.utils import extend_schema_field
|
||||||
from drf_spectacular.types import OpenApiTypes
|
from drf_spectacular.types import OpenApiTypes
|
||||||
from django.db.models import F
|
from django.db.models import F
|
||||||
from breakages.models import BreakageReport
|
from breakages.models import BreakageReport
|
||||||
|
from config.settings import DEBUG
|
||||||
# -- Equipment Serializers
|
# -- Equipment Serializers
|
||||||
|
|
||||||
|
|
||||||
|
@ -46,6 +47,31 @@ class EquipmentSerializer(serializers.HyperlinkedModelSerializer):
|
||||||
if not user.is_technician:
|
if not user.is_technician:
|
||||||
raise exceptions.ValidationError(
|
raise exceptions.ValidationError(
|
||||||
"Non-technician users cannot update equipments")
|
"Non-technician users cannot update equipments")
|
||||||
|
# This is for Breakage Report handling
|
||||||
|
# First we update the EquipmentInstance
|
||||||
|
instance = super().update(instance, validated_data)
|
||||||
|
# Then we check if the EquipmentInstance has an associated BreakageReport which is still pending
|
||||||
|
associated_breakage_report = BreakageReport.objects.filter(
|
||||||
|
equipments=instance, resolved=False).order_by('id').first()
|
||||||
|
# If there is one
|
||||||
|
print('Associated Breakage Report?', bool(associated_breakage_report))
|
||||||
|
if associated_breakage_report:
|
||||||
|
# Check if all the equipments of the currently associated BreakageReport are "Available"
|
||||||
|
all_available = all(
|
||||||
|
eq.status == 'Available' for eq in associated_breakage_report.equipments.all())
|
||||||
|
print('All Available?', all_available)
|
||||||
|
# If all the equipments are "Available", set Breakage Report to be resolved (resolved=True)
|
||||||
|
# Also set the related Transaction to "Finalized"
|
||||||
|
if all_available:
|
||||||
|
associated_breakage_report.resolved = True
|
||||||
|
associated_breakage_report.save()
|
||||||
|
print('Breakage Status', associated_breakage_report.resolved)
|
||||||
|
transaction = associated_breakage_report.transaction
|
||||||
|
transaction.transaction_status = "Finalized"
|
||||||
|
transaction.save()
|
||||||
|
print('Transaction Status',
|
||||||
|
associated_breakage_report.transaction.transaction_status)
|
||||||
|
|
||||||
return super().update(instance, validated_data)
|
return super().update(instance, validated_data)
|
||||||
|
|
||||||
# Do not allow users that are not technicians to delete equipments
|
# Do not allow users that are not technicians to delete equipments
|
||||||
|
@ -143,32 +169,41 @@ class EquipmentInstanceSerializer(serializers.HyperlinkedModelSerializer):
|
||||||
|
|
||||||
def update(self, instance, validated_data):
|
def update(self, instance, validated_data):
|
||||||
user = self.context['request'].user
|
user = self.context['request'].user
|
||||||
# Do not allow users that are not technicians to update equipment instances
|
# Do not allow users that are not technicians to update equipments
|
||||||
if not user.is_technician:
|
if not user.is_technician:
|
||||||
raise exceptions.ValidationError(
|
raise exceptions.ValidationError(
|
||||||
"Non-technician users cannot update equipment instances")
|
"Non-technician users cannot update equipments")
|
||||||
# Forbid user from changing equipment field once the instance is already created
|
|
||||||
# Ignore any changes to 'equipment'
|
|
||||||
validated_data.pop('equipment', None)
|
|
||||||
|
|
||||||
# This is for Breakage Report handling
|
# This is for Breakage Report handling
|
||||||
# First we update the EquipmentInstance
|
# First we update the EquipmentInstance
|
||||||
instance = super().update(instance, validated_data)
|
instance = super().update(instance, validated_data)
|
||||||
# Then we check if the EquipmentInstance has an associated BreakageReport which is still pending
|
# Then we check if the EquipmentInstance has an associated BreakageReport which is still pending
|
||||||
associated_breakage_report = BreakageReport.objects.filter(
|
associated_breakage_report = BreakageReport.objects.filter(
|
||||||
equipments=instance, resolved=False).first()
|
equipments=instance, resolved=False).order_by('id').first()
|
||||||
# If there is one
|
# If there is one
|
||||||
|
if (DEBUG):
|
||||||
|
print('Associated Breakage Report?',
|
||||||
|
bool(associated_breakage_report))
|
||||||
if associated_breakage_report:
|
if associated_breakage_report:
|
||||||
# Check if all the equipments of the currently associated BreakageReport are "Available"
|
# Check if all the equipments of the currently associated BreakageReport are "Available"
|
||||||
all_available = all(
|
all_available = all(
|
||||||
eq.status == 'Available' for eq in associated_breakage_report.equipments.all())
|
eq.status == 'Available' for eq in associated_breakage_report.equipments.all())
|
||||||
|
if (DEBUG):
|
||||||
|
print('All Available?', all_available)
|
||||||
# If all the equipments are "Available", set Breakage Report to be resolved (resolved=True)
|
# If all the equipments are "Available", set Breakage Report to be resolved (resolved=True)
|
||||||
|
# Also set the related Transaction to "Finalized"
|
||||||
if all_available:
|
if all_available:
|
||||||
associated_breakage_report.resolved = True
|
associated_breakage_report.resolved = True
|
||||||
associated_breakage_report.save()
|
associated_breakage_report.save()
|
||||||
|
if (DEBUG):
|
||||||
|
print('Breakage Status', associated_breakage_report.resolved)
|
||||||
|
transaction = associated_breakage_report.transaction
|
||||||
|
transaction.transaction_status = "Finalized"
|
||||||
|
transaction.save()
|
||||||
|
if (DEBUG):
|
||||||
|
print('Transaction Status',
|
||||||
|
associated_breakage_report.transaction.transaction_status)
|
||||||
|
|
||||||
return instance
|
return super().update(instance, validated_data)
|
||||||
|
|
||||||
# Do not allow users that are not technicians to delete equipment instances
|
# Do not allow users that are not technicians to delete equipment instances
|
||||||
def delete(self, instance):
|
def delete(self, instance):
|
||||||
|
|
|
@ -71,7 +71,7 @@ class AvailableEquipmentInstanceViewSet(generics.ListAPIView):
|
||||||
"""
|
"""
|
||||||
# Get all non-finalized transactions
|
# Get all non-finalized transactions
|
||||||
non_finalized_transactions = Transaction.objects.filter(
|
non_finalized_transactions = Transaction.objects.filter(
|
||||||
~Q(transaction_status__in=['Finalized', 'Cancelled']))
|
~Q(transaction_status__in=['Finalized', 'Rejected', 'Cancelled']))
|
||||||
|
|
||||||
# Get all equipment instances associated with non-finalized transactions
|
# Get all equipment instances associated with non-finalized transactions
|
||||||
non_finalized_equipments = EquipmentInstance.objects.filter(
|
non_finalized_equipments = EquipmentInstance.objects.filter(
|
||||||
|
|
|
@ -4,6 +4,8 @@ from accounts.models import CustomUser
|
||||||
|
|
||||||
|
|
||||||
class TransactionAdmin(admin.ModelAdmin):
|
class TransactionAdmin(admin.ModelAdmin):
|
||||||
|
list_display = ('id', 'borrower', 'teacher', 'transaction_status')
|
||||||
|
|
||||||
def formfield_for_foreignkey(self, db_field, request, **kwargs):
|
def formfield_for_foreignkey(self, db_field, request, **kwargs):
|
||||||
if db_field.name == "borrower":
|
if db_field.name == "borrower":
|
||||||
kwargs["queryset"] = CustomUser.objects.exclude(
|
kwargs["queryset"] = CustomUser.objects.exclude(
|
||||||
|
|
Loading…
Reference in a new issue