mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
8256228e69
MINOR Updated jQuery.concrete references to point to the new "entwine" name git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@102695 467b73ca-7a2a-4603-9d3b-597d59a354a9
112 lines
3.2 KiB
JavaScript
112 lines
3.2 KiB
JavaScript
describe 'Entwine'
|
|
describe 'Events'
|
|
|
|
before
|
|
$('body').append('<div id="dom_test"></div>')
|
|
end
|
|
|
|
after
|
|
$('#dom_test').remove()
|
|
end
|
|
|
|
before_each
|
|
$.entwine.synchronous_mode();
|
|
$.entwine.clear_all_rules()
|
|
$('#dom_test').html('<div id="a" class="a b c"></div>')
|
|
end
|
|
|
|
it 'calls onfoo when foo triggered'
|
|
var a = 0;
|
|
$('#a').entwine({onfoo: function(){a = 1;} });
|
|
a.should.equal 0
|
|
$('#a').trigger('foo');
|
|
a.should.equal 1
|
|
end
|
|
|
|
it 'only calls most specific onfoo when foo triggered'
|
|
var a = 0, b = 0;
|
|
$('#a.a').entwine({onfoo: function(){a = 1;} });
|
|
$('#a').entwine({onfoo: function(){b = 1;} });
|
|
a.should.equal 0
|
|
b.should.equal 0
|
|
$('#a').trigger('foo');
|
|
a.should.equal 1
|
|
b.should.equal 0
|
|
end
|
|
|
|
it 'calls namespaced onfoo when foo triggered'
|
|
var a = 0;
|
|
$('#a').entwine('bar', function($){return{onfoo: function(){a = 1;} }});
|
|
a.should.equal 0
|
|
$('#a').trigger('foo');
|
|
a.should.equal 1
|
|
end
|
|
|
|
it 'calls most specific namespaced onfoo and most specific non-namespaced onfoo when foo triggered'
|
|
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;} }});
|
|
[a, b, c, d].should.eql [0, 0, 0, 0]
|
|
|
|
$('#a').trigger('foo');
|
|
[a, b, c, d].should.eql [1, 0, 1, 0]
|
|
end
|
|
|
|
it 'calls up correctly on _super'
|
|
var a = 0, b = 0;
|
|
$('#a').entwine({onfoo: function(){a += 1;} });
|
|
$('#a.a').entwine({onfoo: function(){this._super(); b += 1; this._super();} });
|
|
|
|
[a, b].should.eql [0, 0]
|
|
$('#a').trigger('foo')
|
|
[a, b].should.eql [2, 1]
|
|
end
|
|
|
|
it 'passes event object'
|
|
var event;
|
|
$('#a').entwine({onfoo: function(e){event = e;} });
|
|
$('#a').trigger('foo');
|
|
event.should.have_prop 'type', 'foo'
|
|
$(event.target).should.have_attr 'id', 'a'
|
|
end
|
|
|
|
it 'delegates submit events to forms'
|
|
var a = 0;
|
|
$('<form class="foo" action="javascript:undefined">').appendTo('#dom_test');
|
|
|
|
$('.foo').entwine({onsubmit: function(e, d){a = 1;} });
|
|
|
|
a.should.eql 0
|
|
$('.foo').trigger('submit');
|
|
a.should.eql 1
|
|
end
|
|
|
|
describe 'can pass event data'
|
|
it 'on custom events'
|
|
var data;
|
|
$('#a').entwine({onfoo: function(e, d){data = d;} });
|
|
$('#a').trigger('foo', {cheese: 'burger'});
|
|
data.cheese.should.eql 'burger'
|
|
end
|
|
|
|
it 'on normal events'
|
|
var data;
|
|
$('#a').entwine({onclick: function(e, d){data = d;} });
|
|
$('#a').trigger('click', {finger: 'left'});
|
|
data.finger.should.eql 'left'
|
|
end
|
|
|
|
it 'on submit'
|
|
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'});
|
|
data.cheese.should.eql 'burger'
|
|
end
|
|
end
|
|
end
|
|
end |