import { Controller } from "stimulus"; import Rails from "@rails/ujs"; export default class extends Controller { static targets = [ "timer" ]; static values = { counter: Number, postUrl: String, } connect() { if (!this.timerInterval) this.startUpdating(); this.timerTarget.textContent = this.counterValue; this.postFailures = 0; } 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.counterValue > 0) { controller.timerTarget.textContent = controller.counterValue.toString(); } else { Rails.ajax({ type: "POST", url: controller.postUrlValue, success: () => { clearInterval(controller.timerInterval); controller.timerInterval = null; controller.postFailures = 0; }, error: () => { controller.postFailures++; }, }); } }, 1000); } }