mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
223 lines
4.6 KiB
JavaScript
223 lines
4.6 KiB
JavaScript
describe('Entwine', function(){
|
|
|
|
beforeEach(function(){
|
|
$('body').append('<div id="dom_test"></div>');
|
|
});
|
|
|
|
afterEach(function(){
|
|
$('#dom_test').remove();
|
|
});
|
|
|
|
describe('Events', function(){
|
|
|
|
beforeEach(function(){
|
|
$.entwine.synchronous_mode();
|
|
$.entwine.clear_all_rules();
|
|
$('#dom_test').html('<div id="a" class="a b c"></div>');
|
|
});
|
|
|
|
it('calls onfoo when foo triggered', function(){
|
|
var a = 0;
|
|
|
|
$('#a').entwine({
|
|
onfoo: function(){a = 1;}
|
|
});
|
|
|
|
expect(a).toEqual(0);
|
|
|
|
$('#a').trigger('foo');
|
|
expect(a).toEqual(1);
|
|
});
|
|
|
|
it('only calls most specific onfoo when foo triggered', function(){
|
|
var a = 0, b = 0;
|
|
|
|
$('#a.a').entwine({
|
|
onfoo: function(){a = 1;}
|
|
});
|
|
$('#a').entwine({
|
|
onfoo: function(){b = 1;}
|
|
});
|
|
|
|
expect(a).toEqual(0);
|
|
expect(b).toEqual(0);
|
|
|
|
$('#a').trigger('foo');
|
|
expect(a).toEqual(1);
|
|
expect(b).toEqual(0);
|
|
});
|
|
|
|
it('calls namespaced onfoo when foo triggered', function(){
|
|
var a = 0;
|
|
|
|
$('#a').entwine('bar', function($){return{
|
|
onfoo: function(){a = 1;}
|
|
};});
|
|
|
|
expect(a).toEqual(0);
|
|
|
|
$('#a').trigger('foo');
|
|
expect(a).toEqual(1);
|
|
});
|
|
|
|
it('calls most specific namespaced onfoo and most specific non-namespaced onfoo when foo triggered', function(){
|
|
var a = 0, b = 0, c = 0, d = 0;
|
|
|
|
$('#a.a').entwine({
|
|
onfoo: function(){a = 1;}
|
|
});
|
|
$('#a').entwine({
|
|
onfoo: function(){b = 1;}
|
|
});
|
|
$('#a.a').entwine('bar', function($){return{
|
|
onfoo: function(){c = 1;}
|
|
};});
|
|
$('#a').entwine('bar', function($){return{
|
|
onfoo: function(){d = 1;}
|
|
};});
|
|
|
|
expect([a, b, c, d]).toEqual([0, 0, 0, 0]);
|
|
|
|
$('#a').trigger('foo');
|
|
expect([a, b, c, d]).toEqual([1, 0, 1, 0]);
|
|
});
|
|
|
|
it('calls up correctly on _super', function(){
|
|
var a = 0, b = 0;
|
|
|
|
$('#a').entwine({
|
|
onfoo: function(){a += 1;}
|
|
});
|
|
$('#a.a').entwine({
|
|
onfoo: function(){this._super(); b += 1; this._super();}
|
|
});
|
|
|
|
expect([a, b]).toEqual([0, 0]);
|
|
|
|
$('#a').trigger('foo')
|
|
expect([a, b]).toEqual([2, 1]);
|
|
});
|
|
|
|
it('passes event object', function(){
|
|
var event;
|
|
|
|
$('#a').entwine({
|
|
onfoo: function(e){event = e;}
|
|
});
|
|
|
|
$('#a').trigger('foo');
|
|
expect(event.type).toBeDefined();
|
|
expect(event.type).toEqual('foo');
|
|
expect(event.target).toHaveAttr('id', 'a');
|
|
});
|
|
|
|
it('delegates submit events to forms', function(){
|
|
var a = 0;
|
|
$('<form class="foo" action="javascript:undefined">').appendTo('#dom_test');
|
|
|
|
$('.foo').entwine({
|
|
onsubmit: function(e, d){a = 1;}
|
|
});
|
|
|
|
expect(a).toEqual(0);
|
|
|
|
$('.foo').trigger('submit');
|
|
expect(a).toEqual(1);
|
|
});
|
|
|
|
describe('can pass event data', function(){
|
|
|
|
it('on custom events', function(){
|
|
var data;
|
|
|
|
$('#a').entwine({
|
|
onfoo: function(e, d){data = d;}
|
|
});
|
|
|
|
$('#a').trigger('foo', {cheese: 'burger'});
|
|
expect(data.cheese).toEqual('burger');
|
|
});
|
|
|
|
it('on normal events', function(){
|
|
var data;
|
|
|
|
$('#a').entwine({
|
|
onclick: function(e, d){data = d;}
|
|
});
|
|
|
|
$('#a').trigger('click', {finger: 'left'});
|
|
expect(data.finger).toEqual('left');
|
|
});
|
|
|
|
it('on submit', function(){
|
|
var data;
|
|
$('<form class="foo" action="javascript:undefined">').appendTo('#dom_test');
|
|
|
|
$('.foo').entwine({
|
|
onsubmit: function(e, d){data = d; return false;}
|
|
});
|
|
|
|
$('.foo').trigger('submit', {cheese: 'burger'});
|
|
expect(data.cheese).toEqual('burger');
|
|
});
|
|
});
|
|
|
|
describe('calls onchange on checkboxes properly', function(){
|
|
|
|
beforeEach(function(){
|
|
$('#dom_test').html('<input id="i" type="checkbox" name="test_input_i" value="i" />');
|
|
});
|
|
|
|
it('calls onchange', function(){
|
|
var a = 0;
|
|
|
|
$('#i').entwine({
|
|
onchange: function(){a += 1;}
|
|
});
|
|
|
|
// Can't just "click()" - it's not the same as an actual click event
|
|
$('#i').trigger('focusin');
|
|
$('#i')[0].click();
|
|
expect(a).toEqual(1);
|
|
});
|
|
|
|
it('calls onchange only once per change', function(){
|
|
var a = 0;
|
|
|
|
$('#i').entwine({
|
|
onchange: function(){a += 1;}
|
|
});
|
|
|
|
$('#i').trigger('focusin');
|
|
$('#i')[0].click();
|
|
expect(a).toEqual(1);
|
|
|
|
$('#i').trigger('focusout');
|
|
$('#i').trigger('focusin');
|
|
$('#i').trigger('focusout');
|
|
expect(a).toEqual(1);
|
|
|
|
$('#i')[0].click();
|
|
expect(a).toEqual(2);
|
|
});
|
|
|
|
it('calls onchange even if checked attribute altered in mean time', function(){
|
|
var a = 0;
|
|
|
|
$('#i').entwine({
|
|
onchange: function(){a += 1;}
|
|
});
|
|
|
|
$('#i').trigger('focusin');
|
|
$('#i')[0].click();
|
|
expect(a).toEqual(1);
|
|
|
|
$('#i').removeAttr('checked');
|
|
|
|
$('#i').trigger('focusin');
|
|
$('#i')[0].click();
|
|
expect(a).toEqual(2);
|
|
});
|
|
});
|
|
});
|
|
}); |