Merge pull request #1986 from sveltejs/gh-1985

Fix adjacent tracking across adjacent scopes - #1985
pull/1988/head
Rich Harris 6 years ago committed by GitHub
commit dfb661ec0d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -1,6 +1,6 @@
export default class TemplateScope { export default class TemplateScope {
names: Set<string>; names: Set<string>;
dependenciesForName: Map<string, string>; dependenciesForName: Map<string, Set<string>>;
mutables: Set<string>; mutables: Set<string>;
parent?: TemplateScope; parent?: TemplateScope;
@ -11,7 +11,7 @@ export default class TemplateScope {
this.mutables = new Set(); this.mutables = new Set();
} }
add(name, dependencies) { add(name, dependencies: Set<string>) {
this.names.add(name); this.names.add(name);
this.dependenciesForName.set(name, dependencies); this.dependenciesForName.set(name, dependencies);
return this; return this;
@ -23,8 +23,10 @@ export default class TemplateScope {
} }
setMutable(name: string) { setMutable(name: string) {
if (this.names.has(name)) this.mutables.add(name); if (this.names.has(name)) {
else if (this.parent) this.parent.setMutable(name); this.mutables.add(name);
if (this.parent && this.dependenciesForName.has(name)) this.dependenciesForName.get(name).forEach(dep => this.parent.setMutable(dep));
} else if (this.parent) this.parent.setMutable(name);
else this.mutables.add(name); else this.mutables.add(name);
} }

@ -0,0 +1,12 @@
export default {
async test({ assert, component, target }) {
assert.htmlEqual(component.div.innerHTML, '<div>+</div><div>-</div>');
const event = new window.Event('change');
const input = target.querySelector('input');
input.checked = false;
await input.dispatchEvent(event);
assert.htmlEqual(component.div.innerHTML, '<div>-</div><div>-</div>');
}
};

@ -0,0 +1,18 @@
{#each things as thing}
<div>
<input type=checkbox bind:checked={thing.ok} />
</div>
{/each}
<div bind:this={div}>
{#each things as other}
<div>
{other.ok ? '+' : '-'}
</div>
{/each}
</div>
<script>
const things = [{ ok: true }, { ok: false }];
export let div;
</script>
Loading…
Cancel
Save