shopping_list.py 930 B

12345678910111213141516171819202122
  1. from datetime import datetime
  2. from sqlalchemy import DateTime, Integer, String, func
  3. from sqlalchemy.orm import Mapped, mapped_column
  4. from backend.app.core.database import Base
  5. class ShoppingListItem(Base):
  6. """A filament SKU queued for purchase."""
  7. __tablename__ = "filament_shopping_list"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. material: Mapped[str] = mapped_column(String(50))
  10. subtype: Mapped[str | None] = mapped_column(String(50))
  11. brand: Mapped[str | None] = mapped_column(String(100))
  12. quantity_spools: Mapped[int] = mapped_column(Integer, default=1)
  13. note: Mapped[str | None] = mapped_column(String(500))
  14. status: Mapped[str] = mapped_column(String(20), default="pending") # pending | purchased | received
  15. purchased_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  16. added_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())