Added animation to timer component

This commit is contained in:
Mitchell McCaffrey 2020-08-05 10:49:20 +10:00
parent 3fbfd13e27
commit 0c1ec22234

View File

@ -12,7 +12,6 @@ function getTimerDuration(t) {
}
function Timer({ timer }) {
const [progress, setProgress] = useState(0);
const [maxDuration, setMaxDuration] = useState(0);
const previousTimerRef = useRef(timer);
@ -24,9 +23,27 @@ function Timer({ timer }) {
});
useEffect(() => {
setProgress(getTimerDuration(timer));
progressBarRef.current.value = getTimerDuration(timer);
}, [timer]);
const progressBarRef = useRef();
useEffect(() => {
let request = requestAnimationFrame(animate);
let previousTime = performance.now();
function animate(time) {
request = requestAnimationFrame(animate);
const deltaTime = time - previousTime;
previousTime = time;
progressBarRef.current.value -= deltaTime;
}
return () => {
cancelAnimationFrame(request);
};
}, [maxDuration]);
const timerContainer = usePortal("root");
return ReactDOM.createPortal(
@ -51,9 +68,9 @@ function Timer({ timer }) {
>
<Progress
max={maxDuration}
value={progress}
m={2}
sx={{ width: "100%" }}
ref={progressBarRef}
/>
</Box>,
timerContainer