Split frontend model from backend model
All checks were successful
Build Formula10 Docker Image / build-docker (push) Successful in 26s

This commit is contained in:
2024-02-25 15:09:59 +01:00
parent a9b1bc4403
commit 991a1a177e
38 changed files with 1094 additions and 930 deletions

View File

@ -3,8 +3,8 @@ from urllib.parse import unquote
from flask import redirect, render_template, request
from werkzeug import Response
from formula10.database.model.team import Team
from formula10.database.update_query_util import update_season_guess
from formula10.database.model.db_team import DbTeam
from formula10.database.update_queries import update_season_guess
from formula10.frontend.template_model import TemplateModel
from formula10 import app, db
@ -17,10 +17,10 @@ def season_root() -> Response:
@app.route("/season/<user_name>")
def season_active_user(user_name: str) -> str:
user_name = unquote(user_name)
model = TemplateModel()
return render_template("season.jinja",
active_user=model.user_by(user_name=user_name, ignore=["Everyone"]),
model=model)
model = TemplateModel(active_user_name=user_name,
active_result_race_name=None)
return render_template("season.jinja", model=model)
@app.route("/season-guess/<user_name>", methods=["POST"])
@ -36,7 +36,7 @@ def season_guess_post(user_name: str) -> Response:
]
# TODO: This is pretty ugly, to do queries in the controller
team_winner_guesses: List[str | None] = [
request.form.get(f"teamwinner-{team.name}") for team in db.session.query(Team).all()
request.form.get(f"teamwinner-{team.name}") for team in db.session.query(DbTeam).all()
]
podium_driver_guesses: List[str] = request.form.getlist("podiumdrivers")