]> git.openstreetmap.org Git - osqa.git/blobdiff - forum/models/meta.py
Adds a user preferences page. Not much to see yet, only the preference to make sorts...
[osqa.git] / forum / models / meta.py
index fca763fd5d78a0db59a22900c6d0cc2d0490092a..41dc5d67d35fcc23ca7bda0c3943834976deb480 100644 (file)
@@ -1,99 +1,99 @@
-from django.utils.translation import ugettext as _\r
-from base import *\r
-\r
-class Vote(models.Model):\r
-    user = models.ForeignKey(User, related_name="votes")\r
-    node = models.ForeignKey(Node, related_name="votes")\r
-    value = models.SmallIntegerField()\r
-    action = models.OneToOneField(Action, related_name="vote")\r
-    voted_at = models.DateTimeField(default=datetime.datetime.now)\r
-\r
-    class Meta:\r
-        app_label = 'forum'\r
-        unique_together = ('user', 'node')\r
-\r
-\r
-class Flag(models.Model):\r
-    user = models.ForeignKey(User, related_name="flags")\r
-    node = models.ForeignKey(Node, related_name="flags")\r
-    reason = models.CharField(max_length=300)\r
-    action = models.OneToOneField(Action, related_name="flag")\r
-    flagged_at = models.DateTimeField(default=datetime.datetime.now)\r
-\r
-    class Meta:\r
-        app_label = 'forum'\r
-        unique_together = ('user', 'node')\r
-\r
-class BadgesQuerySet(models.query.QuerySet):\r
-    def get(self, *args, **kwargs):\r
-        try:\r
-            pk = [v for (k,v) in kwargs.items() if k in ('pk', 'pk__exact', 'id', 'id__exact')][0]\r
-        except:\r
-            return super(BadgesQuerySet, self).get(*args, **kwargs)\r
-\r
-        from forum.badges.base import BadgesMeta\r
-        badge = BadgesMeta.by_id.get(int(pk), None)\r
-        if not badge:\r
-            return super(BadgesQuerySet, self).get(*args, **kwargs)\r
-        return badge.ondb\r
-\r
-\r
-class BadgeManager(models.Manager):\r
-    use_for_related_fields = True\r
-\r
-    def get_query_set(self):\r
-        return BadgesQuerySet(self.model)\r
-\r
-class Badge(models.Model):\r
-    GOLD = 1\r
-    SILVER = 2\r
-    BRONZE = 3\r
-\r
-    type        = models.SmallIntegerField()\r
-    cls         = models.CharField(max_length=50, null=True)\r
-    awarded_count = models.PositiveIntegerField(default=0)\r
-    \r
-    awarded_to    = models.ManyToManyField(User, through='Award', related_name='badges')\r
-\r
-    objects = BadgeManager()\r
-\r
-    @property\r
-    def name(self):\r
-        cls = self.__dict__.get('_class', None)\r
-        return cls and cls.name or _("Unknown")\r
-\r
-    @property\r
-    def description(self):\r
-        cls = self.__dict__.get('_class', None)\r
-        return cls and cls.description or _("No description available")\r
-\r
-    @models.permalink\r
-    def get_absolute_url(self):\r
-        return ('badge', [], {'id': self.id, 'slug': slugify(self.name)})\r
-\r
-    def save(self, *args, **kwargs):\r
-        if isinstance(self.awarded_count, models.expressions.ExpressionNode):\r
-            super(Badge, self).save(*args, **kwargs)\r
-            self.awarded_count = self.__class__.objects.filter(id=self.id).values_list('awarded_count', flat=True)[0]\r
-        else:\r
-            super(Badge, self).save(*args, **kwargs)\r
-\r
-\r
-    class Meta:\r
-        app_label = 'forum'\r
-\r
-\r
-class Award(models.Model):\r
-    user = models.ForeignKey(User)\r
-    badge = models.ForeignKey('Badge', related_name="awards")\r
-    node = models.ForeignKey(Node, null=True)\r
-\r
-    awarded_at = models.DateTimeField(default=datetime.datetime.now)\r
-\r
-    trigger = models.ForeignKey(Action, related_name="awards", null=True)\r
-    action = models.OneToOneField(Action, related_name="award")\r
-\r
-\r
-    class Meta:\r
-        unique_together = ('user', 'badge', 'node')\r
+from django.utils.translation import ugettext as _
+from base import *
+
+class Vote(models.Model):
+    user = models.ForeignKey(User, related_name="votes")
+    node = models.ForeignKey(Node, related_name="votes")
+    value = models.SmallIntegerField()
+    action = models.OneToOneField(Action, related_name="vote")
+    voted_at = models.DateTimeField(default=datetime.datetime.now)
+
+    class Meta:
+        app_label = 'forum'
+        unique_together = ('user', 'node')
+
+
+class Flag(models.Model):
+    user = models.ForeignKey(User, related_name="flags")
+    node = models.ForeignKey(Node, related_name="flags")
+    reason = models.CharField(max_length=300)
+    action = models.OneToOneField(Action, related_name="flag")
+    flagged_at = models.DateTimeField(default=datetime.datetime.now)
+
+    class Meta:
+        app_label = 'forum'
+        unique_together = ('user', 'node')
+
+class BadgesQuerySet(models.query.QuerySet):
+    def get(self, *args, **kwargs):
+        try:
+            pk = [v for (k,v) in kwargs.items() if k in ('pk', 'pk__exact', 'id', 'id__exact')][0]
+        except:
+            return super(BadgesQuerySet, self).get(*args, **kwargs)
+
+        from forum.badges.base import BadgesMeta
+        badge = BadgesMeta.by_id.get(int(pk), None)
+        if not badge:
+            return super(BadgesQuerySet, self).get(*args, **kwargs)
+        return badge.ondb
+
+
+class BadgeManager(models.Manager):
+    use_for_related_fields = True
+
+    def get_query_set(self):
+        return BadgesQuerySet(self.model)
+
+class Badge(models.Model):
+    GOLD = 1
+    SILVER = 2
+    BRONZE = 3
+
+    type        = models.SmallIntegerField()
+    cls         = models.CharField(max_length=50, null=True)
+    awarded_count = models.PositiveIntegerField(default=0)
+    
+    awarded_to    = models.ManyToManyField(User, through='Award', related_name='badges')
+
+    objects = BadgeManager()
+
+    @property
+    def name(self):
+        cls = self.__dict__.get('_class', None)
+        return cls and cls.name or _("Unknown")
+
+    @property
+    def description(self):
+        cls = self.__dict__.get('_class', None)
+        return cls and cls.description or _("No description available")
+
+    @models.permalink
+    def get_absolute_url(self):
+        return ('badge', [], {'id': self.id, 'slug': slugify(self.name)})
+
+    def save(self, *args, **kwargs):
+        if isinstance(self.awarded_count, models.expressions.ExpressionNode):
+            super(Badge, self).save(*args, **kwargs)
+            self.awarded_count = self.__class__.objects.filter(id=self.id).values_list('awarded_count', flat=True)[0]
+        else:
+            super(Badge, self).save(*args, **kwargs)
+
+
+    class Meta:
+        app_label = 'forum'
+
+
+class Award(models.Model):
+    user = models.ForeignKey(User)
+    badge = models.ForeignKey('Badge', related_name="awards")
+    node = models.ForeignKey(Node, null=True)
+
+    awarded_at = models.DateTimeField(default=datetime.datetime.now)
+
+    trigger = models.ForeignKey(Action, related_name="awards", null=True)
+    action = models.OneToOneField(Action, related_name="award")
+
+
+    class Meta:
+        unique_together = ('user', 'badge', 'node')
         app_label = 'forum'
\ No newline at end of file
         app_label = 'forum'
\ No newline at end of file