@cloudwerk/ui 0.15.6 → 0.15.17

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -164,7 +164,7 @@ async function initReactRenderer() {
164
164
  return;
165
165
  }
166
166
  try {
167
- const { reactRenderer } = await import("./react-FCDDATY5.js");
167
+ const { reactRenderer } = await import("./react-XOX7IAFN.js");
168
168
  renderers["react"] = reactRenderer;
169
169
  } catch (error) {
170
170
  throw new Error(
package/dist/client.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  createClientComponentWrapper
3
- } from "./chunk-7E6HGQXI.js";
3
+ } from "./chunk-2HWK7DSZ.js";
4
4
  export {
5
5
  createClientComponentWrapper
6
6
  };
package/dist/index.js CHANGED
@@ -10,7 +10,7 @@ import {
10
10
  renderStream,
11
11
  renderToStream,
12
12
  setActiveRenderer
13
- } from "./chunk-7E6HGQXI.js";
13
+ } from "./chunk-2HWK7DSZ.js";
14
14
 
15
15
  // src/hydration.ts
16
16
  import { serializeProps } from "@cloudwerk/core/build";
@@ -1,6 +1,12 @@
1
1
  // src/renderers/react.ts
2
- import { renderToString, renderToReadableStream } from "react-dom/server";
3
2
  import { createElement } from "react";
3
+ var _reactDomServer = null;
4
+ async function getReactDomServer() {
5
+ if (!_reactDomServer) {
6
+ _reactDomServer = await import("react-dom/server");
7
+ }
8
+ return _reactDomServer;
9
+ }
4
10
  var reactRenderer = {
5
11
  /**
6
12
  * Render a React element to an HTML Response.
@@ -12,8 +18,9 @@ var reactRenderer = {
12
18
  * @param options - Render options
13
19
  * @returns Response object with HTML content
14
20
  */
15
- render(element, options = {}) {
21
+ async render(element, options = {}) {
16
22
  const { status = 200, headers = {}, doctype = true } = options;
23
+ const { renderToString } = await getReactDomServer();
17
24
  const htmlString = renderToString(element);
18
25
  const body = doctype ? `<!DOCTYPE html>${htmlString}` : htmlString;
19
26
  return new Response(body, {
@@ -92,6 +99,7 @@ function prependDoctype(stream) {
92
99
  }
93
100
  async function reactRenderToStream(element, options = {}) {
94
101
  const { status = 200, headers = {}, doctype = true } = options;
102
+ const { renderToReadableStream } = await getReactDomServer();
95
103
  const contentStream = await renderToReadableStream(element);
96
104
  const stream = doctype ? prependDoctype(contentStream) : contentStream;
97
105
  return new Response(stream, {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cloudwerk/ui",
3
- "version": "0.15.6",
3
+ "version": "0.15.17",
4
4
  "description": "UI rendering abstraction for Cloudwerk",
5
5
  "repository": {
6
6
  "type": "git",