Skip to content

Commit

Permalink
Fix: React - Use "createRoot" instead of "hydrateRoot" for `client:on…
Browse files Browse the repository at this point in the history
…ly` (#3337)

* feat: pass "client" directive to clientEntrypoints

* refactor: remove hydration warning suppression react 17

* feat: remove hydration warning suppression react 18

* chore: changeset

* fix: change metadata to options bag
  • Loading branch information
bholmesdev committed May 12, 2022
1 parent 13e697f commit 678c2b7
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 22 deletions.
6 changes: 6 additions & 0 deletions .changeset/small-maps-cough.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
'astro': patch
'@astrojs/react': patch
---

Fix: remove hydration failures on React v18 by exposing the "client" directive from Astro core.
8 changes: 4 additions & 4 deletions packages/astro/src/runtime/server/hydration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -110,15 +110,15 @@ export async function generateHydrateScript(
);
}

let hydrationSource = ``;

hydrationSource += renderer.clientEntrypoint
const hydrationSource = renderer.clientEntrypoint
? `const [{ ${
componentExport.value
}: Component }, { default: hydrate }] = await Promise.all([import("${await result.resolve(
componentUrl
)}"), import("${await result.resolve(renderer.clientEntrypoint)}")]);
return (el, children) => hydrate(el)(Component, ${serializeProps(props)}, children);
return (el, children) => hydrate(el)(Component, ${serializeProps(
props
)}, children, ${JSON.stringify({ client: hydrate })});
`
: `await import("${await result.resolve(componentUrl)}");
return () => {};
Expand Down
21 changes: 12 additions & 9 deletions packages/integrations/react/client-v17.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,18 @@
import { createElement } from 'react';
import { hydrate } from 'react-dom';
import { render, hydrate } from 'react-dom';
import StaticHtml from './static-html.js';

export default (element) => (Component, props, children) =>
hydrate(
createElement(
export default (element) => (Component, props, children, { client }) =>
{
const componentEl = createElement(
Component,
{ ...props, suppressHydrationWarning: true },
props,
children != null
? createElement(StaticHtml, { value: children, suppressHydrationWarning: true })
? createElement(StaticHtml, { value: children })
: children
),
element
);
);
if (client === 'only') {
return render(componentEl, element);
}
return hydrate(componentEl, element);
};
21 changes: 12 additions & 9 deletions packages/integrations/react/client.js
Original file line number Diff line number Diff line change
@@ -1,15 +1,18 @@
import { createElement } from 'react';
import { hydrateRoot } from 'react-dom/client';
import { createRoot, hydrateRoot } from 'react-dom/client';
import StaticHtml from './static-html.js';

export default (element) => (Component, props, children) =>
hydrateRoot(
element,
createElement(
export default (element) => (Component, props, children, { client }) =>
{
const componentEl = createElement(
Component,
{ ...props, suppressHydrationWarning: true },
props,
children != null
? createElement(StaticHtml, { value: children, suppressHydrationWarning: true })
? createElement(StaticHtml, { value: children })
: children
)
);
);
if (client === 'only') {
return createRoot(element).render(componentEl);
}
return hydrateRoot(element, componentEl);
};

0 comments on commit 678c2b7

Please sign in to comment.