Improve IndexableObject class methods
This commit is contained in:
@@ -9,11 +9,12 @@ from django.utils.translation import ugettext as _
|
||||
from django.contrib.auth.models import User
|
||||
from django.core.urlresolvers import reverse
|
||||
from django.utils.encoding import smart_unicode, smart_str
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
from django.contrib.contenttypes.models import ContentType
|
||||
from django.contrib.contenttypes import generic
|
||||
from django.utils.translation import ugettext_lazy as _
|
||||
from django.utils.simplejson import loads
|
||||
|
||||
from .managers import RecentSearchManager
|
||||
from .managers import RecentSearchManager, IndexableObjectManager
|
||||
from .api import registered_search_dict
|
||||
|
||||
|
||||
@@ -29,36 +30,27 @@ class RecentSearch(models.Model):
|
||||
objects = RecentSearchManager()
|
||||
|
||||
def __unicode__(self):
|
||||
query_dict = urlparse.parse_qs(urllib.unquote_plus(smart_str(self.query)))
|
||||
if 'q' in query_dict:
|
||||
# Is a simple search
|
||||
display_string = smart_unicode(' '.join(query_dict['q']))
|
||||
if self.is_advanced():
|
||||
return u'%s (%s)' % (self.get_query(), self.hits)
|
||||
else:
|
||||
# Advanced search
|
||||
advanced_string = []
|
||||
for key, value in query_dict.items():
|
||||
# Get model name
|
||||
model, field_name = key.split('__', 1)
|
||||
model_entry = registered_search_dict.get(model, {})
|
||||
if model_entry:
|
||||
# Find the field name title
|
||||
for model_field in model_entry.get('fields', [{}]):
|
||||
if model_field.get('name') == field_name:
|
||||
advanced_string.append(u'%s: %s' % (model_field.get('title', model_field['name']), smart_unicode(' '.join(value))))
|
||||
|
||||
display_string = u', '.join(advanced_string)
|
||||
return u'%s (%s)' % (display_string, self.hits)
|
||||
return u'%s (%s)' % (self.get_query().get('q'), self.hits)
|
||||
|
||||
def save(self, *args, **kwargs):
|
||||
self.datetime_created = datetime.datetime.now()
|
||||
super(RecentSearch, self).save(*args, **kwargs)
|
||||
|
||||
def url(self):
|
||||
view = 'results' if self.is_advanced() else 'search'
|
||||
return '%s?%s' % (reverse(view), self.query)
|
||||
#def readable_query(self):
|
||||
# return self.
|
||||
|
||||
#def url(self):
|
||||
# view = 'results' if self.is_advanced() else 'search'
|
||||
# return '%s?%s' % (reverse(view), self.query)
|
||||
|
||||
def get_query(self):
|
||||
return loads(self.query)
|
||||
|
||||
def is_advanced(self):
|
||||
return 'q' not in urlparse.parse_qs(self.query)
|
||||
return 'q' not in self.get_query()
|
||||
|
||||
class Meta:
|
||||
ordering = ('-datetime_created',)
|
||||
@@ -66,32 +58,14 @@ class RecentSearch(models.Model):
|
||||
verbose_name_plural = _(u'recent searches')
|
||||
|
||||
|
||||
class IndexableObjectManager(models.Manager):
|
||||
def get_dirty(self, datetime=None):
|
||||
if datetime:
|
||||
return self.model.objects.filter(datetime__gte=datetime)
|
||||
else:
|
||||
return self.model.objects.all()
|
||||
|
||||
def get_dirty_pk_list(self, datetime=None):
|
||||
return self.get_dirty(datetime).values_list('object_id', flat=True)
|
||||
|
||||
def mark_dirty(self, obj):
|
||||
content_type = ContentType.objects.get_for_model(obj)
|
||||
self.model.objects.get_or_create(content_type=content_type, object_id=obj.pk)
|
||||
|
||||
def clear_all(self):
|
||||
self.model.objects.all().delete()
|
||||
|
||||
|
||||
class IndexableObject(models.Model):
|
||||
"""
|
||||
Store a list of object links that have been modified and are
|
||||
meant to be indexed in the next search index update
|
||||
"""
|
||||
datetime = models.DateTimeField(verbose_name=_(u'date time'))
|
||||
content_type = models.ForeignKey(ContentType, blank=True, null=True)
|
||||
object_id = models.PositiveIntegerField(blank=True, null=True)
|
||||
content_type = models.ForeignKey(ContentType)
|
||||
object_id = models.PositiveIntegerField()
|
||||
content_object = generic.GenericForeignKey('content_type', 'object_id')
|
||||
|
||||
objects = IndexableObjectManager()
|
||||
|
||||
Reference in New Issue
Block a user