diff options
Diffstat (limited to 'ishtar_common/lookups.py')
| -rw-r--r-- | ishtar_common/lookups.py | 95 | 
1 files changed, 95 insertions, 0 deletions
| diff --git a/ishtar_common/lookups.py b/ishtar_common/lookups.py new file mode 100644 index 000000000..9570f8bc6 --- /dev/null +++ b/ishtar_common/lookups.py @@ -0,0 +1,95 @@ +from ajax_select import register, LookupChannel + +from django.conf import settings +from django.db.models import Q +from ishtar_common.models import Person, Organization, IshtarUser, Town, Author + + +@register('town') +class TownLookup(LookupChannel): +    model = Town + +    def get_query(self, q, request): +        if settings.COUNTRY == 'fr': +            query = Q() +            for term in q.strip().split(' '): +                query &= ( +                    Q(name__icontains=term) | Q(numero_insee__icontains=term) +                ) +        else: +            query = Q(name__icontains=q) +        return self.model.objects.filter(query).order_by('name')[:20] + +    def format_item_display(self, item): +        return u"<span class='ajax-label'>%s</span>" % unicode(item) + + +@register('organization') +class OrganizationLookup(LookupChannel): +    model = Organization + +    def get_query(self, q, request): +        return self.model.objects.filter( +            name__icontains=q).order_by('name')[:20] + +    def format_item_display(self, item): +        return u"<span class='ajax-label'>%s</span>" % unicode(item) + + +@register('person') +class PersonLookup(LookupChannel): +    model = Person + +    def get_query(self, q, request): +        query = Q() +        for term in q.strip().split(' '): +            query &= ( +                Q(name__icontains=term) | Q(surname__icontains=term) | +                Q(email__icontains=term) | Q(attached_to__name__icontains=term)| +                Q(raw_name__icontains=term) +            ) +        return self.model.objects.filter(query).order_by('name')[:20] + +    def format_item_display(self, item): +        return u"<span class='ajax-label'>%s</span>" % unicode(item) + + +@register('author') +class AuthorLookup(LookupChannel): +    model = Author + +    def get_query(self, q, request): +        query = Q() +        for term in q.strip().split(' '): +            query &= ( +                Q(person__name__icontains=term) | +                Q(person__surname__icontains=term) | +                Q(person__raw_name__icontains=term) | +                Q(person__attached_to__name__icontains=term) | +                Q(author_type__label__icontains=term) +            ) +        return self.model.objects.filter(query).order_by('person__name')[:20] + +    def format_item_display(self, item): +        return u"<span class='ajax-label'>%s</span>" % unicode(item) + + +@register('ishtaruser') +class UserLookup(LookupChannel): +    model = IshtarUser + +    def get_query(self, q, request): +        query = Q() +        for term in q.strip().split(' '): +            query &= ( +                Q(user_ptr__username__icontains=term) | +                Q(person__name__icontains=term) | +                Q(person__surname__icontains=term) | +                Q(person__email__icontains=term) | +                Q(person__attached_to__name__icontains=term)| +                Q(person__raw_name__icontains=term) +            ) +        return self.model.objects.filter(query).order_by('person__name')[:20] + +    def format_item_display(self, item): +        return u"<span class='ajax-label'>%s</span>" % unicode(item.person) | 
