astro/packages/integrations/react/client.js

19 lines
502 B
JavaScript
Raw Normal View History

import { createElement } from 'react';
import { createRoot, hydrateRoot } from 'react-dom/client';
import StaticHtml from './static-html.js';
export default (element) => (Component, props, children, { client }) =>
{
const componentEl = createElement(
Component,
props,
2022-04-02 20:15:41 +00:00
children != null
? createElement(StaticHtml, { value: children })
2022-04-02 20:15:41 +00:00
: children
);
if (client === 'only') {
return createRoot(element).render(componentEl);
}
return hydrateRoot(element, componentEl);
};