Add user authentication with login/signup/protected routes, boss pokemon detail fields and result team tracking, moves and abilities selector components and API, run ownership and visibility controls, and various UI improvements across encounters, run list, and journal pages. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
27 lines
908 B
Python
27 lines
908 B
Python
from sqlalchemy import ForeignKey, SmallInteger
|
|
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
|
|
|
from app.core.database import Base
|
|
|
|
|
|
class BossResultTeam(Base):
|
|
__tablename__ = "boss_result_team"
|
|
|
|
id: Mapped[int] = mapped_column(primary_key=True)
|
|
boss_result_id: Mapped[int] = mapped_column(
|
|
ForeignKey("boss_results.id", ondelete="CASCADE"), index=True
|
|
)
|
|
encounter_id: Mapped[int] = mapped_column(
|
|
ForeignKey("encounters.id", ondelete="CASCADE"), index=True
|
|
)
|
|
level: Mapped[int] = mapped_column(SmallInteger)
|
|
|
|
boss_result: Mapped[BossResult] = relationship(back_populates="team")
|
|
encounter: Mapped[Encounter] = relationship()
|
|
|
|
def __repr__(self) -> str:
|
|
return (
|
|
f"<BossResultTeam(id={self.id}, boss_result_id={self.boss_result_id}, "
|
|
f"encounter_id={self.encounter_id}, level={self.level})>"
|
|
)
|