UNPKG

next

Version:

The React Framework

35 lines (34 loc) 1.39 kB
import { jsx as _jsx } from "react/jsx-runtime"; import React from 'react'; import { getSocketUrl } from '../../../client/dev/hot-reloader/get-socket-url'; import { HMR_ACTIONS_SENT_TO_BROWSER } from '../../../server/dev/hot-reloader-types'; import DefaultGlobalError from '../../../client/components/builtin/global-error'; import { AppDevOverlayErrorBoundary } from './app-dev-overlay-error-boundary'; // if an error is thrown while rendering an RSC stream, this will catch it in dev // and show the error overlay export function createRootLevelDevOverlayElement(reactEl) { const socketUrl = getSocketUrl(process.env.__NEXT_ASSET_PREFIX || ''); const socket = new window.WebSocket("" + socketUrl + "/_next/webpack-hmr"); // add minimal "hot reload" support for RSC errors const handler = (event)=>{ let obj; try { obj = JSON.parse(event.data); } catch (e) {} if (!obj || !('action' in obj)) { return; } if (obj.action === HMR_ACTIONS_SENT_TO_BROWSER.SERVER_COMPONENT_CHANGES) { window.location.reload(); } }; socket.addEventListener('message', handler); return /*#__PURE__*/ _jsx(AppDevOverlayErrorBoundary, { globalError: [ DefaultGlobalError, null ], children: reactEl }); } //# sourceMappingURL=client-entry.js.map