from app import app, db from datetime import datetime from flask import render_template, redirect, request, url_for, flash from flask_login import current_user, login_required from forms import WorkoutCreateForm, WorkoutRecordForm from tables import Exercise, User, Workout, WorkoutRecord, SetRecord @app.route("/workout/create", methods=["GET", "POST"]) @login_required def workout_create(): form = WorkoutCreateForm() name = form.name.data if form.validate_on_submit(): # Make sure the user doesn't already have a workout with this name workout = Workout.query.filter_by(user_id=current_user.id, name=name).first() if not workout: # TODO: add exercises workout = Workout( current_user, name, [e.data for e in form.exercises.entries] ) db.session.add(workout) db.session.commit() return redirect(url_for("home")) else: flash("Workout with this name already exists", "danger") else: print(form.errors) return render_template("workout/create.html", form=form) @app.route("/workout/edit/", methods=["GET", "POST"]) @login_required def workout_edit(workout_id=None): # Validate Id workout = Workout.query.filter_by( id=int(workout_id), user_id=current_user.id ).first() if not workout: return redirect(url_for("home")) form = WorkoutCreateForm() if form.validate_on_submit(): # Form has been submitted, write changes for entry in form.exercises.entries: id = entry.data["id"] name = entry.data["name"] sets = entry.data["sets"] units = entry.data["units"] type = entry.data["type"] # Is this a new exercise or an old one if id: # Get the specified exercise exercise = Exercise.query.filter_by( workout_id=workout.id, id=int(id) ).first() if not exercise: continue # Update exercise exercise.name = name exercise.sets = sets exercise.units = units exercise.type = type else: # Create new exercise workout.exercises.append(Exercise(name, sets, units, type)) # FIXME: support deleting exercises # Write changes to database db.session.commit() return redirect(url_for("home")) else: form.name.data = workout.name form.exercises.pop_entry() # TODO: better way to do this? for exercise in workout.exercises: form.exercises.append_entry(exercise) return render_template("workout/create.html", form=form, workout=workout) @app.route("/workout/record") @login_required def workout_record_select(): return render_template("workout/record_select.html") @app.route("/workout/record/", methods=["GET", "POST"]) @login_required def workout_record(workout_id=None): form = WorkoutRecordForm() # Matching workout required workout = Workout.query.filter_by( id=int(workout_id), user_id=current_user.id ).first() if not workout: return redirect(url_for("home")) if form.validate_on_submit(): # Form has been submitted and is valid workout_record = WorkoutRecord(workout, datetime.now()) # Interate over form exercise entries for ee in form.exercises.entries: id = ee.data["id"] # And over that exercise's sets for se in ee.sets.entries: lbs = se.data["lbs"] units = se.data["units"] if lbs and units: # Add the set to the workout record workout_record.sets.append( SetRecord(lbs=lbs, reps=units, exercise_id=id) ) db.session.add(workout_record) db.session.commit() return redirect(url_for("home")) else: print(form.errors) # Populate form with data for exercise in workout.exercises: form.exercises.append_entry( {"id": exercise.id, "sets": [{}] * exercise.sets} ) return render_template("workout/record.html", workout=workout, form=form) @app.route("/workout/history/") @login_required def workout_history(record_id=None): record = WorkoutRecord.query.filter_by( id=int(record_id), user_id=current_user.id ).first() if not record: return redirect(url_for("home")) return render_template("workout/history.html", record=record)