set current = true on mount as well as intro - fixes #2000

pull/2009/head
Richard Harris 6 years ago
parent fcbb8e6eff
commit cdcccfb4e4

@ -223,6 +223,7 @@ export default class Block {
if (!this.builders.intro.isEmpty()) { if (!this.builders.intro.isEmpty()) {
this.builders.intro.addLine(`#current = true;`); this.builders.intro.addLine(`#current = true;`);
this.builders.mount.addLine(`#current = true;`);
} }
if (!this.builders.outro.isEmpty()) { if (!this.builders.outro.isEmpty()) {

@ -429,18 +429,19 @@ export default class EachBlockWrapper extends Wrapper {
? deindent` ? deindent`
if (${iterations}[#i]) { if (${iterations}[#i]) {
${iterations}[#i].p(changed, child_ctx); ${iterations}[#i].p(changed, child_ctx);
${has_transitions && `${iterations}[#i].i(1);`}
} else { } else {
${iterations}[#i] = ${create_each_block}(child_ctx); ${iterations}[#i] = ${create_each_block}(child_ctx);
${iterations}[#i].c(); ${iterations}[#i].c();
${has_transitions && `${iterations}[#i].i(1);`}
${iterations}[#i].m(${updateMountNode}, ${anchor}); ${iterations}[#i].m(${updateMountNode}, ${anchor});
} }
${has_transitions && `${iterations}[#i].i(1);`}
` `
: deindent` : deindent`
${iterations}[#i] = ${create_each_block}(child_ctx); ${iterations}[#i] = ${create_each_block}(child_ctx);
${iterations}[#i].c(); ${iterations}[#i].c();
${iterations}[#i].m(${updateMountNode}, ${anchor});
${has_transitions && `${iterations}[#i].i(1);`} ${has_transitions && `${iterations}[#i].i(1);`}
${iterations}[#i].m(${updateMountNode}, ${anchor});
`; `;
const start = this.block.hasUpdateMethod ? '0' : `${iterations}.length`; const start = this.block.hasUpdateMethod ? '0' : `${iterations}.length`;

@ -671,12 +671,13 @@ export default class ElementWrapper extends Wrapper {
if (outro) { if (outro) {
intro_block = deindent` intro_block = deindent`
@add_render_callback(() => { @add_render_callback(() => {
if (${outroName}) ${outroName}.end(1);
if (!${introName}) ${introName} = @create_in_transition(${this.var}, ${fn}, ${snippet}); if (!${introName}) ${introName} = @create_in_transition(${this.var}, ${fn}, ${snippet});
${introName}.start(); ${introName}.start();
}); });
`; `;
block.builders.outro.addLine(`if (${introName}) ${introName}.invalidate()`); block.builders.outro.addLine(`if (${introName}) ${introName}.invalidate();`);
} else { } else {
intro_block = deindent` intro_block = deindent`
if (!${introName}) { if (!${introName}) {
@ -707,9 +708,11 @@ export default class ElementWrapper extends Wrapper {
const fn = component.qualify(outro.name); const fn = component.qualify(outro.name);
block.builders.intro.addBlock(deindent` if (!intro) {
if (${outroName}) ${outroName}.end(1); block.builders.intro.addBlock(deindent`
`); if (${outroName}) ${outroName}.end(1);
`);
}
// TODO hide elements that have outro'd (unless they belong to a still-outroing // TODO hide elements that have outro'd (unless they belong to a still-outroing
// group) prior to their removal from the DOM // group) prior to their removal from the DOM

@ -235,8 +235,8 @@ export default class IfBlockWrapper extends Wrapper {
${name} = ${current_block_type_and}${current_block_type}(ctx); ${name} = ${current_block_type_and}${current_block_type}(ctx);
if (${name}) { if (${name}) {
${name}.c(); ${name}.c();
${name}.m(${updateMountNode}, ${anchor});
${has_transitions && `${name}.i(1);`} ${has_transitions && `${name}.i(1);`}
${name}.m(${updateMountNode}, ${anchor});
} }
`; `;
@ -334,8 +334,8 @@ export default class IfBlockWrapper extends Wrapper {
${name} = ${if_blocks}[${current_block_type_index}] = ${if_block_creators}[${current_block_type_index}](ctx); ${name} = ${if_blocks}[${current_block_type_index}] = ${if_block_creators}[${current_block_type_index}](ctx);
${name}.c(); ${name}.c();
} }
${name}.m(${updateMountNode}, ${anchor});
${has_transitions && `${name}.i(1);`} ${has_transitions && `${name}.i(1);`}
${name}.m(${updateMountNode}, ${anchor});
`; `;
const changeBlock = hasElse const changeBlock = hasElse
@ -407,20 +407,23 @@ export default class IfBlockWrapper extends Wrapper {
? deindent` ? deindent`
if (${name}) { if (${name}) {
${name}.p(changed, ctx); ${name}.p(changed, ctx);
${has_transitions && `${name}.i(1);`}
} else { } else {
${name} = ${branch.block.name}(ctx); ${name} = ${branch.block.name}(ctx);
${name}.c(); ${name}.c();
${has_transitions && `${name}.i(1);`}
${name}.m(${updateMountNode}, ${anchor}); ${name}.m(${updateMountNode}, ${anchor});
} }
${has_transitions && `${name}.i(1);`}
` `
: deindent` : deindent`
if (!${name}) { if (!${name}) {
${name} = ${branch.block.name}(ctx); ${name} = ${branch.block.name}(ctx);
${name}.c(); ${name}.c();
${has_transitions && `${name}.i(1);`}
${name}.m(${updateMountNode}, ${anchor}); ${name}.m(${updateMountNode}, ${anchor});
${has_transitions && `} else {
${name}.i(1);`}
} }
${has_transitions && `${name}.i(1);`}
`; `;
// no `p()` here — we don't want to update outroing nodes, // no `p()` here — we don't want to update outroing nodes,

@ -408,8 +408,8 @@ export default class InlineComponentWrapper extends Wrapper {
${munged_handlers} ${munged_handlers}
${name}.$$.fragment.c(); ${name}.$$.fragment.c();
@mount_component(${name}, ${updateMountNode}, ${anchor});
${name}.$$.fragment.i(1); ${name}.$$.fragment.i(1);
@mount_component(${name}, ${updateMountNode}, ${anchor});
} else { } else {
${name} = null; ${name} = null;
} }

@ -110,8 +110,8 @@ export function init(component, options, instance, create_fragment, not_equal) {
$$.fragment.c(); $$.fragment.c();
} }
mount_component(component, options.target, options.anchor);
if (options.intro && component.$$.fragment.i) component.$$.fragment.i(); if (options.intro && component.$$.fragment.i) component.$$.fragment.i();
mount_component(component, options.target, options.anchor);
flush(); flush();
} }

@ -31,8 +31,8 @@ export function handlePromise(promise, info) {
} }
block.c(); block.c();
block.m(info.mount(), info.anchor);
if (block.i) block.i(1); if (block.i) block.i(1);
block.m(info.mount(), info.anchor);
flush(); flush();
} }

@ -52,8 +52,8 @@ export function updateKeyedEach(old_blocks, changed, get_key, dynamic, ctx, list
var did_move = {}; var did_move = {};
function insert(block) { function insert(block) {
block.m(node, next);
if (block.i) block.i(1); if (block.i) block.i(1);
block.m(node, next);
lookup[block.key] = block; lookup[block.key] = block;
next = block.first; next = block.first;
n--; n--;

@ -13,6 +13,7 @@ function create_fragment(ctx) {
m(target, anchor) { m(target, anchor) {
mount_component(nested, target, anchor); mount_component(nested, target, anchor);
current = true;
}, },
p: noop, p: noop,

@ -13,6 +13,7 @@ function create_fragment(ctx) {
m(target, anchor) { m(target, anchor) {
mount_component(nested, target, anchor); mount_component(nested, target, anchor);
current = true;
}, },
p: noop, p: noop,

@ -13,6 +13,7 @@ function create_fragment(ctx) {
m(target, anchor) { m(target, anchor) {
mount_component(nested, target, anchor); mount_component(nested, target, anchor);
current = true;
}, },
p: noop, p: noop,

@ -13,6 +13,7 @@ function create_fragment(ctx) {
m(target, anchor) { m(target, anchor) {
mount_component(nested, target, anchor); mount_component(nested, target, anchor);
current = true;
}, },
p: noop, p: noop,

@ -14,6 +14,7 @@ function create_fragment(ctx) {
m(target, anchor) { m(target, anchor) {
mount_component(lazyload, target, anchor); mount_component(lazyload, target, anchor);
current = true;
}, },
p: noop, p: noop,

@ -20,6 +20,7 @@ function create_fragment(ctx) {
mount_component(imported, target, anchor); mount_component(imported, target, anchor);
insert(target, text, anchor); insert(target, text, anchor);
mount_component(nonimported, target, anchor); mount_component(nonimported, target, anchor);
current = true;
}, },
p: noop, p: noop,

@ -23,9 +23,11 @@ function create_if_block(ctx) {
if (!if_block) { if (!if_block) {
if_block = create_if_block_1(ctx); if_block = create_if_block_1(ctx);
if_block.c(); if_block.c();
if_block.i(1);
if_block.m(if_block_anchor.parentNode, if_block_anchor); if_block.m(if_block_anchor.parentNode, if_block_anchor);
} else {
if_block.i(1);
} }
if_block.i(1);
} else if (if_block) { } else if (if_block) {
if_block.d(1); if_block.d(1);
if_block = null; if_block = null;

Loading…
Cancel
Save