summaryrefslogtreecommitdiff
path: root/packages/renderers/renderer-svelte/Wrapper.svelte
diff options
context:
space:
mode:
authorGravatar Nate Moore <natemoo-re@users.noreply.github.com> 2021-05-28 17:19:40 -0500
committerGravatar GitHub <noreply@github.com> 2021-05-28 17:19:40 -0500
commit3df41d23089142ea9b0895110f28a2d4a43a9059 (patch)
tree4b590cdb86e647b479730f5b4f83ee7c147aaf69 /packages/renderers/renderer-svelte/Wrapper.svelte
parent630c36f3516bb500ca6a4bfe84c972b1093b8177 (diff)
downloadastro-3df41d23089142ea9b0895110f28a2d4a43a9059.tar.gz
astro-3df41d23089142ea9b0895110f28a2d4a43a9059.tar.zst
astro-3df41d23089142ea9b0895110f28a2d4a43a9059.zip
Bugbash! (#263)
* fix(vscode): Markdown frontmatter should use TSX, not YAML * test: add test for #153 * chore: bump deps * chore: update to use @astrojs scope * fix: Markdown parse error when only child is `{expression}` * fix: update renderer edge cases * fix: failing test * fix: update renderer
Diffstat (limited to 'packages/renderers/renderer-svelte/Wrapper.svelte')
-rw-r--r--packages/renderers/renderer-svelte/Wrapper.svelte21
1 files changed, 21 insertions, 0 deletions
diff --git a/packages/renderers/renderer-svelte/Wrapper.svelte b/packages/renderers/renderer-svelte/Wrapper.svelte
new file mode 100644
index 000000000..78d4a402b
--- /dev/null
+++ b/packages/renderers/renderer-svelte/Wrapper.svelte
@@ -0,0 +1,21 @@
+<script>
+/**
+ * Why do we need a wrapper component?
+ *
+ * Astro passes `children` as a string of HTML, so we need
+ * a way to render that content.
+ *
+ * Rather than passing a magical prop which needs special
+ * handling, using this wrapper allows Svelte users to just
+ * use `<slot />` like they would for any other component.
+ */
+const { __astro_component: Component, __astro_children, ...props } = $$props;
+</script>
+
+<svelte:component this={Component} {...props}>
+ {#if __astro_children}
+ <astro-fragment>
+ {@html __astro_children}
+ </astro-fragment>
+ {/if}
+</svelte:component>