2022-12-17 11:42:56 +00:00
|
|
|
import { captureException } from "@sentry/nextjs";
|
2022-12-14 15:39:51 +00:00
|
|
|
import Link from "next/link";
|
2022-12-17 11:42:56 +00:00
|
|
|
import { Component, ErrorInfo, ReactNode } from "react";
|
2022-12-14 15:39:51 +00:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
children?: ReactNode;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface State {
|
|
|
|
hasError: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
class ErrorBoundary extends Component<Props, State> {
|
|
|
|
public state: State = {
|
|
|
|
hasError: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
public static getDerivedStateFromError(): State {
|
|
|
|
// Update state so the next render will show the fallback UI.
|
|
|
|
return { hasError: true };
|
|
|
|
}
|
|
|
|
|
|
|
|
public componentDidCatch(error: Error, errorInfo: ErrorInfo) {
|
|
|
|
console.error("Uncaught error:", error, errorInfo);
|
2022-12-17 11:42:56 +00:00
|
|
|
|
2022-12-23 13:30:35 +00:00
|
|
|
const errorMessage = error.message || error;
|
|
|
|
captureException(errorMessage);
|
2022-12-14 15:39:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public render() {
|
|
|
|
if (this.state.hasError) {
|
|
|
|
return (
|
|
|
|
<h1>
|
|
|
|
Oops.. there is something wrong.
|
|
|
|
<br /> Please try again. <Link href="/">Go to home</Link>
|
|
|
|
</h1>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.props.children;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ErrorBoundary;
|