Merge pull request #10090 from Snuffleupagus/pr-10019-followup

Ensure that all event properties are included, even if no (internal) listeners are registered, when re-dispatching events to the DOM (PR 10019 follow-up)
This commit is contained in:
Tim van der Meij 2018-09-21 14:43:55 +02:00 committed by GitHub
commit ad6ab88fdf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 59 additions and 10 deletions

View File

@ -182,12 +182,25 @@ describe('ui_utils', function() {
it('dispatch event', function () {
var eventBus = new EventBus();
var count = 0;
eventBus.on('test', function () {
eventBus.on('test', function(evt) {
expect(evt).toEqual(undefined);
count++;
});
eventBus.dispatch('test');
expect(count).toEqual(1);
});
it('dispatch event with arguments', function() {
const eventBus = new EventBus();
let count = 0;
eventBus.on('test', function(evt) {
expect(evt).toEqual({ abc: 123, });
count++;
});
eventBus.dispatch('test', {
abc: 123,
});
expect(count).toEqual(1);
});
it('dispatch different event', function () {
var eventBus = new EventBus();
var count = 0;
@ -269,16 +282,21 @@ describe('ui_utils', function() {
}
const eventBus = new EventBus();
let count = 0;
eventBus.on('test', function() {
count++;
});
document.addEventListener('test', function() {
eventBus.on('test', function(evt) {
expect(evt).toEqual(undefined);
count++;
});
function domEventListener() {
done.fail('shall not dispatch DOM event.');
}
document.addEventListener('test', domEventListener);
eventBus.dispatch('test');
Promise.resolve().then(() => {
expect(count).toEqual(1);
document.removeEventListener('test', domEventListener);
done();
});
});
@ -288,16 +306,46 @@ describe('ui_utils', function() {
}
const eventBus = new EventBus({ dispatchToDOM: true, });
let count = 0;
eventBus.on('test', function() {
eventBus.on('test', function(evt) {
expect(evt).toEqual(undefined);
count++;
});
document.addEventListener('test', function() {
function domEventListener(evt) {
expect(evt.detail).toEqual({});
count++;
});
}
document.addEventListener('test', domEventListener);
eventBus.dispatch('test');
Promise.resolve().then(() => {
expect(count).toEqual(2);
document.removeEventListener('test', domEventListener);
done();
});
});
it('should re-dispatch to DOM, with arguments (without internal listeners)',
function(done) {
if (isNodeJS()) {
pending('Document in not supported in Node.js.');
}
const eventBus = new EventBus({ dispatchToDOM: true, });
let count = 0;
function domEventListener(evt) {
expect(evt.detail).toEqual({ abc: 123, });
count++;
}
document.addEventListener('test', domEventListener);
eventBus.dispatch('test', {
abc: 123,
});
Promise.resolve().then(() => {
expect(count).toEqual(1);
document.removeEventListener('test', domEventListener);
done();
});
});

View File

@ -708,12 +708,13 @@ class EventBus {
let eventListeners = this._listeners[eventName];
if (!eventListeners || eventListeners.length === 0) {
if (this._dispatchToDOM) {
this._dispatchDOMEvent(eventName);
const args = Array.prototype.slice.call(arguments, 1);
this._dispatchDOMEvent(eventName, args);
}
return;
}
// Passing all arguments after the eventName to the listeners.
let args = Array.prototype.slice.call(arguments, 1);
const args = Array.prototype.slice.call(arguments, 1);
// Making copy of the listeners array in case if it will be modified
// during dispatch.
eventListeners.slice(0).forEach(function (listener) {