123456789101112131415161718192021222324252627282930313233343536373839404142 |
- /**
- * @fileoverview A set of helper functions to make it easier to work
- * with events in async/await manner.
- */
- /**
- * @param {!EventTarget} target
- * @param {string} eventName
- * @return {!Promise<!Event>}
- */
- const waitForEvent = (target, eventName) => {
- return new Promise(resolve => {
- target.addEventListener(eventName, resolve, { once: true });
- });
- };
- /**
- * @param {!EventEmitter} emitter
- * @param {string} eventName
- * @return {!Promise<!Array>} With Event as the first item.
- */
- const emittedOnce = (emitter, eventName) => {
- return emittedNTimes(emitter, eventName, 1).then(([result]) => result);
- };
- const emittedNTimes = (emitter, eventName, times) => {
- const events = [];
- return new Promise(resolve => {
- const handler = (...args) => {
- events.push(args);
- if (events.length === times) {
- emitter.removeListener(eventName, handler);
- resolve(events);
- }
- };
- emitter.on(eventName, handler);
- });
- };
- exports.emittedOnce = emittedOnce;
- exports.emittedNTimes = emittedNTimes;
- exports.waitForEvent = waitForEvent;
|