diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2024-05-03 12:28:46 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2024-05-03 16:49:12 +0200 |
commit | 4dd47534de59d7c6162a92a308dfa765ede9e6ea (patch) | |
tree | a0865fd39d6882bcd6fa0ea40e172b9dc0687368 /archaeological_context_records/models.py | |
parent | 65431dd76a453aa106882669d8923d85adbd4573 (diff) | |
download | Ishtar-4dd47534de59d7c6162a92a308dfa765ede9e6ea.tar.bz2 Ishtar-4dd47534de59d7c6162a92a308dfa765ede9e6ea.zip |
✨ item deletion: better display of associated deleted items
Diffstat (limited to 'archaeological_context_records/models.py')
-rw-r--r-- | archaeological_context_records/models.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/archaeological_context_records/models.py b/archaeological_context_records/models.py index 179ed154d..1c0acadbc 100644 --- a/archaeological_context_records/models.py +++ b/archaeological_context_records/models.py @@ -1225,6 +1225,23 @@ class ContextRecord( def find_docs_q(self): return Document.objects.filter(finds__base_finds__context_record=self) + def get_deleted_data(self) -> dict: + """ + Return sub object list that will be deleted + :return: {"Sub object type": ["Sub object 1", "Sub object 2", ...]} + """ + if not self.base_finds.count(): + return {} + lbl = str(_("Base finds")) + data = {lbl: []} + for item in self.base_finds.all(): + data[lbl].append(str(item)) + for key, value in item.get_deleted_data().items(): + if key not in data: + data[key] = [] + data[key] += value + return data + def fix(self): """ Fix redundant m2m dating association (usually after imports) |