PHP Classes

File: src/MSD/HomeBundle/Resources/public/css/jquery-ui-1.10.3/tests/unit/datepicker/datepicker_core.js

Recommend this page to a friend!
  Classes of Manolo Salsas  >  Online PHP Image Transform  >  src/MSD/HomeBundle/Resources/public/css/jquery-ui-1.10.3/tests/unit/datepicker/datepicker_core.js  >  Download  
File: src/MSD/HomeBundle/Resources/public/css/jquery-ui-1.10.3/tests/unit/datepicker/datepicker_core.js
Role: Auxiliary data
Content type: text/plain
Description: Auxiliary data
Class: Online PHP Image Transform
Application to do interactive image manipulation
Author: By
Last change:
Date: 2 years ago
Size: 23,302 bytes
 

Contents

Class file image Download
/*
 * datepicker_core.js
 */

(function($) {

module("datepicker: core");

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.init("#inp"),
		dp = $("#ui-datepicker-div");

	function step1() {
		inp[0].focus();
		setTimeout(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.init("#inp", {changeMonth: true, changeYear: true, showButtonPanel: true});
		inp.focus();
		setTimeout(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.init("#inp", {numberOfMonths: 2});
		inp.focus();
		setTimeout(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.init("#inp", {numberOfMonths: 3});
		inp.focus();
		setTimeout(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.init("#inp", {numberOfMonths: [2, 2]});
		inp.focus();
		setTimeout(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();
});

test("customStructure", function() {
	expect( 20 );
	var header, panel, title, thead,
		dp = $("#ui-datepicker-div"),
		// Check right-to-left localisation
		inp = TestHelpers.datepicker.init("#inp", $.datepicker.regional.he);
	inp.datepicker( "option", "showButtonPanel", true);
	inp.focus();
	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");

	// Hide prev/next
	inp = TestHelpers.datepicker.init("#inp", {hideIfNoPrevNext: true, minDate: new Date(2008, 2 - 1, 4), maxDate: new Date(2008, 2 - 1, 14)});
	inp.val("02/10/2008").focus();
	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");

	// Changeable Month with read-only year
	inp = TestHelpers.datepicker.init("#inp", {changeMonth: true});
	inp.focus();
	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");

	// Changeable year with read-only month
	inp = TestHelpers.datepicker.init("#inp", {changeYear: true});
	inp.focus();
	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");

	// Read-only first day of week
	inp = TestHelpers.datepicker.init("#inp", {changeFirstDay: false});
	inp.focus();
	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");
});

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);
For more information send a message to info at phpclasses dot org.