2023-04-21 15:58:47 +03:00
|
|
|
from app import db
|
|
|
|
from app.models.utils import BaseModel
|
|
|
|
|
|
|
|
|
|
|
|
class Section(BaseModel):
|
|
|
|
__tablename__ = "sections"
|
|
|
|
|
2023-04-27 16:17:25 +03:00
|
|
|
label = db.Column(db.String(256), unique=False, nullable=False)
|
2023-04-21 17:20:22 +03:00
|
|
|
about = db.Column(db.Text, unique=False, nullable=True)
|
2023-04-21 15:58:47 +03:00
|
|
|
|
|
|
|
# Foreign keys
|
|
|
|
collection_id = db.Column(db.ForeignKey("collections.id"))
|
|
|
|
user_id = db.Column(db.ForeignKey("users.id"))
|
2023-04-21 17:20:22 +03:00
|
|
|
version_id = db.Column(db.ForeignKey("book_versions.id"))
|
|
|
|
selected_interpretation_id = db.Column(db.Integer, nullable=True)
|
2023-04-21 15:58:47 +03:00
|
|
|
|
|
|
|
# Relationships
|
|
|
|
collection = db.relationship("Collection", viewonly=True)
|
2023-04-21 17:20:22 +03:00
|
|
|
user = db.relationship("User", viewonly=True)
|
|
|
|
version = db.relationship("BookVersion", viewonly=True)
|
|
|
|
interpretations = db.relationship("Interpretation", viewonly=True)
|
2023-04-21 15:58:47 +03:00
|
|
|
|
2023-04-27 15:40:48 +03:00
|
|
|
@property
|
|
|
|
def path(self):
|
|
|
|
parent = self.collection
|
|
|
|
grand_parent = parent.parent
|
|
|
|
path = f"{self.version.book.label} / "
|
|
|
|
if grand_parent.is_root:
|
|
|
|
path += f"{parent.label} / "
|
|
|
|
else:
|
|
|
|
path += f"{grand_parent.label} / {parent.label} / "
|
|
|
|
path += self.label
|
|
|
|
return path
|
|
|
|
|
2023-04-21 15:58:47 +03:00
|
|
|
def __repr__(self):
|
|
|
|
return f"<{self.id}: {self.label}>"
|