2022-07-15 23:02:13 +02:00
|
|
|
/**
|
|
|
|
* This page is loaded by Nextjs:
|
|
|
|
* - on the server, when data-fetching methods throw or reject
|
|
|
|
* - on the client, when `getInitialProps` throws or rejects
|
|
|
|
* - on the client, when a React lifecycle method throws or rejects, and it's
|
|
|
|
* caught by the built-in Nextjs error boundary
|
|
|
|
*
|
|
|
|
* See:
|
|
|
|
* - https://nextjs.org/docs/basic-features/data-fetching/overview
|
|
|
|
* - https://nextjs.org/docs/api-reference/data-fetching/get-initial-props
|
2023-04-04 20:56:03 +02:00
|
|
|
* - https://react.dev/reference/react/Component#catching-rendering-errors-with-an-error-boundary
|
2022-07-15 23:02:13 +02:00
|
|
|
*/
|
2021-05-07 14:52:03 +02:00
|
|
|
|
|
|
|
import * as Sentry from "@sentry/nextjs";
|
2022-07-15 23:02:13 +02:00
|
|
|
import NextErrorComponent from "next/error";
|
2019-11-06 18:32:28 +01:00
|
|
|
|
2022-07-15 23:02:13 +02:00
|
|
|
const CustomErrorComponent = (props) => (
|
|
|
|
<NextErrorComponent statusCode={props.statusCode} />
|
|
|
|
);
|
2020-11-09 19:36:36 +01:00
|
|
|
|
2022-07-15 23:02:13 +02:00
|
|
|
CustomErrorComponent.getInitialProps = async (contextData) => {
|
|
|
|
// In case this is running in a serverless function, await this in order to give Sentry
|
|
|
|
// time to send the error before the lambda exits
|
|
|
|
await Sentry.captureUnderscoreErrorException(contextData);
|
2019-11-06 18:32:28 +01:00
|
|
|
|
2022-07-15 23:02:13 +02:00
|
|
|
// This will contain the status code of the response
|
|
|
|
return NextErrorComponent.getInitialProps(contextData);
|
2019-11-06 18:32:28 +01:00
|
|
|
};
|
|
|
|
|
2022-07-15 23:02:13 +02:00
|
|
|
export default CustomErrorComponent;
|