1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-18 11:53:59 -05:00
denoland-deno/js/event_target.ts

57 lines
1.9 KiB
TypeScript
Raw Normal View History

2019-01-22 04:03:30 +09:00
// Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
2019-01-05 15:02:44 +00:00
import * as domTypes from "./dom_types";
2019-03-31 01:40:03 +08:00
import { requiredArguments } from "./util";
2019-01-05 15:02:44 +00:00
/* TODO: This is an incomplete implementation to provide functionality
* for Event. A proper spec is still required for a proper Web API.
*/
export class EventTarget implements domTypes.EventTarget {
public listeners: {
[type in string]: domTypes.EventListenerOrEventListenerObject[]
} = {};
public addEventListener(
type: string,
listener: domTypes.EventListenerOrEventListenerObject | null,
_options?: boolean | domTypes.AddEventListenerOptions
2019-01-05 15:02:44 +00:00
): void {
2019-03-31 01:40:03 +08:00
requiredArguments("EventTarget.addEventListener", arguments.length, 2);
2019-03-30 20:18:19 +08:00
if (!this.listeners.hasOwnProperty(type)) {
2019-01-05 15:02:44 +00:00
this.listeners[type] = [];
}
if (listener !== null) {
this.listeners[type].push(listener);
}
}
public removeEventListener(
type: string,
callback: domTypes.EventListenerOrEventListenerObject | null,
_options?: domTypes.EventListenerOptions | boolean
2019-01-05 15:02:44 +00:00
): void {
2019-03-31 01:40:03 +08:00
requiredArguments("EventTarget.removeEventListener", arguments.length, 2);
2019-03-30 20:18:19 +08:00
if (this.listeners.hasOwnProperty(type) && callback !== null) {
2019-01-05 15:02:44 +00:00
this.listeners[type] = this.listeners[type].filter(
listener => listener !== callback
);
}
}
public dispatchEvent(event: domTypes.Event): boolean {
2019-03-31 01:40:03 +08:00
requiredArguments("EventTarget.dispatchEvent", arguments.length, 1);
2019-03-30 20:18:19 +08:00
if (!this.listeners.hasOwnProperty(event.type)) {
2019-01-05 15:02:44 +00:00
return true;
}
const stack = this.listeners[event.type].slice();
for (const stackElement of stack) {
if ((stackElement as domTypes.EventListenerObject).handleEvent) {
(stackElement as domTypes.EventListenerObject).handleEvent(event);
} else {
(stackElement as domTypes.EventListener).call(this, event);
}
}
return !event.defaultPrevented;
}
}