summaryrefslogtreecommitdiff
path: root/ishtar_common/models.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2024-06-07 17:41:03 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2024-06-07 17:42:56 +0200
commit0d585824a02b3f7133e323d72bd1e778f9fa12ea (patch)
tree5963b99db4e79f28d4f4603074906b01c7c10efa /ishtar_common/models.py
parent26ba00071ad1eb8b5bd3479290b6ffe02101298d (diff)
downloadIshtar-0d585824a02b3f7133e323d72bd1e778f9fa12ea.tar.bz2
Ishtar-0d585824a02b3f7133e323d72bd1e778f9fa12ea.zip
🗃️ Document: add cache_authors field (refs #5709)
Diffstat (limited to 'ishtar_common/models.py')
-rw-r--r--ishtar_common/models.py15
1 files changed, 12 insertions, 3 deletions
diff --git a/ishtar_common/models.py b/ishtar_common/models.py
index c098eee02..ed7df17c2 100644
--- a/ishtar_common/models.py
+++ b/ishtar_common/models.py
@@ -4229,7 +4229,7 @@ class Document(
"title",
"source_type__label",
"cache_related_label",
- "authors__cached_label",
+ "cache_authors",
"associated_url",
]
NEW_QUERY_ENGINE = True
@@ -4273,7 +4273,7 @@ class Document(
"source_type__label": _("Type"),
}
- CACHED_LABELS = ["cache_related_label"]
+ CACHED_LABELS = ["cache_related_label", "cache_authors"]
CACHED_COMPLETE_ID = ""
EXTRA_REQUEST_KEYS = {
"operations": "operations__pk",
@@ -4568,7 +4568,6 @@ class Document(
]
SERIALIZATION_FILES = ["image", "thumbnail", "associated_file"]
SERIALIZE_PROPERTIES = ["external_id", "images_number"]
- SELECT_GROUP_BY = True # v4.0 patch
title = models.TextField(_("Title"), blank=True, default="")
associated_file = models.FileField(
@@ -4709,6 +4708,13 @@ class Document(
db_index=True,
help_text=_("Cached value - do not edit"),
)
+ cache_authors = models.TextField(
+ _("Authors"),
+ blank=True,
+ default="",
+ db_index=True,
+ help_text=_("Cached value - do not edit"),
+ )
history = HistoricalRecords(inherit=True)
class Meta:
@@ -5135,6 +5141,9 @@ class Document(
def _generate_cache_related_label(self):
return self.related_label()[:1000]
+ def _generate_cache_authors(self):
+ return " ; ".join([author.cached_label for author in self.authors.all()])
+
@classmethod
def get_next_index(cls):
q = cls.objects.values("index").filter(index__isnull=False).order_by("-index")