2022-03-18 15:35:45 -07:00
|
|
|
import { renderToString, ssr, createComponent } from 'solid-js/web';
|
|
|
|
|
2022-06-23 10:10:54 -05:00
|
|
|
const slotName = str => str.trim().replace(/[-_]([a-z])/g, (_, w) => w.toUpperCase());
|
|
|
|
|
2022-03-18 15:35:45 -07:00
|
|
|
function check(Component, props, children) {
|
|
|
|
if (typeof Component !== 'function') return false;
|
2022-05-11 12:23:34 -04:00
|
|
|
const { html } = renderToStaticMarkup(Component, props, children);
|
|
|
|
return typeof html === 'string';
|
2022-03-18 15:35:45 -07:00
|
|
|
}
|
|
|
|
|
2022-06-23 10:10:54 -05:00
|
|
|
function renderToStaticMarkup(Component, props, { default: children, ...slotted }) {
|
|
|
|
const slots = {};
|
|
|
|
for (const [key, value] of Object.entries(slotted)) {
|
|
|
|
const name = slotName(key);
|
|
|
|
slots[name] = ssr(`<astro-slot name="${name}">${value}</astro-slot>`);
|
|
|
|
}
|
|
|
|
// Note: create newProps to avoid mutating `props` before they are serialized
|
|
|
|
const newProps = {
|
|
|
|
...props,
|
|
|
|
...slots,
|
|
|
|
// In Solid SSR mode, `ssr` creates the expected structure for `children`.
|
|
|
|
children: children != null ? ssr(`<astro-slot>${children}</astro-slot>`) : children,
|
|
|
|
}
|
|
|
|
const html = renderToString(() => createComponent(Component, newProps));
|
|
|
|
return { html }
|
2022-03-18 15:35:45 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export default {
|
|
|
|
check,
|
|
|
|
renderToStaticMarkup,
|
|
|
|
};
|