From fd7a9ed3379a123f02f297b69fa5da0053e84a89 Mon Sep 17 00:00:00 2001 From: Gabriele Angrisani <6270387+Angrigo@users.noreply.github.com> Date: Tue, 30 Apr 2024 14:01:21 +0200 Subject: [PATCH] fix a deprecated method in react integration using SSR: renderToStaticNodeStream (#10893) * deprecated method renderToStaticNodeStream * Create twelve-bulldogs-raise.md --------- Co-authored-by: Bjorn Lu --- .changeset/twelve-bulldogs-raise.md | 5 ++++ packages/integrations/react/server.js | 36 +++------------------------ 2 files changed, 8 insertions(+), 33 deletions(-) create mode 100644 .changeset/twelve-bulldogs-raise.md diff --git a/.changeset/twelve-bulldogs-raise.md b/.changeset/twelve-bulldogs-raise.md new file mode 100644 index 0000000000..d0acf5c094 --- /dev/null +++ b/.changeset/twelve-bulldogs-raise.md @@ -0,0 +1,5 @@ +--- +"@astrojs/react": patch +--- + +Removes using deprecated `ReactDOMServer.renderToStaticNodeStream` API diff --git a/packages/integrations/react/server.js b/packages/integrations/react/server.js index b2e94fbf0b..2ff3f55fb2 100644 --- a/packages/integrations/react/server.js +++ b/packages/integrations/react/server.js @@ -106,18 +106,10 @@ async function renderToStaticMarkup(Component, props, { default: children, ...sl identifierPrefix: prefix, }; let html; - if (metadata?.hydrate) { - if ('renderToReadableStream' in ReactDOM) { - html = await renderToReadableStreamAsync(vnode, renderOptions); - } else { - html = await renderToPipeableStreamAsync(vnode, renderOptions); - } + if ('renderToReadableStream' in ReactDOM) { + html = await renderToReadableStreamAsync(vnode, renderOptions); } else { - if ('renderToReadableStream' in ReactDOM) { - html = await renderToReadableStreamAsync(vnode, renderOptions); - } else { - html = await renderToStaticNodeStreamAsync(vnode, renderOptions); - } + html = await renderToPipeableStreamAsync(vnode, renderOptions); } return { html, attrs }; } @@ -150,28 +142,6 @@ async function renderToPipeableStreamAsync(vnode, options) { }); } -async function renderToStaticNodeStreamAsync(vnode, options) { - const Writable = await getNodeWritable(); - let html = ''; - return new Promise((resolve, reject) => { - let stream = ReactDOM.renderToStaticNodeStream(vnode, options); - stream.on('error', (err) => { - reject(err); - }); - stream.pipe( - new Writable({ - write(chunk, _encoding, callback) { - html += chunk.toString('utf-8'); - callback(); - }, - destroy() { - resolve(html); - }, - }) - ); - }); -} - /** * Use a while loop instead of "for await" due to cloudflare and Vercel Edge issues * See https://github.com/facebook/react/issues/24169