diff options
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 |
commit | d0ce06a5899ee38a6c97a00c3f3512080a6169f8 (patch) | |
tree | 61235d58ad63a44cd66ddc0c2664bc3dd0ee3fa7 /archaeological_context_records/lookups.py | |
parent | 985dc2b18a551ead39a12fa0ed2601b2bda1d6e4 (diff) | |
download | Ishtar-d0ce06a5899ee38a6c97a00c3f3512080a6169f8.tar.bz2 Ishtar-d0ce06a5899ee38a6c97a00c3f3512080a6169f8.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.py | 23 |
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 |