summaryrefslogtreecommitdiff
path: root/models.py
blob: 4059e20614df419e7e257e3d2f90d0a38cf4b9d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
from datetime import datetime, date
from sqlalchemy import Column, Integer, String, Float, DateTime, Date, Text, Boolean, ForeignKey
from sqlalchemy.orm import relationship
from database import Base


class Ingredient(Base):
    __tablename__ = "ingredients"

    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String, nullable=False)
    quantity = Column(Float, nullable=False)
    unit = Column(String, nullable=False)
    category = Column(String, nullable=True)
    expiry_date = Column(Date, nullable=True)
    added_at = Column(DateTime, default=datetime.utcnow)
    updated_at = Column(DateTime, default=datetime.utcnow, onupdate=datetime.utcnow)


class MealLog(Base):
    __tablename__ = "meal_log"

    id = Column(Integer, primary_key=True, autoincrement=True)
    meal_name = Column(String, nullable=False)
    meal_type = Column(String, nullable=False)
    eaten_at = Column(DateTime, nullable=False, default=datetime.utcnow)
    notes = Column(String, nullable=True)
    servings = Column(Integer, default=1)
    ingredients = relationship("MealIngredient", cascade="all, delete-orphan")


class MealIngredient(Base):
    __tablename__ = "meal_ingredients"

    id = Column(Integer, primary_key=True, autoincrement=True)
    meal_log_id = Column(Integer, ForeignKey("meal_log.id", ondelete="CASCADE"), nullable=False)
    ingredient_name = Column(String, nullable=False)
    quantity_used = Column(Float, nullable=True)
    unit = Column(String, nullable=True)


class Recipe(Base):
    __tablename__ = "recipes"

    id = Column(Integer, primary_key=True, autoincrement=True)
    name = Column(String, nullable=False)
    description = Column(Text, nullable=True)
    meal_type = Column(String, nullable=False)
    ingredients = Column(Text, nullable=False)
    instructions = Column(Text, nullable=True)
    estimated_time_minutes = Column(Integer, nullable=True)
    servings = Column(Integer, default=2)
    source = Column(String, default="ai")
    created_at = Column(DateTime, default=datetime.utcnow)


class MenuPlan(Base):
    __tablename__ = "menu_plans"

    id = Column(Integer, primary_key=True, autoincrement=True)
    week_start = Column(Date, nullable=False, unique=True)
    plan = Column(Text, nullable=False)
    generated_at = Column(DateTime, default=datetime.utcnow)
    model_used = Column(String, nullable=True)
    notes = Column(Text, nullable=True)


class GroceryList(Base):
    __tablename__ = "grocery_lists"

    id = Column(Integer, primary_key=True, autoincrement=True)
    generated_for = Column(Date, nullable=False)
    items = Column(Text, nullable=False)
    total_estimate = Column(Float, nullable=True)
    generated_at = Column(DateTime, default=datetime.utcnow)
    is_purchased = Column(Boolean, default=False)
    notes = Column(Text, nullable=True)