robosats/frontend/src/components/OrderDetails/LinearDeterminate.tsx

39 lines
950 B
TypeScript
Raw Normal View History

2022-09-09 17:18:04 +00:00
import React, { useState, useEffect } from 'react';
import { Box, LinearProgress } from '@mui/material';
import { calcTimeDelta } from 'react-countdown';
interface Props {
expiresAt: string;
totalSecsExp: number;
}
2022-09-09 17:18:04 +00:00
const LinearDeterminate = ({ expiresAt, totalSecsExp }: Props): JSX.Element => {
const [progress, setProgress] = useState<number>(100);
useEffect(() => {
const timer = setInterval(() => {
const left = calcTimeDelta(new Date(expiresAt)).total / 1000;
const newProgress = (left / totalSecsExp) * 100;
setProgress(newProgress);
}, 1000);
return () => {
clearInterval(timer);
};
}, [expiresAt, totalSecsExp]);
return (
<Box sx={{ width: '100%' }}>
<LinearProgress
sx={{ height: '0.4em' }}
variant='determinate'
value={progress}
color={progress < 20 ? 'secondary' : 'primary'}
/>
</Box>
);
};
export default LinearDeterminate;