summaryrefslogtreecommitdiff
path: root/packages/renderers/renderer-solid/client.js
blob: 9aa0ecbb8016c8dc50f094431d1eab7b0b1dc98c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import { hydrate, createComponent } from 'solid-js/web';

export default (element) => (Component, props, childHTML) => {
  let children;
  if (childHTML != null) {
    children = document.createElement('astro-fragment');
    children.innerHTML = childHTML;
  }

  // Using Solid's `hydrate` method ensures that a `root` is created
  // in order to properly handle reactivity. It also handles
  // components that are not native HTML elements.
  hydrate(() => createComponent(Component, { ...props, children }), element);
};