2015-05-04 01:12:38 +02:00
|
|
|
import * as Events from '../../src/js/utils/events.js';
|
2015-03-26 06:43:41 +02:00
|
|
|
import document from 'global/document';
|
2013-01-11 00:06:12 +03:00
|
|
|
|
2015-03-26 06:43:41 +02:00
|
|
|
q.module('Events');
|
2015-03-11 03:01:11 +02:00
|
|
|
|
2013-01-11 00:06:12 +03:00
|
|
|
test('should add and remove an event listener to an element', function(){
|
|
|
|
expect(1);
|
|
|
|
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var listener = function(){
|
|
|
|
ok(true, 'Click Triggered');
|
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, 'click', listener);
|
|
|
|
Events.trigger(el, 'click'); // 1 click
|
|
|
|
Events.off(el, 'click', listener);
|
|
|
|
Events.trigger(el, 'click'); // No click should happen.
|
2013-01-11 00:06:12 +03:00
|
|
|
});
|
|
|
|
|
2014-07-08 21:51:47 +03:00
|
|
|
test('should add and remove multiple event listeners to an element with a single call', function(){
|
|
|
|
expect(6);
|
|
|
|
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var listener = function(){
|
|
|
|
ok(true, 'Callback triggered');
|
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, ['click', 'event1', 'event2'], listener);
|
2014-07-08 21:51:47 +03:00
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(el, 'click');
|
|
|
|
Events.trigger(el, 'click');
|
|
|
|
Events.off(el, 'click', listener);
|
|
|
|
Events.trigger(el, 'click'); // No click should happen.
|
2014-07-08 21:51:47 +03:00
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(el, 'event1');
|
|
|
|
Events.trigger(el, 'event1');
|
|
|
|
Events.off(el, 'event1', listener);
|
|
|
|
Events.trigger(el, 'event1'); // No event1 should happen.
|
2014-07-08 21:51:47 +03:00
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(el, 'event2');
|
|
|
|
Events.trigger(el, 'event2');
|
|
|
|
Events.off(el, 'event2', listener);
|
|
|
|
Events.trigger(el, 'event2'); // No event2 should happen.
|
2014-07-08 21:51:47 +03:00
|
|
|
});
|
|
|
|
|
2015-06-05 19:36:59 +02:00
|
|
|
test('should be possible to pass data when you trigger an event', function () {
|
|
|
|
expect(6);
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var fakeData1 = 'Fake Data 1';
|
|
|
|
var fakeData2 = {txt: 'Fake Data 2'};
|
|
|
|
|
|
|
|
var listener = function(evt, hash){
|
|
|
|
ok(true, 'Callback triggered');
|
|
|
|
deepEqual(fakeData1, hash.d1, 'Shoulbe be passed to the handler');
|
|
|
|
deepEqual(fakeData2, hash.d2, 'Shoulbe be passed to the handler');
|
|
|
|
};
|
|
|
|
|
|
|
|
Events.on(el, ['event1', 'event2'], listener);
|
|
|
|
Events.trigger(el, 'event1', { d1: fakeData1, d2:fakeData2});
|
|
|
|
Events.trigger(el, 'event2', { d1: fakeData1, d2:fakeData2});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2013-01-11 00:06:12 +03:00
|
|
|
test('should remove all listeners of a type', function(){
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var clicks = 0;
|
|
|
|
var listener = function(){
|
|
|
|
clicks++;
|
|
|
|
};
|
|
|
|
var listener2 = function(){
|
|
|
|
clicks++;
|
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, 'click', listener);
|
|
|
|
Events.on(el, 'click', listener2);
|
|
|
|
Events.trigger(el, 'click'); // 2 clicks
|
2013-01-11 00:06:12 +03:00
|
|
|
|
2013-02-09 01:20:46 +03:00
|
|
|
ok(clicks === 2, 'both click listeners fired');
|
2013-01-11 00:06:12 +03:00
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.off(el, 'click');
|
|
|
|
Events.trigger(el, 'click'); // No click should happen.
|
2013-01-11 00:06:12 +03:00
|
|
|
|
2013-02-09 01:20:46 +03:00
|
|
|
ok(clicks === 2, 'no click listeners fired');
|
2013-01-11 00:06:12 +03:00
|
|
|
});
|
|
|
|
|
2014-07-08 21:51:47 +03:00
|
|
|
test('should remove all listeners of an array of types', function(){
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var calls = 0;
|
|
|
|
var listener = function(){
|
|
|
|
calls++;
|
|
|
|
};
|
|
|
|
var listener2 = function(){
|
|
|
|
calls++;
|
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, ['click', 'event1'], listener);
|
|
|
|
Events.on(el, ['click', 'event1'], listener2);
|
|
|
|
Events.trigger(el, 'click'); // 2 calls
|
|
|
|
Events.trigger(el, 'event1'); // 2 calls
|
2014-07-08 21:51:47 +03:00
|
|
|
|
|
|
|
ok(calls === 4, 'both click listeners fired');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.off(el, ['click', 'event1']);
|
|
|
|
Events.trigger(el, 'click'); // No click should happen.
|
|
|
|
Events.trigger(el, 'event1'); // No event1 should happen.
|
2014-07-08 21:51:47 +03:00
|
|
|
|
|
|
|
ok(calls === 4, 'no event listeners fired');
|
|
|
|
});
|
|
|
|
|
2013-01-11 00:06:12 +03:00
|
|
|
test('should remove all listeners from an element', function(){
|
|
|
|
expect(2);
|
|
|
|
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var listener = function(){
|
|
|
|
ok(true, 'Fake1 Triggered');
|
|
|
|
};
|
|
|
|
var listener2 = function(){
|
|
|
|
ok(true, 'Fake2 Triggered');
|
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, 'fake1', listener);
|
|
|
|
Events.on(el, 'fake2', listener2);
|
2013-01-11 00:06:12 +03:00
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(el, 'fake1');
|
|
|
|
Events.trigger(el, 'fake2');
|
2013-01-11 00:06:12 +03:00
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.off(el);
|
2013-01-11 00:06:12 +03:00
|
|
|
|
|
|
|
// No listener should happen.
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(el, 'fake1');
|
|
|
|
Events.trigger(el, 'fake2');
|
2013-01-11 00:06:12 +03:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should listen only once', function(){
|
|
|
|
expect(1);
|
|
|
|
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var listener = function(){
|
|
|
|
ok(true, 'Click Triggered');
|
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.one(el, 'click', listener);
|
|
|
|
Events.trigger(el, 'click'); // 1 click
|
|
|
|
Events.trigger(el, 'click'); // No click should happen.
|
2013-01-11 00:06:12 +03:00
|
|
|
});
|
2013-01-18 04:33:53 +03:00
|
|
|
|
2014-07-08 21:51:47 +03:00
|
|
|
test( 'should listen only once in multiple events from a single call', function(){
|
|
|
|
expect(3);
|
|
|
|
|
|
|
|
var el = document.createElement('div');
|
|
|
|
var listener = function(){
|
|
|
|
ok(true, 'Callback Triggered');
|
|
|
|
};
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.one(el, ['click', 'event1', 'event2'], listener);
|
|
|
|
Events.trigger(el, 'click'); // 1 click
|
|
|
|
Events.trigger(el, 'click'); // No click should happen.
|
|
|
|
Events.trigger(el, 'event1'); // event1 must be handled.
|
|
|
|
Events.trigger(el, 'event1'); // No event1 should be handled.
|
|
|
|
Events.trigger(el, 'event2'); // event2 must be handled.
|
|
|
|
Events.trigger(el, 'event2'); // No event2 should be handled.
|
2014-07-08 21:51:47 +03:00
|
|
|
});
|
|
|
|
|
2013-01-18 04:33:53 +03:00
|
|
|
test('should stop immediate propagtion', function(){
|
|
|
|
expect(1);
|
|
|
|
|
|
|
|
var el = document.createElement('div');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, 'test', function(e){
|
2013-01-18 04:33:53 +03:00
|
|
|
ok(true, 'First listener fired');
|
|
|
|
e.stopImmediatePropagation();
|
|
|
|
});
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, 'test', function(e){
|
2013-01-18 04:33:53 +03:00
|
|
|
ok(false, 'Second listener fired');
|
|
|
|
});
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(el, 'test');
|
2013-01-18 04:33:53 +03:00
|
|
|
});
|
2013-09-04 23:33:27 +03:00
|
|
|
|
|
|
|
test('should bubble up DOM unless bubbles == false', function(){
|
|
|
|
expect(3);
|
|
|
|
|
|
|
|
var outer = document.createElement('div');
|
|
|
|
var inner = outer.appendChild(document.createElement('div'));
|
|
|
|
|
|
|
|
// Verify that if bubbles === true, event bubbles up dom.
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(inner, 'bubbles', function(e){
|
2013-09-04 23:33:27 +03:00
|
|
|
ok(true, 'Inner listener fired');
|
|
|
|
});
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(outer, 'bubbles', function(e){
|
2013-09-04 23:33:27 +03:00
|
|
|
ok(true, 'Outer listener fired');
|
|
|
|
});
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(inner, { type:'bubbles', target:inner, bubbles:true });
|
2013-09-04 23:33:27 +03:00
|
|
|
|
|
|
|
// Only change 'bubbles' to false, and verify only inner handler is called.
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(inner, 'nobub', function(e){
|
2013-09-04 23:33:27 +03:00
|
|
|
ok(true, 'Inner listener fired');
|
|
|
|
});
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(outer, 'nobub', function(e){
|
2013-09-04 23:33:27 +03:00
|
|
|
ok(false, 'Outer listener fired');
|
|
|
|
});
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(inner, { type:'nobub', target:inner, bubbles:false });
|
2013-09-04 23:33:27 +03:00
|
|
|
});
|
2014-03-25 00:56:02 +03:00
|
|
|
|
|
|
|
test('should have a defaultPrevented property on an event that was prevent from doing default action', function() {
|
|
|
|
expect(2);
|
|
|
|
|
|
|
|
var el = document.createElement('div');
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, 'test', function(e){
|
2014-03-25 00:56:02 +03:00
|
|
|
ok(true, 'First listener fired');
|
|
|
|
e.preventDefault();
|
|
|
|
});
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.on(el, 'test', function(e){
|
2014-03-25 00:56:02 +03:00
|
|
|
ok(e.defaultPrevented, 'Should have `defaultPrevented` to signify preventDefault being called');
|
|
|
|
});
|
|
|
|
|
2015-03-11 03:01:11 +02:00
|
|
|
Events.trigger(el, 'test');
|
2014-03-25 00:56:02 +03:00
|
|
|
});
|
2015-04-09 12:03:29 +02:00
|
|
|
|
|
|
|
test('should have relatedTarget correctly set on the event', function() {
|
|
|
|
expect(2);
|
|
|
|
|
|
|
|
var el1 = document.createElement('div'),
|
|
|
|
el2 = document.createElement('div'),
|
|
|
|
relatedEl = document.createElement('div');
|
|
|
|
|
|
|
|
Events.on(el1, 'click', function(e){
|
|
|
|
equal(e.relatedTarget, relatedEl, 'relatedTarget is set for all browsers when related element is set on the event');
|
|
|
|
});
|
|
|
|
|
|
|
|
Events.trigger(el1, { type:'click', relatedTarget:relatedEl });
|
|
|
|
|
|
|
|
Events.on(el2, 'click', function(e) {
|
|
|
|
equal(e.relatedTarget, null, 'relatedTarget is null when none is provided');
|
|
|
|
});
|
|
|
|
|
|
|
|
Events.trigger(el2, { type:'click', relatedTarget:undefined });
|
|
|
|
});
|