UNPKG

next

Version:

The React Framework

129 lines (127 loc) 6.79 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "pageBootstrap", { enumerable: true, get: function() { return pageBootstrap; } }); const _interop_require_default = require("@swc/helpers/_/_interop_require_default"); require("../lib/require-instrumentation-client"); const _ = require("./"); const _ondemandentriesclient = /*#__PURE__*/ _interop_require_default._(require("./dev/on-demand-entries-client")); const _devbuildindicator = require("./dev/dev-build-indicator/internal/dev-build-indicator"); const _fouc = require("./dev/fouc"); const _websocket = require("./components/react-dev-overlay/pages/websocket"); const _querystring = require("../shared/lib/router/utils/querystring"); const _hotreloadertypes = require("../server/dev/hot-reloader-types"); const _runtimeerrorhandler = require("./components/errors/runtime-error-handler"); const _shared = require("./components/react-dev-overlay/shared"); const _hotreloaderclient = require("./components/react-dev-overlay/pages/hot-reloader-client"); const _initializeforpagerouter = require("./dev/dev-build-indicator/initialize-for-page-router"); function pageBootstrap(assetPrefix) { (0, _websocket.connectHMR)({ assetPrefix, path: '/_next/webpack-hmr' }); return (0, _.hydrate)({ beforeRender: _fouc.displayContent }).then(()=>{ (0, _ondemandentriesclient.default)(); (0, _initializeforpagerouter.initializeDevBuildIndicatorForPageRouter)(); let reloading = false; (0, _websocket.addMessageListener)((payload)=>{ if (reloading) return; if ('action' in payload) { switch(payload.action){ case _hotreloadertypes.HMR_ACTIONS_SENT_TO_BROWSER.SERVER_ERROR: { const { stack, message } = JSON.parse(payload.errorJSON); const error = Object.defineProperty(new Error(message), "__NEXT_ERROR_CODE", { value: "E394", enumerable: false, configurable: true }); error.stack = stack; throw error; } case _hotreloadertypes.HMR_ACTIONS_SENT_TO_BROWSER.RELOAD_PAGE: { reloading = true; window.location.reload(); break; } case _hotreloadertypes.HMR_ACTIONS_SENT_TO_BROWSER.DEV_PAGES_MANIFEST_UPDATE: { fetch("" + assetPrefix + "/_next/static/development/_devPagesManifest.json").then((res)=>res.json()).then((manifest)=>{ window.__DEV_PAGES_MANIFEST = manifest; }).catch((err)=>{ console.log("Failed to fetch devPagesManifest", err); }); break; } default: break; } } else if ('event' in payload) { switch(payload.event){ case _hotreloadertypes.HMR_ACTIONS_SENT_TO_BROWSER.MIDDLEWARE_CHANGES: { return window.location.reload(); } case _hotreloadertypes.HMR_ACTIONS_SENT_TO_BROWSER.CLIENT_CHANGES: { // This is used in `../server/dev/turbopack-utils.ts`. const isOnErrorPage = window.next.router.pathname === '/_error'; // On the error page we want to reload the page when a page was changed if (isOnErrorPage) { if (_runtimeerrorhandler.RuntimeErrorHandler.hadRuntimeError) { console.warn(_shared.REACT_REFRESH_FULL_RELOAD_FROM_ERROR); } reloading = true; (0, _hotreloaderclient.performFullReload)(null); } break; } case _hotreloadertypes.HMR_ACTIONS_SENT_TO_BROWSER.SERVER_ONLY_CHANGES: { if (_runtimeerrorhandler.RuntimeErrorHandler.hadRuntimeError) { console.warn(_shared.REACT_REFRESH_FULL_RELOAD_FROM_ERROR); (0, _hotreloaderclient.performFullReload)(null); } const { pages } = payload; // Make sure to reload when the dev-overlay is showing for an // API route // TODO: Fix `__NEXT_PAGE` type if (pages.includes(_.router.query.__NEXT_PAGE)) { return window.location.reload(); } if (!_.router.clc && pages.includes(_.router.pathname)) { console.log('Refreshing page data due to server-side change'); _devbuildindicator.devBuildIndicator.show(); const clearIndicator = ()=>_devbuildindicator.devBuildIndicator.hide(); _.router.replace(_.router.pathname + '?' + String((0, _querystring.assign)((0, _querystring.urlQueryToSearchParams)(_.router.query), new URLSearchParams(location.search))), _.router.asPath, { scroll: false }).catch(()=>{ // trigger hard reload when failing to refresh data // to show error overlay properly location.reload(); }).finally(clearIndicator); } break; } default: break; } } }); }); } 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=page-bootstrap.js.map