stacker.news/components/error-boundary.js

42 lines
1.1 KiB
JavaScript
Raw Normal View History

2023-05-06 21:51:17 +00:00
import { Component } from 'react'
import { StaticLayout } from './layout'
2023-02-08 21:56:43 +00:00
import styles from '../styles/404.module.css'
2023-05-06 21:51:17 +00:00
class ErrorBoundary extends Component {
2023-02-08 21:56:43 +00:00
constructor (props) {
super(props)
// Define a state variable to track whether is an error or not
this.state = { hasError: false }
}
static getDerivedStateFromError () {
// 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 (
<StaticLayout>
<Image width='500' height='375' src={`${process.env.NEXT_PUBLIC_ASSET_PREFIX}/floating.gif`} fluid />
2023-02-08 21:56:43 +00:00
<h1 className={styles.fourZeroFour} style={{ fontSize: '48px' }}>something went wrong</h1>
</StaticLayout>
2023-02-08 21:56:43 +00:00
)
}
// Return children components in case of no error
return this.props.children
}
}
export default ErrorBoundary