78 lines
1.8 KiB
JavaScript
78 lines
1.8 KiB
JavaScript
import * as React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import CircularProgress from '@mui/material/CircularProgress';
|
|
import Typography from '@mui/material/Typography';
|
|
import Box from '@mui/material/Box';
|
|
import Card from "@mui/material/Card";
|
|
|
|
function CircularProgressWithLabel(props) {
|
|
return (
|
|
<Box sx={{ position: 'relative', display: 'inline-flex' }}>
|
|
<CircularProgress variant="determinate" {...props} />
|
|
<Box
|
|
sx={{
|
|
top: 0,
|
|
left: 0,
|
|
bottom: 0,
|
|
right: 0,
|
|
position: 'absolute',
|
|
display: 'flex',
|
|
alignItems: 'center',
|
|
justifyContent: 'center',
|
|
}}
|
|
>
|
|
<Typography variant="caption" component="div" color="text.secondary">
|
|
{`${Math.round(props.value)}%`}
|
|
</Typography>
|
|
</Box>
|
|
</Box>
|
|
);
|
|
}
|
|
|
|
CircularProgressWithLabel.propTypes = {
|
|
/**
|
|
* The value of the progress indicator for the determinate variant.
|
|
* Value between 0 and 100.
|
|
* @default 0
|
|
*/
|
|
value: PropTypes.number.isRequired,
|
|
};
|
|
|
|
export default function CircularStatic() {
|
|
const [progress, setProgress] = React.useState(10);
|
|
|
|
React.useEffect(() => {
|
|
const timer = setInterval(() => {
|
|
setProgress((prevProgress) => (prevProgress >= 100 ? 0 : prevProgress + 10));
|
|
}, 800);
|
|
return () => {
|
|
clearInterval(timer);
|
|
};
|
|
}, []);
|
|
|
|
return (
|
|
<>
|
|
<Card
|
|
sx={{
|
|
boxShadow: "none",
|
|
borderRadius: "10px",
|
|
p: "25px",
|
|
mb: "15px",
|
|
}}
|
|
>
|
|
<Typography
|
|
as="h3"
|
|
sx={{
|
|
fontSize: 18,
|
|
fontWeight: 500,
|
|
mb: '15px'
|
|
}}
|
|
>
|
|
Default
|
|
</Typography>
|
|
|
|
<CircularProgressWithLabel value={progress} />
|
|
</Card>
|
|
</>
|
|
);
|
|
} |