open-law/app/models/interpretation.py

57 lines
1.5 KiB
Python
Raw Normal View History

2023-05-05 16:42:20 +03:00
from datetime import datetime
2023-05-10 15:07:07 +03:00
from flask_login import current_user
2023-04-21 15:58:47 +03:00
from app import db
from app.models.utils import BaseModel
class Interpretation(BaseModel):
__tablename__ = "interpretations"
2023-04-27 16:17:25 +03:00
label = db.Column(db.String(256), unique=False, nullable=False)
2023-04-21 17:01:07 +03:00
text = db.Column(db.Text, unique=False, nullable=False)
2023-04-21 15:58:47 +03:00
marked = db.Column(db.Boolean, default=False)
2023-05-05 16:42:20 +03:00
created_at = db.Column(db.DateTime, default=datetime.now)
2023-04-21 15:58:47 +03:00
# Foreign keys
user_id = db.Column(db.ForeignKey("users.id"))
section_id = db.Column(db.ForeignKey("sections.id"))
# Relationships
user = db.relationship("User")
section = db.relationship("Section")
comments = db.relationship("Comment", viewonly=True)
votes = db.relationship("InterpretationVote", viewonly=True)
tags = db.relationship(
"Tag",
secondary="interpretation_tags",
back_populates="interpretations",
)
2023-05-09 17:56:29 +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-09 17:56:29 +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
2023-05-09 12:52:37 +03:00
@property
def active_comments(self):
return [comment for comment in self.comments if not comment.is_deleted]
2023-04-21 15:58:47 +03:00
def __repr__(self):
return f"<{self.id}: {self.label}>"