summaryrefslogtreecommitdiff
path: root/packages/renderers/renderer-solid/client.js
blob: b67b3acdb7b955cd3b57729b3351da7615e7e7d5 (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);
};