fix indirect dependencies

pull/1367/head
Rich Harris 7 years ago
parent fbc5d8312d
commit fa2b1f8784

@ -150,7 +150,7 @@ export default class Element extends Node {
if (select && select.selectBindingDependencies) { if (select && select.selectBindingDependencies) {
select.selectBindingDependencies.forEach(prop => { select.selectBindingDependencies.forEach(prop => {
dependencies.forEach((dependency: string) => { attr.dependencies.forEach((dependency: string) => {
this.compiler.indirectDependencies.get(prop).add(dependency); this.compiler.indirectDependencies.get(prop).add(dependency);
}); });
}); });
@ -198,10 +198,10 @@ export default class Element extends Node {
// so that if `foo.qux` changes, we know that we need to // so that if `foo.qux` changes, we know that we need to
// mark `bar` and `baz` as dirty too // mark `bar` and `baz` as dirty too
if (this.name === 'select') { if (this.name === 'select') {
const binding = this.attributes.find(node => node.type === 'Binding' && node.name === 'value'); const binding = this.bindings.find(node => node.name === 'value');
if (binding) { if (binding) {
// TODO does this also apply to e.g. `<input type='checkbox' bind:group='foo'>`? // TODO does this also apply to e.g. `<input type='checkbox' bind:group='foo'>`?
const dependencies = binding.expression.dependencies; const dependencies = binding.value.dependencies;
this.selectBindingDependencies = dependencies; this.selectBindingDependencies = dependencies;
dependencies.forEach((prop: string) => { dependencies.forEach((prop: string) => {
this.compiler.indirectDependencies.set(prop, new Set()); this.compiler.indirectDependencies.set(prop, new Set());

@ -36,10 +36,7 @@ export default class Node {
cannotUseInnerHTML() { cannotUseInnerHTML() {
if (this.canUseInnerHTML !== false) { if (this.canUseInnerHTML !== false) {
this.canUseInnerHTML = false; this.canUseInnerHTML = false;
if (this.parent) { if (this.parent) this.parent.cannotUseInnerHTML();
if (!this.parent.cannotUseInnerHTML) console.log(this.parent.type, this.type);
this.parent.cannotUseInnerHTML();
}
} }
} }

Loading…
Cancel
Save