41 lines
1.1 KiB
JavaScript
41 lines
1.1 KiB
JavaScript
import { Component } from "react"
|
|
import Page500 from "./500Page"
|
|
|
|
class ErrorBoundary extends Component {
|
|
constructor(props) {
|
|
super(props)
|
|
// Define a state variable to track whether is an error or not
|
|
this.state = { hasError: false }
|
|
}
|
|
static getDerivedStateFromError(error) {
|
|
// Update state so the next render will show the fallback UI
|
|
return { hasError: true }
|
|
}
|
|
componentDidCatch(error, errorInfo) {
|
|
// You can use your own error logging service here
|
|
console.log({ error, errorInfo })
|
|
}
|
|
render() {
|
|
// Check if the error is thrown
|
|
if (this.state.hasError) {
|
|
// You can render any custom fallback UI
|
|
return (
|
|
<div>
|
|
<Page500 />
|
|
<h2>Oops, there is an error!</h2>
|
|
<button
|
|
type="button"
|
|
onClick={() => this.setState({ hasError: false })}
|
|
>
|
|
Try again?
|
|
</button>
|
|
</div>
|
|
)
|
|
}
|
|
// Return children components in case of no error
|
|
return this.props.children
|
|
}
|
|
}
|
|
|
|
export default ErrorBoundary
|
|
|