bpms_site/.svn/pristine/60/600bc3747cae6fc3ff1da9a9a6f7980cb236e530.svn-base
2025-11-02 16:38:49 +03:30

83 lines
3.2 KiB
Plaintext

import { useEffect } from "react";
import { hydrationErrorWarning, hydrationErrorComponentStack } from "./hydration-error-info";
import { isNextRouterError } from "../../../is-next-router-error";
export const RuntimeErrorHandler = {
hadRuntimeError: false
};
function isHydrationError(error) {
return error.message.match(/(hydration|content does not match|did not match)/i) != null;
}
if (typeof window !== "undefined") {
try {
// Increase the number of stack frames on the client
Error.stackTraceLimit = 50;
} catch (e) {}
}
const errorQueue = [];
const rejectionQueue = [];
const errorHandlers = [];
const rejectionHandlers = [];
if (typeof window !== "undefined") {
// These event handlers must be added outside of the hook because there is no
// guarantee that the hook will be alive in a mounted component in time to
// when the errors occur.
window.addEventListener("error", (ev)=>{
if (isNextRouterError(ev.error)) {
ev.preventDefault();
return;
}
const error = ev == null ? void 0 : ev.error;
if (!error || !(error instanceof Error) || typeof error.stack !== "string") {
// A non-error was thrown, we don't have anything to show. :-(
return;
}
if (isHydrationError(error) && !error.message.includes("https://nextjs.org/docs/messages/react-hydration-error")) {
if (hydrationErrorWarning) {
// The patched console.error found hydration errors logged by React
// Append the logged warning to the error message
error.message += "\n\n" + hydrationErrorWarning;
}
if (hydrationErrorComponentStack) {
error._componentStack = hydrationErrorComponentStack;
}
error.message += "\n\nSee more info here: https://nextjs.org/docs/messages/react-hydration-error";
}
const e = error;
errorQueue.push(e);
for (const handler of errorHandlers){
handler(e);
}
});
window.addEventListener("unhandledrejection", (ev)=>{
const reason = ev == null ? void 0 : ev.reason;
if (!reason || !(reason instanceof Error) || typeof reason.stack !== "string") {
// A non-error was thrown, we don't have anything to show. :-(
return;
}
const e = reason;
rejectionQueue.push(e);
for (const handler of rejectionHandlers){
handler(e);
}
});
}
export function useErrorHandler(handleOnUnhandledError, handleOnUnhandledRejection) {
useEffect(()=>{
// Handle queued errors.
errorQueue.forEach(handleOnUnhandledError);
rejectionQueue.forEach(handleOnUnhandledRejection);
// Listen to new errors.
errorHandlers.push(handleOnUnhandledError);
rejectionHandlers.push(handleOnUnhandledRejection);
return ()=>{
// Remove listeners.
errorHandlers.splice(errorHandlers.indexOf(handleOnUnhandledError), 1);
rejectionHandlers.splice(rejectionHandlers.indexOf(handleOnUnhandledRejection), 1);
};
}, [
handleOnUnhandledError,
handleOnUnhandledRejection
]);
}
//# sourceMappingURL=use-error-handler.js.map