File size: 1,680 Bytes
cbe4551 ee1b5be cbe4551 b784ba3 cbe4551 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
// script.js
document.addEventListener('DOMContentLoaded', () => {
const clickButton = document.getElementById('clickButton');
const cpsDisplay = document.getElementById('cpsDisplay');
const timerElement = document.getElementById('timer');
let clickCount = 0;
let intervalId;
let testDuration = 15; // Duration in seconds
function startTest() {
clickCount = 0;
cpsDisplay.textContent = 'CPS: 0.00';
timerElement.textContent = testDuration;
clickButton.classList.add('white');
clickButton.textContent = clickCount;
intervalId = setInterval(updateTimer, 1000);
clickButton.removeEventListener('click', startTest);
clickButton.addEventListener('click', recordClick);
}
function updateTimer() {
testDuration--;
timerElement.textContent = testDuration;
if (testDuration <= 0) {
clearInterval(intervalId);
clickButton.classList.remove('white');
clickButton.textContent = 'Done';
clickButton.removeEventListener('click', recordClick);
displayFinalCPS();
}
}
function recordClick() {
clickCount++;
clickButton.textContent = clickCount; // Update button with the new click count
updateCPS();
}
function updateCPS() {
const cps = clickCount / (15 - testDuration);
cpsDisplay.textContent = `CPS: ${cps.toFixed(2)}`;
}
function displayFinalCPS() {
const finalCPS = clickCount / 15;
cpsDisplay.textContent = `Final CPS: ${finalCPS.toFixed(2)}`;
}
clickButton.addEventListener('click', startTest);
});
|