X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/410bfa05ee36ed1d99356c443a5f3f6aa3ee9578..cf4c6f115a98cb8574c9665f34a50ae503a57b79:/forum/models/tag.py diff --git a/forum/models/tag.py b/forum/models/tag.py index 16f1c6c..0bff004 100644 --- a/forum/models/tag.py +++ b/forum/models/tag.py @@ -3,12 +3,12 @@ from base import * from django.utils.translation import ugettext as _ import django.dispatch -class ActiveTagManager(UndeletedObjectManager): +class ActiveTagManager(models.Manager): def get_query_set(self): - return super(UndeletedObjectManager, self).get_query_set().exclude(used_count=0) + return super(ActiveTagManager, self).get_query_set().exclude(used_count__lt=1) -class Tag(BaseModel, DeletableContent): +class Tag(BaseModel): name = models.CharField(max_length=255, unique=True) created_by = models.ForeignKey(User, related_name='created_tags') marked_by = models.ManyToManyField(User, related_name="marked_tags", through="MarkedTag") @@ -17,14 +17,25 @@ class Tag(BaseModel, DeletableContent): active = ActiveTagManager() - class Meta(DeletableContent.Meta): + class Meta: ordering = ('-used_count', 'name') + app_label = 'forum' def __unicode__(self): return self.name + def add_to_usage_count(self, value): + if self.used_count + value < 0: + self.used_count = 0 + else: + self.used_count = models.F('used_count') + value + + @models.permalink + def get_absolute_url(self): + return ('tag_questions', (), {'tag': self.name}) + class MarkedTag(models.Model): - TAG_MARK_REASONS = (('good',_('interesting')),('bad',_('ignored'))) + TAG_MARK_REASONS = (('good', _('interesting')), ('bad', _('ignored'))) tag = models.ForeignKey(Tag, related_name='user_selections') user = models.ForeignKey(User, related_name='tag_selections') reason = models.CharField(max_length=16, choices=TAG_MARK_REASONS)