summaryrefslogtreecommitdiff
path: root/packages/integrations/solid/src/server.ts
diff options
context:
space:
mode:
authorGravatar Matthew Phillips <matthew@skypack.dev> 2022-08-10 15:10:31 -0400
committerGravatar GitHub <noreply@github.com> 2022-08-10 15:10:31 -0400
commit0af5aa7a3b2a858c6b6cdbeda46bc3d90be1250f (patch)
treeb4f9dc145005c31c0d0f4cce66a30130908f650c /packages/integrations/solid/src/server.ts
parent58941e93c396bf35becc7431e1743afbaad6dd69 (diff)
downloadastro-0af5aa7a3b2a858c6b6cdbeda46bc3d90be1250f.tar.gz
astro-0af5aa7a3b2a858c6b6cdbeda46bc3d90be1250f.tar.zst
astro-0af5aa7a3b2a858c6b6cdbeda46bc3d90be1250f.zip
Fix solid recursion bug (#4215)
* Fix solid recursion bug * Fix types * Remove debug code * Remove logging from e2e test
Diffstat (limited to 'packages/integrations/solid/src/server.ts')
-rw-r--r--packages/integrations/solid/src/server.ts45
1 files changed, 45 insertions, 0 deletions
diff --git a/packages/integrations/solid/src/server.ts b/packages/integrations/solid/src/server.ts
new file mode 100644
index 000000000..bd50d8d77
--- /dev/null
+++ b/packages/integrations/solid/src/server.ts
@@ -0,0 +1,45 @@
+import type { RendererContext } from './types';
+import { renderToString, ssr, createComponent } from 'solid-js/web';
+import { getContext, incrementId } from './context.js';
+
+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';
+}
+
+function renderToStaticMarkup(this: RendererContext, Component: any, props: Record<string, any>, { default: children, ...slotted }: any, metadata?: undefined | Record<string, any>) {
+ const renderId = metadata?.hydrate ? incrementId(getContext(this.result)) : '';
+
+ const html = renderToString(() => {
+ const slots: Record<string, any> = {};
+ 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,
+ };
+
+ return createComponent(Component, newProps);
+ }, {
+ renderId
+ });
+ return {
+ attrs: {
+ 'data-solid-render-id': renderId
+ },
+ html
+ };
+}
+
+export default {
+ check,
+ renderToStaticMarkup,
+};