2021-12-28 14:22:50 -08:00
|
|
|
import React from 'react'
|
|
|
|
|
|
|
|
class ErrorBoundary extends React.Component<
|
|
|
|
any,
|
|
|
|
{ hasError: boolean; error: any }
|
|
|
|
> {
|
|
|
|
constructor(props) {
|
|
|
|
super(props)
|
|
|
|
this.state = { hasError: false, error: null }
|
|
|
|
}
|
|
|
|
|
|
|
|
static getDerivedStateFromError(error) {
|
|
|
|
// Update state so the next render will show the fallback UI.
|
|
|
|
return { hasError: true, error: error }
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidCatch(error, errorInfo) {
|
|
|
|
// You can also log the error to an error reporting service
|
|
|
|
// logErrorToMyService(error, errorInfo)
|
|
|
|
|
|
|
|
if (process.env.NEXT_ERROR_WEBHOOK_URL) {
|
|
|
|
try {
|
|
|
|
fetch(process.env.NEXT_ERROR_WEBHOOK_URL, {
|
|
|
|
method: 'POST',
|
|
|
|
headers: { 'Content-Type': 'application/json' },
|
|
|
|
body: JSON.stringify({
|
2021-12-28 22:39:32 -08:00
|
|
|
content: `UI ERROR: ${error} : ${errorInfo?.componentStack}`.slice(
|
|
|
|
0,
|
|
|
|
1999
|
|
|
|
),
|
2021-12-28 14:22:50 -08:00
|
|
|
}),
|
|
|
|
})
|
|
|
|
} catch (err) {
|
|
|
|
console.error('Error posting to notify webhook:', err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
if (this.state.hasError) {
|
|
|
|
// You can render any custom fallback UI
|
|
|
|
return (
|
2021-12-28 22:39:32 -08:00
|
|
|
<div className="text-th-fgd-2 text-center pt-1">
|
2021-12-28 14:22:50 -08:00
|
|
|
<div>Something went wrong.</div>
|
|
|
|
<div className="text-th-red">{this.state.error.message}</div>
|
|
|
|
<button className="mt-2" onClick={() => location.reload()}>
|
|
|
|
Refresh and try again
|
|
|
|
</button>
|
2021-12-28 22:39:32 -08:00
|
|
|
<div className="mt-4 px-8 mx-8">{this.state.error.stack}</div>
|
2021-12-28 14:22:50 -08:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.props.children
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ErrorBoundary
|