Spaces:
Sleeping
Sleeping
File size: 1,440 Bytes
3299552 |
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 |
import React from 'react';
import { Box, Typography, Button } from '@mui/material';
import ErrorIcon from '@mui/icons-material/Error';
class ErrorBoundary extends React.Component {
constructor(props) {
super(props);
this.state = { hasError: false, error: null };
}
static getDerivedStateFromError(error) {
return { hasError: true, error };
}
componentDidCatch(error, errorInfo) {
console.error('ErrorBoundary caught an error:', error, errorInfo);
}
render() {
if (this.state.hasError) {
return (
<Box
sx={{
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
justifyContent: 'center',
padding: 4,
minHeight: '100vh',
textAlign: 'center',
}}
>
<ErrorIcon color="error" sx={{ fontSize: 60, mb: 2 }} />
<Typography variant="h4" gutterBottom>
Something went wrong
</Typography>
<Typography variant="body1" color="textSecondary" sx={{ mb: 3 }}>
{this.state.error && this.state.error.toString()}
</Typography>
<Button
variant="contained"
color="primary"
onClick={() => window.location.reload()}
>
Reload page
</Button>
</Box>
);
}
return this.props.children;
}
}
export default ErrorBoundary; |