summaryrefslogtreecommitdiff
path: root/archaeological_context_records/lookups.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-04 17:11:52 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-04 17:11:52 +0200
commit5063bf07c5128131f5eecbce994cfeb670ef8a08 (patch)
tree61235d58ad63a44cd66ddc0c2664bc3dd0ee3fa7 /archaeological_context_records/lookups.py
parentb35c53bbf266153e478a776209e35aad36e9cd5b (diff)
downloadIshtar-5063bf07c5128131f5eecbce994cfeb670ef8a08.tar.bz2
Ishtar-5063bf07c5128131f5eecbce994cfeb670ef8a08.zip
Admin context records: add context record lookup, improve admin forms
Diffstat (limited to 'archaeological_context_records/lookups.py')
-rw-r--r--archaeological_context_records/lookups.py23
1 files changed, 23 insertions, 0 deletions
diff --git a/archaeological_context_records/lookups.py b/archaeological_context_records/lookups.py
new file mode 100644
index 000000000..92115d98b
--- /dev/null
+++ b/archaeological_context_records/lookups.py
@@ -0,0 +1,23 @@
+from ajax_select import register, LookupChannel
+
+from django.db.models import Q
+
+from archaeological_context_records import models
+
+
+@register('context_record')
+class ContextRecordLookup(LookupChannel):
+ model = models.ContextRecord
+
+ def get_query(self, q, request):
+ query = Q()
+ for term in q.strip().split(' '):
+ subquery = (
+ Q(cached_label__icontains=term) |
+ Q(parcel__town__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>" % item.cached_label