"""Модель портфолио фрилансера.""" import uuid from datetime import datetime, timezone from sqlalchemy import Column, DateTime, ForeignKey, Integer, String, Text, func from sqlalchemy.dialects.postgresql import UUID as PG_UUID from sqlalchemy.orm import Mapped, mapped_column, relationship from app.core.database import Base class PortfolioItem(Base): __tablename__ = "portfolio_items" id: Mapped[uuid.UUID] = mapped_column(PG_UUID(as_uuid=True), primary_key=True, default=uuid.uuid4) freelancer_id: Mapped[uuid.UUID] = mapped_column(PG_UUID(as_uuid=True), ForeignKey("users.id"), nullable=False) title: Mapped[str] = mapped_column(String(255), nullable=False) description: Mapped[str | None] = mapped_column(Text) image_url: Mapped[str | None] = mapped_column(Text) # URL превью работы live_url: Mapped[str | None] = mapped_column(Text) # Ссылка на работу technologies: Mapped[list] = mapped_column("technologies", postgresql.JSONB, default=list) created_at: Mapped[datetime] = mapped_column(DateTime(timezone=True), server_default=func.now())