diff --git a/packages/docs/src/components/module-preload/module-preload.tsx b/packages/docs/src/components/module-preload/module-preload.tsx new file mode 100644 index 00000000000..68e2681c761 --- /dev/null +++ b/packages/docs/src/components/module-preload/module-preload.tsx @@ -0,0 +1,58 @@ +import { component$, sync$, useOnWindow } from '@qwik.dev/core'; + +export const ModulePreload = component$(() => { + useOnWindow( + 'load', + sync$(() => { + // for safari support + if (!window.requestIdleCallback) { + window.requestIdleCallback = function ( + callback: IdleRequestCallback, + options?: IdleRequestOptions + ): number { + const opts = options || {}; + const relaxation = 1; + const timeout = opts.timeout || relaxation; + const start = performance.now(); + return setTimeout(function () { + callback({ + get didTimeout() { + return opts.timeout ? false : performance.now() - start - relaxation > timeout; + }, + timeRemaining: function () { + return Math.max(0, relaxation + (performance.now() - start)); + }, + }); + }, relaxation) as unknown as number; + }; + } + + const startPreloading = () => { + const stateScript = document.querySelector('script[type="qwik/state"]'); + if (!stateScript?.textContent) { + return; + } + + const state = JSON.parse(stateScript.textContent); + const qChunks = new Set(); + + JSON.stringify(state).replace(/q-[A-Za-z0-9_]+\.js/g, (match) => { + qChunks.add(match); + return match; + }); + + qChunks.forEach((chunk) => { + const link = document.createElement('link'); + link.rel = 'modulepreload'; + link.as = 'script'; + link.href = 'build/' + chunk; + document.head.appendChild(link); + }); + }; + + requestIdleCallback(startPreloading); + }) + ); + + return <>; +}); diff --git a/packages/docs/src/entry.ssr.tsx b/packages/docs/src/entry.ssr.tsx index ac4c54f5fe7..83c7cb93d75 100644 --- a/packages/docs/src/entry.ssr.tsx +++ b/packages/docs/src/entry.ssr.tsx @@ -14,16 +14,5 @@ export default function (opts: RenderToStreamOptions) { lang: 'en', ...opts.containerAttributes, }, - // Core Web Vitals experiment until November 8: Do not remove! Reach out to @maiieul first if you believe you have a good reason to change this. - prefetchStrategy: { - implementation: { - linkInsert: 'html-append', - linkRel: 'modulepreload', - }, - }, - // Core Web Vitals experiment until November 8: Do not remove! Reach out to @maiieul first if you believe you have a good reason to change this. - qwikPrefetchServiceWorker: { - include: false, - }, }); } diff --git a/packages/docs/src/root.tsx b/packages/docs/src/root.tsx index 26c489b8ee0..d30da4ca382 100644 --- a/packages/docs/src/root.tsx +++ b/packages/docs/src/root.tsx @@ -6,6 +6,7 @@ import { RouterHead } from './components/router-head/router-head'; import { BUILDER_PUBLIC_API_KEY } from './constants'; import { GlobalStore, type SiteStore } from './context'; import './global.css'; +import { ModulePreload } from './components/module-preload/module-preload'; export const uwu = /*javascript*/ ` ;(function () { @@ -76,6 +77,7 @@ export default component$(() => { {/*