astro/packages/renderers/renderer-solid/server.js
Ryan Carniato f8d1a35ace
Add hydration to Solid renderer (#1479)
* feat: add hydration to Solid renderer

* fix: intersection observer, move script to the end
2021-10-05 12:20:51 -04:00

26 lines
845 B
JavaScript

import { renderToString, ssr, createComponent } from 'solid-js/web/dist/server.js';
function check(Component, props, children) {
if (typeof Component !== 'function') return false;
const { html } = renderToStaticMarkup(Component, props, children);
return typeof html === 'string';
}
function renderToStaticMarkup(Component, props, children) {
const html = renderToString(
() =>
createComponent(Component, {
...props,
// In Solid SSR mode, `ssr` creates the expected structure for `children`.
// In Solid client mode, `ssr` is just a stub.
children: ssr(`<astro-fragment>${children}</astro-fragment>`),
})
);
return { html: html + `<script>window._$HYDRATION||(window._$HYDRATION={events:[],completed:new WeakSet})</script>` };
}
export default {
check,
renderToStaticMarkup,
};