Remove manual food item addition and barcode scanning

Deleted routes and templates related to manual food item entry and barcode scanning, including add_food_item, add_food_item_manual, food_item, log_food, and related session-based selection routes. Updated navigation in base.html to remove links to these features and added links to overview, daily log, and dashboard. Simplified daily_log.html to format log amounts, and removed unused imports and forms from routes.py.
This commit is contained in:
2025-08-07 17:09:47 +02:00
parent c552a4571e
commit b282f333fd
8 changed files with 11 additions and 395 deletions

View File

@@ -4,14 +4,11 @@ from flask import (
url_for,
render_template,
flash,
session,
jsonify,
abort,
)
from flask_login import current_user
from application import db
from forms import FoodItemForm, FoodLogForm
from models import FoodItem, FoodLog
from forms import FoodItemForm
from models import FoodItem
from datetime import datetime, timezone
user_bp = Blueprint(
@@ -47,46 +44,6 @@ def delete_food_item(id: int):
return redirect(url_for("user.dashboard"))
@user_bp.route("/add_food_item/<string:barcode>", methods=["GET", "POST"])
def add_food_item(barcode):
form = FoodItemForm(barcode=barcode)
print(form)
if form.validate_on_submit():
print("[DEBUG] Valid form")
if FoodItem.query.filter_by(barcode=form.barcode.data).first() is None:
assert form.name.data is not None
assert form.energy.data is not None
assert form.protein.data is not None
assert form.carbs.data is not None
assert form.fat.data is not None
db.session.add(
FoodItem(
name=form.name.data,
owner_id=current_user.id,
energy=form.energy.data,
protein=form.protein.data,
carbs=form.carbs.data,
fat=form.fat.data,
barcode=form.barcode.data,
saturated_fat=form.saturated_fat.data,
sugar=form.sugar.data,
)
)
db.session.commit()
print("[DEBUG] New item added")
return redirect(
url_for("user.food_item", barcode=form.barcode.data)
)
else:
print("[DEBUG] Invalid form")
if form.barcode.data:
print("1")
return render_template("add_food_item.html", form=form)
else:
return redirect("/")
@user_bp.route("/edit_food_item/<int:id>", methods=["GET", "POST"])
def edit_food_item(id: int):
item = FoodItem.query.get(id)
@@ -109,103 +66,11 @@ def edit_food_item(id: int):
return redirect(url_for("user.dashboard"))
@user_bp.route("/food_item/<string:barcode>", methods=["GET"])
def food_item(barcode):
food = FoodItem.query.filter_by(barcode=barcode).first()
if food:
return redirect(url_for("user.log_food", item_id=food.id))
else:
return render_template(
"add_food_item.html",
barcode=barcode,
form=FoodItemForm(barcode=barcode),
)
@user_bp.route("/add_food_item_manual", methods=["GET", "POST"])
def add_food_item_manual():
form = FoodItemForm()
for item in form:
print(item)
if form.validate_on_submit():
assert form.name.data is not None
assert form.energy.data is not None
assert form.protein.data is not None
assert form.carbs.data is not None
assert form.fat.data is not None
db.session.add(
FoodItem(
name=form.name.data,
owner_id=current_user.id,
energy=form.energy.data,
protein=form.protein.data,
carbs=form.carbs.data,
fat=form.fat.data,
barcode=form.barcode.data,
saturated_fat=form.saturated_fat.data,
sugar=form.sugar.data,
)
)
db.session.commit()
return redirect(url_for("user.dashboard"))
return render_template("add_food_item_manual.html", form=form)
@user_bp.route("/log_food", methods=["GET", "POST"])
def log_food():
form = FoodLogForm()
item_id = session["item_id"]
meal_type = session["meal_type"]
if item_id is None or meal_type is None:
return redirect("/")
if db.session.get(FoodItem, item_id):
if form.validate_on_submit():
assert form.amount.data is not None
db.session.add(
FoodLog(
item_id,
current_user.id,
form.amount.data,
part_of_day=meal_type,
)
)
db.session.commit()
return redirect(url_for("user.dashboard"))
return render_template("log_food.html", form=form)
@user_bp.route("/overview", methods=["GET"])
def overview():
return render_template("overview.html")
@user_bp.route("/select_meal/<int:meal_type>", methods=["GET"])
def select_meal(meal_type: int):
assert type(meal_type) is int
session["meal_type"] = meal_type
return redirect(url_for("user.scan_product"))
@user_bp.route("/select_item/<int:item_id>", methods=["GET"])
def select_item(item_id: int):
assert type(item_id) is int
session["item_id"] = item_id
return redirect(url_for("user.log_food"))
@user_bp.route("/get_foodid", methods=["GET"])
def scan_product():
return render_template("get_item.html")
@user_bp.route("/add_meal", methods=["GET"])
def add_meal():
meal_type = session["meal_type"]
if meal_type is None:
return redirect("/")
return render_template("scan.html")
@user_bp.route("/", methods=["GET"])
def daily_log():
today = datetime.now(timezone.utc).date()
@@ -217,17 +82,3 @@ def daily_log():
return render_template(
"daily_log.html", date=(today.strftime("%d/%m/%y")), logs=logs
)
@user_bp.route("/foodId_from_barcode/<string:barcode>", methods=["GET"])
def foodId_from_barcode(barcode: str):
# Check if barcode contains only digits
if not barcode.isdigit():
return abort(
400, description="Invalid barcode: must contain only digits"
)
item = current_user.food_items.filter_by(barcode=barcode).first()
if item is None:
return redirect(url_for("user.add_food_item", barcode=barcode))
return jsonify({"item_id": item.id})