Skip to content

Commit

Permalink
Merge pull request #1424 from sveltejs/single-outrocallback
Browse files Browse the repository at this point in the history
simpler code for case where there is only one outro in a block
  • Loading branch information
Rich-Harris authored May 6, 2018
2 parents a9464c7 + 2d8d27a commit 3f906fb
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 9 deletions.
2 changes: 1 addition & 1 deletion src/compile/dom/Block.ts
Original file line number Diff line number Diff line change
Expand Up @@ -262,7 +262,7 @@ export default class Block {
${outroing} = true;
${hasIntros && `${introing} = false;`}
var #outros = ${this.outros};
${this.outros > 1 && `var #outros = ${this.outros};`}
${this.builders.outro}
},
Expand Down
16 changes: 8 additions & 8 deletions src/compile/nodes/Element.ts
Original file line number Diff line number Diff line change
Expand Up @@ -701,18 +701,18 @@ export default class Element extends Node {
const fn = `%transitions-${intro.name}`;

block.builders.intro.addBlock(deindent`
#component.root._aftercreate.push(function() {
#component.root._aftercreate.push(() => {
if (!${name}) ${name} = @wrapTransition(#component, ${this.var}, ${fn}, ${snippet}, true, null);
${name}.run(true, function() {
${name}.run(true, () => {
#component.fire("intro.end", { node: ${this.var} });
});
});
`);

block.builders.outro.addBlock(deindent`
${name}.run(false, function() {
${name}.run(false, () => {
#component.fire("outro.end", { node: ${this.var} });
if (--#outros === 0) #outrocallback();
${block.outros > 1 ? `if (--#outros === 0) #outrocallback();` : `#outrocallback();`}
${name} = null;
});
`);
Expand All @@ -736,9 +736,9 @@ export default class Element extends Node {
}

block.builders.intro.addBlock(deindent`
#component.root._aftercreate.push(function() {
#component.root._aftercreate.push(() => {
${introName} = @wrapTransition(#component, ${this.var}, ${fn}, ${snippet}, true, null);
${introName}.run(true, function() {
${introName}.run(true, () => {
#component.fire("intro.end", { node: ${this.var} });
});
});
Expand All @@ -757,9 +757,9 @@ export default class Element extends Node {
// group) prior to their removal from the DOM
block.builders.outro.addBlock(deindent`
${outroName} = @wrapTransition(#component, ${this.var}, ${fn}, ${snippet}, false, null);
${outroName}.run(false, function() {
${outroName}.run(false, () => {
#component.fire("outro.end", { node: ${this.var} });
if (--#outros === 0) #outrocallback();
${block.outros > 1 ? `if (--#outros === 0) #outrocallback();` : `#outrocallback();`}
});
`);
}
Expand Down

0 comments on commit 3f906fb

Please sign in to comment.