diff options
Diffstat (limited to 'archaeological_warehouse/views.py')
| -rw-r--r-- | archaeological_warehouse/views.py | 30 | 
1 files changed, 26 insertions, 4 deletions
| diff --git a/archaeological_warehouse/views.py b/archaeological_warehouse/views.py index bc8bac127..efa5bdf19 100644 --- a/archaeological_warehouse/views.py +++ b/archaeological_warehouse/views.py @@ -95,20 +95,42 @@ def autocomplete_container(request, warehouse_id=None):          return HttpResponse(content_type='text/plain')      if not request.GET.get('term'):          return HttpResponse(content_type='text/plain') -    term = request.GET.get('term') +    term = request.GET.get('term').strip()      limit = 15      base_query = Q()      if warehouse_id:          base_query = Q(location_id=warehouse_id)      query = base_query +    # exact index +    try: +        query = query & Q(index=int(term)) +        containers = list(models.Container.objects.filter( +            query).values('id', 'cached_label')[:limit]) +    except ValueError: +        containers = []      # exact ref      query = query & Q(reference__unaccent__iexact=term) -    containers = list(models.Container.objects.filter( +    containers += list(models.Container.objects.filter(          query).values('id', 'cached_label')[:limit])      limit = 15 - len(containers) -    splitted = term.split(' ') +    splitted = [s for s in term.split(' ') if s]      if limit > 0: -        if len(splitted) > 1: +        if len(splitted) > 1 and not len(splitted) % 2: +            # group by container type, ref tuple +            groups = [(splitted[idx * 2], splitted[idx * 2 + 1]) +                      for idx in range(int(len(splitted) / 2))] +            query = base_query +            for idx, g in enumerate(reversed(groups)): +                base_key = "parent__" * idx +                key1 = base_key + "container_type__label__unaccent__iexact" +                key2 = base_key + "reference__unaccent__iexact" +                query &= Q(**{key1: g[0], key2: g[1]}) +            ids = set([c["id"] for c in containers]) +            containers += list(models.Container.objects.filter( +                query).exclude(pk__in=ids).values('id', 'cached_label')[ +                               :limit]) + +        if len(splitted) > 1 and (15 - len(containers)) > 0:              # group to do a "type" "reference" search              for idx in range(1, len(splitted)):                  group_1 = splitted[:idx] | 
