summaryrefslogtreecommitdiff
path: root/archaeological_context_records/models.py
diff options
context:
space:
mode:
Diffstat (limited to 'archaeological_context_records/models.py')
-rw-r--r--archaeological_context_records/models.py86
1 files changed, 79 insertions, 7 deletions
diff --git a/archaeological_context_records/models.py b/archaeological_context_records/models.py
index 29deae5ee..b12782e3a 100644
--- a/archaeological_context_records/models.py
+++ b/archaeological_context_records/models.py
@@ -30,7 +30,9 @@ from django.db.models import Q
from django.db.models.signals import post_delete, post_save, m2m_changed
from django.urls import reverse, reverse_lazy
-from ishtar_common.utils import gettext_lazy as _, pgettext_lazy, pgettext
+from ishtar_common.utils import get_generated_id, gettext_lazy as _, pgettext_lazy, \
+ pgettext
+
from django.utils.text import slugify
from ishtar_common.utils import (
@@ -101,12 +103,17 @@ post_save.connect(post_save_cache, sender=DatingQuality)
post_delete.connect(post_save_cache, sender=DatingQuality)
-class Dating(models.Model, SerializeItem):
+class BaseDating(models.Model, SerializeItem):
SLUG = "dating"
SERIALIZE_EXCLUDE = ["find", "context_record"]
+ CURRENT_MODEL = None
uuid = models.UUIDField(default=uuid.uuid4)
+ reference = models.TextField(_("Reference"), blank=True, default="")
+ external_id = models.TextField(_("External ID"), blank=True, default="")
period = models.ForeignKey(
- Period, verbose_name=_("Chronological period"), on_delete=models.PROTECT
+ Period, verbose_name=_("Chronological period"), on_delete=models.PROTECT,
+ blank=True,
+ null=True,
)
start_date = models.IntegerField(_("Start date"), blank=True, null=True)
end_date = models.IntegerField(_("End date"), blank=True, null=True)
@@ -154,8 +161,7 @@ class Dating(models.Model, SerializeItem):
}
class Meta:
- verbose_name = _("Dating")
- verbose_name_plural = _("Datings")
+ abstract = True
def __str__(self):
if self.precise_dating and self.precise_dating.strip():
@@ -294,6 +300,50 @@ class Dating(models.Model, SerializeItem):
continue
dating.delete()
+ @property
+ def q_parent(self):
+ if not self.pk or not self.CURRENT_MODEL:
+ return
+ if getattr(self, "__q_parent", None):
+ return self.__q_parent
+ q = self.CURRENT_MODEL.objects.filter(datings__pk=self.pk)
+ if q.count():
+ self.__q_parent = q
+ return q
+
+ @property
+ def parent_external_id(self):
+ if not self.pk or not self.q_parent:
+ return ""
+ return self.q_parent.all()[0].external_id
+
+ @property
+ def auto_id(self):
+ if not self.pk or not self.q_parent:
+ return 0
+ parent_pk = self.q_parent.all()[0].pk
+ attr = "context_record" if self.CURRENT_MODEL == ContextRecord else "find"
+ for idx, dating_pk in enumerate(
+ self.__class__.objects.filter(**{attr: parent_pk}).values_list(
+ "pk", flat=True).all()).all():
+ if dating_pk == self.pk:
+ return idx + 1
+ return 0
+
+ def save(self, *args, **kwargs):
+ super().save(*args, **kwargs)
+ if not self.pk:
+ return
+ external_id = get_generated_id("dating_external_id", self)
+ if external_id != self.external_id:
+ self.__class__.objects.filter(pk=self.pk).update(external_id=external_id)
+
+
+class Dating(BaseDating):
+ class Meta:
+ verbose_name = _("Dating - deprecated")
+ verbose_name_plural = _("Datings - deprecated")
+
class Unit(GeneralType):
order = models.IntegerField(_("Order"))
@@ -693,6 +743,10 @@ class ContextRecord(
pgettext_lazy("key for text search", "excavation-technique"),
"excavation_technics__label__iexact",
),
+ "periods": SearchAltName(
+ pgettext_lazy("key for text search", "period"),
+ "periods__label__iexact",
+ ),
"cultural_attributions": SearchAltName(
pgettext_lazy("key for text search", "cultural-attribution"),
"cultural_attributions__label__iexact",
@@ -790,7 +844,8 @@ class ContextRecord(
("site", "archaeological_site__pk"),
("file", "operation__associated_file__pk"),
]
- HISTORICAL_M2M = ["datings", "documentations", "excavation_technics", "identifications"]
+ # HISTORICAL_M2M = ["datings", "documentations", "excavation_technics", "identifications"]
+ HISTORICAL_M2M = ["documentations", "excavation_technics", "identifications"]
CACHED_LABELS = ["cached_label", "cached_periods", "cached_related_context_records"]
DOWN_MODEL_UPDATE = ["base_finds"]
GET_VALUES_EXTRA = ValueGetter.GET_VALUES_EXTRA + ["context_record"]
@@ -917,7 +972,8 @@ class ContextRecord(
default="",
help_text=_("A short description of the location of the context record"),
)
- datings = models.ManyToManyField(Dating, related_name="context_records")
+ datings_old = models.ManyToManyField(Dating, related_name="context_records")
+ periods = models.ManyToManyField(Period, verbose_name=_("Periods"), blank=True)
documentations = models.ManyToManyField(DocumentationType, blank=True)
structures = models.ManyToManyField(StructureType, blank=True)
textures = models.ManyToManyField(TextureType, blank=True)
@@ -1467,6 +1523,22 @@ for attr in ContextRecord.HISTORICAL_M2M:
)
+class ContextRecordDating(BaseDating):
+ SERIALIZE_EXCLUDE = ["context_record"]
+ CURRENT_MODEL = ContextRecord
+
+ context_record = models.ForeignKey(
+ ContextRecord,
+ verbose_name=_("Context record"),
+ related_name="datings",
+ on_delete=models.CASCADE,
+ )
+
+ class Meta:
+ verbose_name = _("Context record dating")
+ verbose_name_plural = _("Context record datings")
+
+
class RelationType(GeneralRelationType):
class Meta:
verbose_name = _("Relation type")