From 8206cac29ec2ce86e0b0a68360ec714b573e13f6 Mon Sep 17 00:00:00 2001 From: David Gay Date: Fri, 4 Jun 2021 10:21:20 -0400 Subject: Timer progress bar --- app/javascript/controllers/timer_controller.js | 32 +++++++++++--------------- app/models/character.rb | 10 +++++--- app/views/application/_timer.html.erb | 16 +++++++++---- 3 files changed, 33 insertions(+), 25 deletions(-) (limited to 'app') diff --git a/app/javascript/controllers/timer_controller.js b/app/javascript/controllers/timer_controller.js index e85e7ca..b13188a 100644 --- a/app/javascript/controllers/timer_controller.js +++ b/app/javascript/controllers/timer_controller.js @@ -1,47 +1,43 @@ -import { Controller } from "stimulus"; +import {Controller} from "stimulus"; import Rails from "@rails/ujs"; export default class extends Controller { - static targets = [ "timer" ]; + static targets = [ "timer", "progressBar" ]; static values = { - counter: Number, + timeRemaining: Number, + activityDuration: Number, postUrl: String, } connect() { if (!this.timerInterval) this.startUpdating(); - this.timerTarget.textContent = this.counterValue; - this.postFailures = 0; + this.timerTarget.textContent = Math.ceil(this.timeRemainingValue); } startUpdating() { let controller = this; controller.timerInterval = setInterval(() => { - if (controller.postFailures >= 5) { - alert("An error occurred. Please submit a bug report, explaining what you were doing when it occurred."); - clearInterval(controller.timerInterval); - return; - } - if (controller.counterValue > 0) controller.counterValue--; + if (controller.timeRemainingValue > 0) { + controller.timeRemainingValue = controller.timeRemainingValue - 0.01; + } - if (controller.counterValue > 0) { - controller.timerTarget.textContent = controller.counterValue.toString(); + if (controller.timeRemainingValue > 0) { + controller.timerTarget.textContent = Math.ceil(controller.timeRemainingValue).toString(); + controller.progressBarTarget.style.width = `${(1 - (controller.timeRemainingValue / controller.activityDurationValue)) * 100}%`; } else { + clearInterval(controller.timerInterval); + controller.timerInterval = null; Rails.ajax({ type: "POST", url: controller.postUrlValue, success: () => { - clearInterval(controller.timerInterval); - controller.timerInterval = null; - controller.postFailures = 0; }, error: () => { - controller.postFailures++; }, }); } - }, 1000); + }, 10); } } diff --git a/app/models/character.rb b/app/models/character.rb index 1169672..8a72ccd 100644 --- a/app/models/character.rb +++ b/app/models/character.rb @@ -187,12 +187,12 @@ class Character < ApplicationRecord end def activity_time_remaining - time = duration_of_activity - (Time.now - self.activity_started_at) + time = activity_duration - (Time.now - self.activity_started_at) time -= rested_duration_to_spend_on_activity if self.rested_duration > 0 time end - def duration_of_activity + def activity_duration return nil unless self.activity duration_data = self.activity.whatnot[:duration] duration = duration_data[:base] @@ -209,9 +209,13 @@ class Character < ApplicationRecord [duration, duration_data[:minimum] || 10].max end + def percentage_of_activity_completed + (1 - (activity_time_remaining / activity_duration)) * 100 + end + def rested_duration_to_spend_on_activity return nil unless self.activity - [(duration_of_activity / 2).floor, self.rested_duration].min + [(activity_duration / 2).floor, self.rested_duration].min end def can_do_activity?(activity, ignore_cost: false, ignore_requirements: false) diff --git a/app/views/application/_timer.html.erb b/app/views/application/_timer.html.erb index 46b1134..f301ffc 100644 --- a/app/views/application/_timer.html.erb +++ b/app/views/application/_timer.html.erb @@ -1,12 +1,20 @@ <% if current_char.activity %>

<%= current_char.activity.name %>

- + data-timer-time-remaining-value="<%= current_char.activity_time_remaining %>" + data-timer-activity-duration-value="<%= current_char.activity_duration %>" + data-timer-post-url-value="<%= finish_activity_url %>"> +
+ +
+
+
+
+
+ <% most_recent_cs = current_char.character_skills.order(:updated_at).last %>
<%= most_recent_cs.skill.name %> level <%= most_recent_cs.level %>
-- cgit v1.2.3