mirror of
https://github.com/tuxis-ie/nsedit.git
synced 2025-05-24 00:24:07 +03:00
Merge commit 'd21ea7816e
' as 'jquery-ui'
This commit is contained in:
commit
e904a80717
629 changed files with 341074 additions and 0 deletions
26
jquery-ui/tests/unit/datepicker/all.html
Normal file
26
jquery-ui/tests/unit/datepicker/all.html
Normal file
|
@ -0,0 +1,26 @@
|
|||
<!doctype html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>jQuery UI Datepicker Test Suite</title>
|
||||
|
||||
<script src="../../../external/jquery/jquery.js"></script>
|
||||
|
||||
<link rel="stylesheet" href="../../../external/qunit/qunit.css">
|
||||
<link rel="stylesheet" href="../qunit-composite.css">
|
||||
<script src="../../../external/qunit/qunit.js"></script>
|
||||
<script src="../qunit-composite.js"></script>
|
||||
<script src="../subsuite.js"></script>
|
||||
|
||||
<script>
|
||||
testAllVersions( "datepicker" );
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div id="qunit"></div>
|
||||
<div id="qunit-fixture">
|
||||
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
44
jquery-ui/tests/unit/datepicker/datepicker.html
Normal file
44
jquery-ui/tests/unit/datepicker/datepicker.html
Normal file
|
@ -0,0 +1,44 @@
|
|||
<!doctype html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>jQuery UI Datepicker Test Suite</title>
|
||||
|
||||
<script src="../../jquery.js"></script>
|
||||
<link rel="stylesheet" href="../../../external/qunit/qunit.css">
|
||||
<script src="../../../external/qunit/qunit.js"></script>
|
||||
<script src="../../../external/jquery-simulate/jquery.simulate.js"></script>
|
||||
<script src="../testsuite.js"></script>
|
||||
<script>
|
||||
TestHelpers.loadResources({
|
||||
css: [ "core", "datepicker" ],
|
||||
js: [
|
||||
"ui/core.js",
|
||||
"ui/datepicker.js",
|
||||
"ui/i18n/datepicker-fr.js",
|
||||
"ui/i18n/datepicker-he.js",
|
||||
"ui/i18n/datepicker-zh-CN.js"
|
||||
]
|
||||
});
|
||||
</script>
|
||||
|
||||
<script src="datepicker_common.js"></script>
|
||||
<script src="datepicker_core.js"></script>
|
||||
<script src="datepicker_events.js"></script>
|
||||
<script src="datepicker_methods.js"></script>
|
||||
<script src="datepicker_options.js"></script>
|
||||
<script src="datepicker_test_helpers.js"></script>
|
||||
|
||||
<script src="../swarminject.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div id="qunit"></div>
|
||||
<div id="qunit-fixture">
|
||||
|
||||
<div><input type="text" id="inp"><input type="text" id="alt"><div id="inl"></div></div>
|
||||
<p><input type="text" id="inp2"></p>
|
||||
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
7
jquery-ui/tests/unit/datepicker/datepicker_common.js
vendored
Normal file
7
jquery-ui/tests/unit/datepicker/datepicker_common.js
vendored
Normal file
|
@ -0,0 +1,7 @@
|
|||
/*
|
||||
TestHelpers.commonWidgetTests( "datepicker", {
|
||||
defaults: {
|
||||
disabled: false
|
||||
}
|
||||
});
|
||||
*/
|
528
jquery-ui/tests/unit/datepicker/datepicker_core.js
vendored
Normal file
528
jquery-ui/tests/unit/datepicker/datepicker_core.js
vendored
Normal file
|
@ -0,0 +1,528 @@
|
|||
/*
|
||||
* datepicker_core.js
|
||||
*/
|
||||
|
||||
(function($) {
|
||||
|
||||
module( "datepicker: core", {
|
||||
setup: function() {
|
||||
$( "body" ).focus();
|
||||
}
|
||||
});
|
||||
|
||||
TestHelpers.testJshint( "datepicker" );
|
||||
|
||||
test("initialization - Reinitialization after body had been emptied.", function() {
|
||||
expect( 1 );
|
||||
var bodyContent = $("body").children(), inp = $("#inp");
|
||||
$("#inp").datepicker();
|
||||
$("body").empty().append(inp);
|
||||
$("#inp").datepicker();
|
||||
ok( $("#"+$.datepicker._mainDivId).length===1, "Datepicker container added" );
|
||||
$("body").empty().append(bodyContent); // Returning to initial state for later tests
|
||||
});
|
||||
|
||||
test( "widget method - empty collection", function() {
|
||||
expect( 1 );
|
||||
$( "#nonExist" ).datepicker(); // should create nothing
|
||||
ok( !$( "#ui-datepicker-div" ).length, "Non init on empty collection" );
|
||||
});
|
||||
|
||||
test("widget method", function() {
|
||||
expect( 1 );
|
||||
var actual = $("#inp").datepicker().datepicker("widget")[0];
|
||||
deepEqual($("body > #ui-datepicker-div:last-child")[0], actual);
|
||||
});
|
||||
|
||||
asyncTest( "baseStructure", function() {
|
||||
expect( 58 );
|
||||
var header, title, table, thead, week, panel, inl, child,
|
||||
inp = TestHelpers.datepicker.initNewInput(),
|
||||
dp = $( "#ui-datepicker-div" );
|
||||
|
||||
function step1() {
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
ok( dp.is( ":visible" ), "Structure - datepicker visible" );
|
||||
ok( !dp.is( ".ui-datepicker-rtl" ), "Structure - not right-to-left" );
|
||||
ok( !dp.is( ".ui-datepicker-multi" ), "Structure - not multi-month" );
|
||||
equal( dp.children().length, 2, "Structure - child count" );
|
||||
|
||||
header = dp.children( ":first" );
|
||||
ok( header.is( "div.ui-datepicker-header" ), "Structure - header division" );
|
||||
equal( header.children().length, 3, "Structure - header child count" );
|
||||
ok( header.children( ":first" ).is( "a.ui-datepicker-prev" ) && header.children( ":first" ).html() !== "", "Structure - prev link" );
|
||||
ok( header.children( ":eq(1)" ).is( "a.ui-datepicker-next" ) && header.children( ":eq(1)" ).html() !== "", "Structure - next link" );
|
||||
|
||||
title = header.children( ":last" );
|
||||
ok( title.is( "div.ui-datepicker-title" ) && title.html() !== "","Structure - title division" );
|
||||
equal( title.children().length, 2, "Structure - title child count" );
|
||||
ok( title.children( ":first" ).is( "span.ui-datepicker-month" ) && title.children( ":first" ).text() !== "", "Structure - month text" );
|
||||
ok( title.children( ":last" ).is( "span.ui-datepicker-year" ) && title.children( ":last" ).text() !== "", "Structure - year text" );
|
||||
|
||||
table = dp.children( ":eq(1)" );
|
||||
ok( table.is( "table.ui-datepicker-calendar" ), "Structure - month table" );
|
||||
ok( table.children( ":first" ).is( "thead" ), "Structure - month table thead" );
|
||||
|
||||
thead = table.children( ":first" ).children( ":first" );
|
||||
ok( thead.is( "tr" ), "Structure - month table title row" );
|
||||
equal( thead.find( "th" ).length, 7, "Structure - month table title cells" );
|
||||
ok( table.children( ":eq(1)" ).is( "tbody" ), "Structure - month table body" );
|
||||
ok( table.children( ":eq(1)" ).children( "tr" ).length >= 4, "Structure - month table week count" );
|
||||
|
||||
week = table.children( ":eq(1)" ).children( ":first" );
|
||||
ok( week.is( "tr" ), "Structure - month table week row" );
|
||||
equal( week.children().length, 7, "Structure - week child count" );
|
||||
ok( week.children( ":first" ).is( "td.ui-datepicker-week-end" ), "Structure - month table first day cell" );
|
||||
ok( week.children( ":last" ).is( "td.ui-datepicker-week-end" ), "Structure - month table second day cell" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step2();
|
||||
});
|
||||
}
|
||||
|
||||
function step2() {
|
||||
// Editable month/year and button panel
|
||||
inp = TestHelpers.datepicker.initNewInput({
|
||||
changeMonth: true,
|
||||
changeYear: true,
|
||||
showButtonPanel: true
|
||||
});
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
title = dp.find( "div.ui-datepicker-title" );
|
||||
ok( title.children( ":first" ).is( "select.ui-datepicker-month" ), "Structure - month selector" );
|
||||
ok( title.children( ":last" ).is( "select.ui-datepicker-year" ), "Structure - year selector" );
|
||||
|
||||
panel = dp.children( ":last" );
|
||||
ok( panel.is( "div.ui-datepicker-buttonpane" ), "Structure - button panel division" );
|
||||
equal( panel.children().length, 2, "Structure - button panel child count" );
|
||||
ok( panel.children( ":first" ).is( "button.ui-datepicker-current" ), "Structure - today button" );
|
||||
ok( panel.children( ":last" ).is( "button.ui-datepicker-close" ), "Structure - close button" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step3();
|
||||
});
|
||||
}
|
||||
|
||||
function step3() {
|
||||
// Multi-month 2
|
||||
inp = TestHelpers.datepicker.initNewInput({ numberOfMonths: 2 });
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
ok( dp.is( ".ui-datepicker-multi" ), "Structure multi [2] - multi-month" );
|
||||
equal( dp.children().length, 3, "Structure multi [2] - child count" );
|
||||
|
||||
child = dp.children( ":first" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-first" ), "Structure multi [2] - first month division" );
|
||||
|
||||
child = dp.children( ":eq(1)" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-last" ), "Structure multi [2] - second month division" );
|
||||
|
||||
child = dp.children( ":eq(2)" );
|
||||
ok( child.is( "div.ui-datepicker-row-break" ), "Structure multi [2] - row break" );
|
||||
ok( dp.is( ".ui-datepicker-multi-2" ), "Structure multi [2] - multi-2" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step4();
|
||||
});
|
||||
}
|
||||
|
||||
function step4() {
|
||||
// Multi-month 3
|
||||
inp = TestHelpers.datepicker.initNewInput({ numberOfMonths: 3 });
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
ok( dp.is( ".ui-datepicker-multi-3" ), "Structure multi [3] - multi-3" );
|
||||
ok( !dp.is( ".ui-datepicker-multi-2" ), "Structure multi [3] - Trac #6704" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step5();
|
||||
});
|
||||
}
|
||||
|
||||
function step5() {
|
||||
// Multi-month [2, 2]
|
||||
inp = TestHelpers.datepicker.initNewInput({ numberOfMonths: [ 2, 2 ] });
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
ok( dp.is( ".ui-datepicker-multi" ), "Structure multi - multi-month" );
|
||||
equal( dp.children().length, 6, "Structure multi [2,2] - child count" );
|
||||
|
||||
child = dp.children( ":first" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-first" ), "Structure multi [2,2] - first month division" );
|
||||
|
||||
child = dp.children( ":eq(1)" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-last" ), "Structure multi [2,2] - second month division" );
|
||||
|
||||
child = dp.children( ":eq(2)" );
|
||||
ok( child.is( "div.ui-datepicker-row-break" ), "Structure multi [2,2] - row break" );
|
||||
|
||||
child = dp.children( ":eq(3)" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-first" ), "Structure multi [2,2] - third month division" );
|
||||
|
||||
child = dp.children( ":eq(4)" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-last" ), "Structure multi [2,2] - fourth month division" );
|
||||
|
||||
child = dp.children( ":eq(5)" );
|
||||
ok( child.is( "div.ui-datepicker-row-break" ), "Structure multi [2,2] - row break" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
|
||||
// Inline
|
||||
inl = TestHelpers.datepicker.init( "#inl" );
|
||||
dp = inl.children();
|
||||
|
||||
ok( dp.is( ".ui-datepicker-inline" ), "Structure inline - main div" );
|
||||
ok( !dp.is( ".ui-datepicker-rtl" ), "Structure inline - not right-to-left" );
|
||||
ok( !dp.is( ".ui-datepicker-multi" ), "Structure inline - not multi-month" );
|
||||
equal( dp.children().length, 2, "Structure inline - child count" );
|
||||
|
||||
header = dp.children( ":first" );
|
||||
ok( header.is( "div.ui-datepicker-header" ), "Structure inline - header division" );
|
||||
equal( header.children().length, 3, "Structure inline - header child count" );
|
||||
|
||||
table = dp.children( ":eq(1)" );
|
||||
ok( table.is( "table.ui-datepicker-calendar" ), "Structure inline - month table" );
|
||||
ok( table.children( ":first" ).is( "thead" ), "Structure inline - month table thead" );
|
||||
ok( table.children( ":eq(1)" ).is( "tbody" ), "Structure inline - month table body" );
|
||||
|
||||
inl.datepicker( "destroy" );
|
||||
|
||||
// Inline multi-month
|
||||
inl = TestHelpers.datepicker.init( "#inl", { numberOfMonths: 2 } );
|
||||
dp = inl.children();
|
||||
|
||||
ok( dp.is( ".ui-datepicker-inline" ) && dp.is( ".ui-datepicker-multi" ), "Structure inline multi - main div" );
|
||||
equal( dp.children().length, 3, "Structure inline multi - child count" );
|
||||
|
||||
child = dp.children( ":first" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-first" ), "Structure inline multi - first month division" );
|
||||
|
||||
child = dp.children( ":eq(1)" );
|
||||
ok( child.is( "div.ui-datepicker-group" ) && child.is( "div.ui-datepicker-group-last" ), "Structure inline multi - second month division" );
|
||||
|
||||
child = dp.children( ":eq(2)" );
|
||||
ok( child.is( "div.ui-datepicker-row-break" ), "Structure inline multi - row break" );
|
||||
|
||||
inl.datepicker( "destroy" );
|
||||
start();
|
||||
});
|
||||
}
|
||||
|
||||
step1();
|
||||
});
|
||||
|
||||
asyncTest( "customStructure", function() {
|
||||
expect( 20 );
|
||||
var header, panel, title, thead,
|
||||
inp = TestHelpers.datepicker.initNewInput( $.datepicker.regional.he ),
|
||||
dp = $( "#ui-datepicker-div" );
|
||||
|
||||
function step1() {
|
||||
inp.datepicker( "option", "showButtonPanel", true );
|
||||
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
ok( dp.is( ".ui-datepicker-rtl" ), "Structure RTL - right-to-left" );
|
||||
|
||||
header = dp.children( ":first" );
|
||||
ok( header.is( "div.ui-datepicker-header" ), "Structure RTL - header division" );
|
||||
equal( header.children().length, 3, "Structure RTL - header child count" );
|
||||
ok( header.children( ":first" ).is( "a.ui-datepicker-next" ), "Structure RTL - prev link" );
|
||||
ok( header.children( ":eq(1)" ).is( "a.ui-datepicker-prev" ), "Structure RTL - next link" );
|
||||
|
||||
panel = dp.children( ":last" );
|
||||
ok( panel.is( "div.ui-datepicker-buttonpane" ), "Structure RTL - button division" );
|
||||
equal( panel.children().length, 2, "Structure RTL - button panel child count" );
|
||||
ok( panel.children( ":first" ).is( "button.ui-datepicker-close" ), "Structure RTL - close button" );
|
||||
ok( panel.children( ":last" ).is( "button.ui-datepicker-current" ), "Structure RTL - today button" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step2();
|
||||
});
|
||||
}
|
||||
|
||||
// Hide prev/next
|
||||
function step2() {
|
||||
inp = TestHelpers.datepicker.initNewInput({
|
||||
hideIfNoPrevNext: true,
|
||||
minDate: new Date( 2008, 2 - 1, 4 ),
|
||||
maxDate: new Date( 2008, 2 - 1, 14 )
|
||||
});
|
||||
inp.val( "02/10/2008" );
|
||||
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
header = dp.children( ":first" );
|
||||
ok( header.is( "div.ui-datepicker-header" ), "Structure hide prev/next - header division" );
|
||||
equal( header.children().length, 1, "Structure hide prev/next - links child count" );
|
||||
ok( header.children( ":first" ).is( "div.ui-datepicker-title" ), "Structure hide prev/next - title division" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step3();
|
||||
});
|
||||
}
|
||||
|
||||
// Changeable Month with read-only year
|
||||
function step3() {
|
||||
inp = TestHelpers.datepicker.initNewInput({ changeMonth: true });
|
||||
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
title = dp.children( ":first" ).children( ":last" );
|
||||
equal( title.children().length, 2, "Structure changeable month - title child count" );
|
||||
ok( title.children( ":first" ).is( "select.ui-datepicker-month" ), "Structure changeable month - month selector" );
|
||||
ok( title.children( ":last" ).is( "span.ui-datepicker-year" ), "Structure changeable month - read-only year" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step4();
|
||||
});
|
||||
}
|
||||
|
||||
// Changeable year with read-only month
|
||||
function step4() {
|
||||
inp = TestHelpers.datepicker.initNewInput({ changeYear: true });
|
||||
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
title = dp.children( ":first" ).children( ":last" );
|
||||
equal( title.children().length, 2, "Structure changeable year - title child count" );
|
||||
ok( title.children( ":first" ).is( "span.ui-datepicker-month" ), "Structure changeable year - read-only month" );
|
||||
ok( title.children( ":last" ).is( "select.ui-datepicker-year" ), "Structure changeable year - year selector" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
step5();
|
||||
});
|
||||
}
|
||||
|
||||
// Read-only first day of week
|
||||
function step5() {
|
||||
inp = TestHelpers.datepicker.initNewInput({ changeFirstDay: false });
|
||||
|
||||
TestHelpers.datepicker.onFocus( inp, function() {
|
||||
thead = dp.find( ".ui-datepicker-calendar thead tr" );
|
||||
equal( thead.children().length, 7, "Structure read-only first day - thead child count" );
|
||||
equal( thead.find( "a" ).length, 0, "Structure read-only first day - thead links count" );
|
||||
|
||||
inp.datepicker( "hide" ).datepicker( "destroy" );
|
||||
start();
|
||||
});
|
||||
}
|
||||
|
||||
// TODO: figure out why this setTimeout is needed in IE,
|
||||
// it only is necessary when the previous baseStructure tests runs first
|
||||
// Support: IE
|
||||
setTimeout( step1 );
|
||||
});
|
||||
|
||||
test("keystrokes", function() {
|
||||
expect( 26 );
|
||||
var inp = TestHelpers.datepicker.init("#inp"),
|
||||
date = new Date();
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke enter");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 4),
|
||||
"Keystroke enter - preset");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.HOME}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke ctrl+home");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.END});
|
||||
ok(inp.datepicker("getDate") == null, "Keystroke ctrl+end");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ESCAPE});
|
||||
ok(inp.datepicker("getDate") == null, "Keystroke esc");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ESCAPE});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 4),
|
||||
"Keystroke esc - preset");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ESCAPE});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 4),
|
||||
"Keystroke esc - abandoned");
|
||||
// Moving by day or week
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.LEFT}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() - 1);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke ctrl+left");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.LEFT}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() + 1);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke left");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.RIGHT}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() + 1);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke ctrl+right");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.RIGHT}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() - 1);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke right");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() - 7);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke ctrl+up");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() + 7);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke up");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() + 7);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke ctrl+down");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() - 7);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Keystroke down");
|
||||
// Moving by month or year
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 1 - 1, 4),
|
||||
"Keystroke pgup");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 3 - 1, 4),
|
||||
"Keystroke pgdn");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2007, 2 - 1, 4),
|
||||
"Keystroke ctrl+pgup");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2009, 2 - 1, 4),
|
||||
"Keystroke ctrl+pgdn");
|
||||
// Check for moving to short months
|
||||
inp.val("03/31/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 29),
|
||||
"Keystroke pgup - Feb");
|
||||
inp.val("01/30/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 29),
|
||||
"Keystroke pgdn - Feb");
|
||||
inp.val("02/29/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2007, 2 - 1, 28),
|
||||
"Keystroke ctrl+pgup - Feb");
|
||||
inp.val("02/29/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2009, 2 - 1, 28),
|
||||
"Keystroke ctrl+pgdn - Feb");
|
||||
// Goto current
|
||||
inp.datepicker("option", {gotoCurrent: true}).
|
||||
datepicker("hide").val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_DOWN}).
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.HOME}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 4),
|
||||
"Keystroke ctrl+home");
|
||||
// Change steps
|
||||
inp.datepicker("option", {stepMonths: 2, gotoCurrent: false}).
|
||||
datepicker("hide").val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_UP}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2007, 12 - 1, 4),
|
||||
"Keystroke pgup step 2");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 4 - 1, 4),
|
||||
"Keystroke pgdn step 2");
|
||||
});
|
||||
|
||||
test("mouse", function() {
|
||||
expect( 15 );
|
||||
var inl,
|
||||
inp = TestHelpers.datepicker.init("#inp"),
|
||||
dp = $("#ui-datepicker-div"),
|
||||
date = new Date();
|
||||
inp.val("").datepicker("show");
|
||||
$(".ui-datepicker-calendar tbody a:contains(10)", dp).simulate("click", {});
|
||||
date.setDate(10);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Mouse click");
|
||||
inp.val("02/04/2008").datepicker("show");
|
||||
$(".ui-datepicker-calendar tbody a:contains(12)", dp).simulate("click", {});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 12),
|
||||
"Mouse click - preset");
|
||||
inp.val("02/04/2008").datepicker("show");
|
||||
inp.val("").datepicker("show");
|
||||
$("button.ui-datepicker-close", dp).simulate("click", {});
|
||||
ok(inp.datepicker("getDate") == null, "Mouse click - close");
|
||||
inp.val("02/04/2008").datepicker("show");
|
||||
$("button.ui-datepicker-close", dp).simulate("click", {});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 4),
|
||||
"Mouse click - close + preset");
|
||||
inp.val("02/04/2008").datepicker("show");
|
||||
$("a.ui-datepicker-prev", dp).simulate("click", {});
|
||||
$("button.ui-datepicker-close", dp).simulate("click", {});
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 4),
|
||||
"Mouse click - abandoned");
|
||||
// Current/previous/next
|
||||
inp.val("02/04/2008").datepicker("option", {showButtonPanel: true}).datepicker("show");
|
||||
$(".ui-datepicker-current", dp).simulate("click", {});
|
||||
$(".ui-datepicker-calendar tbody a:contains(14)", dp).simulate("click", {});
|
||||
date.setDate(14);
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), date, "Mouse click - current");
|
||||
inp.val("02/04/2008").datepicker("show");
|
||||
$(".ui-datepicker-prev", dp).simulate("click");
|
||||
$(".ui-datepicker-calendar tbody a:contains(16)", dp).simulate("click");
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 1 - 1, 16),
|
||||
"Mouse click - previous");
|
||||
inp.val("02/04/2008").datepicker("show");
|
||||
$(".ui-datepicker-next", dp).simulate("click");
|
||||
$(".ui-datepicker-calendar tbody a:contains(18)", dp).simulate("click");
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 3 - 1, 18),
|
||||
"Mouse click - next");
|
||||
// Previous/next with minimum/maximum
|
||||
inp.datepicker("option", {minDate: new Date(2008, 2 - 1, 2),
|
||||
maxDate: new Date(2008, 2 - 1, 26)}).val("02/04/2008").datepicker("show");
|
||||
$(".ui-datepicker-prev", dp).simulate("click");
|
||||
$(".ui-datepicker-calendar tbody a:contains(16)", dp).simulate("click");
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 16),
|
||||
"Mouse click - previous + min/max");
|
||||
inp.val("02/04/2008").datepicker("show");
|
||||
$(".ui-datepicker-next", dp).simulate("click");
|
||||
$(".ui-datepicker-calendar tbody a:contains(18)", dp).simulate("click");
|
||||
TestHelpers.datepicker.equalsDate(inp.datepicker("getDate"), new Date(2008, 2 - 1, 18),
|
||||
"Mouse click - next + min/max");
|
||||
// Inline
|
||||
inl = TestHelpers.datepicker.init("#inl");
|
||||
dp = $(".ui-datepicker-inline", inl);
|
||||
date = new Date();
|
||||
inl.datepicker("setDate", date);
|
||||
$(".ui-datepicker-calendar tbody a:contains(10)", dp).simulate("click", {});
|
||||
date.setDate(10);
|
||||
TestHelpers.datepicker.equalsDate(inl.datepicker("getDate"), date, "Mouse click inline");
|
||||
inl.datepicker("option", {showButtonPanel: true}).datepicker("setDate", new Date(2008, 2 - 1, 4));
|
||||
$(".ui-datepicker-calendar tbody a:contains(12)", dp).simulate("click", {});
|
||||
TestHelpers.datepicker.equalsDate(inl.datepicker("getDate"), new Date(2008, 2 - 1, 12), "Mouse click inline - preset");
|
||||
inl.datepicker("option", {showButtonPanel: true});
|
||||
$(".ui-datepicker-current", dp).simulate("click", {});
|
||||
$(".ui-datepicker-calendar tbody a:contains(14)", dp).simulate("click", {});
|
||||
date.setDate(14);
|
||||
TestHelpers.datepicker.equalsDate(inl.datepicker("getDate"), date, "Mouse click inline - current");
|
||||
inl.datepicker("setDate", new Date(2008, 2 - 1, 4));
|
||||
$(".ui-datepicker-prev", dp).simulate("click");
|
||||
$(".ui-datepicker-calendar tbody a:contains(16)", dp).simulate("click");
|
||||
TestHelpers.datepicker.equalsDate(inl.datepicker("getDate"), new Date(2008, 1 - 1, 16),
|
||||
"Mouse click inline - previous");
|
||||
inl.datepicker("setDate", new Date(2008, 2 - 1, 4));
|
||||
$(".ui-datepicker-next", dp).simulate("click");
|
||||
$(".ui-datepicker-calendar tbody a:contains(18)", dp).simulate("click");
|
||||
TestHelpers.datepicker.equalsDate(inl.datepicker("getDate"), new Date(2008, 3 - 1, 18),
|
||||
"Mouse click inline - next");
|
||||
});
|
||||
|
||||
})(jQuery);
|
153
jquery-ui/tests/unit/datepicker/datepicker_events.js
vendored
Normal file
153
jquery-ui/tests/unit/datepicker/datepicker_events.js
vendored
Normal file
|
@ -0,0 +1,153 @@
|
|||
/*
|
||||
* datepicker_events.js
|
||||
*/
|
||||
(function($) {
|
||||
|
||||
module("datepicker: events");
|
||||
|
||||
var selectedThis = null,
|
||||
selectedDate = null,
|
||||
selectedInst = null;
|
||||
|
||||
function callback(date, inst) {
|
||||
selectedThis = this;
|
||||
selectedDate = date;
|
||||
selectedInst = inst;
|
||||
}
|
||||
|
||||
function callback2(year, month, inst) {
|
||||
selectedThis = this;
|
||||
selectedDate = year + "/" + month;
|
||||
selectedInst = inst;
|
||||
}
|
||||
|
||||
test("events", function() {
|
||||
expect( 26 );
|
||||
var dateStr, newMonthYear, inp2,
|
||||
inp = TestHelpers.datepicker.init("#inp", {onSelect: callback}),
|
||||
date = new Date();
|
||||
// onSelect
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
equal(selectedThis, inp[0], "Callback selected this");
|
||||
equal(selectedInst, $.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Callback selected inst");
|
||||
equal(selectedDate, $.datepicker.formatDate("mm/dd/yy", date),
|
||||
"Callback selected date");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.DOWN}).
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
date.setDate(date.getDate() + 7);
|
||||
equal(selectedDate, $.datepicker.formatDate("mm/dd/yy", date),
|
||||
"Callback selected date - ctrl+down");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ESCAPE});
|
||||
equal(selectedDate, $.datepicker.formatDate("mm/dd/yy", date),
|
||||
"Callback selected date - esc");
|
||||
dateStr = "02/04/2008";
|
||||
inp.val(dateStr).datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
equal(dateStr, selectedDate,
|
||||
"onSelect is called after enter keydown");
|
||||
// onChangeMonthYear
|
||||
inp.datepicker("option", {onChangeMonthYear: callback2, onSelect: null}).
|
||||
val("").datepicker("show");
|
||||
newMonthYear = function(date) {
|
||||
return date.getFullYear() + "/" + (date.getMonth() + 1);
|
||||
};
|
||||
date = new Date();
|
||||
date.setDate(1);
|
||||
inp.simulate("keydown", {keyCode: $.ui.keyCode.PAGE_UP});
|
||||
date.setMonth(date.getMonth() - 1);
|
||||
equal(selectedThis, inp[0], "Callback change month/year this");
|
||||
equal(selectedInst, $.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Callback change month/year inst");
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year date - pgup");
|
||||
inp.simulate("keydown", {keyCode: $.ui.keyCode.PAGE_DOWN});
|
||||
date.setMonth(date.getMonth() + 1);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year date - pgdn");
|
||||
inp.simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_UP});
|
||||
date.setFullYear(date.getFullYear() - 1);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year date - ctrl+pgup");
|
||||
inp.simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.HOME});
|
||||
date.setFullYear(date.getFullYear() + 1);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year date - ctrl+home");
|
||||
inp.simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_DOWN});
|
||||
date.setFullYear(date.getFullYear() + 1);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year date - ctrl+pgdn");
|
||||
inp.datepicker("setDate", new Date(2007, 1 - 1, 26));
|
||||
equal(selectedDate, "2007/1", "Callback change month/year date - setDate");
|
||||
selectedDate = null;
|
||||
inp.datepicker("setDate", new Date(2007, 1 - 1, 12));
|
||||
ok(selectedDate == null, "Callback change month/year date - setDate no change");
|
||||
// onChangeMonthYear step by 2
|
||||
inp.datepicker("option", {stepMonths: 2}).
|
||||
datepicker("hide").val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.PAGE_UP});
|
||||
date.setMonth(date.getMonth() - 14);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year by 2 date - pgup");
|
||||
inp.simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_UP});
|
||||
date.setMonth(date.getMonth() - 12);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year by 2 date - ctrl+pgup");
|
||||
inp.simulate("keydown", {keyCode: $.ui.keyCode.PAGE_DOWN});
|
||||
date.setMonth(date.getMonth() + 2);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year by 2 date - pgdn");
|
||||
inp.simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.PAGE_DOWN});
|
||||
date.setMonth(date.getMonth() + 12);
|
||||
equal(selectedDate, newMonthYear(date),
|
||||
"Callback change month/year by 2 date - ctrl+pgdn");
|
||||
// onClose
|
||||
inp.datepicker("option", {onClose: callback, onChangeMonthYear: null, stepMonths: 1}).
|
||||
val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ESCAPE});
|
||||
equal(selectedThis, inp[0], "Callback close this");
|
||||
equal(selectedInst, $.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Callback close inst");
|
||||
equal(selectedDate, "", "Callback close date - esc");
|
||||
inp.val("").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ENTER});
|
||||
equal(selectedDate, $.datepicker.formatDate("mm/dd/yy", new Date()),
|
||||
"Callback close date - enter");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {keyCode: $.ui.keyCode.ESCAPE});
|
||||
equal(selectedDate, "02/04/2008", "Callback close date - preset");
|
||||
inp.val("02/04/2008").datepicker("show").
|
||||
simulate("keydown", {ctrlKey: true, keyCode: $.ui.keyCode.END});
|
||||
equal(selectedDate, "", "Callback close date - ctrl+end");
|
||||
|
||||
inp2 = TestHelpers.datepicker.init("#inp2");
|
||||
inp2.datepicker().datepicker("option", {onClose: callback}).datepicker("show");
|
||||
inp.datepicker("show");
|
||||
equal(selectedThis, inp2[0], "Callback close this");
|
||||
});
|
||||
|
||||
test("beforeShowDay-getDate", function() {
|
||||
expect( 3 );
|
||||
var inp = TestHelpers.datepicker.init("#inp", {beforeShowDay: function() { inp.datepicker("getDate"); return [true, ""]; }}),
|
||||
dp = $("#ui-datepicker-div");
|
||||
inp.val("01/01/2010").datepicker("show");
|
||||
// contains non-breaking space
|
||||
equal($("div.ui-datepicker-title").text(),
|
||||
// support: IE <9, jQuery <1.8
|
||||
// In IE7/8 with jQuery <1.8, encoded spaces behave in strange ways
|
||||
$( "<span>January 2010</span>" ).text(), "Initial month");
|
||||
$("a.ui-datepicker-next", dp).click();
|
||||
$("a.ui-datepicker-next", dp).click();
|
||||
// contains non-breaking space
|
||||
equal($("div.ui-datepicker-title").text(),
|
||||
$( "<span>March 2010</span>" ).text(), "After next clicks");
|
||||
inp.datepicker("hide").datepicker("show");
|
||||
$("a.ui-datepicker-prev", dp).click();
|
||||
$("a.ui-datepicker-prev", dp).click();
|
||||
// contains non-breaking space
|
||||
equal($("div.ui-datepicker-title").text(),
|
||||
$( "<span>November 2009</span>" ).text(), "After prev clicks");
|
||||
inp.datepicker("hide");
|
||||
});
|
||||
|
||||
})(jQuery);
|
125
jquery-ui/tests/unit/datepicker/datepicker_methods.js
vendored
Normal file
125
jquery-ui/tests/unit/datepicker/datepicker_methods.js
vendored
Normal file
|
@ -0,0 +1,125 @@
|
|||
/*
|
||||
* datepicker_methods.js
|
||||
*/
|
||||
(function($) {
|
||||
|
||||
module("datepicker: methods");
|
||||
|
||||
test("destroy", function() {
|
||||
expect( 33 );
|
||||
var inl,
|
||||
inp = TestHelpers.datepicker.init("#inp");
|
||||
ok(inp.is(".hasDatepicker"), "Default - marker class set");
|
||||
ok($.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Default - instance present");
|
||||
ok(inp.next().is("#alt"), "Default - button absent");
|
||||
inp.datepicker("destroy");
|
||||
inp = $("#inp");
|
||||
ok(!inp.is(".hasDatepicker"), "Default - marker class cleared");
|
||||
ok(!$.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Default - instance absent");
|
||||
ok(inp.next().is("#alt"), "Default - button absent");
|
||||
// With button
|
||||
inp= TestHelpers.datepicker.init("#inp", {showOn: "both"});
|
||||
ok(inp.is(".hasDatepicker"), "Button - marker class set");
|
||||
ok($.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Button - instance present");
|
||||
ok(inp.next().text() === "...", "Button - button added");
|
||||
inp.datepicker("destroy");
|
||||
inp = $("#inp");
|
||||
ok(!inp.is(".hasDatepicker"), "Button - marker class cleared");
|
||||
ok(!$.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Button - instance absent");
|
||||
ok(inp.next().is("#alt"), "Button - button removed");
|
||||
// With append text
|
||||
inp = TestHelpers.datepicker.init("#inp", {appendText: "Testing"});
|
||||
ok(inp.is(".hasDatepicker"), "Append - marker class set");
|
||||
ok($.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Append - instance present");
|
||||
ok(inp.next().text() === "Testing", "Append - append text added");
|
||||
inp.datepicker("destroy");
|
||||
inp = $("#inp");
|
||||
ok(!inp.is(".hasDatepicker"), "Append - marker class cleared");
|
||||
ok(!$.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Append - instance absent");
|
||||
ok(inp.next().is("#alt"), "Append - append text removed");
|
||||
// With both
|
||||
inp= TestHelpers.datepicker.init("#inp", {showOn: "both", buttonImageOnly: true,
|
||||
buttonImage: "images/calendar.gif", appendText: "Testing"});
|
||||
ok(inp.is(".hasDatepicker"), "Both - marker class set");
|
||||
ok($.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Both - instance present");
|
||||
ok(inp.next()[0].nodeName.toLowerCase() === "img", "Both - button added");
|
||||
ok(inp.next().next().text() === "Testing", "Both - append text added");
|
||||
inp.datepicker("destroy");
|
||||
inp = $("#inp");
|
||||
ok(!inp.is(".hasDatepicker"), "Both - marker class cleared");
|
||||
ok(!$.data(inp[0], TestHelpers.datepicker.PROP_NAME), "Both - instance absent");
|
||||
ok(inp.next().is("#alt"), "Both - button and append text absent");
|
||||
// Inline
|
||||
inl = TestHelpers.datepicker.init("#inl");
|
||||
ok(inl.is(".hasDatepicker"), "Inline - marker class set");
|
||||
ok(inl.html() !== "", "Inline - datepicker present");
|
||||
ok($.data(inl[0], TestHelpers.datepicker.PROP_NAME), "Inline - instance present");
|
||||
ok(inl.next().length === 0 || inl.next().is("p"), "Inline - button absent");
|
||||
inl.datepicker("destroy");
|
||||
inl = $("#inl");
|
||||
ok(!inl.is(".hasDatepicker"), "Inline - marker class cleared");
|
||||
ok(inl.html() === "", "Inline - datepicker absent");
|
||||
ok(!$.data(inl[0], TestHelpers.datepicker.PROP_NAME), "Inline - instance absent");
|
||||
ok(inl.next().length === 0 || inl.next().is("p"), "Inline - button absent");
|
||||
});
|
||||
|
||||
test("enableDisable", function() {
|
||||
expect( 33 );
|
||||
var inl, dp,
|
||||
inp = TestHelpers.datepicker.init("#inp");
|
||||
ok(!inp.datepicker("isDisabled"), "Enable/disable - initially marked as enabled");
|
||||
ok(!inp[0].disabled, "Enable/disable - field initially enabled");
|
||||
inp.datepicker("disable");
|
||||
ok(inp.datepicker("isDisabled"), "Enable/disable - now marked as disabled");
|
||||
ok(inp[0].disabled, "Enable/disable - field now disabled");
|
||||
inp.datepicker("enable");
|
||||
ok(!inp.datepicker("isDisabled"), "Enable/disable - now marked as enabled");
|
||||
ok(!inp[0].disabled, "Enable/disable - field now enabled");
|
||||
inp.datepicker("destroy");
|
||||
// With a button
|
||||
inp = TestHelpers.datepicker.init("#inp", {showOn: "button"});
|
||||
ok(!inp.datepicker("isDisabled"), "Enable/disable button - initially marked as enabled");
|
||||
ok(!inp[0].disabled, "Enable/disable button - field initially enabled");
|
||||
ok(!inp.next("button")[0].disabled, "Enable/disable button - button initially enabled");
|
||||
inp.datepicker("disable");
|
||||
ok(inp.datepicker("isDisabled"), "Enable/disable button - now marked as disabled");
|
||||
ok(inp[0].disabled, "Enable/disable button - field now disabled");
|
||||
ok(inp.next("button")[0].disabled, "Enable/disable button - button now disabled");
|
||||
inp.datepicker("enable");
|
||||
ok(!inp.datepicker("isDisabled"), "Enable/disable button - now marked as enabled");
|
||||
ok(!inp[0].disabled, "Enable/disable button - field now enabled");
|
||||
ok(!inp.next("button")[0].disabled, "Enable/disable button - button now enabled");
|
||||
inp.datepicker("destroy");
|
||||
// With an image button
|
||||
inp = TestHelpers.datepicker.init("#inp", {showOn: "button", buttonImageOnly: true,
|
||||
buttonImage: "images/calendar.gif"});
|
||||
ok(!inp.datepicker("isDisabled"), "Enable/disable image - initially marked as enabled");
|
||||
ok(!inp[0].disabled, "Enable/disable image - field initially enabled");
|
||||
ok(parseFloat(inp.next("img").css("opacity")) === 1, "Enable/disable image - image initially enabled");
|
||||
inp.datepicker("disable");
|
||||
ok(inp.datepicker("isDisabled"), "Enable/disable image - now marked as disabled");
|
||||
ok(inp[0].disabled, "Enable/disable image - field now disabled");
|
||||
ok(parseFloat(inp.next("img").css("opacity")) !== 1, "Enable/disable image - image now disabled");
|
||||
inp.datepicker("enable");
|
||||
ok(!inp.datepicker("isDisabled"), "Enable/disable image - now marked as enabled");
|
||||
ok(!inp[0].disabled, "Enable/disable image - field now enabled");
|
||||
ok(parseFloat(inp.next("img").css("opacity")) === 1, "Enable/disable image - image now enabled");
|
||||
inp.datepicker("destroy");
|
||||
// Inline
|
||||
inl = TestHelpers.datepicker.init("#inl", {changeYear: true});
|
||||
dp = $(".ui-datepicker-inline", inl);
|
||||
ok(!inl.datepicker("isDisabled"), "Enable/disable inline - initially marked as enabled");
|
||||
ok(!dp.children().is(".ui-state-disabled"), "Enable/disable inline - not visually disabled initially");
|
||||
ok(!dp.find("select").prop("disabled"), "Enable/disable inline - form element enabled initially");
|
||||
inl.datepicker("disable");
|
||||
ok(inl.datepicker("isDisabled"), "Enable/disable inline - now marked as disabled");
|
||||
ok(dp.children().is(".ui-state-disabled"), "Enable/disable inline - visually disabled");
|
||||
ok(dp.find("select").prop("disabled"), "Enable/disable inline - form element disabled");
|
||||
inl.datepicker("enable");
|
||||
ok(!inl.datepicker("isDisabled"), "Enable/disable inline - now marked as enabled");
|
||||
ok(!dp.children().is(".ui-state-disabled"), "Enable/disable inline - not visiually disabled");
|
||||
ok(!dp.find("select").prop("disabled"), "Enable/disable inline - form element enabled");
|
||||
inl.datepicker("destroy");
|
||||
});
|
||||
|
||||
})(jQuery);
|
1125
jquery-ui/tests/unit/datepicker/datepicker_options.js
vendored
Normal file
1125
jquery-ui/tests/unit/datepicker/datepicker_options.js
vendored
Normal file
File diff suppressed because it is too large
Load diff
27
jquery-ui/tests/unit/datepicker/datepicker_test_helpers.js
vendored
Normal file
27
jquery-ui/tests/unit/datepicker/datepicker_test_helpers.js
vendored
Normal file
|
@ -0,0 +1,27 @@
|
|||
TestHelpers.datepicker = {
|
||||
addMonths: function(date, offset) {
|
||||
var maxDay = 32 - new Date(date.getFullYear(), date.getMonth() + offset, 32).getDate();
|
||||
date.setDate(Math.min(date.getDate(), maxDay));
|
||||
date.setMonth(date.getMonth() + offset);
|
||||
return date;
|
||||
},
|
||||
equalsDate: function(d1, d2, message) {
|
||||
if (!d1 || !d2) {
|
||||
ok(false, message + " - missing date");
|
||||
return;
|
||||
}
|
||||
d1 = new Date(d1.getFullYear(), d1.getMonth(), d1.getDate());
|
||||
d2 = new Date(d2.getFullYear(), d2.getMonth(), d2.getDate());
|
||||
equal(d1.toString(), d2.toString(), message);
|
||||
},
|
||||
init: function( id, options ) {
|
||||
$.datepicker.setDefaults( $.datepicker.regional[ "" ] );
|
||||
return $( id ).datepicker( $.extend( { showAnim: "" }, options || {} ) );
|
||||
},
|
||||
initNewInput: function( options ) {
|
||||
var id = $( "<input>" ).appendTo( "#qunit-fixture" );
|
||||
return TestHelpers.datepicker.init( id, options );
|
||||
},
|
||||
onFocus: TestHelpers.onFocus,
|
||||
PROP_NAME: "datepicker"
|
||||
};
|
BIN
jquery-ui/tests/unit/datepicker/images/calendar.gif
Normal file
BIN
jquery-ui/tests/unit/datepicker/images/calendar.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 258 B |
Loading…
Add table
Add a link
Reference in a new issue