feat: use implicit return for each block keys (#10938)

* feat: use implicit return for each block keys

* swap args

* update test
pull/10947/head
Rich Harris 10 months ago committed by GitHub
parent 808cc6fca6
commit f2cca537a3
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -0,0 +1,5 @@
---
'svelte': patch
---
feat: use implicit return for each block keys

@ -2317,11 +2317,13 @@ export const template_visitors = {
const key_function = node.key const key_function = node.key
? b.arrow( ? b.arrow(
[node.context.type === 'Identifier' ? node.context : b.id('$$item'), index], [node.context.type === 'Identifier' ? node.context : b.id('$$item'), index],
b.block( declarations.length > 0
declarations.concat( ? b.block(
b.return(/** @type {import('estree').Expression} */ (context.visit(node.key))) declarations.concat(
) b.return(/** @type {import('estree').Expression} */ (context.visit(node.key)))
) )
)
: /** @type {import('estree').Expression} */ (context.visit(node.key))
) )
: b.literal(null); : b.literal(null);
@ -2347,16 +2349,16 @@ export const template_visitors = {
args.push( args.push(
context.state.node, context.state.node,
each_node_meta.array_name ? each_node_meta.array_name : b.thunk(collection),
b.literal(each_type), b.literal(each_type),
each_node_meta.array_name ? each_node_meta.array_name : b.thunk(collection),
key_function, key_function,
b.arrow([b.id('$$anchor'), item, index], b.block(declarations.concat(children))) b.arrow([b.id('$$anchor'), item, index], b.block(declarations.concat(children)))
); );
} else { } else {
args.push( args.push(
context.state.node, context.state.node,
each_node_meta.array_name ? each_node_meta.array_name : b.thunk(collection),
b.literal(each_type), b.literal(each_type),
each_node_meta.array_name ? each_node_meta.array_name : b.thunk(collection),
b.arrow([b.id('$$anchor'), item, index], b.block(declarations.concat(children))) b.arrow([b.id('$$anchor'), item, index], b.block(declarations.concat(children)))
); );
} }

@ -46,15 +46,15 @@ export function set_current_each_item(item) {
/** /**
* @template V * @template V
* @param {Element | Comment} anchor The next sibling node, or the parent node if this is a 'controlled' block * @param {Element | Comment} anchor The next sibling node, or the parent node if this is a 'controlled' block
* @param {() => V[]} get_collection
* @param {number} flags * @param {number} flags
* @param {() => V[]} get_collection
* @param {null | ((item: V) => string)} get_key * @param {null | ((item: V) => string)} get_key
* @param {(anchor: null, item: V, index: import('#client').MaybeSource<number>) => void} render_fn * @param {(anchor: null, item: V, index: import('#client').MaybeSource<number>) => void} render_fn
* @param {null | ((anchor: Node | null) => void)} fallback_fn * @param {null | ((anchor: Node | null) => void)} fallback_fn
* @param {typeof reconcile_indexed_array | reconcile_tracked_array} reconcile_fn * @param {typeof reconcile_indexed_array | reconcile_tracked_array} reconcile_fn
* @returns {void} * @returns {void}
*/ */
function each(anchor, get_collection, flags, get_key, render_fn, fallback_fn, reconcile_fn) { function each(anchor, flags, get_collection, get_key, render_fn, fallback_fn, reconcile_fn) {
/** @type {import('#client').EachState} */ /** @type {import('#client').EachState} */
var state = { flags, items: [] }; var state = { flags, items: [] };
@ -193,28 +193,28 @@ function each(anchor, get_collection, flags, get_key, render_fn, fallback_fn, re
/** /**
* @template V * @template V
* @param {Element | Comment} anchor * @param {Element | Comment} anchor
* @param {() => V[]} get_collection
* @param {number} flags * @param {number} flags
* @param {() => V[]} get_collection
* @param {null | ((item: V) => string)} get_key * @param {null | ((item: V) => string)} get_key
* @param {(anchor: null, item: V, index: import('#client').MaybeSource<number>) => void} render_fn * @param {(anchor: null, item: V, index: import('#client').MaybeSource<number>) => void} render_fn
* @param {null | ((anchor: Node | null) => void)} [fallback_fn] * @param {null | ((anchor: Node | null) => void)} [fallback_fn]
* @returns {void} * @returns {void}
*/ */
export function each_keyed(anchor, get_collection, flags, get_key, render_fn, fallback_fn = null) { export function each_keyed(anchor, flags, get_collection, get_key, render_fn, fallback_fn = null) {
each(anchor, get_collection, flags, get_key, render_fn, fallback_fn, reconcile_tracked_array); each(anchor, flags, get_collection, get_key, render_fn, fallback_fn, reconcile_tracked_array);
} }
/** /**
* @template V * @template V
* @param {Element | Comment} anchor * @param {Element | Comment} anchor
* @param {() => V[]} get_collection
* @param {number} flags * @param {number} flags
* @param {() => V[]} get_collection
* @param {(anchor: null, item: V, index: import('#client').MaybeSource<number>) => void} render_fn * @param {(anchor: null, item: V, index: import('#client').MaybeSource<number>) => void} render_fn
* @param {null | ((anchor: Node | null) => void)} [fallback_fn] * @param {null | ((anchor: Node | null) => void)} [fallback_fn]
* @returns {void} * @returns {void}
*/ */
export function each_indexed(anchor, get_collection, flags, render_fn, fallback_fn = null) { export function each_indexed(anchor, flags, get_collection, render_fn, fallback_fn = null) {
each(anchor, get_collection, flags, null, render_fn, fallback_fn, reconcile_indexed_array); each(anchor, flags, get_collection, null, render_fn, fallback_fn, reconcile_indexed_array);
} }
/** /**

@ -10,7 +10,7 @@ export default function Each_string_template($$anchor, $$props) {
var fragment = $.comment($$anchor); var fragment = $.comment($$anchor);
var node = $.first_child(fragment); var node = $.first_child(fragment);
$.each_indexed(node, () => ['foo', 'bar', 'baz'], 1, ($$anchor, thing, $$index) => { $.each_indexed(node, 1, () => ['foo', 'bar', 'baz'], ($$anchor, thing, $$index) => {
var text = $.space_frag($$anchor); var text = $.space_frag($$anchor);
$.render_effect(() => $.set_text(text, `${$.stringify($.unwrap(thing))}, `)); $.render_effect(() => $.set_text(text, `${$.stringify($.unwrap(thing))}, `));

Loading…
Cancel
Save