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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
from app import app, db
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
@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")
return render_template("workout/create.html", form=form)
@app.route("/workout/edit", methods=["GET", "POST"])
@login_required
def workout_edit():
# Id is required
if "id" not in request.args:
return redirect(url_for("home"))
# Validate Id
workout = Workout.query.filter_by(
id=int(request.args["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 FIXME
for entry in form.exercises.entries:
# Get the specified exercise TODO needs hidden id field
exercise = Exercise.query.filter_by(
workout_id=workout.id, id=int(entry.data["id"])
).first()
if not exercise: # NOTE error?
continue
# Update exercise
exercise.name = entry.data["name"]
exercise.sets = entry.data["sets"]
exercise.units = entry.data["units"]
exercise.type = entry.data["type"]
print(exercise)
# 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, title=f'Edit Workout "{workout.name}"'
)
@app.route("/workout/record", methods=["GET", "POST"])
@login_required
def workout_record():
form = WorkoutRecordForm()
# Id is required
if "id" not in request.args:
return redirect(url_for("home"))
# Matching workout required
workout = Workout.query.filter_by(
id=int(request.args["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 FIXME
print(form)
return render_template("workout/record.html", workout=workout, form=form)
@app.route("/workout/select", methods=["GET"])
@login_required
def workout_select():
return render_template("workout/select.html")
|