2022-08-10 14:13:28 -05:00
|
|
|
import { createComponent, renderToString, ssr } from 'solid-js/web';
|
2022-08-10 14:10:31 -05:00
|
|
|
import { getContext, incrementId } from './context.js';
|
2022-08-10 14:13:28 -05:00
|
|
|
import type { RendererContext } from './types';
|
2022-08-10 14:10:31 -05:00
|
|
|
|
|
|
|
const slotName = (str: string) => str.trim().replace(/[-_]([a-z])/g, (_, w) => w.toUpperCase());
|
|
|
|
|
|
|
|
function check(this: RendererContext, Component: any, props: Record<string, any>, children: any) {
|
|
|
|
if (typeof Component !== 'function') return false;
|
|
|
|
const { html } = renderToStaticMarkup.call(this, Component, props, children);
|
|
|
|
return typeof html === 'string';
|
|
|
|
}
|
|
|
|
|
2022-08-10 14:13:28 -05:00
|
|
|
function renderToStaticMarkup(
|
|
|
|
this: RendererContext,
|
|
|
|
Component: any,
|
|
|
|
props: Record<string, any>,
|
|
|
|
{ default: children, ...slotted }: any,
|
|
|
|
metadata?: undefined | Record<string, any>
|
|
|
|
) {
|
2022-08-10 14:10:31 -05:00
|
|
|
const renderId = metadata?.hydrate ? incrementId(getContext(this.result)) : '';
|
2023-05-17 09:18:04 -05:00
|
|
|
const needsHydrate = metadata?.astroStaticSlot ? !!metadata.hydrate : true;
|
|
|
|
const tagName = needsHydrate ? 'astro-slot' : 'astro-static-slot';
|
2022-08-10 14:10:31 -05:00
|
|
|
|
2022-08-10 14:13:28 -05:00
|
|
|
const html = renderToString(
|
|
|
|
() => {
|
|
|
|
const slots: Record<string, any> = {};
|
|
|
|
for (const [key, value] of Object.entries(slotted)) {
|
|
|
|
const name = slotName(key);
|
2023-05-17 09:18:04 -05:00
|
|
|
slots[name] = ssr(`<${tagName} name="${name}">${value}</${tagName}>`);
|
2022-08-10 14:13:28 -05:00
|
|
|
}
|
|
|
|
// 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`.
|
2023-05-17 09:18:04 -05:00
|
|
|
children: children != null ? ssr(`<${tagName}>${children}</${tagName}>`) : children,
|
2022-08-10 14:13:28 -05:00
|
|
|
};
|
2022-08-10 14:10:31 -05:00
|
|
|
|
2022-08-10 14:13:28 -05:00
|
|
|
return createComponent(Component, newProps);
|
|
|
|
},
|
|
|
|
{
|
|
|
|
renderId,
|
|
|
|
}
|
|
|
|
);
|
2022-08-10 14:10:31 -05:00
|
|
|
return {
|
|
|
|
attrs: {
|
2022-08-10 14:13:28 -05:00
|
|
|
'data-solid-render-id': renderId,
|
2022-08-10 14:10:31 -05:00
|
|
|
},
|
2022-08-10 14:13:28 -05:00
|
|
|
html,
|
2022-08-10 14:10:31 -05:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export default {
|
|
|
|
check,
|
|
|
|
renderToStaticMarkup,
|
2023-05-17 09:18:04 -05:00
|
|
|
supportsAstroStaticSlot: true,
|
2022-08-10 14:10:31 -05:00
|
|
|
};
|