2018-02-12 16:01:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
|
|
|
* @copyright 2018 Photon Storm Ltd.
|
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
2018-01-12 18:59:01 +00:00
|
|
|
var Class = require('../utils/Class');
|
|
|
|
var EE = require('eventemitter3');
|
2018-02-12 23:03:48 +00:00
|
|
|
var PluginManager = require('../boot/PluginManager');
|
2018-01-12 18:59:01 +00:00
|
|
|
|
2018-01-31 13:54:44 +00:00
|
|
|
/**
|
|
|
|
* @namespace Phaser.Events
|
|
|
|
*/
|
|
|
|
|
2018-02-07 15:27:21 +00:00
|
|
|
/**
|
|
|
|
* @classdesc
|
|
|
|
* EventEmitter is a Scene Systems plugin compatible version of eventemitter3.
|
|
|
|
*
|
|
|
|
* @class EventEmitter
|
2018-02-13 00:40:51 +00:00
|
|
|
* @extends EventEmitter
|
2018-02-07 15:27:21 +00:00
|
|
|
* @memberOf Phaser.Events
|
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-12 18:59:01 +00:00
|
|
|
var EventEmitter = new Class({
|
|
|
|
|
|
|
|
Extends: EE,
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
|
|
|
function EventEmitter ()
|
|
|
|
{
|
|
|
|
EE.call(this);
|
2018-01-18 05:19:00 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 03:40:49 +00:00
|
|
|
/**
|
|
|
|
* Removes all listeners.
|
|
|
|
*
|
|
|
|
* @method Phaser.Events.EventEmitter#shutdown
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-18 05:19:00 +00:00
|
|
|
shutdown: function ()
|
|
|
|
{
|
|
|
|
this.removeAllListeners();
|
|
|
|
},
|
|
|
|
|
2018-01-26 03:40:49 +00:00
|
|
|
/**
|
|
|
|
* Removes all listeners.
|
|
|
|
*
|
|
|
|
* @method Phaser.Events.EventEmitter#destroy
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-18 05:19:00 +00:00
|
|
|
destroy: function ()
|
|
|
|
{
|
|
|
|
this.removeAllListeners();
|
2018-01-12 18:59:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2018-02-13 00:40:51 +00:00
|
|
|
/**
|
|
|
|
* @namespace EventEmitter
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return an array listing the events for which the emitter has registered listeners.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#eventNames
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @return {array}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the listeners registered for a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#listeners
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
*
|
|
|
|
* @return {array} The registered listeners.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the number of listeners listening to a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#listenerCount
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
*
|
|
|
|
* @return {number} The number of listeners.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Calls each of the listeners registered for a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#emit
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
*
|
|
|
|
* @return {Boolean} `true` if the event had listeners, else `false`.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a listener for a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#on
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
* @param {function} fn - The listener function.
|
|
|
|
* @param {*} [context=this] - The context to invoke the listener with.
|
|
|
|
*
|
|
|
|
* @return {EventEmitter} `this`.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a listener for a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#addListener
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
* @param {function} fn - The listener function.
|
|
|
|
* @param {*} [context=this] - The context to invoke the listener with.
|
|
|
|
*
|
|
|
|
* @return {EventEmitter} `this`.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a one-time listener for a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#once
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
* @param {function} fn - The listener function.
|
|
|
|
* @param {*} [context=this] - The context to invoke the listener with.
|
|
|
|
*
|
|
|
|
* @return {EventEmitter} `this`.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove the listeners of a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#removeListener
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
* @param {function} fn - Only remove the listeners that match this function.
|
|
|
|
* @param {*} context - Only remove the listeners that have this context.
|
|
|
|
* @param {boolean} once - Only remove one-time listeners.
|
|
|
|
*
|
|
|
|
* @return {EventEmitter} `this`.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove the listeners of a given event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#off
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} event - The event name.
|
|
|
|
* @param {function} fn - Only remove the listeners that match this function.
|
|
|
|
* @param {*} context - Only remove the listeners that have this context.
|
|
|
|
* @param {boolean} once - Only remove one-time listeners.
|
|
|
|
*
|
|
|
|
* @return {EventEmitter} `this`.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove all listeners, or those of the specified event.
|
|
|
|
*
|
|
|
|
* @method EventEmitter#removeAllListeners
|
2018-03-15 17:27:30 +00:00
|
|
|
* @since 3.0.0
|
2018-02-13 00:40:51 +00:00
|
|
|
*
|
|
|
|
* @param {string|symbol} [event] - The event name.
|
|
|
|
*
|
|
|
|
* @return {EventEmitter} `this`.
|
|
|
|
*/
|
|
|
|
|
2018-01-18 05:19:00 +00:00
|
|
|
PluginManager.register('EventEmitter', EventEmitter, 'events');
|
|
|
|
|
2018-01-12 18:59:01 +00:00
|
|
|
module.exports = EventEmitter;
|