one
Version:
One is a new React Framework that makes Vite serve both native and web.
28 lines (27 loc) • 1.03 kB
JavaScript
import ReactDOMServer from "react-dom/server.browser";
const renderToString = async (app, options) => {
const readableStream = await ReactDOMServer.renderToReadableStream(app, {
// Only pass critical scripts to bootstrapModules
// These generate both modulepreload links AND async script tags
bootstrapModules: options.preloads
});
await readableStream.allReady;
let out = await streamToString(readableStream);
if (options.deferredPreloads?.length) {
const modulepreloadLinks = options.deferredPreloads.map(src => `<link rel="modulepreload" fetchPriority="low" href="${src}"/>`).join("");
out = out.replace("</head>", `${modulepreloadLinks}</head>`);
}
return out;
};
async function streamToString(stream) {
const decoder = new TextDecoder("utf-8", {
fatal: !0
});
let result = "";
for await (const chunk of stream) result += decoder.decode(chunk, {
stream: !0
});
return result += decoder.decode(), result;
}
export { renderToString };
//# sourceMappingURL=server-render.mjs.map