You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
pokercc/news/models.py

91 lines
3.0 KiB

from django.db import models
from django.contrib.auth.models import User
from django.conf import settings
from enum import Enum
from django.db.models import Q
# Create your models here.
class PostState(Enum):
DRAFT = 0
PUBLISHED = 1
WAITING_LIST = 2
USER_SUBMITTED = 3
class Post(models.Model):
author = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.SET_NULL, null=True)
title = models.CharField(max_length=200)
body = models.CharField(max_length=10000)
url = models.CharField(max_length=200)
date = models.DateTimeField('date published')
state = models.IntegerField(default=0)
style = models.IntegerField(default=0)
image_url = models.CharField(max_length=100)
def __str__(self):
string = self.title
if self.style == 2:
string = "some image"
elif self.style == 3:
string = "Youtube: " + self.title
return string
def top_comments(self):
return self.comment_set.filter(Q(parent_comment=None)).order_by('-voters').all()[:1]
def flat_comments(self, user):
flat = []
for comment in self.comment_set.filter(Q(parent_comment=None)).all():
children = comment.flat_children(0, user)
flat.extend(children)
return flat
def formatted_tags(self):
tag_names = map(lambda t: t.name, self.tag_set.all())
return ", ".join(tag_names)
def html_title(self):
if self.title:
return title
return 'Poker Rumble - Amazing content'
class Comment(models.Model):
author = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, null=True)
post = models.ForeignKey(Post, on_delete=models.CASCADE)
parent_comment = models.ForeignKey("self", on_delete=models.SET_NULL, null=True, blank=True)
body = models.CharField(max_length=100)
voters = models.ManyToManyField(User, related_name='voted_comments', blank=True)
date = models.DateTimeField('date published')
deleted = models.BooleanField(default=False)
def __str__(self):
return self.body
def voters_count(self):
return voters.count
def upvoted_by(User):
return user in self.voters
def flat_children(self, level, user):
self.level = range(level)
self.upvoted = user in self.voters.all()
self.score = len(self.voters.all())
self.is_deletable = (self.deleted == False and user == self.author)
flat = [self]
for comment in self.comment_set.all():
flat.extend(comment.flat_children(level + 1, user))
return flat
class Player(models.Model):
name = models.CharField(max_length=100)
post = models.ForeignKey(Post, on_delete=models.SET_NULL, null=True)
image_url = models.CharField(max_length=100)
def __str__(self):
return self.name
# photo
class Tag(models.Model):
name = models.CharField(max_length=100)
post = models.ManyToManyField(Post, null=True, blank=True)
def __str__(self):
return self.name