summaryrefslogtreecommitdiff
path: root/archaeological_finds/models_finds.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2023-05-15 17:33:49 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2023-05-15 18:14:00 +0200
commitf44bca5141fa5b3f59ee6bf237778749451e2e15 (patch)
tree8e09e8c56425ee73912b07901e556e94a4e5dd89 /archaeological_finds/models_finds.py
parentc1cc4454309084090aecc7e407076c57c6b7c4d0 (diff)
downloadIshtar-f44bca5141fa5b3f59ee6bf237778749451e2e15.tar.bz2
Ishtar-f44bca5141fa5b3f59ee6bf237778749451e2e15.zip
🐛 recalculate container weight on find remove (refs #5470)
Diffstat (limited to 'archaeological_finds/models_finds.py')
-rw-r--r--archaeological_finds/models_finds.py14
1 files changed, 9 insertions, 5 deletions
diff --git a/archaeological_finds/models_finds.py b/archaeological_finds/models_finds.py
index 4b976a730..5eb204949 100644
--- a/archaeological_finds/models_finds.py
+++ b/archaeological_finds/models_finds.py
@@ -3241,7 +3241,7 @@ class Find(
old_container = self.__class__.objects.filter(pk=self.pk).values_list(
"container_id", flat=True
)[0]
- super(Find, self).save(*args, **kwargs)
+ super().save(*args, **kwargs)
self.skip_history_when_saving = True
if self.container_ref and not self.container:
@@ -3249,12 +3249,16 @@ class Find(
if self.container and self.container._calculate_weight():
self.container.save()
- elif not self.container and old_container:
+ if (self.container and self.container.pk != old_container) or (
+ not self.container and old_container):
# force recalculation of weight when a find is removed
Container = apps.get_model("archaeological_warehouse.Container")
- old_container = Container.objects.get(pk=old_container)
- if old_container._calculate_weight():
- old_container.save()
+ try:
+ old_container = Container.objects.get(pk=old_container)
+ if old_container._calculate_weight():
+ old_container.save()
+ except Container.DoesNotExist:
+ pass
updated = self.update_external_id(save=False)
if updated: