fix: add snippet symbol to children prop (#9395)

* add snippet symbol to children prop

* fix error message for snippet validation

* changeset
svelte-4-base
gtmnayan 1 year ago committed by GitHub
parent 304a29e1cc
commit 7a84e78b4d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1,5 @@
---
'svelte': patch
---
fix: add snippet marker symbol to children prop

@ -819,15 +819,21 @@ function serialize_inline_component(node, component_name, context) {
const body = create_block(node, `${node.name}_${slot_name}`, children[slot_name], context); const body = create_block(node, `${node.name}_${slot_name}`, children[slot_name], context);
if (body.length === 0) continue; if (body.length === 0) continue;
const fn = b.arrow( const slot_fn = b.arrow(
[b.id('$$anchor'), b.id('$$slotProps')], [b.id('$$anchor'), b.id('$$slotProps')],
b.block([...(slot_name === 'default' ? default_lets : []), ...body]) b.block([...(slot_name === 'default' ? default_lets : []), ...body])
); );
if (slot_name === 'default') { if (slot_name === 'default') {
push_prop(b.prop('init', b.id('children'), fn)); push_prop(
b.prop(
'init',
b.id('children'),
context.state.options.dev ? b.call('$.add_snippet_symbol', slot_fn) : slot_fn
)
);
} else { } else {
serialized_slots.push(b.prop('init', b.key(slot_name), fn)); serialized_slots.push(b.prop('init', b.key(slot_name), slot_fn));
} }
} }

@ -847,26 +847,21 @@ function serialize_inline_component(node, component_name, context) {
const body = create_block(node, children[slot_name], context); const body = create_block(node, children[slot_name], context);
if (body.length === 0) continue; if (body.length === 0) continue;
const slot_fn = b.arrow(
[b.id('$$payload'), b.id('$$slotProps')],
b.block([...(slot_name === 'default' ? default_lets : []), ...body])
);
if (slot_name === 'default') { if (slot_name === 'default') {
push_prop( push_prop(
b.prop( b.prop(
'init', 'init',
b.id('children'), b.id('children'),
b.arrow( context.state.options.dev ? b.call('$.add_snippet_symbol', slot_fn) : slot_fn
[b.id('$$payload'), b.id('$$slotProps')],
b.block([...(slot_name === 'default' ? default_lets : []), ...body])
)
) )
); );
} else { } else {
const slot = b.prop( const slot = b.prop('init', b.literal(slot_name), slot_fn);
'init',
b.literal(slot_name),
b.arrow(
[b.id('$$payload'), b.id('$$slotProps')],
b.block([...(slot_name === 'default' ? default_lets : []), ...body])
)
);
serialized_slots.push(slot); serialized_slots.push(slot);
} }
} }

@ -119,7 +119,7 @@ export function add_snippet_symbol(fn) {
export function validate_snippet(snippet_fn) { export function validate_snippet(snippet_fn) {
if (snippet_fn[symbol] !== true) { if (snippet_fn[symbol] !== true) {
throw new Error( throw new Error(
'The argument to `{@html ...}` must be a snippet function, not a component or some other kind of function. ' + 'The argument to `{@render ...}` must be a snippet function, not a component or some other kind of function. ' +
'If you want to dynamically render one snippet or another, use `$derived` and pass its result to `{@render ...}`.' 'If you want to dynamically render one snippet or another, use `$derived` and pass its result to `{@render ...}`.'
); );
} }

@ -5,6 +5,6 @@ export default test({
dev: true dev: true
}, },
error: error:
'The argument to `{@html ...}` must be a snippet function, not a component or some other kind of function. ' + 'The argument to `{@render ...}` must be a snippet function, not a component or some other kind of function. ' +
'If you want to dynamically render one snippet or another, use `$derived` and pass its result to `{@render ...}`.' 'If you want to dynamically render one snippet or another, use `$derived` and pass its result to `{@render ...}`.'
}); });

Loading…
Cancel
Save