import _async_to_generator from "@swc/helpers/src/_async_to_generator.mjs"; import Router from 'next/router'; import { addMessageListener, sendMessage } from './error-overlay/websocket'; export default _async_to_generator(function*(page) { if (page) { // in AMP the router isn't initialized on the client and // client-transitions don't occur so ping initial page setInterval(()=>{ sendMessage(JSON.stringify({ event: 'ping', page })); }, 2500); } else { Router.ready(()=>{ setInterval(()=>{ // when notFound: true is returned we should use the notFoundPage // as the Router.pathname will point to the 404 page but we want // to ping the source page that returned notFound: true instead const notFoundSrcPage = self.__NEXT_DATA__.notFoundSrcPage; const pathname = (Router.pathname === '/404' || Router.pathname === '/_error') && notFoundSrcPage ? notFoundSrcPage : Router.pathname; sendMessage(JSON.stringify({ event: 'ping', page: pathname })); }, 2500); }); } addMessageListener((event)=>{ if (event.data.indexOf('{') === -1) return; try { const payload = JSON.parse(event.data); // don't attempt fetching the page if we're already showing // the dev overlay as this can cause the error to be triggered // repeatedly if (payload.event === 'pong' && payload.invalid && !self.__NEXT_DATA__.err) { // Payload can be invalid even if the page does exist. // So, we check if it can be created. fetch(location.href, { credentials: 'same-origin' }).then((pageRes)=>{ if (pageRes.status === 200) { // Page exists now, reload location.reload(); } else { // Page doesn't exist if (self.__NEXT_DATA__.page === Router.pathname && Router.pathname !== '/_error') { // We are still on the page, // reload to show 404 error page location.reload(); } } }); } } catch (err) { console.error('on-demand-entries failed to parse response', err); } }); }); //# sourceMappingURL=on-demand-entries-client.js.map