diff --git a/dist/dush.common.js b/dist/dush.common.js index 707fc1d..205dc63 100644 --- a/dist/dush.common.js +++ b/dist/dush.common.js @@ -19,7 +19,7 @@ * const dush = require('dush') * const emitter = dush() * - * console.log(emitter.all) // => {} + * console.log(emitter._allEvents) // => {} * console.log(emitter.on) // => Function * console.log(emitter.once) // => Function * console.log(emitter.off) // => Function @@ -32,7 +32,7 @@ */ function dush () { - var all = Object.create(null); + var _allEvents = Object.create(null); var app = { /** * > An listeners map of all registered events @@ -51,16 +51,16 @@ function dush () { * emitter.on('foo', () => {}) * emitter.on('bar', () => {}) * - * console.log(emitter.all) + * console.log(emitter._allEvents) * // => { foo: [Function, Function], bar: [Functon] } * ``` * - * @name .all - * @type {Object} `all` a key/value store of all events and their listeners + * @name ._allEvents + * @type {Object} `_allEvents` a key/value store of all events and their listeners * @api public */ - all: all, + _allEvents: _allEvents, /** * > Invokes `plugin` function immediately, which is passed @@ -126,7 +126,7 @@ function dush () { */ on: function on (name, handler, once) { - var e = app.all[name] || (app.all[name] = []); + var e = app._allEvents[name] || (app._allEvents[name] = []); function func () { if (!func.called) { @@ -216,13 +216,13 @@ function dush () { */ off: function off (name, handler) { - if (handler && app.all[name]) { + if (handler && app._allEvents[name]) { var fnStr = handler.toString(); - app.all[name] = app.all[name].filter(function (func) { return func.sourceString !== fnStr; }); + app._allEvents[name] = app._allEvents[name].filter(function (func) { return func.sourceString !== fnStr; }); } else if (name) { - app.all[name] = []; + app._allEvents[name] = []; } else { - app.all = Object.create(null); + app._allEvents = Object.create(null); } return app @@ -264,8 +264,8 @@ function dush () { emit: function emit (name) { if (name !== '*') { var args = [].slice.call(arguments); - (app.all[name] || []).map(function (handler) { handler.apply(handler, args.slice(1)); }); - (app.all['*'] || []).map(function (handler) { handler.apply(handler, args); }); + (app._allEvents[name] || []).map(function (handler) { handler.apply(handler, args.slice(1)); }); + (app._allEvents['*'] || []).map(function (handler) { handler.apply(handler, args); }); } return app diff --git a/dist/dush.es.js b/dist/dush.es.js index 704586e..f66e8ec 100644 --- a/dist/dush.es.js +++ b/dist/dush.es.js @@ -17,7 +17,7 @@ * const dush = require('dush') * const emitter = dush() * - * console.log(emitter.all) // => {} + * console.log(emitter._allEvents) // => {} * console.log(emitter.on) // => Function * console.log(emitter.once) // => Function * console.log(emitter.off) // => Function @@ -30,7 +30,7 @@ */ function dush () { - var all = Object.create(null); + var _allEvents = Object.create(null); var app = { /** * > An listeners map of all registered events @@ -49,16 +49,16 @@ function dush () { * emitter.on('foo', () => {}) * emitter.on('bar', () => {}) * - * console.log(emitter.all) + * console.log(emitter._allEvents) * // => { foo: [Function, Function], bar: [Functon] } * ``` * - * @name .all - * @type {Object} `all` a key/value store of all events and their listeners + * @name ._allEvents + * @type {Object} `_allEvents` a key/value store of all events and their listeners * @api public */ - all: all, + _allEvents: _allEvents, /** * > Invokes `plugin` function immediately, which is passed @@ -124,7 +124,7 @@ function dush () { */ on: function on (name, handler, once) { - var e = app.all[name] || (app.all[name] = []); + var e = app._allEvents[name] || (app._allEvents[name] = []); function func () { if (!func.called) { @@ -214,13 +214,13 @@ function dush () { */ off: function off (name, handler) { - if (handler && app.all[name]) { + if (handler && app._allEvents[name]) { var fnStr = handler.toString(); - app.all[name] = app.all[name].filter(function (func) { return func.sourceString !== fnStr; }); + app._allEvents[name] = app._allEvents[name].filter(function (func) { return func.sourceString !== fnStr; }); } else if (name) { - app.all[name] = []; + app._allEvents[name] = []; } else { - app.all = Object.create(null); + app._allEvents = Object.create(null); } return app @@ -262,8 +262,8 @@ function dush () { emit: function emit (name) { if (name !== '*') { var args = [].slice.call(arguments); - (app.all[name] || []).map(function (handler) { handler.apply(handler, args.slice(1)); }); - (app.all['*'] || []).map(function (handler) { handler.apply(handler, args); }); + (app._allEvents[name] || []).map(function (handler) { handler.apply(handler, args.slice(1)); }); + (app._allEvents['*'] || []).map(function (handler) { handler.apply(handler, args); }); } return app diff --git a/dist/dush.umd.js b/dist/dush.umd.js index cf1ad7a..948b6b7 100644 --- a/dist/dush.umd.js +++ b/dist/dush.umd.js @@ -1,2 +1,2 @@ -!function(n,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):n.dush=e()}(this,function(){function n(){var n=Object.create(null),e={all:n,use:function(n){return n(e)||e},on:function(n,t,l){function r(){r.called||(e.off(n,r),t.apply(t,arguments),r.called=!0)}var u=e.all[n]||(e.all[n]=[]),o=l?r:t;return o.sourceString=t.toString(),u.push(o),e},once:function(n,t){return e.on(n,t,!0),e},off:function(n,t){if(t&&e.all[n]){var l=t.toString();e.all[n]=e.all[n].filter(function(n){return n.sourceString!==l})}else n?e.all[n]=[]:e.all=Object.create(null);return e},emit:function(n){if("*"!==n){var t=[].slice.call(arguments);(e.all[n]||[]).map(function(n){n.apply(n,t.slice(1))}),(e.all["*"]||[]).map(function(n){n.apply(n,t)})}return e}};return e}return n}); +!function(n,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):n.dush=e()}(this,function(){function n(){var n=Object.create(null),e={_allEvents:n,use:function(n){return n(e)||e},on:function(n,t,l){function r(){r.called||(e.off(n,r),t.apply(t,arguments),r.called=!0)}var u=e._allEvents[n]||(e._allEvents[n]=[]),o=l?r:t;return o.sourceString=t.toString(),u.push(o),e},once:function(n,t){return e.on(n,t,!0),e},off:function(n,t){if(t&&e._allEvents[n]){var l=t.toString();e._allEvents[n]=e._allEvents[n].filter(function(n){return n.sourceString!==l})}else n?e._allEvents[n]=[]:e._allEvents=Object.create(null);return e},emit:function(n){if("*"!==n){var t=[].slice.call(arguments);(e._allEvents[n]||[]).map(function(n){n.apply(n,t.slice(1))}),(e._allEvents["*"]||[]).map(function(n){n.apply(n,t)})}return e}};return e}return n}); //# sourceMappingURL=dush.umd.js.map diff --git a/dist/dush.umd.js.gz b/dist/dush.umd.js.gz index 5816593..b7c7aac 100644 Binary files a/dist/dush.umd.js.gz and b/dist/dush.umd.js.gz differ diff --git a/dist/dush.umd.js.map b/dist/dush.umd.js.map index 68a8e81..6e490af 100644 --- a/dist/dush.umd.js.map +++ b/dist/dush.umd.js.map @@ -1 +1 @@ -{"version":3,"file":"dush.umd.js","sources":["../src/index.js"],"sourcesContent":["/*!\n * dush \n *\n * Copyright (c) Charlike Mike Reagent <@tunnckoCore> (https://i.am.charlike.online)\n * Released under the MIT license.\n */\n\n'use strict'\n\n/**\n * > A constructor function that returns an object\n * with a few methods.\n *\n * See [JSBin Example](http://jsbin.com/mepemeluhi/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const dush = require('dush')\n * const emitter = dush()\n *\n * console.log(emitter.all) // => {}\n * console.log(emitter.on) // => Function\n * console.log(emitter.once) // => Function\n * console.log(emitter.off) // => Function\n * console.log(emitter.emit) // => Function\n * ```\n *\n * @name dush()\n * @return {Object} methods\n * @api public\n */\n\nexport default function dush () {\n let all = Object.create(null)\n const app = {\n /**\n * > An listeners map of all registered events\n * and their listeners. A key/value store, where 1) value\n * is an array of event listeners for the key and 2) key\n * is the name of the event.\n *\n * See [JSBin Example](http://jsbin.com/zuwayalovi/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * emitter.on('foo', () => {})\n * emitter.on('foo', () => {})\n * emitter.on('bar', () => {})\n *\n * console.log(emitter.all)\n * // => { foo: [Function, Function], bar: [Functon] }\n * ```\n *\n * @name .all\n * @type {Object} `all` a key/value store of all events and their listeners\n * @api public\n */\n\n all,\n\n /**\n * > Invokes `plugin` function immediately, which is passed\n * with `app` instance. You can use it for adding more methods\n * or properties to the instance. Useful if you want to make\n * dush to work with DOM for example.\n *\n * ```js\n * const app = dush()\n *\n * app.on('hi', (str) => {\n * console.log(str) // => 'Hello World!!'\n * })\n *\n * app.use((app) => {\n * app.foo = 'bar'\n * app.hello = (place) => app.emit('hi', `Hello ${place}!!`)\n * })\n *\n * console.log(app.foo) // => 'bar'\n * app.hello('World')\n * ```\n *\n * @name .use\n * @param {Function} `plugin` A function passed with `(app)` signature\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n use (plugin) {\n const ret = plugin(app)\n return ret || app\n },\n\n /**\n * > Add `handler` for `name` event.\n *\n * See [JSBin Example](http://jsbin.com/xeketuruto/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * emitter\n * .on('hi', (place) => {\n * console.log(`hello ${place}!`) // => 'hello world!'\n * })\n * .on('hi', (place) => {\n * console.log(`hi ${place}, yeah!`) // => 'hi world, yeah!'\n * })\n *\n * emitter.emit('hi', 'world')\n * ```\n *\n * @name .on\n * @param {String} `name` Type of event to listen for, or `'*'` for all events\n * @param {Function} `handler` Function to call in response to given event\n * @param {Boolean} `once` Make `handler` be called only once,\n * the `.once` method use this internally\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n on (name, handler, once) {\n let e = app.all[name] || (app.all[name] = [])\n\n function func () {\n if (!func.called) {\n app.off(name, func)\n handler.apply(handler, arguments)\n func.called = true\n }\n }\n\n var fn = once ? func : handler\n fn.sourceString = handler.toString()\n\n e.push(fn)\n return app\n },\n\n /**\n * > Add `handler` for `name` event that\n * will be called only one time.\n *\n * See [JSBin Example](http://jsbin.com/teculorima/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n * let called = 0\n *\n * emitter.once('foo', () => {\n * console.log('called only once')\n * called++\n * })\n *\n * emitter\n * .emit('foo', 111)\n * .emit('foo', 222)\n * .emit('foo', 333)\n *\n * console.log(called) // => 1\n * ```\n *\n * @name .once\n * @param {String} `name` Type of event to listen for, or `'*'` for all events\n * @param {Function} `handler` Function to call in response to given event\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n once (name, handler) {\n app.on(name, handler, true)\n return app\n },\n\n /**\n * > Remove `handler` for `name` event. If `handler` not\n * passed will remove **all** listeners for that `name` event.\n *\n * See [JSBin Example](http://jsbin.com/nujucoquvi/3/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * const handler = () => {\n * console.log('not called')\n * }\n *\n * emitter.on('foo', handler)\n * emitter.off('foo', handler)\n *\n * emitter.on('foo', (abc) => {\n * console.log('called', abc) // => 'called 123'\n * })\n * emitter.emit('foo', 123)\n *\n * // or removing all listeners of `foo`\n * emitter.off('foo')\n * emitter.emit('foo')\n * ```\n *\n * @name .off\n * @param {String} `name` Type of event to listen for, or `'*'` for all events\n * @param {Function} `handler` Function to call in response to given event\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n off (name, handler) {\n if (handler && app.all[name]) {\n const fnStr = handler.toString()\n app.all[name] = app.all[name].filter((func) => func.sourceString !== fnStr)\n } else if (name) {\n app.all[name] = []\n } else {\n app.all = Object.create(null)\n }\n\n return app\n },\n\n /**\n * > Invoke all handlers for given `name` event.\n * If present, `'*'` listeners are invoked too with `(type, ...rest)` signature,\n * where the `type` argument is a string representing the name of the\n * called event; and all of the rest arguments.\n *\n * See [JSBin Example](http://jsbin.com/muqujavolu/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * emitter.on('foo', (a, b, c) => {\n * console.log(`${a}, ${b}, ${c}`) // => 1, 2, 3\n * })\n *\n * emitter.on('*', (name, a, b, c) => {\n * console.log(`name is: ${name}`)\n * console.log(`rest args are: ${a}, ${b}, ${c}`)\n * })\n *\n * emitter.emit('foo', 1, 2, 3)\n * emitter.emit('bar', 555)\n * ```\n *\n * @name .emit\n * @param {String} `name` The name of the event to invoke\n * @param {any} `args` Any number of arguments of any type of value, passed to each listener\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n emit (name) {\n if (name !== '*') {\n var args = [].slice.call(arguments);\n (app.all[name] || []).map((handler) => { handler.apply(handler, args.slice(1)) });\n (app.all['*'] || []).map((handler) => { handler.apply(handler, args) })\n }\n\n return app\n }\n }\n\n return app\n}\n"],"names":["dush","let","all","Object","create","app","use","plugin","on","name","handler","once","func","called","off","apply","arguments","e","fn","sourceString","toString","push","const","fnStr","filter","emit","args","slice","call","map"],"mappings":"mKAiCA,QAAwBA,KACtBC,GAAIC,GAAMC,OAAOC,OAAO,MAClBC,GA2BJH,IAAAA,EA8BAI,aAAKC,GAEH,MADYA,GAAOF,IACLA,GAiChBG,YAAIC,EAAMC,EAASC,GAGjB,QAASC,KACFA,EAAKC,SACRR,EAAIS,IAAIL,EAAMG,GACdF,EAAQK,MAAML,EAASM,WACvBJ,EAAKC,QAAS,GANlBZ,GAAIgB,GAAIZ,EAAIH,IAAIO,KAAUJ,EAAIH,IAAIO,OAU9BS,EAAKP,EAAOC,EAAOF,CAIvB,OAHAQ,GAAGC,aAAeT,EAAQU,WAE1BH,EAAEI,KAAKH,GACAb,GAmCTM,cAAMF,EAAMC,GAEV,MADAL,GAAIG,GAAGC,EAAMC,GAAS,GACfL,GAsCTS,aAAKL,EAAMC,GACT,GAAIA,GAAWL,EAAIH,IAAIO,GAAO,CAC5Ba,GAAMC,GAAQb,EAAQU,UACtBf,GAAIH,IAAIO,GAAQJ,EAAIH,IAAIO,GAAMe,OAAO,SAACZ,SAASA,GAAKO,eAAiBI,QAC5Dd,GACTJ,EAAIH,IAAIO,MAERJ,EAAIH,IAAMC,OAAOC,OAAO,KAG1B,OAAOC,IAoCToB,cAAMhB,GACJ,GAAa,MAATA,EAAc,CAChB,GAAIiB,MAAUC,MAAMC,KAAKZ,YACxBX,EAAIH,IAAIO,QAAaoB,IAAI,SAACnB,GAAcA,EAAQK,MAAML,EAASgB,EAAKC,MAAM,OAC1EtB,EAAIH,IAAI,UAAY2B,IAAI,SAACnB,GAAcA,EAAQK,MAAML,EAASgB,KAGjE,MAAOrB,IAIX,OAAOA"} \ No newline at end of file +{"version":3,"file":"dush.umd.js","sources":["../src/index.js"],"sourcesContent":["/*!\n * dush \n *\n * Copyright (c) Charlike Mike Reagent <@tunnckoCore> (https://i.am.charlike.online)\n * Released under the MIT license.\n */\n\n'use strict'\n\n/**\n * > A constructor function that returns an object\n * with a few methods.\n *\n * See [JSBin Example](http://jsbin.com/mepemeluhi/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const dush = require('dush')\n * const emitter = dush()\n *\n * console.log(emitter._allEvents) // => {}\n * console.log(emitter.on) // => Function\n * console.log(emitter.once) // => Function\n * console.log(emitter.off) // => Function\n * console.log(emitter.emit) // => Function\n * ```\n *\n * @name dush()\n * @return {Object} methods\n * @api public\n */\n\nexport default function dush () {\n let _allEvents = Object.create(null)\n const app = {\n /**\n * > An listeners map of all registered events\n * and their listeners. A key/value store, where 1) value\n * is an array of event listeners for the key and 2) key\n * is the name of the event.\n *\n * See [JSBin Example](http://jsbin.com/zuwayalovi/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * emitter.on('foo', () => {})\n * emitter.on('foo', () => {})\n * emitter.on('bar', () => {})\n *\n * console.log(emitter._allEvents)\n * // => { foo: [Function, Function], bar: [Functon] }\n * ```\n *\n * @name ._allEvents\n * @type {Object} `_allEvents` a key/value store of all events and their listeners\n * @api public\n */\n\n _allEvents,\n\n /**\n * > Invokes `plugin` function immediately, which is passed\n * with `app` instance. You can use it for adding more methods\n * or properties to the instance. Useful if you want to make\n * dush to work with DOM for example.\n *\n * ```js\n * const app = dush()\n *\n * app.on('hi', (str) => {\n * console.log(str) // => 'Hello World!!'\n * })\n *\n * app.use((app) => {\n * app.foo = 'bar'\n * app.hello = (place) => app.emit('hi', `Hello ${place}!!`)\n * })\n *\n * console.log(app.foo) // => 'bar'\n * app.hello('World')\n * ```\n *\n * @name .use\n * @param {Function} `plugin` A function passed with `(app)` signature\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n use (plugin) {\n const ret = plugin(app)\n return ret || app\n },\n\n /**\n * > Add `handler` for `name` event.\n *\n * See [JSBin Example](http://jsbin.com/xeketuruto/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * emitter\n * .on('hi', (place) => {\n * console.log(`hello ${place}!`) // => 'hello world!'\n * })\n * .on('hi', (place) => {\n * console.log(`hi ${place}, yeah!`) // => 'hi world, yeah!'\n * })\n *\n * emitter.emit('hi', 'world')\n * ```\n *\n * @name .on\n * @param {String} `name` Type of event to listen for, or `'*'` for all events\n * @param {Function} `handler` Function to call in response to given event\n * @param {Boolean} `once` Make `handler` be called only once,\n * the `.once` method use this internally\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n on (name, handler, once) {\n let e = app._allEvents[name] || (app._allEvents[name] = [])\n\n function func () {\n if (!func.called) {\n app.off(name, func)\n handler.apply(handler, arguments)\n func.called = true\n }\n }\n\n var fn = once ? func : handler\n fn.sourceString = handler.toString()\n\n e.push(fn)\n return app\n },\n\n /**\n * > Add `handler` for `name` event that\n * will be called only one time.\n *\n * See [JSBin Example](http://jsbin.com/teculorima/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n * let called = 0\n *\n * emitter.once('foo', () => {\n * console.log('called only once')\n * called++\n * })\n *\n * emitter\n * .emit('foo', 111)\n * .emit('foo', 222)\n * .emit('foo', 333)\n *\n * console.log(called) // => 1\n * ```\n *\n * @name .once\n * @param {String} `name` Type of event to listen for, or `'*'` for all events\n * @param {Function} `handler` Function to call in response to given event\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n once (name, handler) {\n app.on(name, handler, true)\n return app\n },\n\n /**\n * > Remove `handler` for `name` event. If `handler` not\n * passed will remove **all** listeners for that `name` event.\n *\n * See [JSBin Example](http://jsbin.com/nujucoquvi/3/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * const handler = () => {\n * console.log('not called')\n * }\n *\n * emitter.on('foo', handler)\n * emitter.off('foo', handler)\n *\n * emitter.on('foo', (abc) => {\n * console.log('called', abc) // => 'called 123'\n * })\n * emitter.emit('foo', 123)\n *\n * // or removing all listeners of `foo`\n * emitter.off('foo')\n * emitter.emit('foo')\n * ```\n *\n * @name .off\n * @param {String} `name` Type of event to listen for, or `'*'` for all events\n * @param {Function} `handler` Function to call in response to given event\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n off (name, handler) {\n if (handler && app._allEvents[name]) {\n const fnStr = handler.toString()\n app._allEvents[name] = app._allEvents[name].filter((func) => func.sourceString !== fnStr)\n } else if (name) {\n app._allEvents[name] = []\n } else {\n app._allEvents = Object.create(null)\n }\n\n return app\n },\n\n /**\n * > Invoke all handlers for given `name` event.\n * If present, `'*'` listeners are invoked too with `(type, ...rest)` signature,\n * where the `type` argument is a string representing the name of the\n * called event; and all of the rest arguments.\n *\n * See [JSBin Example](http://jsbin.com/muqujavolu/edit?js,console).\n *\n * **Example**\n *\n * ```js\n * const emitter = dush()\n *\n * emitter.on('foo', (a, b, c) => {\n * console.log(`${a}, ${b}, ${c}`) // => 1, 2, 3\n * })\n *\n * emitter.on('*', (name, a, b, c) => {\n * console.log(`name is: ${name}`)\n * console.log(`rest args are: ${a}, ${b}, ${c}`)\n * })\n *\n * emitter.emit('foo', 1, 2, 3)\n * emitter.emit('bar', 555)\n * ```\n *\n * @name .emit\n * @param {String} `name` The name of the event to invoke\n * @param {any} `args` Any number of arguments of any type of value, passed to each listener\n * @return {Object} The `dush` instance for chaining\n * @api public\n */\n\n emit (name) {\n if (name !== '*') {\n var args = [].slice.call(arguments);\n (app._allEvents[name] || []).map((handler) => { handler.apply(handler, args.slice(1)) });\n (app._allEvents['*'] || []).map((handler) => { handler.apply(handler, args) })\n }\n\n return app\n }\n }\n\n return app\n}\n"],"names":["dush","let","_allEvents","Object","create","app","use","plugin","on","name","handler","once","func","called","off","apply","arguments","e","fn","sourceString","toString","push","const","fnStr","filter","emit","args","slice","call","map"],"mappings":"mKAiCA,QAAwBA,KACtBC,GAAIC,GAAaC,OAAOC,OAAO,MACzBC,GA2BJH,WAAAA,EA8BAI,aAAKC,GAEH,MADYA,GAAOF,IACLA,GAiChBG,YAAIC,EAAMC,EAASC,GAGjB,QAASC,KACFA,EAAKC,SACRR,EAAIS,IAAIL,EAAMG,GACdF,EAAQK,MAAML,EAASM,WACvBJ,EAAKC,QAAS,GANlBZ,GAAIgB,GAAIZ,EAAIH,WAAWO,KAAUJ,EAAIH,WAAWO,OAU5CS,EAAKP,EAAOC,EAAOF,CAIvB,OAHAQ,GAAGC,aAAeT,EAAQU,WAE1BH,EAAEI,KAAKH,GACAb,GAmCTM,cAAMF,EAAMC,GAEV,MADAL,GAAIG,GAAGC,EAAMC,GAAS,GACfL,GAsCTS,aAAKL,EAAMC,GACT,GAAIA,GAAWL,EAAIH,WAAWO,GAAO,CACnCa,GAAMC,GAAQb,EAAQU,UACtBf,GAAIH,WAAWO,GAAQJ,EAAIH,WAAWO,GAAMe,OAAO,SAACZ,SAASA,GAAKO,eAAiBI,QAC1Ed,GACTJ,EAAIH,WAAWO,MAEfJ,EAAIH,WAAaC,OAAOC,OAAO,KAGjC,OAAOC,IAoCToB,cAAMhB,GACJ,GAAa,MAATA,EAAc,CAChB,GAAIiB,MAAUC,MAAMC,KAAKZ,YACxBX,EAAIH,WAAWO,QAAaoB,IAAI,SAACnB,GAAcA,EAAQK,MAAML,EAASgB,EAAKC,MAAM,OACjFtB,EAAIH,WAAW,UAAY2B,IAAI,SAACnB,GAAcA,EAAQK,MAAML,EAASgB,KAGxE,MAAOrB,IAIX,OAAOA"} \ No newline at end of file diff --git a/src/index.js b/src/index.js index 8397d3d..b14e9ad 100644 --- a/src/index.js +++ b/src/index.js @@ -19,7 +19,7 @@ * const dush = require('dush') * const emitter = dush() * - * console.log(emitter.all) // => {} + * console.log(emitter._allEvents) // => {} * console.log(emitter.on) // => Function * console.log(emitter.once) // => Function * console.log(emitter.off) // => Function @@ -32,7 +32,7 @@ */ export default function dush () { - let all = Object.create(null) + let _allEvents = Object.create(null) const app = { /** * > An listeners map of all registered events @@ -51,16 +51,16 @@ export default function dush () { * emitter.on('foo', () => {}) * emitter.on('bar', () => {}) * - * console.log(emitter.all) + * console.log(emitter._allEvents) * // => { foo: [Function, Function], bar: [Functon] } * ``` * - * @name .all - * @type {Object} `all` a key/value store of all events and their listeners + * @name ._allEvents + * @type {Object} `_allEvents` a key/value store of all events and their listeners * @api public */ - all, + _allEvents, /** * > Invokes `plugin` function immediately, which is passed @@ -126,7 +126,7 @@ export default function dush () { */ on (name, handler, once) { - let e = app.all[name] || (app.all[name] = []) + let e = app._allEvents[name] || (app._allEvents[name] = []) function func () { if (!func.called) { @@ -216,13 +216,13 @@ export default function dush () { */ off (name, handler) { - if (handler && app.all[name]) { + if (handler && app._allEvents[name]) { const fnStr = handler.toString() - app.all[name] = app.all[name].filter((func) => func.sourceString !== fnStr) + app._allEvents[name] = app._allEvents[name].filter((func) => func.sourceString !== fnStr) } else if (name) { - app.all[name] = [] + app._allEvents[name] = [] } else { - app.all = Object.create(null) + app._allEvents = Object.create(null) } return app @@ -264,8 +264,8 @@ export default function dush () { emit (name) { if (name !== '*') { var args = [].slice.call(arguments); - (app.all[name] || []).map((handler) => { handler.apply(handler, args.slice(1)) }); - (app.all['*'] || []).map((handler) => { handler.apply(handler, args) }) + (app._allEvents[name] || []).map((handler) => { handler.apply(handler, args.slice(1)) }); + (app._allEvents['*'] || []).map((handler) => { handler.apply(handler, args) }) } return app diff --git a/test.js b/test.js index 8a4641e..b77ffd5 100644 --- a/test.js +++ b/test.js @@ -13,8 +13,8 @@ var test = require('mukla') var dush = require('./dist/dush.common') var app = dush() -test('should return an instance with methods and `.all` object', function (done) { - test.strictEqual(typeof app.all, 'object') +test('should return an instance with methods and `._allEvents` object', function (done) { + test.strictEqual(typeof app._allEvents, 'object') test.strictEqual(typeof app.use, 'function') test.strictEqual(typeof app.on, 'function') test.strictEqual(typeof app.off, 'function') @@ -23,7 +23,7 @@ test('should return an instance with methods and `.all` object', function (done) done() }) -test('should instace has .all object that contains all handlers', function (done) { +test('should instace has ._allEvents object that contains all handlers', function (done) { var fn = function () {} app.on('aaa', fn) @@ -33,10 +33,10 @@ test('should instace has .all object that contains all handlers', function (done app.on('ccc', fn) app.on('ccc', fn) - test.deepStrictEqual(Object.keys(app.all), ['aaa', 'bbb', 'ccc']) - test.strictEqual(app.all.aaa.length, 2) - test.strictEqual(app.all.bbb.length, 1) - test.strictEqual(app.all.ccc.length, 3) + test.deepStrictEqual(Object.keys(app._allEvents), ['aaa', 'bbb', 'ccc']) + test.strictEqual(app._allEvents.aaa.length, 2) + test.strictEqual(app._allEvents.bbb.length, 1) + test.strictEqual(app._allEvents.ccc.length, 3) app.emit('zzz') done() }) @@ -106,7 +106,7 @@ test('should .off("foo", fn) remove the handler', function (done) { test.strictEqual(called, 0) test.strictEqual(second, 1) - test.strictEqual(app.all.qux.length, 1) + test.strictEqual(app._allEvents.qux.length, 1) done() }) @@ -116,7 +116,7 @@ test('should .off("foo") remove all "foo" handlers', function (done) { .on('zzz', function () {}) .off('zzz') - test.strictEqual(app.all.zzz.length, 0) + test.strictEqual(app._allEvents.zzz.length, 0) done() }) @@ -278,14 +278,14 @@ test('should `.off()` remove all listeners', function (done) { app.once('b', fixture) app.on('c', fixture) - var evts = Object.keys(app.all) + var evts = Object.keys(app._allEvents) test.strictEqual(evts.length, 3) - test.strictEqual(app.all.a.length, 3) - test.strictEqual(app.all.b.length, 2) - test.strictEqual(app.all.c.length, 1) + test.strictEqual(app._allEvents.a.length, 3) + test.strictEqual(app._allEvents.b.length, 2) + test.strictEqual(app._allEvents.c.length, 1) app.off() - var allEvents = Object.keys(app.all) + var allEvents = Object.keys(app._allEvents) test.strictEqual(allEvents.length, 0) done() })