mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
147 lines
3.3 KiB
JavaScript
147 lines
3.3 KiB
JavaScript
describe('Entwine', function(){
|
|
|
|
beforeEach(function(){
|
|
$('body').append('<div id="dom_test"></div>');
|
|
});
|
|
|
|
afterEach(function(){
|
|
$('#dom_test').remove();
|
|
});
|
|
|
|
describe('Ctors', function(){
|
|
|
|
beforeEach(function(){
|
|
$.entwine.synchronous_mode();
|
|
$.entwine.clear_all_rules();
|
|
$('#dom_test').html('<div id="a" class="a b c"></div>');
|
|
});
|
|
|
|
it('calls onmatch when new element created', function(){
|
|
var a = false;
|
|
|
|
$('#b').entwine({
|
|
onmatch: function(){a = true;}
|
|
});
|
|
|
|
expect(a).toBeFalsy();
|
|
|
|
$('#a').after('<div id="b"></div>');
|
|
expect(a).toBeTruthy();
|
|
});
|
|
|
|
it('calls onunmatch when new element deleted', function(){
|
|
var a = 0;
|
|
|
|
$('#b').entwine({
|
|
onmatch: function(){a = 1;},
|
|
onunmatch: function(){a = 2;}
|
|
});
|
|
|
|
expect(a).toEqual(0);
|
|
|
|
$('#a').after('<div id="b"></div>');
|
|
expect(a).toEqual(1);
|
|
|
|
$('#b').remove();
|
|
expect(a).toEqual(2);
|
|
});
|
|
|
|
it('calls onmatch when ruleset matches after class added', function(){
|
|
var a = 0;
|
|
|
|
$('#a.foo').entwine({
|
|
onmatch: function(){a = 1;}
|
|
});
|
|
|
|
expect(a).toEqual(0);
|
|
|
|
$('#a').addClass('foo');
|
|
expect(a).toEqual(1);
|
|
});
|
|
|
|
it('calls onmatch in both direct and namespaced onmatch, does not call less specific onmatch', function(){
|
|
var a = 0, b = 0, c = 0, d = 0;
|
|
|
|
$('.foo').entwine({
|
|
onmatch: function(){a = 1;}
|
|
});
|
|
$('.foo').entwine('bar', function($){return{
|
|
onmatch: function(){b = 1;}
|
|
};});
|
|
$('#a.foo').entwine({
|
|
onmatch: function(){c = 1;}
|
|
});
|
|
$('#a.foo').entwine('bar', function($){return{
|
|
onmatch: function(){d = 1;}
|
|
};});
|
|
|
|
expect([a, b, c, d]).toEqual([0, 0, 0, 0]);
|
|
|
|
$('#a').addClass('foo');
|
|
expect([a, b, c, d]).toEqual([0, 0, 1, 1]);
|
|
});
|
|
|
|
it('calls onmatch in both direct and namespaced onmatch, super works as expected', function(){
|
|
var a = 0, b = 0, c = 0, d = 0;
|
|
|
|
$('.foo').entwine({
|
|
onmatch: function(){a += 1;}
|
|
});
|
|
$('.foo').entwine('bar', function($){return{
|
|
onmatch: function(){b += 1;}
|
|
};});
|
|
$('#a.foo').entwine({
|
|
onmatch: function(){this._super(); c = 1; this._super();}
|
|
});
|
|
$('#a.foo').entwine('bar', function($){return{
|
|
onmatch: function(){this._super(); d = 1; this._super();}
|
|
};});
|
|
|
|
expect([a, b, c, d]).toEqual([0, 0, 0, 0]);
|
|
|
|
$('#a').addClass('foo');
|
|
expect([a, b, c, d]).toEqual([2, 2, 1, 1]);
|
|
});
|
|
|
|
it('handles onmatch rules being added post document.onready', function(){
|
|
var a = 0, b = 0;
|
|
|
|
$('#a').entwine({
|
|
onmatch: function(){a += 1;}
|
|
});
|
|
$('#a.a').entwine({
|
|
onmatch: function(){b += 1;}
|
|
});
|
|
|
|
// Rules are new, and no DOM change, so no triggers yet
|
|
expect([a, b]).toEqual([0, 0]);
|
|
|
|
// New #a.a rule thinks it matches no nodes, and so removing .a would normally not release it. Check we handle
|
|
$('#a').removeClass('a');
|
|
expect([a, b]).toEqual([1, 0]);
|
|
});
|
|
|
|
it('calls onmatch in less specific rule when more specific rule no longer matches', function(){
|
|
var a = 0, b = 0, c = 0;
|
|
|
|
$('#a').entwine({
|
|
onmatch: function(){a += 1;}
|
|
});
|
|
$('#a.a').entwine({
|
|
onmatch: function(){b += 1;}
|
|
});
|
|
$('#a.a.b').entwine({
|
|
onmatch: function(){c += 1;}
|
|
});
|
|
|
|
$.entwine.triggerMatching();
|
|
expect([a, b, c]).toEqual([0, 0, 1]);
|
|
|
|
$('#a').removeClass('b');
|
|
expect([a, b, c]).toEqual([0, 1, 1]);
|
|
|
|
$('#a').removeClass('a');
|
|
expect([a, b, c]).toEqual([1, 1, 1]);
|
|
});
|
|
});
|
|
}); |