summaryrefslogtreecommitdiff
path: root/archaeological_operations/lookups.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-03 20:56:56 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-03 20:56:56 +0200
commit6044b3522b2511eae088a40338115c902a9b0f82 (patch)
tree0e342a579be32b7d2b276dc75b7db7876a569739 /archaeological_operations/lookups.py
parentbcfad74d5033491a65f8310c258cb0163242b282 (diff)
downloadIshtar-6044b3522b2511eae088a40338115c902a9b0f82.tar.bz2
Ishtar-6044b3522b2511eae088a40338115c902a9b0f82.zip
Admin: improve operation form
Diffstat (limited to 'archaeological_operations/lookups.py')
-rw-r--r--archaeological_operations/lookups.py20
1 files changed, 19 insertions, 1 deletions
diff --git a/archaeological_operations/lookups.py b/archaeological_operations/lookups.py
index b6fdaad23..690b3c566 100644
--- a/archaeological_operations/lookups.py
+++ b/archaeological_operations/lookups.py
@@ -1,7 +1,7 @@
from ajax_select import register, LookupChannel
from django.db.models import Q
-from archaeological_operations.models import Operation
+from archaeological_operations.models import Operation, ArchaeologicalSite
@register('operation')
@@ -19,3 +19,21 @@ class OperationLookup(LookupChannel):
def format_item_display(self, item):
return u"<span class='ajax-label'>%s</span>" % item.cached_label
+
+
+@register('archaeological_site')
+class ArchaeologicalSiteLookup(LookupChannel):
+ model = ArchaeologicalSite
+
+ def get_query(self, q, request):
+ query = Q()
+ for term in q.strip().split(' '):
+ subquery = (
+ Q(reference__icontains=term) |
+ Q(name__icontains=term)
+ )
+ query &= subquery
+ return self.model.objects.filter(query).order_by('cached_label')[:20]
+
+ def format_item_display(self, item):
+ return u"<span class='ajax-label'>%s</span>" % unicode(item)