/*
  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};