tag.py
94 lines
| 2.4 KiB
| text/x-python
|
PythonLexer
neko259
|
r692 | from django.template.loader import render_to_string | ||
neko259
|
r386 | from django.db import models | ||
neko259
|
r607 | from django.db.models import Count, Sum | ||
neko259
|
r692 | from django.core.urlresolvers import reverse | ||
neko259
|
r732 | |||
from boards.models import Thread | ||||
neko259
|
r692 | from boards.models.base import Viewable | ||
neko259
|
r385 | |||
neko259
|
r732 | |||
neko259
|
r385 | __author__ = 'neko259' | ||
class TagManager(models.Manager): | ||||
def get_not_empty_tags(self): | ||||
neko259
|
r623 | """ | ||
Gets tags that have non-archived threads. | ||||
""" | ||||
neko259
|
r911 | not_empty_tags = list() | ||
neko259
|
r922 | tags = self.order_by('-required', 'name') | ||
neko259
|
r911 | for tag in tags: | ||
if tag.get_thread_count() > 0: | ||||
not_empty_tags.append(tag) | ||||
neko259
|
r385 | |||
neko259
|
r911 | return not_empty_tags | ||
neko259
|
r385 | |||
neko259
|
r692 | class Tag(models.Model, Viewable): | ||
neko259
|
r385 | """ | ||
neko259
|
r398 | A tag is a text node assigned to the thread. The tag serves as a board | ||
section. There can be multiple tags for each thread | ||||
neko259
|
r385 | """ | ||
objects = TagManager() | ||||
class Meta: | ||||
app_label = 'boards' | ||||
neko259
|
r649 | ordering = ('name',) | ||
neko259
|
r385 | |||
neko259
|
r609 | name = models.CharField(max_length=100, db_index=True) | ||
neko259
|
r922 | required = models.BooleanField(default=False) | ||
neko259
|
r385 | |||
neko259
|
r875 | def __str__(self): | ||
neko259
|
r385 | return self.name | ||
neko259
|
r908 | def is_empty(self) -> bool: | ||
neko259
|
r623 | """ | ||
Checks if the tag has some threads. | ||||
""" | ||||
neko259
|
r606 | return self.get_thread_count() == 0 | ||
neko259
|
r385 | |||
neko259
|
r908 | def get_thread_count(self) -> int: | ||
return self.get_threads().count() | ||||
neko259
|
r385 | |||
neko259
|
r606 | def get_post_count(self, archived=False): | ||
neko259
|
r623 | """ | ||
Gets posts count for the tag's threads. | ||||
""" | ||||
neko259
|
r606 | posts_count = 0 | ||
neko259
|
r908 | threads = self.get_threads().filter(archived=archived) | ||
neko259
|
r607 | if threads.exists(): | ||
neko259
|
r715 | posts_count = threads.annotate(posts_count=Count('replies')) \ | ||
.aggregate(posts_sum=Sum('posts_count'))['posts_sum'] | ||||
neko259
|
r607 | |||
if not posts_count: | ||||
posts_count = 0 | ||||
neko259
|
r606 | |||
return posts_count | ||||
neko259
|
r692 | |||
def get_url(self): | ||||
return reverse('tag', kwargs={'tag_name': self.name}) | ||||
neko259
|
r908 | def get_threads(self): | ||
return Thread.objects.filter(tags__in=[self]).order_by('-bump_time') | ||||
neko259
|
r922 | |||
def is_required(self): | ||||
return self.required | ||||
def get_view(self): | ||||
#prefix = '##' if self.is_required() else '#' | ||||
link = '<a class="tag" href="{}">{}</a>'.format( | ||||
self.get_url(), self.name) | ||||
if self.is_required(): | ||||
link = '<b>{}</b>'.format(link) | ||||
return link | ||||
def get_search_view(self, *args, **kwargs): | ||||
return render_to_string('boards/tag.html', { | ||||
'tag': self, | ||||
}) | ||||