Display elapsed time for offline participations
All checks were successful
CI / scan_ruby (push) Successful in 21s
CI / scan_js (push) Successful in 15s
CI / lint (push) Successful in 14s
CI / test (push) Successful in 39s

This commit is contained in:
sto
2025-11-03 11:03:46 +01:00
parent ff5f387a87
commit aeb6989223
4 changed files with 25 additions and 7 deletions

View File

@@ -1,9 +1,23 @@
= form_with model: @offline, url: "/public/#{@contest.friendly_id}/offline/#{@offline.generate_token_for(:token)}" do |form| = form_with model: @offline, url: "/public/#{@contest.friendly_id}/offline/#{@offline.generate_token_for(:token)}" do |form|
= form.hidden_field :completed = form.hidden_field :completed
.row.mb-3 h3 = t("offlines.form.start_message")
h1 id="display-time" style="font-size: 80px;"
javascript:
const startTime = #{@offline.start_time.to_i};
function updateTime() {
const displayTimeEl = document.getElementById('display-time');
const s = Math.floor((Date.now() - 1000 * startTime) / 1000);
let ss = s % 60;
let mm = Math.floor(s / 60) % 60;
let hh = Math.floor(s / 3600);
displayTimeEl.innerHTML = `${hh < 10 ? `0${hh}` : hh}:${mm < 10 ? `0${mm}` : mm}:${ss < 10 ? `0${ss}` : ss}`;
setTimeout(updateTime, 1000);
}
setTimeout(updateTime, 5);
.row.mt-5.mb-3
.col .col
.form-text.mb-1 .form-text.mb-1
= t("offlines.end_image_select") = t("offlines.form.end_image_select")
= form.file_field :end_image, accept: "image/*", class: "form-control" = form.file_field :end_image, accept: "image/*", class: "form-control"
.form-text.error-message style="display: none;" id="image-error-message" .form-text.error-message style="display: none;" id="image-error-message"
= t("puzzles.form.file_too_big") = t("puzzles.form.file_too_big")

View File

@@ -7,7 +7,7 @@
.row.mb-3 .row.mb-3
.col .col
.form-text.mb-1 .form-text.mb-1
= t("offlines.start_image_select") = t("offlines.form.start_image_select")
= form.file_field :images, accept: "image/*", class: "form-control" = form.file_field :images, accept: "image/*", class: "form-control"
.form-text.error-message style="display: none;" id="image-error-message" .form-text.error-message style="display: none;" id="image-error-message"
= t("puzzles.form.file_too_big") = t("puzzles.form.file_too_big")

View File

@@ -245,8 +245,10 @@ en:
settings: Settings settings: Settings
log_out: Log out log_out: Log out
offlines: offlines:
form:
end_image_select: Take a photo of your completed puzzle end_image_select: Take a photo of your completed puzzle
start_image_select: Take a photo of the puzzle with the provided code written on a paper before starting it start_image_select: Take a photo of the puzzle with the provided code written on a paper before starting it
start_message: Let's go!
puzzles: puzzles:
destroy: destroy:
notice: Puzzle deleted notice: Puzzle deleted

View File

@@ -216,8 +216,10 @@ fr:
settings: Paramètres settings: Paramètres
log_out: Déconnexion log_out: Déconnexion
offlines: offlines:
form:
end_image_select: Prends une photo du puzzle une fois complété end_image_select: Prends une photo du puzzle une fois complété
start_image_select: Prends une photo du puzzle avant de le commencer, avec le code donné par l'organisateur.ice écrit sur du papier start_image_select: Prends une photo du puzzle avant de le commencer, avec le code donné par l'organisateur.ice écrit sur du papier
start_message: C'est parti !
puzzles: puzzles:
destroy: destroy:
notice: Puzzle supprimé notice: Puzzle supprimé