aboutsummaryrefslogtreecommitdiffstats
path: root/tests/unit/button/button_core.js
blob: 5b30aa860d1dfb1b8847de995480e3a9fced6a72 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*
 * button_core.js
 */


(function($) {

module("button: core");

test("checkbox", function() {
	var input = $("#check");
		label = $("label[for=check]");
	ok( input.is(":visible") );	
	ok( label.is(":not(.ui-button)") );
	input.button();
	ok( input.is(".ui-helper-hidden-accessible") );
	ok( label.is(".ui-button") );
});

test("radios", function() {
	var inputs = $("#radio0 input");
		labels = $("#radio0 label");
	ok( inputs.is(":visible") );	
	ok( labels.is(":not(.ui-button)") );
	inputs.button();
	ok( inputs.is(".ui-helper-hidden-accessible") );
	ok( labels.is(".ui-button") );
});

function assert(noForm, form1, form2) {
	ok( $("#radio0 .ui-button" + noForm).is(".ui-state-active") );
	ok( $("#radio1 .ui-button" + form1).is(".ui-state-active") );
	ok( $("#radio2 .ui-button" + form2).is(".ui-state-active") );
}

test("radio groups", function() {
	$(":radio").button();
	assert(":eq(0)", ":eq(1)", ":eq(2)");
	
	// click outside of forms
	$("#radio0 .ui-button:eq(1)").click();
	assert(":eq(1)", ":eq(1)", ":eq(2)");
	
	// click in first form
	$("#radio1 .ui-button:eq(0)").click();
	assert(":eq(1)", ":eq(0)", ":eq(2)");
	
	// click in second form
	$("#radio2 .ui-button:eq(0)").click();
	assert(":eq(1)", ":eq(0)", ":eq(0)");
});

test("input type submit, don't create child elements", function() {
	var input = $("#submit")
	same( input.children().length, 0 );
	input.button();
	same( input.children().length, 0 );
});

test("buttonset", function() {
	var set = $("#radio1").buttonset();
	ok( set.is(".ui-buttonset") );
	same( set.children(".ui-button").length, 3 );
	same( set.children("input:radio.ui-helper-hidden-accessible").length, 3 );
	ok( set.children("label:eq(0)").is(".ui-button.ui-corner-left:not(.ui-corner-all)") );
	ok( set.children("label:eq(1)").is(".ui-button:not(.ui-corner-all)") );
	ok( set.children("label:eq(2)").is(".ui-button.ui-corner-right:not(.ui-corner-all)") );
});

})(jQuery);