Compare commits

...

2 Commits

Author SHA1 Message Date
150a185439 Implement entering results 2024-02-14 18:40:42 +01:00
dd2a638f47 Update templates 2024-02-14 18:40:33 +01:00
5 changed files with 107 additions and 248 deletions

View File

@ -29,7 +29,7 @@ def save():
@app.route("/race") @app.route("/race")
def race(): def guessraceresults():
users = User.query.all() users = User.query.all()
raceresults = RaceResult.query.all() raceresults = RaceResult.query.all()
drivers = Driver.query.all() drivers = Driver.query.all()
@ -65,29 +65,47 @@ def guessrace(raceid, username):
if pxx is None or dnf is None: if pxx is None or dnf is None:
return redirect("/race") return redirect("/race")
if RaceResult.query.filter_by(race_id=raceid).first() is not None:
print("Error: Can't guess race result if the race result is already known!")
return redirect("/race")
raceguess: RaceGuess | None = RaceGuess.query.filter_by(user_id=username, race_id=raceid).first() raceguess: RaceGuess | None = RaceGuess.query.filter_by(user_id=username, race_id=raceid).first()
if raceguess is not None: if raceguess is None:
raceguess.pxx_id = pxx
raceguess.dnf_id = dnf
else:
raceguess = RaceGuess() raceguess = RaceGuess()
raceguess.user_id = username raceguess.user_id = username
raceguess.race_id = raceid raceguess.race_id = raceid
raceguess.pxx_id = pxx
raceguess.dnf_id = dnf
db.session.add(raceguess) db.session.add(raceguess)
raceguess.pxx_id = pxx
raceguess.dnf_id = dnf
db.session.commit() db.session.commit()
return redirect("/race") return redirect("/race")
@app.route("/enterresult") @app.route("/enterresult/<raceid>", methods=["POST"])
def enterresult(): def enterresult(raceid):
return render_template("enterresult.jinja") pxx = request.form.get("pxxselect")
dnf = request.form.get("dnfselect")
if pxx is None or dnf is None:
return redirect("/race")
raceresult: RaceResult | None = RaceResult.query.filter_by(race_id=raceid).first()
if raceresult is not None:
print("RaceResult already exists!")
return redirect("/race")
raceresult = RaceResult()
raceresult.race_id = raceid
raceresult.pxx_id = pxx
raceresult.dnf_id = dnf
db.session.add(raceresult)
db.session.commit()
return redirect("/race")
if __name__ == "__main__": if __name__ == "__main__":

214
model.py
View File

@ -65,226 +65,32 @@ class Driver(db.Model):
class RaceResult(db.Model): class RaceResult(db.Model):
__tablename__ = "raceresult" __tablename__ = "raceresult"
__csv_header__ = [ __csv_header__ = ["id", "race_id", "pxx_id", "dnf_id"]
"id",
"race_id",
"p01_id",
"p02_id",
"p03_id",
"p04_id",
"p05_id",
"p06_id",
"p07_id",
"p08_id",
"p09_id",
"p10_id",
"p11_id",
"p12_id",
"p13_id",
"p14_id",
"p15_id",
"p16_id",
"p17_id",
"p18_id",
"p19_id",
"p20_id",
"dnf01_id",
"dnf02_id",
"dnf03_id",
"dnf04_id",
"dnf05_id",
"dnf06_id",
"dnf07_id",
"dnf08_id",
"dnf09_id",
"dnf10_id",
"dnf11_id",
"dnf12_id",
"dnf13_id",
"dnf14_id",
"dnf15_id",
"dnf16_id",
"dnf17_id",
"dnf18_id",
"dnf19_id",
"dnf20_id"
]
def from_csv(self, row): def from_csv(self, row):
self.id = int(row[0]) self.id = int(row[0])
self.race_id = str(row[1]) self.race_id = str(row[1])
self.p01_id = str(row[2]) self.pxx_id = str(row[2])
self.p02_id = str(row[3]) self.dnf_id = str(row[22])
self.p03_id = str(row[4])
self.p04_id = str(row[5])
self.p05_id = str(row[6])
self.p06_id = str(row[7])
self.p07_id = str(row[8])
self.p08_id = str(row[9])
self.p09_id = str(row[10])
self.p10_id = str(row[11])
self.p11_id = str(row[12])
self.p12_id = str(row[13])
self.p13_id = str(row[14])
self.p14_id = str(row[15])
self.p15_id = str(row[16])
self.p16_id = str(row[17])
self.p17_id = str(row[18])
self.p18_id = str(row[19])
self.p19_id = str(row[20])
self.p20_id = str(row[21])
self.dnf01_id = str(row[22])
self.dnf02_id = str(row[23])
self.dnf03_id = str(row[24])
self.dnf04_id = str(row[25])
self.dnf05_id = str(row[26])
self.dnf06_id = str(row[27])
self.dnf07_id = str(row[28])
self.dnf08_id = str(row[29])
self.dnf09_id = str(row[30])
self.dnf10_id = str(row[31])
self.dnf11_id = str(row[32])
self.dnf12_id = str(row[33])
self.dnf13_id = str(row[34])
self.dnf14_id = str(row[35])
self.dnf15_id = str(row[36])
self.dnf16_id = str(row[37])
self.dnf17_id = str(row[38])
self.dnf18_id = str(row[39])
self.dnf19_id = str(row[40])
self.dnf20_id = str(row[41])
return self return self
def to_csv(self): def to_csv(self):
return [ return [
self.id, self.id,
self.p01_id, self.race_id,
self.p02_id, self.pxx_id,
self.p03_id, self.dnf_id
self.p04_id,
self.p05_id,
self.p06_id,
self.p07_id,
self.p08_id,
self.p09_id,
self.p10_id,
self.p11_id,
self.p12_id,
self.p13_id,
self.p14_id,
self.p15_id,
self.p16_id,
self.p17_id,
self.p18_id,
self.p19_id,
self.p20_id,
self.dnf01_id,
self.dnf02_id,
self.dnf03_id,
self.dnf04_id,
self.dnf05_id,
self.dnf06_id,
self.dnf07_id,
self.dnf08_id,
self.dnf09_id,
self.dnf10_id,
self.dnf11_id,
self.dnf12_id,
self.dnf13_id,
self.dnf14_id,
self.dnf15_id,
self.dnf16_id,
self.dnf17_id,
self.dnf18_id,
self.dnf19_id,
self.dnf20_id
] ]
id: Mapped[int] = mapped_column(Integer, primary_key=True) id: Mapped[int] = mapped_column(Integer, primary_key=True)
race_id: Mapped[str] = mapped_column(ForeignKey("race.id")) race_id: Mapped[str] = mapped_column(ForeignKey("race.id"))
p01_id: Mapped[str] = mapped_column(ForeignKey("driver.name")) pxx_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p02_id: Mapped[str] = mapped_column(ForeignKey("driver.name")) dnf_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p03_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p04_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p05_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p06_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p07_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p08_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p09_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p10_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p11_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p12_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p13_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p14_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p15_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p16_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p17_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p18_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p19_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
p20_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf01_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf02_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf03_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf04_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf05_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf06_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf07_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf08_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf09_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf10_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf11_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf12_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf13_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf14_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf15_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf16_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf17_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf18_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf19_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
dnf20_id: Mapped[str] = mapped_column(ForeignKey("driver.name"))
# Relationships # Relationships
race: Mapped["Race"] = relationship("Race", foreign_keys=[race_id]) race: Mapped["Race"] = relationship("Race", foreign_keys=[race_id])
p01: Mapped["Driver"] = relationship("Driver", foreign_keys=[p01_id]) pxx: Mapped["Driver"] = relationship("Driver", foreign_keys=[pxx_id])
p02: Mapped["Driver"] = relationship("Driver", foreign_keys=[p02_id]) dnf: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf_id])
p03: Mapped["Driver"] = relationship("Driver", foreign_keys=[p03_id])
p04: Mapped["Driver"] = relationship("Driver", foreign_keys=[p04_id])
p05: Mapped["Driver"] = relationship("Driver", foreign_keys=[p05_id])
p06: Mapped["Driver"] = relationship("Driver", foreign_keys=[p06_id])
p07: Mapped["Driver"] = relationship("Driver", foreign_keys=[p07_id])
p08: Mapped["Driver"] = relationship("Driver", foreign_keys=[p08_id])
p09: Mapped["Driver"] = relationship("Driver", foreign_keys=[p09_id])
p10: Mapped["Driver"] = relationship("Driver", foreign_keys=[p10_id])
p11: Mapped["Driver"] = relationship("Driver", foreign_keys=[p11_id])
p12: Mapped["Driver"] = relationship("Driver", foreign_keys=[p12_id])
p13: Mapped["Driver"] = relationship("Driver", foreign_keys=[p13_id])
p14: Mapped["Driver"] = relationship("Driver", foreign_keys=[p14_id])
p15: Mapped["Driver"] = relationship("Driver", foreign_keys=[p15_id])
p16: Mapped["Driver"] = relationship("Driver", foreign_keys=[p16_id])
p17: Mapped["Driver"] = relationship("Driver", foreign_keys=[p17_id])
p18: Mapped["Driver"] = relationship("Driver", foreign_keys=[p18_id])
p19: Mapped["Driver"] = relationship("Driver", foreign_keys=[p19_id])
p20: Mapped["Driver"] = relationship("Driver", foreign_keys=[p20_id])
dnf01: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf01_id])
dnf02: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf02_id])
dnf03: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf03_id])
dnf04: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf04_id])
dnf05: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf05_id])
dnf06: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf06_id])
dnf07: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf07_id])
dnf08: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf08_id])
dnf09: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf09_id])
dnf10: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf10_id])
dnf11: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf11_id])
dnf12: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf12_id])
dnf13: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf13_id])
dnf14: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf14_id])
dnf15: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf15_id])
dnf16: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf16_id])
dnf17: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf17_id])
dnf18: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf18_id])
dnf19: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf19_id])
dnf20: Mapped["Driver"] = relationship("Driver", foreign_keys=[dnf20_id])
# Per race guesses: PX, DNF # Per race guesses: PX, DNF

View File

@ -29,10 +29,9 @@
</a> </a>
<div class="collapse navbar-collapse" id="navbarNavAltMarkup"> <div class="collapse navbar-collapse" id="navbarNavAltMarkup">
<div class="navbar-nav"> <div class="navbar-nav">
{{ nav_selector("race", "Guess a Race") }} {{ nav_selector("race", "Guess Race") }}
{{ nav_selector("season", "Guess the Season") }} {{ nav_selector("season", "Guess Season") }}
{{ nav_selector("graphs", "Result Graphs") }} {{ nav_selector("graphs", "Statistics") }}
{{ nav_selector("enterresult", "Enter Race Result") }}
{{ nav_selector("rules", "Rules") }} {{ nav_selector("rules", "Rules") }}
</div> </div>
</div> </div>

View File

@ -1,11 +0,0 @@
{% extends 'base.jinja' %}
{% set active_page = "enterresult" %}
{% block title %}Formula 10{% endblock title %}
{% block body %}
{% endblock body %}

View File

@ -34,22 +34,24 @@
<td>{{ raceresult.race.grandprix }}</td> <td>{{ raceresult.race.grandprix }}</td>
{% for user in users %} {% for user in users %}
{% set pxx = guesses.get(raceresult.race_id).get(user.name).pxx.abbr %}
{% set dnf = guesses.get(raceresult.race_id).get(user.name).dnf.abbr %}
<td> <td>
<ul class="list-group-flush"> {% if (raceresult.race_id in guesses) and (user.name in guesses.get(raceresult.race_id)) %}
<li class="list-group-item {% if pxx == raceresult.pxx.abbr %}text-success fw-bold{% endif %}"> {% set pxx = guesses.get(raceresult.race_id).get(user.name).pxx.abbr %}
P{{ raceresult.race.pxx }}: {{ pxx }}</li> {% set dnf = guesses.get(raceresult.race_id).get(user.name).dnf.abbr %}
<li class="list-group-item {% if dnf == raceresult.dnf.abbr %}text-success fw-bold{% endif %}"> <ul class="list-group list-group-flush">
DNF: {{ dnf }}</li> <li class="list-group-item {% if pxx == raceresult.pxx.abbr %}text-success fw-bold{% endif %}">
</ul> P{{ raceresult.race.pxx }}: {{ pxx }}</li>
<li class="list-group-item {% if dnf == raceresult.dnf.abbr %}text-success fw-bold{% endif %}">
DNF: {{ dnf }}</li>
</ul>
{% endif %}
</td> </td>
{% endfor %} {% endfor %}
<td> <td>
<ul class="list-group-flush"> <ul class="list-group list-group-flush">
<li class="list-group-item">PXX: {{ pxx }}</li> <li class="list-group-item">P{{ raceresult.race.pxx }}: {{ raceresult.pxx.abbr }}</li>
<li class="list-group-item {% if raceresult.dnf.abbr == 'NON' %}text-muted{% endif %}"> <li class="list-group-item {% if raceresult.dnf.abbr == 'NON' %}text-muted{% endif %}">
DNF: {{ raceresult.dnf.abbr }}</li> DNF: {{ raceresult.dnf.abbr }}</li>
</ul> </ul>
@ -68,11 +70,20 @@
{# Driver PXX Select #} {# Driver PXX Select #}
<div class="form-floating"> <div class="form-floating">
<select name="pxxselect" class="form-select" aria-label="Select PXX"> <select name="pxxselect" class="form-select" aria-label="Select PXX">
<option value="" selected disabled hidden></option> {% set user_has_chosen = namespace(pxx="false") %}
{% for driver in drivers %} {% for driver in drivers %}
<option {% if (user.name in nextguesses) and (nextguesses.get(user.name).pxx.abbr == driver.abbr) %}selected{% endif %} {% if (user.name in nextguesses) and (nextguesses.get(user.name).pxx.abbr == driver.abbr) %}
value="{{ driver.name }}">{{ driver.abbr }}</option> {% set user_has_chosen.pxx = "true" %}
<option selected="selected" value="{{ driver.name }}">{{ driver.abbr }}</option>
{% else %}
<option value="{{ driver.name }}">{{ driver.abbr }}</option>
{% endif %}
{% endfor %} {% endfor %}
{% if user_has_chosen.pxx == "false" %}
<option value="" selected="selected" disabled="disabled" hidden="hidden"></option>
{% endif %}
</select> </select>
<label for="pxxselect" class="text-primary">P{{ nextrace.pxx }}:</label> <label for="pxxselect" class="text-primary">P{{ nextrace.pxx }}:</label>
</div> </div>
@ -80,11 +91,20 @@
{# Driver DNF Select #} {# Driver DNF Select #}
<div class="form-floating mt-2"> <div class="form-floating mt-2">
<select name="dnfselect" class="form-select" aria-label="Select DNF"> <select name="dnfselect" class="form-select" aria-label="Select DNF">
<option value="" selected disabled hidden></option> {% set user_has_chosen = namespace(dnf="false") %}
{% for driver in drivers %} {% for driver in drivers %}
<option {% if (user.name in nextguesses) and (nextguesses.get(user.name).dnf.abbr == driver.abbr) %}selected{% endif %} {% if (user.name in nextguesses) and (nextguesses.get(user.name).dnf.abbr == driver.abbr) %}
value="{{ driver.name }}">{{ driver.abbr }}</option> {% set user_has_chosen.dnf = "true" %}
<option selected="selected" value="{{ driver.name }}">{{ driver.abbr }}</option>
{% else %}
<option value="{{ driver.name }}">{{ driver.abbr }}</option>
{% endif %}
{% endfor %} {% endfor %}
{% if user_has_chosen.dnf == "false" %}
<option value="" selected="selected" disabled="disabled" hidden="hidden"></option>
{% endif %}
</select> </select>
<label for="dnfselect" class="text-primary">DNF:</label> <label for="dnfselect" class="text-primary">DNF:</label>
</div> </div>
@ -94,7 +114,34 @@
</td> </td>
{% endfor %} {% endfor %}
<td>&nbsp;</td> {# Enter Race Result #}
<td>
<form action="/enterresult/{{ nextrace.id }}" method="post">
{# Driver PXX Select #}
<div class="form-floating">
<select name="pxxselect" class="form-select" aria-label="Select PXX">
<option value="" selected disabled hidden></option>
{% for driver in drivers %}
<option value="{{ driver.name }}">{{ driver.abbr }}</option>
{% endfor %}
</select>
<label for="pxxselect" class="text-primary">P{{ nextrace.pxx }}:</label>
</div>
{# Driver DNF Select #}
<div class="form-floating mt-2">
<select name="dnfselect" class="form-select" aria-label="Select DNF">
<option value="" selected disabled hidden></option>
{% for driver in drivers %}
<option value="{{ driver.name }}">{{ driver.abbr }}</option>
{% endfor %}
</select>
<label for="dnfselect" class="text-primary">DNF:</label>
</div>
<input type="submit" class="btn btn-primary mt-2 w-100" value="Save">
</form>
</td>
</tr> </tr>
{% endif %} {% endif %}