Make actions execute with the component context

pull/1279/head
Jacob Wright 7 years ago
parent fcfbffe50b
commit 9b0a884035

@ -669,7 +669,7 @@ export default class Element extends Node {
const fn = `%actions-${attribute.name}`;
block.builders.hydrate.addLine(
`${name} = ${fn}(${this.var}${snippet ? `, ${snippet}` : ''}) || {};`
`${name} = ${fn}.call(#component, ${this.var}${snippet ? `, ${snippet}` : ''}) || {};`
);
if (dependencies && dependencies.length) {
@ -679,12 +679,12 @@ export default class Element extends Node {
block.builders.update.addConditional(
conditional,
`${name}.update(${snippet});`
`${name}.update.call(#component, ${snippet});`
);
}
block.builders.destroy.addLine(
`if (typeof ${name}.destroy === 'function') ${name}.destroy();`
`if (typeof ${name}.destroy === 'function') ${name}.destroy.call(#component);`
);
});
}

@ -210,7 +210,7 @@ function create_main_fragment(component, state) {
h: function hydrate() {
a.href = "#";
link_action = link(a) || {};
link_action = link.call(component, a) || {};
},
m: function mount(target, anchor) {
@ -224,7 +224,7 @@ function create_main_fragment(component, state) {
},
d: function destroy$$1() {
if (typeof link_action.destroy === 'function') link_action.destroy();
if (typeof link_action.destroy === 'function') link_action.destroy.call(component);
}
};
}

@ -29,7 +29,7 @@ function create_main_fragment(component, state) {
h: function hydrate() {
a.href = "#";
link_action = link(a) || {};
link_action = link.call(component, a) || {};
},
m: function mount(target, anchor) {
@ -43,7 +43,7 @@ function create_main_fragment(component, state) {
},
d: function destroy() {
if (typeof link_action.destroy === 'function') link_action.destroy();
if (typeof link_action.destroy === 'function') link_action.destroy.call(component);
}
};
}

@ -0,0 +1,11 @@
export default {
html: `<button>0</button>`,
test ( assert, component, target, window ) {
const button = target.querySelector( 'button' );
const click = new window.MouseEvent( 'click' );
button.dispatchEvent( click );
assert.htmlEqual( target.innerHTML, `<button>1</button>` );
}
};

@ -0,0 +1,22 @@
<button use:foo>{{x}}</button>
<script>
export default {
actions: {
foo(node) {
let x = 0;
const handler = () => this.set({ x: x++ });
node.addEventListener('click', handler);
handler();
return {
destroy() {
node.removeEventListener('click', handler);
}
};
}
},
};
</script>
Loading…
Cancel
Save