summaryrefslogtreecommitdiff
path: root/archaeological_warehouse
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-07 21:23:25 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-07 21:23:25 +0200
commita52afe958a6f9d45d55065be044e3daf101936cd (patch)
treeb75fdd0ee3bd9104919b20d7059adf5561694636 /archaeological_warehouse
parentdc643fdf32e0e27b99dc560f8b2c4107b6cefc19 (diff)
downloadIshtar-a52afe958a6f9d45d55065be044e3daf101936cd.tar.bz2
Ishtar-a52afe958a6f9d45d55065be044e3daf101936cd.zip
Imports, add post import trigger for finds: set_localisation_1, _2, ...
Diffstat (limited to 'archaeological_warehouse')
-rw-r--r--archaeological_warehouse/models.py36
1 files changed, 34 insertions, 2 deletions
diff --git a/archaeological_warehouse/models.py b/archaeological_warehouse/models.py
index 35e5536fa..31701dbf9 100644
--- a/archaeological_warehouse/models.py
+++ b/archaeological_warehouse/models.py
@@ -21,10 +21,10 @@ import datetime
from django.conf import settings
from django.contrib.gis.db import models
-from django.db.models import Q, Count
+from django.db.models import Q
from django.db.models.signals import post_save, post_delete
from django.template.defaultfilters import slugify
-from django.utils.translation import ugettext_lazy as _, ugettext
+from django.utils.translation import ugettext_lazy as _
from ishtar_common.utils import cached_label_changed
@@ -328,6 +328,38 @@ class Container(LightHistorizedItem, ImageModel):
def precise_location(self):
return self.location.name + u" - " + self.divisions_lbl
+ def get_localisations(self):
+ """
+ Get precise localisation of the container in the warehouse.
+
+ :return: tuple of strings with localisations
+ """
+ return tuple((
+ loca.reference
+ for loca in ContainerLocalisation.objects.filter(
+ container=self).order_by('division__order')
+ ))
+
+ def set_localisation(self, place, value):
+ """
+ Set the reference for the localisation number "place" (starting from 0)
+ :param place: the number of the localisation
+ :param value: the reference to be set
+ :return: the container location object or None if the place does not
+ exist
+ """
+ q = WarehouseDivisionLink.objects.filter(
+ warehouse=self.location).order_by('order')
+ for idx, division_link in enumerate(q.all()):
+ if idx == place:
+ break
+ else:
+ return
+ obj, created = ContainerLocalisation.objects.update_or_create(
+ container=self, division=division_link,
+ defaults={'reference': value})
+ return obj
+
@property
def divisions_lbl(self):
locas = [