mirror of https://github.com/sveltejs/svelte
use listen helper for <svelte:body> events (#4278)
parent
bda254e250
commit
62d5480687
@ -1,26 +1,23 @@
|
|||||||
import Block from '../Block';
|
import Block from '../Block';
|
||||||
import Wrapper from './shared/Wrapper';
|
import Wrapper from './shared/Wrapper';
|
||||||
import { b } from 'code-red';
|
import { x } from 'code-red';
|
||||||
import Body from '../../nodes/Body';
|
import Body from '../../nodes/Body';
|
||||||
import { Identifier } from 'estree';
|
import { Identifier } from 'estree';
|
||||||
import EventHandler from './Element/EventHandler';
|
import EventHandler from './Element/EventHandler';
|
||||||
|
import add_event_handlers from './shared/add_event_handlers';
|
||||||
|
import { TemplateNode } from '../../../interfaces';
|
||||||
|
import Renderer from '../Renderer';
|
||||||
|
|
||||||
export default class BodyWrapper extends Wrapper {
|
export default class BodyWrapper extends Wrapper {
|
||||||
node: Body;
|
node: Body;
|
||||||
|
handlers: EventHandler[];
|
||||||
|
|
||||||
render(block: Block, _parent_node: Identifier, _parent_nodes: Identifier) {
|
constructor(renderer: Renderer, block: Block, parent: Wrapper, node: TemplateNode) {
|
||||||
this.node.handlers
|
super(renderer, block, parent, node);
|
||||||
.map(handler => new EventHandler(handler, this))
|
this.handlers = this.node.handlers.map(handler => new EventHandler(handler, this));
|
||||||
.forEach(handler => {
|
}
|
||||||
const snippet = handler.get_snippet(block);
|
|
||||||
|
|
||||||
block.chunks.init.push(b`
|
|
||||||
@_document.body.addEventListener("${handler.node.name}", ${snippet});
|
|
||||||
`);
|
|
||||||
|
|
||||||
block.chunks.destroy.push(b`
|
render(block: Block, _parent_node: Identifier, _parent_nodes: Identifier) {
|
||||||
@_document.body.removeEventListener("${handler.node.name}", ${snippet});
|
add_event_handlers(block, x`@_document.body`, this.handlers);
|
||||||
`);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in new issue