"use client"; "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "NotFoundBoundary", { enumerable: true, get: function() { return NotFoundBoundary; } }); const _interop_require_default = require("@swc/helpers/_/_interop_require_default"); const _react = /*#__PURE__*/ _interop_require_default._(require("react")); const _navigation = require("./navigation"); class NotFoundErrorBoundary extends _react.default.Component { static getDerivedStateFromError(error) { if ((error == null ? void 0 : error.digest) === "NEXT_NOT_FOUND") { return { notFoundTriggered: true }; } // Re-throw if error is not for 404 throw error; } static getDerivedStateFromProps(props, state) { /** * Handles reset of the error boundary when a navigation happens. * Ensures the error boundary does not stay enabled when navigating to a new page. * Approach of setState in render is safe as it checks the previous pathname and then overrides * it as outlined in https://react.dev/reference/react/useState#storing-information-from-previous-renders */ if (props.pathname !== state.previousPathname && state.notFoundTriggered) { return { notFoundTriggered: false, previousPathname: props.pathname }; } return { notFoundTriggered: state.notFoundTriggered, previousPathname: props.pathname }; } render() { if (this.state.notFoundTriggered) { return /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement("meta", { name: "robots", content: "noindex" }), process.env.NODE_ENV === "development" && /*#__PURE__*/ _react.default.createElement("meta", { name: "next-error", content: "not-found" }), this.props.notFoundStyles, this.props.notFound); } return this.props.children; } constructor(props){ super(props); this.state = { notFoundTriggered: !!props.asNotFound, previousPathname: props.pathname }; } } function NotFoundBoundary(param) { let { notFound, notFoundStyles, asNotFound, children } = param; const pathname = (0, _navigation.usePathname)(); return notFound ? /*#__PURE__*/ _react.default.createElement(NotFoundErrorBoundary, { pathname: pathname, notFound: notFound, notFoundStyles: notFoundStyles, asNotFound: asNotFound }, children) : /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, children); } if ((typeof exports.default === 'function' || (typeof exports.default === 'object' && exports.default !== null)) && typeof exports.default.__esModule === 'undefined') { Object.defineProperty(exports.default, '__esModule', { value: true }); Object.assign(exports.default, exports); module.exports = exports.default; } //# sourceMappingURL=not-found-boundary.js.map