diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-08-04 20:01:24 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2017-08-04 20:01:24 +0200 |
commit | 8dac0d41c0760c4bce6de81ecae2edb7364b5772 (patch) | |
tree | 8d6a6331b88e9a88f0bbbad9fef3008c560982a9 /archaeological_warehouse/lookups.py | |
parent | c2cd149c3298d7fb1fb9dba9e58dc54168a45c0c (diff) | |
download | Ishtar-8dac0d41c0760c4bce6de81ecae2edb7364b5772.tar.bz2 Ishtar-8dac0d41c0760c4bce6de81ecae2edb7364b5772.zip |
Admin: add lookups for finds, base finds, warehouses and containers
Diffstat (limited to 'archaeological_warehouse/lookups.py')
-rw-r--r-- | archaeological_warehouse/lookups.py | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/archaeological_warehouse/lookups.py b/archaeological_warehouse/lookups.py new file mode 100644 index 000000000..57d3a892d --- /dev/null +++ b/archaeological_warehouse/lookups.py @@ -0,0 +1,49 @@ +from ajax_select import register, LookupChannel + +from django.db.models import Q +from django.utils.encoding import force_text +from django.utils.html import escape + +from archaeological_warehouse import models + + +@register('container') +class ContainerLookup(LookupChannel): + model = models.Container + + def get_query(self, q, request): + query = Q() + for term in q.strip().split(' '): + subquery = ( + Q(reference__icontains=term) | + Q(container_type__label__icontains=term) | + Q(cached_label__icontains=term) | + Q(responsible__name__icontains=term) + ) + query &= subquery + return self.model.objects.filter(query).order_by( + 'cached_label')[:20] + + def format_match(self, obj): + return escape(force_text(obj.cached_label)) + + def format_item_display(self, item): + return u"<span class='ajax-label'>%s</span>" % item.cached_label + + +@register('warehouse') +class WarehouseLookup(LookupChannel): + model = models.Warehouse + + def get_query(self, q, request): + query = Q() + for term in q.strip().split(' '): + subquery = ( + Q(warehouse_type__label=term) | + Q(name__icontains=term) + ) + query &= subquery + return self.model.objects.filter(query).order_by('name')[:20] + + def format_item_display(self, item): + return u"<span class='ajax-label'>%s</span>" % item.name |