You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
1.6 KiB
70 lines
1.6 KiB
/* |
|
Copyright 2019 Google LLC |
|
|
|
Use of this source code is governed by an MIT-style |
|
license that can be found in the LICENSE file or at |
|
https://opensource.org/licenses/MIT. |
|
*/ |
|
|
|
import '../_version.mjs'; |
|
|
|
|
|
/** |
|
* A minimal `EventTarget` shim. |
|
* This is necessary because not all browsers support constructable |
|
* `EventTarget`, so using a real `EventTarget` will error. |
|
* @private |
|
*/ |
|
class EventTargetShim { |
|
/** |
|
* Creates an event listener registry |
|
* |
|
* @private |
|
*/ |
|
constructor() { |
|
// A registry of event types to listeners. |
|
this._eventListenerRegistry = {}; |
|
} |
|
/** |
|
* @param {string} type |
|
* @param {Function} listener |
|
* @private |
|
*/ |
|
addEventListener(type, listener) { |
|
this._getEventListenersByType(type).add(listener); |
|
} |
|
|
|
/** |
|
* @param {string} type |
|
* @param {Function} listener |
|
* @private |
|
*/ |
|
removeEventListener(type, listener) { |
|
this._getEventListenersByType(type).delete(listener); |
|
} |
|
|
|
/** |
|
* @param {Event} event |
|
* @private |
|
*/ |
|
dispatchEvent(event) { |
|
event.target = this; |
|
this._getEventListenersByType(event.type).forEach( |
|
(listener) => listener(event)); |
|
} |
|
|
|
/** |
|
* Returns a Set of listeners associated with the passed event type. |
|
* If no handlers have been registered, an empty Set is returned. |
|
* |
|
* @param {string} type The event type. |
|
* @return {Set} An array of handler functions. |
|
* @private |
|
*/ |
|
_getEventListenersByType(type) { |
|
return this._eventListenerRegistry[type] = |
|
(this._eventListenerRegistry[type] || new Set()); |
|
} |
|
} |
|
|
|
export {EventTargetShim};
|
|
|