diff options
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 |
commit | f44bca5141fa5b3f59ee6bf237778749451e2e15 (patch) | |
tree | 8e09e8c56425ee73912b07901e556e94a4e5dd89 /archaeological_finds/models_finds.py | |
parent | c1cc4454309084090aecc7e407076c57c6b7c4d0 (diff) | |
download | Ishtar-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.py | 14 |
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: |