from base import *
from tag import Tag
from django.utils.translation import ugettext as _
-from forum.modules.decorators import decoratable
-
-question_view = django.dispatch.Signal(providing_args=['instance', 'user'])
class QuestionManager(NodeManager):
- @decoratable.method
- def search(self, keywords):
- return self.filter(models.Q(title__icontains=keywords) | models.Q(body__icontains=keywords))
+ def search(self, keywords, **kwargs):
+ return False, self.filter(models.Q(title__icontains=keywords) | models.Q(body__icontains=keywords))
class Question(Node):
class Meta(Node.Meta):
proxy = True
- answer_count = DenormalizedField("children", node_type="answer", deleted=None)
+ answer_count = DenormalizedField("children", ~models.Q(state_string__contains="(deleted)"), node_type="answer")
+ accepted_count = DenormalizedField("children", ~models.Q(state_string__contains="(deleted)"), node_type="answer", marked=True)
favorite_count = DenormalizedField("actions", action_type="favorite", canceled=False)
friendly_name = _("question")
objects = QuestionManager()
- @property
+ @property
def closed(self):
- return self.extra_action
+ return self.nis.closed
@property
def view_count(self):
@property
def headline(self):
- if self.marked:
- return _('[closed] ') + self.title
+ return self._headline()
- if self.deleted:
+ def _headline(self):
+ if self.nis.deleted:
return _('[deleted] ') + self.title
- return self.title
+ if self.nis.closed:
+ return _('[closed] ') + self.title
- @property
- def answer_accepted(self):
- return self.extra_ref is not None
+ return self.title
@property
- def accepted_answer(self):
- return self.extra_ref
+ def accepted_answers(self):
+ return self.answers.filter(~models.Q(state_string__contains="(deleted)"), marked=True)
@models.permalink
def get_absolute_url(self):
return ('question', (), {'id': self.id, 'slug': django_urlquote(slugify(self.title))})
+
+ def meta_description(self):
+ return self.summary
def get_revision_url(self):
return reverse('question_revisions', args=[self.id])
related_list = cache.get(cache_key)
if related_list is None:
- related_list = Question.objects.values('id').filter(tags__id__in=[t.id for t in self.tags.all()]
- ).exclude(id=self.id).filter(deleted=None).annotate(frequency=models.Count('id')).order_by('-frequency')[:count]
+ related_list = Question.objects.filter_state(deleted=False).values('id').filter(tags__id__in=[t.id for t in self.tags.all()]
+ ).exclude(id=self.id).annotate(frequency=models.Count('id')).order_by('-frequency')[:count]
cache.set(cache_key, related_list, 60 * 60)
return [Question.objects.get(id=r['id']) for r in related_list]
+
-def question_viewed(instance, **kwargs):
- instance.extra_count += 1
- instance.save()
-
-question_view.connect(question_viewed)
-
class QuestionSubscription(models.Model):
user = models.ForeignKey(User)