From 4dd47534de59d7c6162a92a308dfa765ede9e6ea Mon Sep 17 00:00:00 2001 From: Étienne Loks Date: Fri, 3 May 2024 12:28:46 +0200 Subject: ✨ item deletion: better display of associated deleted items MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- archaeological_context_records/models.py | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'archaeological_context_records') 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) -- cgit v1.2.3