35 lines
953 B
Python
35 lines
953 B
Python
from typing import TYPE_CHECKING
|
|
|
|
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
|
|
|
from models.base import BaseModel
|
|
from models.mixins import SoftDeleteMixin, CreatedAtMixin, IdMixin
|
|
|
|
if TYPE_CHECKING:
|
|
from models import Board, Module, DealTag
|
|
|
|
|
|
class Project(BaseModel, IdMixin, SoftDeleteMixin, CreatedAtMixin):
|
|
__tablename__ = "projects"
|
|
|
|
name: Mapped[str] = mapped_column()
|
|
|
|
boards: Mapped[list["Board"]] = relationship(
|
|
back_populates="project",
|
|
lazy="noload",
|
|
)
|
|
|
|
modules: Mapped[list["Module"]] = relationship(
|
|
secondary="project_module",
|
|
back_populates="projects",
|
|
lazy="selectin",
|
|
order_by="asc(Module.id)",
|
|
)
|
|
|
|
tags: Mapped[list["DealTag"]] = relationship(
|
|
back_populates="project",
|
|
primaryjoin="and_(Project.id == DealTag.project_id, DealTag.is_deleted == False)",
|
|
order_by="asc(DealTag.id)",
|
|
lazy="selectin",
|
|
)
|