X-Git-Url: https://git.mdrn.pl/prawokultury.git/blobdiff_plain/999340c55d5402900dd013ab5ced2413cd4f22f8..b4ededb44a47569b05671f08e95a2fe595732fd4:/migdal/search_indexes.py?ds=inline diff --git a/migdal/search_indexes.py b/migdal/search_indexes.py index 333899f..2001dab 100644 --- a/migdal/search_indexes.py +++ b/migdal/search_indexes.py @@ -2,11 +2,10 @@ from django.conf import settings import datetime from haystack import indexes from migdal.models import Entry +from migdal.helpers import add_translatable_index -from copy import copy - -class EntryIndex(indexes.SearchIndex, indexes.Indexable): +class EntryIndex(indexes.RealTimeSearchIndex, indexes.Indexable): date = indexes.DateTimeField(indexed=True, model_attr="date") author = indexes.CharField(model_attr="author") @@ -15,27 +14,13 @@ class EntryIndex(indexes.SearchIndex, indexes.Indexable): def index_queryset(self): """Used when the entire index for model is updated.""" - return self.get_model().objects.filter(date__lte=datetime.datetime.now()) - - -def add_translatable(index_class, fields, languages=None): - """Adds some translatable fields to a search index, and a getter.""" - if languages is None: - languages = settings.LANGUAGES - for name, field in fields.items(): - for lang_code, lang_name in languages: - new_field = copy(field) - fname = "%s_%s" % (name, lang_code) - new_field.index_fieldname = fname - new_field.model_attr = fname - setattr(index_class, fname, new_field) - index_class.fields[fname] = new_field - - -add_translatable(EntryIndex, { - 'title': indexes.CharField(indexed=True, document=False), - 'lead': indexes.CharField(indexed=True, document=False), - 'body': indexes.CharField(indexed=True, document=False) + return self.get_model().objects.all() # from example: filter(date__lte=datetime.datetime.now()) + + +add_translatable_index(EntryIndex, { + 'title': indexes.CharField(), + 'lead': indexes.CharField(), + 'body': indexes.CharField() })