diff options
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 |
commit | 6044b3522b2511eae088a40338115c902a9b0f82 (patch) | |
tree | 0e342a579be32b7d2b276dc75b7db7876a569739 /archaeological_operations/lookups.py | |
parent | bcfad74d5033491a65f8310c258cb0163242b282 (diff) | |
download | Ishtar-6044b3522b2511eae088a40338115c902a9b0f82.tar.bz2 Ishtar-6044b3522b2511eae088a40338115c902a9b0f82.zip |
Admin: improve operation form
Diffstat (limited to 'archaeological_operations/lookups.py')
-rw-r--r-- | archaeological_operations/lookups.py | 20 |
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) |