regluit/core/lookups.py

58 lines
1.8 KiB
Python
Raw Normal View History

from selectable.base import ModelLookup
from selectable.registry import registry
from django.contrib.auth.models import User
2015-01-16 13:56:36 +00:00
from django.db.models import Count
2015-01-14 20:07:54 +00:00
from regluit.core.models import Work, PublisherName, Edition, Subject
class OwnerLookup(ModelLookup):
model = User
search_fields = ('username__icontains',)
class WorkLookup(ModelLookup):
model = Work
search_fields = ('title__istartswith',)
def get_item_label(self,item):
return "%s (%s, %s)"%(item.title,item.id,item.language)
def get_query(self, request, term):
results = super(WorkLookup, self).get_query(request, term)
return results
2013-03-26 14:56:49 +00:00
class PublisherNameLookup(ModelLookup):
model = PublisherName
search_fields = ('name__icontains',)
def create_item(self, value):
publisher_name, created = PublisherName.objects.get_or_create(name=value)
publisher_name.save()
return publisher_name
2013-07-08 15:14:25 +00:00
class EditionLookup(ModelLookup):
model = Edition
search_fields = ('title__icontains',)
filters = {'ebooks__isnull': False, }
2013-07-08 15:14:25 +00:00
2013-07-26 23:51:45 +00:00
def get_query(self, request, term):
return super(EditionLookup, self).get_query(request, term).distinct()
def get_item(self, value):
item = None
if value:
try:
item = Edition.objects.get(pk=value)
except (ValueError, Edition.DoesNotExist):
item = None
return item
2015-01-14 20:07:54 +00:00
class SubjectLookup(ModelLookup):
model = Subject
search_fields = ('name__icontains',)
2015-01-16 13:56:36 +00:00
def get_query(self, request, term):
return super(SubjectLookup, self).get_query( request, term).annotate(Count('works')).order_by('-works__count')
2015-01-14 20:07:54 +00:00
registry.register(OwnerLookup)
2013-03-26 14:56:49 +00:00
registry.register(WorkLookup)
2013-07-08 15:14:25 +00:00
registry.register(PublisherNameLookup)
2015-01-14 20:07:54 +00:00
registry.register(EditionLookup)
registry.register(SubjectLookup)