diff options
| author | Étienne Loks <etienne.loks@proxience.com> | 2014-12-12 16:07:39 +0100 | 
|---|---|---|
| committer | Étienne Loks <etienne.loks@proxience.com> | 2014-12-12 16:07:39 +0100 | 
| commit | 982bface0b1d11c614f457a40bffb7c84d987cc7 (patch) | |
| tree | c9ff24219dcb5bb3b1ec0dc67f322d9e1163728b /archaeological_files/views.py | |
| parent | a77d68b9600c33b8a46d538b977276f66cdc4f2f (diff) | |
| download | Ishtar-982bface0b1d11c614f457a40bffb7c84d987cc7.tar.bz2 Ishtar-982bface0b1d11c614f457a40bffb7c84d987cc7.zip | |
Archaeological files: autocomplete also search by address and year-index (refs #2066)
Diffstat (limited to 'archaeological_files/views.py')
| -rw-r--r-- | archaeological_files/views.py | 11 | 
1 files changed, 9 insertions, 2 deletions
| diff --git a/archaeological_files/views.py b/archaeological_files/views.py index 8498352cf..bd91c1040 100644 --- a/archaeological_files/views.py +++ b/archaeological_files/views.py @@ -17,7 +17,7 @@  # See the file COPYING for details. -import json +import json, re  from django.core.urlresolvers import reverse  from django.db.models import Q @@ -41,6 +41,8 @@ from forms import *  from archaeological_operations.views import generatedoc_administrativeactop +RE_YEAR_INDEX = re.compile(r"([1-2][0-9]{3})-([0-9]+)") # eg.: 2014-123 +  def autocomplete_file(request):      if not request.user.has_perm('ishtar_common.view_file', models.File) and \         not request.user.has_perm('ishtar_common.view_own_file', models.File) \ @@ -52,12 +54,17 @@ def autocomplete_file(request):      query = Q()      for q in q.split(' '):          extra = Q(internal_reference__icontains=q) | \ -                Q(towns__name__icontains=q) +                Q(towns__name__icontains=q) | \ +                Q(address__icontains=q)          try:              value = int(q)              extra = extra | Q(year=q) | Q(numeric_reference=q)          except ValueError:              pass +        m = RE_YEAR_INDEX.match(q) +        if m: +            yr, idx = m.groups() +            extra = extra | Q(year=yr, numeric_reference=idx)          query = query & extra      limit = 20      files = models.File.objects.filter(query)[:limit] | 
