From 0c2313e1f08fcdf6f832c60b168ceaadc4636b47 Mon Sep 17 00:00:00 2001 From: Abanoub Ghadban Date: Sat, 24 Aug 2024 20:07:57 +0300 Subject: [PATCH] make render function returns Readable stream instead of PassThrough --- node_package/src/ReactOnRails.ts | 4 ++-- node_package/src/serverRenderReactComponent.ts | 13 +++++++------ node_package/src/types/index.ts | 4 ++-- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/node_package/src/ReactOnRails.ts b/node_package/src/ReactOnRails.ts index ffd1851d6..29f4dff4d 100644 --- a/node_package/src/ReactOnRails.ts +++ b/node_package/src/ReactOnRails.ts @@ -1,5 +1,5 @@ import type { ReactElement } from 'react'; -import type { PassThrough } from 'stream'; +import type { Readable } from 'stream'; import * as ClientStartup from './clientStartup'; import handleError from './handleError'; @@ -250,7 +250,7 @@ ctx.ReactOnRails = { * Used by server rendering by Rails * @param options */ - streamServerRenderedReactComponent(options: RenderParams): PassThrough { + streamServerRenderedReactComponent(options: RenderParams): Readable { return streamServerRenderedReactComponent(options); }, diff --git a/node_package/src/serverRenderReactComponent.ts b/node_package/src/serverRenderReactComponent.ts index c57703a5e..46e2f064e 100644 --- a/node_package/src/serverRenderReactComponent.ts +++ b/node_package/src/serverRenderReactComponent.ts @@ -1,5 +1,5 @@ import ReactDOMServer from 'react-dom/server'; -import { PassThrough } from 'stream'; +import { PassThrough, Readable } from 'stream'; import type { ReactElement } from 'react'; import ComponentRegistry from './ComponentRegistry'; @@ -185,17 +185,17 @@ const serverRenderReactComponent: typeof serverRenderReactComponentInternal = (o return result; }; -const stringToStream = (str: string) => { +const stringToStream = (str: string): Readable => { const stream = new PassThrough(); stream.push(str); stream.push(null); return stream; }; -export const streamServerRenderedReactComponent = (options: RenderParams) => { +export const streamServerRenderedReactComponent = (options: RenderParams): Readable => { const { name, domNodeId, trace, props, railsContext, throwJsErrors } = options; - let renderResult: null | PassThrough = null; + let renderResult: null | Readable = null; try { const componentObj = ComponentRegistry.get(name); @@ -217,8 +217,9 @@ See https://github.com/shakacode/react_on_rails#renderer-functions`); throw new Error('Server rendering of streams is not supported for server render hashes or promises.'); } - renderResult = new PassThrough(); - ReactDOMServer.renderToPipeableStream(reactRenderingResult).pipe(renderResult); + const renderStream = new PassThrough(); + ReactDOMServer.renderToPipeableStream(reactRenderingResult).pipe(renderStream); + renderResult = renderStream; // TODO: Add console replay script to the stream // Ensure to avoid console messages leaking between different components rendering diff --git a/node_package/src/types/index.ts b/node_package/src/types/index.ts index b73efacc1..b9d7f7d3c 100644 --- a/node_package/src/types/index.ts +++ b/node_package/src/types/index.ts @@ -1,5 +1,5 @@ import type { ReactElement, ReactNode, Component, ComponentType } from 'react'; -import type { PassThrough } from 'stream'; +import type { Readable } from 'stream'; // Don't import redux just for the type definitions // See https://github.com/shakacode/react_on_rails/issues/1321 @@ -139,7 +139,7 @@ export interface ReactOnRails { ): RenderReturnType; getComponent(name: string): RegisteredComponent; serverRenderReactComponent(options: RenderParams): null | string | Promise; - streamServerRenderedReactComponent(options: RenderParams): PassThrough; + streamServerRenderedReactComponent(options: RenderParams): Readable; handleError(options: ErrorOptions): string | undefined; buildConsoleReplay(): string; registeredComponents(): Map;