2026-02-05 13:29:34 +01:00
|
|
|
from sqlalchemy import SmallInteger, String
|
|
|
|
|
from sqlalchemy.dialects.postgresql import ARRAY
|
|
|
|
|
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
|
|
|
|
|
|
|
|
|
from app.core.database import Base
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class Pokemon(Base):
|
|
|
|
|
__tablename__ = "pokemon"
|
|
|
|
|
|
|
|
|
|
id: Mapped[int] = mapped_column(primary_key=True)
|
|
|
|
|
national_dex: Mapped[int] = mapped_column(SmallInteger, unique=True)
|
|
|
|
|
name: Mapped[str] = mapped_column(String(50))
|
|
|
|
|
types: Mapped[list[str]] = mapped_column(ARRAY(String(20)))
|
|
|
|
|
sprite_url: Mapped[str | None] = mapped_column(String(500))
|
|
|
|
|
|
|
|
|
|
route_encounters: Mapped[list["RouteEncounter"]] = relationship(
|
|
|
|
|
back_populates="pokemon"
|
|
|
|
|
)
|
2026-02-05 19:20:19 +01:00
|
|
|
encounters: Mapped[list["Encounter"]] = relationship(
|
|
|
|
|
foreign_keys="[Encounter.pokemon_id]", back_populates="pokemon"
|
|
|
|
|
)
|
2026-02-05 13:29:34 +01:00
|
|
|
|
|
|
|
|
def __repr__(self) -> str:
|
|
|
|
|
return f"<Pokemon(id={self.id}, name='{self.name}', dex={self.national_dex})>"
|