open-law/app/models/comment.py

60 lines
1.6 KiB
Python
Raw Normal View History

2023-05-10 15:07:07 +03:00
from flask_login import current_user
from app import db, models as m
2023-04-21 15:58:47 +03:00
from app.models.utils import BaseModel
class Comment(BaseModel):
__tablename__ = "comments"
2023-04-27 16:17:25 +03:00
# need to redeclare id to use it in the parent relationship
2023-04-21 15:58:47 +03:00
id = db.Column(db.Integer, primary_key=True)
text = db.Column(db.Text, unique=False, nullable=False)
approved = db.Column(db.Boolean, default=False)
2023-05-09 17:32:07 +03:00
edited = db.Column(db.Boolean, default=False)
2023-06-13 11:34:17 +03:00
copy_of = db.Column(db.Integer, default=0, nullable=True)
2023-04-21 15:58:47 +03:00
# Foreign keys
user_id = db.Column(db.ForeignKey("users.id"))
2023-04-27 16:17:25 +03:00
parent_id = db.Column(db.ForeignKey("comments.id"))
2023-04-21 15:58:47 +03:00
interpretation_id = db.Column(db.ForeignKey("interpretations.id"))
# Relationships
user = db.relationship("User")
children = db.relationship(
"Comment", backref=db.backref("parent", remote_side=[id]), viewonly=True
)
interpretation = db.relationship("Interpretation")
votes = db.relationship("CommentVote")
tags = db.relationship(
"Tag",
secondary="comment_tags",
back_populates="comments",
)
2023-05-10 11:43:17 +03:00
@property
def vote_count(self):
count = 0
for vote in self.votes:
if vote.positive:
count += 1
2023-05-10 15:38:04 +03:00
continue
count -= 1
2023-05-10 11:43:17 +03:00
return count
2023-05-10 15:07:07 +03:00
@property
def current_user_vote(self):
for vote in self.votes:
if vote.user_id == current_user.id:
return vote.positive
return None
@property
def book(self) -> m.Book:
return self.interpretation.book
2023-04-21 15:58:47 +03:00
def __repr__(self):
return f"<{self.id}: {self.text[:20]}>"