icns-frontend/components/error-boundary/index.tsx

45 lines
988 B
TypeScript
Raw Permalink Normal View History

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;