summaryrefslogtreecommitdiff
path: root/archaeological_files/lookups.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-03 17:59:59 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2017-08-03 17:59:59 +0200
commit27c69b3032201fac570b1cd3a648266874726554 (patch)
treec334490e42c8c9e70de4984eb7a0bee82589e058 /archaeological_files/lookups.py
parent9b05b0bf718c5f0ab0c420660f034d2684f4f63a (diff)
downloadIshtar-27c69b3032201fac570b1cd3a648266874726554.tar.bz2
Ishtar-27c69b3032201fac570b1cd3a648266874726554.zip
Admin: improve files and common
* Town admin: OSM overlay * add a File lookup * improve considerably File edition (make it usable)
Diffstat (limited to 'archaeological_files/lookups.py')
-rw-r--r--archaeological_files/lookups.py32
1 files changed, 32 insertions, 0 deletions
diff --git a/archaeological_files/lookups.py b/archaeological_files/lookups.py
new file mode 100644
index 000000000..4de713419
--- /dev/null
+++ b/archaeological_files/lookups.py
@@ -0,0 +1,32 @@
+from ajax_select import register, LookupChannel
+
+from django.db.models import Q
+from archaeological_files.models import File
+
+
+@register('file')
+class FileLookup(LookupChannel):
+ model = File
+
+ def get_query(self, q, request):
+ query = Q()
+ for term in q.strip().split(' '):
+ subquery = (
+ Q(towns__name__icontains=term) |
+ Q(towns__numero_insee__icontains=term) |
+ Q(main_town__name__icontains=term) |
+ Q(main_town__numero_insee__icontains=term) |
+ Q(name__icontains=term) |
+ Q(internal_reference__icontains=term) |
+ Q(permit_reference__icontains=term)
+ )
+ try:
+ num = int(term)
+ subquery |= Q(year=num) | Q(numeric_reference=num)
+ except ValueError:
+ pass
+ 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