Display elapsed time for offline participations
This commit is contained in:
		@@ -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")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -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")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -245,8 +245,10 @@ en:
 | 
				
			|||||||
    settings: Settings
 | 
					    settings: Settings
 | 
				
			||||||
    log_out: Log out
 | 
					    log_out: Log out
 | 
				
			||||||
  offlines:
 | 
					  offlines:
 | 
				
			||||||
    end_image_select: Take a photo of your completed puzzle
 | 
					    form:
 | 
				
			||||||
    start_image_select: Take a photo of the puzzle with the provided code written on a paper before starting it
 | 
					      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_message: Let's go!
 | 
				
			||||||
  puzzles:
 | 
					  puzzles:
 | 
				
			||||||
    destroy:
 | 
					    destroy:
 | 
				
			||||||
      notice: Puzzle deleted
 | 
					      notice: Puzzle deleted
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -216,8 +216,10 @@ fr:
 | 
				
			|||||||
    settings: Paramètres
 | 
					    settings: Paramètres
 | 
				
			||||||
    log_out: Déconnexion
 | 
					    log_out: Déconnexion
 | 
				
			||||||
  offlines:
 | 
					  offlines:
 | 
				
			||||||
    end_image_select: Prends une photo du puzzle une fois complété
 | 
					    form:
 | 
				
			||||||
    start_image_select: Prends une photo du puzzle avant de le commencer, avec le code donné par l'organisateur.ice écrit sur du papier
 | 
					      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_message: C'est parti !
 | 
				
			||||||
  puzzles:
 | 
					  puzzles:
 | 
				
			||||||
    destroy:
 | 
					    destroy:
 | 
				
			||||||
      notice: Puzzle supprimé
 | 
					      notice: Puzzle supprimé
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user