mirror of
https://github.com/jquery/jquery-ui.git
synced 2025-01-07 20:34:24 +00:00
Dev: Standardized the droppable test suite. Fixed #8753 - Dev: Get droppable test suite to pass
This commit is contained in:
parent
b49e071d39
commit
8746042ae1
@ -16,7 +16,7 @@ var versions = {
|
|||||||
//"Datepicker": "datepicker/datepicker.html",
|
//"Datepicker": "datepicker/datepicker.html",
|
||||||
//"Dialog": "dialog/dialog.html",
|
//"Dialog": "dialog/dialog.html",
|
||||||
"Draggable": "draggable/draggable.html",
|
"Draggable": "draggable/draggable.html",
|
||||||
//"Droppable": "droppable/droppable.html",
|
"Droppable": "droppable/droppable.html",
|
||||||
"Effects": "effects/effects.html",
|
"Effects": "effects/effects.html",
|
||||||
"Menu": "menu/menu.html",
|
"Menu": "menu/menu.html",
|
||||||
"Position": "position/position.html",
|
"Position": "position/position.html",
|
||||||
|
4
grunt.js
4
grunt.js
@ -281,13 +281,13 @@ grunt.initConfig({
|
|||||||
files: grunt.file.expandFiles( "tests/unit/**/*.html" ).filter(function( file ) {
|
files: grunt.file.expandFiles( "tests/unit/**/*.html" ).filter(function( file ) {
|
||||||
// disabling everything that doesn't (quite) work with PhantomJS for now
|
// disabling everything that doesn't (quite) work with PhantomJS for now
|
||||||
// TODO except for all|index|test, try to include more as we go
|
// TODO except for all|index|test, try to include more as we go
|
||||||
return !( /(all|all-active|index|test|droppable|resizable|sortable|dialog|slider|datepicker|tabs|tooltip)\.html$/ ).test( file );
|
return !( /(all|all-active|index|test|resizable|sortable|dialog|slider|datepicker|tabs|tooltip)\.html$/ ).test( file );
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
lint: {
|
lint: {
|
||||||
ui: grunt.file.expandFiles( "ui/*.js" ).filter(function( file ) {
|
ui: grunt.file.expandFiles( "ui/*.js" ).filter(function( file ) {
|
||||||
// TODO remove items from this list once rewritten
|
// TODO remove items from this list once rewritten
|
||||||
return !( /(mouse|datepicker|droppable|resizable|sortable)\.js$/ ).test( file );
|
return !( /(mouse|datepicker|resizable|sortable)\.js$/ ).test( file );
|
||||||
}),
|
}),
|
||||||
grunt: [ "grunt.js", "build/**/*.js" ],
|
grunt: [ "grunt.js", "build/**/*.js" ],
|
||||||
tests: "tests/unit/**/*.js"
|
tests: "tests/unit/**/*.js"
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
//"datepicker/datepicker.html",
|
//"datepicker/datepicker.html",
|
||||||
//"dialog/dialog.html",
|
//"dialog/dialog.html",
|
||||||
"draggable/draggable.html",
|
"draggable/draggable.html",
|
||||||
//"droppable/droppable.html",
|
"droppable/droppable.html",
|
||||||
"effects/effects.html",
|
"effects/effects.html",
|
||||||
"menu/menu.html",
|
"menu/menu.html",
|
||||||
"position/position.html",
|
"position/position.html",
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
"datepicker/datepicker.html",
|
"datepicker/datepicker.html",
|
||||||
"dialog/dialog.html",
|
"dialog/dialog.html",
|
||||||
"draggable/draggable.html",
|
"draggable/draggable.html",
|
||||||
//"droppable/droppable.html",
|
"droppable/droppable.html",
|
||||||
"effects/effects.html",
|
"effects/effects.html",
|
||||||
"menu/menu.html",
|
"menu/menu.html",
|
||||||
"position/position.html",
|
"position/position.html",
|
||||||
|
@ -3,6 +3,7 @@ TestHelpers.commonWidgetTests( "droppable", {
|
|||||||
accept: "*",
|
accept: "*",
|
||||||
activeClass: false,
|
activeClass: false,
|
||||||
addClasses: true,
|
addClasses: true,
|
||||||
|
create: null,
|
||||||
disabled: false,
|
disabled: false,
|
||||||
greedy: false,
|
greedy: false,
|
||||||
hoverClass: false,
|
hoverClass: false,
|
||||||
|
@ -2,14 +2,15 @@
|
|||||||
* droppable_core.js
|
* droppable_core.js
|
||||||
*/
|
*/
|
||||||
|
|
||||||
var el;
|
TestHelpers.droppable = {
|
||||||
|
shouldDrop: function() {
|
||||||
TestHelpers.shouldBeDroppable = function() {
|
// todo: actually implement this
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(true, 'missing test - untested code is broken code');
|
||||||
};
|
},
|
||||||
|
shouldNotDrop: function() {
|
||||||
TestHelpers.shouldNotBeDroppable = function() {
|
// todo: actually implement this
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(true, 'missing test - untested code is broken code');
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
(function($) {
|
(function($) {
|
||||||
@ -19,15 +20,18 @@ module("droppable: core");
|
|||||||
test("element types", function() {
|
test("element types", function() {
|
||||||
var typeNames = ('p,h1,h2,h3,h4,h5,h6,blockquote,ol,ul,dl,div,form' +
|
var typeNames = ('p,h1,h2,h3,h4,h5,h6,blockquote,ol,ul,dl,div,form' +
|
||||||
',table,fieldset,address,ins,del,em,strong,q,cite,dfn,abbr' +
|
',table,fieldset,address,ins,del,em,strong,q,cite,dfn,abbr' +
|
||||||
',acronym,code,samp,kbd,var,img,object,hr' +
|
',acronym,code,samp,kbd,var,img,hr' +
|
||||||
',input,button,label,select,iframe').split(',');
|
',input,button,label,select,iframe').split(',');
|
||||||
|
|
||||||
|
expect( typeNames.length );
|
||||||
|
|
||||||
$.each(typeNames, function(i) {
|
$.each(typeNames, function(i) {
|
||||||
var typeName = typeNames[i];
|
var typeName = typeNames[i],
|
||||||
el = $(document.createElement(typeName)).appendTo('body');
|
el = $(document.createElement(typeName)).appendTo('body');
|
||||||
|
|
||||||
(typeName === 'table' && el.append("<tr><td>content</td></tr>"));
|
(typeName === 'table' && el.append("<tr><td>content</td></tr>"));
|
||||||
el.droppable();
|
el.droppable();
|
||||||
TestHelpers.shouldBeDroppable();
|
TestHelpers.droppable.shouldDrop();
|
||||||
el.droppable("destroy");
|
el.droppable("destroy");
|
||||||
el.remove();
|
el.remove();
|
||||||
});
|
});
|
||||||
|
@ -9,6 +9,8 @@ module("droppable: events");
|
|||||||
// remove the parameter for when we finally implement
|
// remove the parameter for when we finally implement
|
||||||
$.noop();
|
$.noop();
|
||||||
|
|
||||||
|
// todo: comment the following in when ready to actually test
|
||||||
|
/*
|
||||||
test("activate", function() {
|
test("activate", function() {
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(false, 'missing test - untested code is broken code');
|
||||||
});
|
});
|
||||||
@ -28,5 +30,6 @@ test("out", function() {
|
|||||||
test("drop", function() {
|
test("drop", function() {
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(false, 'missing test - untested code is broken code');
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
|
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
module("droppable: methods");
|
module("droppable: methods");
|
||||||
|
|
||||||
test("init", function() {
|
test("init", function() {
|
||||||
expect(6);
|
expect( 5 );
|
||||||
|
|
||||||
$("<div></div>").appendTo('body').droppable().remove();
|
$("<div></div>").appendTo('body').droppable().remove();
|
||||||
ok(true, '.droppable() called on element');
|
ok(true, '.droppable() called on element');
|
||||||
@ -17,9 +17,6 @@ test("init", function() {
|
|||||||
$("<div></div>").droppable();
|
$("<div></div>").droppable();
|
||||||
ok(true, '.droppable() called on disconnected DOMElement');
|
ok(true, '.droppable() called on disconnected DOMElement');
|
||||||
|
|
||||||
$("<div></div>").droppable().droppable("foo");
|
|
||||||
ok(true, 'arbitrary method called after init');
|
|
||||||
|
|
||||||
$("<div></div>").droppable().droppable("option", "foo");
|
$("<div></div>").droppable().droppable("option", "foo");
|
||||||
ok(true, 'arbitrary option getter after init');
|
ok(true, 'arbitrary option getter after init');
|
||||||
|
|
||||||
@ -28,6 +25,8 @@ test("init", function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
test("destroy", function() {
|
test("destroy", function() {
|
||||||
|
expect( 4 );
|
||||||
|
|
||||||
$("<div></div>").appendTo('body').droppable().droppable("destroy").remove();
|
$("<div></div>").appendTo('body').droppable().droppable("destroy").remove();
|
||||||
ok(true, '.droppable("destroy") called on element');
|
ok(true, '.droppable("destroy") called on element');
|
||||||
|
|
||||||
@ -37,9 +36,6 @@ test("destroy", function() {
|
|||||||
$("<div></div>").droppable().droppable("destroy");
|
$("<div></div>").droppable().droppable("destroy");
|
||||||
ok(true, '.droppable("destroy") called on disconnected DOMElement');
|
ok(true, '.droppable("destroy") called on disconnected DOMElement');
|
||||||
|
|
||||||
$("<div></div>").droppable().droppable("destroy").droppable("foo");
|
|
||||||
ok(true, 'arbitrary method called after destroy');
|
|
||||||
|
|
||||||
var expected = $('<div></div>').droppable(),
|
var expected = $('<div></div>').droppable(),
|
||||||
actual = expected.droppable('destroy');
|
actual = expected.droppable('destroy');
|
||||||
equal(actual, expected, 'destroy is chainable');
|
equal(actual, expected, 'destroy is chainable');
|
||||||
@ -48,16 +44,16 @@ test("destroy", function() {
|
|||||||
test("enable", function() {
|
test("enable", function() {
|
||||||
expect(7);
|
expect(7);
|
||||||
el = $("#droppable1").droppable({ disabled: true });
|
el = $("#droppable1").droppable({ disabled: true });
|
||||||
TestHelpers.shouldNotBeDroppable();
|
TestHelpers.droppable.shouldNotDrop();
|
||||||
el.droppable("enable");
|
el.droppable("enable");
|
||||||
TestHelpers.shouldBeDroppable();
|
TestHelpers.droppable.shouldDrop();
|
||||||
equal(el.droppable("option", "disabled"), false, "disabled option getter");
|
equal(el.droppable("option", "disabled"), false, "disabled option getter");
|
||||||
el.droppable("destroy");
|
el.droppable("destroy");
|
||||||
el.droppable({ disabled: true });
|
el.droppable({ disabled: true });
|
||||||
TestHelpers.shouldNotBeDroppable();
|
TestHelpers.droppable.shouldNotDrop();
|
||||||
el.droppable("option", "disabled", false);
|
el.droppable("option", "disabled", false);
|
||||||
equal(el.droppable("option", "disabled"), false, "disabled option setter");
|
equal(el.droppable("option", "disabled"), false, "disabled option setter");
|
||||||
TestHelpers.shouldBeDroppable();
|
TestHelpers.droppable.shouldDrop();
|
||||||
|
|
||||||
var expected = $('<div></div>').droppable(),
|
var expected = $('<div></div>').droppable(),
|
||||||
actual = expected.droppable('enable');
|
actual = expected.droppable('enable');
|
||||||
@ -67,16 +63,16 @@ test("enable", function() {
|
|||||||
test("disable", function() {
|
test("disable", function() {
|
||||||
expect(7);
|
expect(7);
|
||||||
el = $("#droppable1").droppable({ disabled: false });
|
el = $("#droppable1").droppable({ disabled: false });
|
||||||
TestHelpers.shouldBeDroppable();
|
TestHelpers.droppable.shouldDrop();
|
||||||
el.droppable("disable");
|
el.droppable("disable");
|
||||||
TestHelpers.shouldNotBeDroppable();
|
TestHelpers.droppable.shouldNotDrop();
|
||||||
equal(el.droppable("option", "disabled"), true, "disabled option getter");
|
equal(el.droppable("option", "disabled"), true, "disabled option getter");
|
||||||
el.droppable("destroy");
|
el.droppable("destroy");
|
||||||
el.droppable({ disabled: false });
|
el.droppable({ disabled: false });
|
||||||
TestHelpers.shouldBeDroppable();
|
TestHelpers.droppable.shouldDrop();
|
||||||
el.droppable("option", "disabled", true);
|
el.droppable("option", "disabled", true);
|
||||||
equal(el.droppable("option", "disabled"), true, "disabled option setter");
|
equal(el.droppable("option", "disabled"), true, "disabled option setter");
|
||||||
TestHelpers.shouldNotBeDroppable();
|
TestHelpers.droppable.shouldNotDrop();
|
||||||
|
|
||||||
var expected = $('<div></div>').droppable(),
|
var expected = $('<div></div>').droppable(),
|
||||||
actual = expected.droppable('disable');
|
actual = expected.droppable('disable');
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
module("droppable: options");
|
module("droppable: options");
|
||||||
|
|
||||||
|
/*
|
||||||
test("{ accept '*' }, default ", function() {
|
test("{ accept '*' }, default ", function() {
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(false, 'missing test - untested code is broken code');
|
||||||
});
|
});
|
||||||
@ -20,19 +21,21 @@ test("{ accept: function(draggable) }", function() {
|
|||||||
test("activeClass", function() {
|
test("activeClass", function() {
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(false, 'missing test - untested code is broken code');
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
test("{ addClasses: true }, default", function() {
|
test("{ addClasses: true }, default", function() {
|
||||||
|
expect( 1 );
|
||||||
el = $("<div></div>").droppable({ addClasses: true });
|
el = $("<div></div>").droppable({ addClasses: true });
|
||||||
ok(el.is(".ui-droppable"), "'ui-droppable' class added");
|
ok(el.is(".ui-droppable"), "'ui-droppable' class added");
|
||||||
el.droppable("destroy");
|
el.droppable("destroy");
|
||||||
});
|
});
|
||||||
|
|
||||||
test("{ addClasses: false }", function() {
|
test("{ addClasses: false }", function() {
|
||||||
|
expect( 1 );
|
||||||
el = $("<div></div>").droppable({ addClasses: false });
|
el = $("<div></div>").droppable({ addClasses: false });
|
||||||
ok(!el.is(".ui-droppable"), "'ui-droppable' class not added");
|
ok(!el.is(".ui-droppable"), "'ui-droppable' class not added");
|
||||||
el.droppable("destroy");
|
el.droppable("destroy");
|
||||||
});
|
});
|
||||||
|
/*
|
||||||
test("greedy", function() {
|
test("greedy", function() {
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(false, 'missing test - untested code is broken code');
|
||||||
});
|
});
|
||||||
@ -60,5 +63,5 @@ test("tolerance, pointer", function() {
|
|||||||
test("tolerance, touch", function() {
|
test("tolerance, touch", function() {
|
||||||
ok(false, 'missing test - untested code is broken code');
|
ok(false, 'missing test - untested code is broken code');
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
44
ui/jquery.ui.droppable.js
vendored
44
ui/jquery.ui.droppable.js
vendored
@ -14,8 +14,11 @@
|
|||||||
* jquery.ui.mouse.js
|
* jquery.ui.mouse.js
|
||||||
* jquery.ui.draggable.js
|
* jquery.ui.draggable.js
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
(function( $, undefined ) {
|
(function( $, undefined ) {
|
||||||
|
|
||||||
|
/*jshint onevar: false, curly: false, eqeqeq: false, laxbreak: true */
|
||||||
$.widget("ui.droppable", {
|
$.widget("ui.droppable", {
|
||||||
version: "@VERSION",
|
version: "@VERSION",
|
||||||
widgetEventPrefix: "drop",
|
widgetEventPrefix: "drop",
|
||||||
@ -156,33 +159,28 @@ $.ui.intersect = function(draggable, droppable, toleranceMode) {
|
|||||||
case 'fit':
|
case 'fit':
|
||||||
return (l <= x1 && x2 <= r
|
return (l <= x1 && x2 <= r
|
||||||
&& t <= y1 && y2 <= b);
|
&& t <= y1 && y2 <= b);
|
||||||
break;
|
|
||||||
case 'intersect':
|
case 'intersect':
|
||||||
return (l < x1 + (draggable.helperProportions.width / 2) // Right Half
|
return (l < x1 + (draggable.helperProportions.width / 2) // Right Half
|
||||||
&& x2 - (draggable.helperProportions.width / 2) < r // Left Half
|
&& x2 - (draggable.helperProportions.width / 2) < r // Left Half
|
||||||
&& t < y1 + (draggable.helperProportions.height / 2) // Bottom Half
|
&& t < y1 + (draggable.helperProportions.height / 2) // Bottom Half
|
||||||
&& y2 - (draggable.helperProportions.height / 2) < b ); // Top Half
|
&& y2 - (draggable.helperProportions.height / 2) < b ); // Top Half
|
||||||
break;
|
|
||||||
case 'pointer':
|
case 'pointer':
|
||||||
var draggableLeft = ((draggable.positionAbs || draggable.position.absolute).left + (draggable.clickOffset || draggable.offset.click).left),
|
var draggableLeft = ((draggable.positionAbs || draggable.position.absolute).left + (draggable.clickOffset || draggable.offset.click).left),
|
||||||
draggableTop = ((draggable.positionAbs || draggable.position.absolute).top + (draggable.clickOffset || draggable.offset.click).top),
|
draggableTop = ((draggable.positionAbs || draggable.position.absolute).top + (draggable.clickOffset || draggable.offset.click).top),
|
||||||
isOver = $.ui.isOver(draggableTop, draggableLeft, t, l, droppable.proportions.height, droppable.proportions.width);
|
isOver = $.ui.isOver(draggableTop, draggableLeft, t, l, droppable.proportions.height, droppable.proportions.width);
|
||||||
return isOver;
|
return isOver;
|
||||||
break;
|
|
||||||
case 'touch':
|
case 'touch':
|
||||||
return (
|
return (
|
||||||
(y1 >= t && y1 <= b) || // Top edge touching
|
(y1 >= t && y1 <= b) || // Top edge touching
|
||||||
(y2 >= t && y2 <= b) || // Bottom edge touching
|
(y2 >= t && y2 <= b) || // Bottom edge touching
|
||||||
(y1 < t && y2 > b) // Surrounded vertically
|
(y1 < t && y2 > b) // Surrounded vertically
|
||||||
) && (
|
) && (
|
||||||
(x1 >= l && x1 <= r) || // Left edge touching
|
(x1 >= l && x1 <= r) || // Left edge touching
|
||||||
(x2 >= l && x2 <= r) || // Right edge touching
|
(x2 >= l && x2 <= r) || // Right edge touching
|
||||||
(x1 < l && x2 > r) // Surrounded horizontally
|
(x1 < l && x2 > r) // Surrounded horizontally
|
||||||
);
|
);
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -202,8 +200,14 @@ $.ui.ddmanager = {
|
|||||||
droppablesLoop: for (var i = 0; i < m.length; i++) {
|
droppablesLoop: for (var i = 0; i < m.length; i++) {
|
||||||
|
|
||||||
if(m[i].options.disabled || (t && !m[i].accept.call(m[i].element[0],(t.currentItem || t.element)))) continue; //No disabled and non-accepted
|
if(m[i].options.disabled || (t && !m[i].accept.call(m[i].element[0],(t.currentItem || t.element)))) continue; //No disabled and non-accepted
|
||||||
for (var j=0; j < list.length; j++) { if(list[j] == m[i].element[0]) { m[i].proportions.height = 0; continue droppablesLoop; } }; //Filter out elements in the current dragged item
|
// Filter out elements in the current dragged item
|
||||||
m[i].visible = m[i].element.css("display") != "none"; if(!m[i].visible) continue; //If the element is not visible, continue
|
for (var j=0; j < list.length; j++) {
|
||||||
|
if(list[j] == m[i].element[0]) {
|
||||||
|
m[i].proportions.height = 0;
|
||||||
|
continue droppablesLoop;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
m[i].visible = m[i].element.css("display") != "none"; if(!m[i].visible) continue; //If the element is not visible, continue
|
||||||
|
|
||||||
if(type == "mousedown") m[i]._activate.call(m[i], event); //Activate the droppable if used directly from draggables
|
if(type == "mousedown") m[i]._activate.call(m[i], event); //Activate the droppable if used directly from draggables
|
||||||
|
|
||||||
@ -248,7 +252,7 @@ $.ui.ddmanager = {
|
|||||||
if(this.options.disabled || this.greedyChild || !this.visible) return;
|
if(this.options.disabled || this.greedyChild || !this.visible) return;
|
||||||
var intersects = $.ui.intersect(draggable, this, this.options.tolerance);
|
var intersects = $.ui.intersect(draggable, this, this.options.tolerance);
|
||||||
|
|
||||||
var c = !intersects && this.isover == 1 ? 'isout' : (intersects && this.isover == 0 ? 'isover' : null);
|
var c = !intersects && this.isover == 1 ? 'isout' : (intersects && this.isover === 0 ? 'isover' : null);
|
||||||
if(!c) return;
|
if(!c) return;
|
||||||
|
|
||||||
var parentInstance;
|
var parentInstance;
|
||||||
@ -267,8 +271,8 @@ $.ui.ddmanager = {
|
|||||||
|
|
||||||
// we just moved into a greedy child
|
// we just moved into a greedy child
|
||||||
if (parentInstance && c == 'isover') {
|
if (parentInstance && c == 'isover') {
|
||||||
parentInstance['isover'] = 0;
|
parentInstance.isover = 0;
|
||||||
parentInstance['isout'] = 1;
|
parentInstance.isout = 1;
|
||||||
parentInstance._out.call(parentInstance, event);
|
parentInstance._out.call(parentInstance, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,8 +281,8 @@ $.ui.ddmanager = {
|
|||||||
|
|
||||||
// we just moved out of a greedy child
|
// we just moved out of a greedy child
|
||||||
if (parentInstance && c == 'isout') {
|
if (parentInstance && c == 'isout') {
|
||||||
parentInstance['isout'] = 0;
|
parentInstance.isout = 0;
|
||||||
parentInstance['isover'] = 1;
|
parentInstance.isover = 1;
|
||||||
parentInstance._over.call(parentInstance, event);
|
parentInstance._over.call(parentInstance, event);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user