next
Version:
The React Framework
85 lines (84 loc) • 3.64 kB
JavaScript
// TODO: Remove use of `any` type.
import "./webpack";
import { initialize, hydrate, version, router, emitter } from "./";
import initOnDemandEntries from "./dev/on-demand-entries-client";
import initWebpackHMR from "./dev/webpack-hot-middleware-client";
import initializeBuildWatcher from "./dev/dev-build-watcher";
import { displayContent } from "./dev/fouc";
import { connectHMR, addMessageListener } from "./dev/error-overlay/websocket";
import { assign, urlQueryToSearchParams } from "../shared/lib/router/utils/querystring";
import "./setup-hydration-warning";
window.next = {
version,
// router is initialized later so it has to be live-binded
get router () {
return router;
},
emitter
};
const webpackHMR = initWebpackHMR();
initialize({
webpackHMR
}).then((param)=>{
let { assetPrefix } = param;
connectHMR({
assetPrefix,
path: "/_next/webpack-hmr"
});
return hydrate({
beforeRender: displayContent
}).then(()=>{
initOnDemandEntries();
let buildIndicatorHandler = ()=>{};
function devPagesHmrListener(event) {
let payload;
try {
payload = JSON.parse(event.data);
} catch (e) {}
if (payload.event === "server-error" && payload.errorJSON) {
const { stack , message } = JSON.parse(payload.errorJSON);
const error = new Error(message);
error.stack = stack;
throw error;
} else if (payload.action === "reloadPage") {
window.location.reload();
} else if (payload.action === "devPagesManifestUpdate") {
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);
});
} else if (payload.event === "middlewareChanges") {
return window.location.reload();
} else if (payload.event === "serverOnlyChanges") {
const { pages } = payload;
// Make sure to reload when the dev-overlay is showing for an
// API route
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");
buildIndicatorHandler("building");
const clearIndicator = ()=>buildIndicatorHandler("built");
router.replace(router.pathname + "?" + String(assign(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);
}
}
}
addMessageListener(devPagesHmrListener);
if (process.env.__NEXT_BUILD_INDICATOR) {
initializeBuildWatcher((handler)=>{
buildIndicatorHandler = handler;
}, process.env.__NEXT_BUILD_INDICATOR_POSITION);
}
});
}).catch((err)=>{
console.error("Error was not caught", err);
});
//# sourceMappingURL=next-dev.js.map