summaryrefslogtreecommitdiff
path: root/app/routes/workout.py
blob: ffdacb9f6a5c0342af6db37d063f2fc66788edf3 (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
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")