diff options
author | asketonim <anton.dubik33@gmail.com> | 2020-01-02 20:46:12 +0300 |
---|---|---|
committer | asketonim <anton.dubik33@gmail.com> | 2020-01-02 20:46:12 +0300 |
commit | b2dd58bd08fb5120dd74b8e1484970cc0a68b4d6 (patch) | |
tree | d0eb900c13db1859091c0289b661731b5c7c612e | |
parent | 48e8c85e742c476205f55e44a5f4111bcde44770 (diff) | |
download | chrono-cube-ui-b2dd58bd08fb5120dd74b8e1484970cc0a68b4d6.tar.gz |
Simplify state and fix event handlers
-rw-r--r-- | src/components/Timer/Timer.js | 77 |
1 files changed, 37 insertions, 40 deletions
diff --git a/src/components/Timer/Timer.js b/src/components/Timer/Timer.js index d0f8ff1..e095902 100644 --- a/src/components/Timer/Timer.js +++ b/src/components/Timer/Timer.js @@ -2,60 +2,57 @@ import React, { useState, useEffect } from 'react'; import styled from 'styled-components'; -const Timer = () => { - const [minute, setMinute] = useState(0); - const [second, setSecond] = useState(0); - const [mill, setMill] = useState(0); +const Timer = () => { + const SPACE = 32 const [time, setTime] = useState("00:00:00") - const [stopwatchStart, setStopwatchStart] = useState(false); - const [stopwatchTime, setStopwatchTime] = useState(0); + const [stopwatchStarted, setStopwatchStarted] = useState(false); + const [timer, setTimer] = useState(0); + let startingTime; + - const handleKeyDown = event => { - if (event.keyCode === 32){ + const handleKeyPress = event => { + if (event.keyCode === SPACE){ + if (!stopwatchStarted) { + startingTime = Date.now(); + setStopwatchStarted(true); + setTimer(setInterval(() => setTime(() => { + const timeGap = Math.floor((Date.now() - startingTime) / 10); + let resultTime = ""; - if (!stopwatchStart) { - setStopwatchTime(Date.now()); - setStopwatchStart(true); - } + const minute = Math.floor(timeGap / 6000); + if (minute < 10) resultTime += '0'; + resultTime += minute + ':'; - const timeGap = Date.now() - stopwatchTime; - setMill(Math.floor((timeGap % 1000) / 10)); - setSecond(Math.floor(timeGap / 1000)); - setMinute(Math.floor(timeGap / 60000)); - setTime(() => { - let resultTime = ""; - if (minute < 10) resultTime += '0'; - resultTime += minute + ':'; - if (second < 10) resultTime += '0'; - resultTime += second + ':'; - if (mill < 10) resultTime += '0'; - resultTime += mill; - return resultTime; - }); - } - } + let second = Math.floor(timeGap / 100); + if (second < 10) resultTime += '0'; + if (second > 59) second %= 60 + resultTime += second + ':'; - const handleKeyUp = event => { - if (event.keyCode === 32) { - setTime("00:00:00"); - setMill(0); - setSecond(0); - setMinute(0); - setStopwatchStart(false); - setStopwatchTime(0); + const mill = timeGap % 100; + if (mill < 10) resultTime += '0'; + resultTime += mill; + + return resultTime; + }), 10)) + } else { + clearInterval(timer) + setStopwatchStarted(false); + startingTime = 0; + return false; + } } } + useEffect(() => { - window.addEventListener("keydown", handleKeyDown); - window.addEventListener("keyup", handleKeyUp); + window.addEventListener("keypress", handleKeyPress); return () => { - window.removeEventListener("keydown", handleKeyDown); - window.removeEventListener("keyup", handleKeyUp); + window.removeEventListener("keypress", handleKeyPress); }; }) + return ( <Root> <span>{time}</ span> |