6 module("dialog: methods", {
8 $("body>.ui-dialog").remove();
12 test("init", function() {
15 $("<div></div>").appendTo("body").dialog().remove();
16 ok(true, ".dialog() called on element");
18 $([]).dialog().remove();
19 ok(true, ".dialog() called on empty collection");
21 $("<div></div>").dialog().remove();
22 ok(true, ".dialog() called on disconnected DOMElement - never connected");
24 $("<div></div>").appendTo("body").remove().dialog().remove();
25 ok(true, ".dialog() called on disconnected DOMElement - removed");
27 var element = $("<div></div>").dialog();
28 element.dialog("option", "foo");
30 ok(true, "arbitrary option getter after init");
32 $("<div></div>").dialog().dialog("option", "foo", "bar").remove();
33 ok(true, "arbitrary option setter after init");
36 test("destroy", function() {
39 var element, element2;
41 $( "#dialog1, #form-dialog" ).hide();
42 domEqual( "#dialog1", function() {
43 var dialog = $( "#dialog1" ).dialog().dialog( "destroy" );
44 equal( dialog.parent()[ 0 ], $( "#qunit-fixture" )[ 0 ] );
45 equal( dialog.index(), 0 );
47 domEqual( "#form-dialog", function() {
48 var dialog = $( "#form-dialog" ).dialog().dialog( "destroy" );
49 equal( dialog.parent()[ 0 ], $( "#qunit-fixture" )[ 0 ] );
50 equal( dialog.index(), 2 );
53 // Ensure dimensions are restored (#8119)
54 $( "#dialog1" ).show().css({
59 domEqual( "#dialog1", function() {
60 $( "#dialog1" ).dialog().dialog( "destroy" );
63 // Don't throw errors when destroying a never opened modal dialog (#9004)
64 $( "#dialog1" ).dialog({ autoOpen: false, modal: true }).dialog( "destroy" );
65 equal( $( ".ui-widget-overlay" ).length, 0, "overlay does not exist" );
66 equal( $.ui.dialog.overlayInstances, 0, "overlayInstances equals the number of open overlays");
68 element = $( "#dialog1" ).dialog({ modal: true }),
69 element2 = $( "#dialog2" ).dialog({ modal: true });
70 equal( $( ".ui-widget-overlay" ).length, 2, "overlays created when dialogs are open" );
71 equal( $.ui.dialog.overlayInstances, 2, "overlayInstances equals the number of open overlays" );
72 element.dialog( "close" );
73 equal( $( ".ui-widget-overlay" ).length, 1, "overlay remains after closing one dialog" );
74 equal( $.ui.dialog.overlayInstances, 1, "overlayInstances equals the number of open overlays" );
75 element.dialog( "destroy" );
76 equal( $( ".ui-widget-overlay" ).length, 1, "overlay remains after destroying one dialog" );
77 equal( $.ui.dialog.overlayInstances, 1, "overlayInstances equals the number of open overlays" );
78 element2.dialog( "destroy" );
79 equal( $( ".ui-widget-overlay" ).length, 0, "overlays removed when all dialogs are destoryed" );
80 equal( $.ui.dialog.overlayInstances, 0, "overlayInstances equals the number of open overlays" );
83 asyncTest("#9000: Dialog leaves broken event handler after close/destroy in certain cases", function() {
85 $( "#dialog1" ).dialog({ modal:true }).dialog( "close" ).dialog( "destroy" );
86 setTimeout(function() {
87 $( "#favorite-animal" ).focus();
88 ok( true, "close and destroy modal dialog before its really opened" );
93 test("#4980: Destroy should place element back in original DOM position", function(){
95 var container = $("<div id='container'><div id='modal'>Content</div></div>"),
96 modal = container.find("#modal");
98 ok(!$.contains(container[0], modal[0]), "dialog should move modal element to outside container element");
99 modal.dialog("destroy");
100 ok($.contains(container[0], modal[0]), "dialog(destroy) should place element back in original DOM position");
103 test( "enable/disable disabled", function() {
105 var element = $( "<div></div>" ).dialog();
106 element.dialog( "disable" );
107 equal(element.dialog( "option", "disabled" ), false, "disable method doesn't do anything" );
108 ok( !element.dialog( "widget" ).hasClass( "ui-dialog-disabled" ), "disable method doesn't add ui-dialog-disabled class" );
111 test("close", function() {
115 expected = $("<div></div>").dialog(),
116 actual = expected.dialog("close");
117 equal(actual, expected, "close is chainable");
119 element = $("<div></div>").dialog();
120 ok(element.dialog("widget").is(":visible") && !element.dialog("widget").is(":hidden"), "dialog visible before close method called");
121 element.dialog("close");
122 ok(element.dialog("widget").is(":hidden") && !element.dialog("widget").is(":visible"), "dialog hidden after close method called");
125 test("isOpen", function() {
128 var element = $("<div></div>").dialog();
129 equal(element.dialog("isOpen"), true, "dialog is open after init");
130 element.dialog("close");
131 equal(element.dialog("isOpen"), false, "dialog is closed");
134 element = $("<div></div>").dialog({autoOpen: false});
135 equal(element.dialog("isOpen"), false, "dialog is closed after init");
136 element.dialog("open");
137 equal(element.dialog("isOpen"), true, "dialog is open");
141 test("moveToTop", function() {
144 var actual = $( ".ui-dialog" ).map(function() {
145 return +$( this ).find( ".ui-dialog-content" ).attr( "id" ).replace( /\D+/, "" );
147 deepEqual( actual, $.makeArray( arguments ) );
149 var dialog1, dialog2,
151 dialog1 = $( "#dialog1" ).dialog({
153 equal( focusOn, "dialog1" );
157 dialog2 = $( "#dialog2" ).dialog({
159 equal( focusOn, "dialog2" );
164 dialog1.dialog( "moveToTop" );
168 test("open", function() {
171 expected = $("<div></div>").dialog(),
172 actual = expected.dialog("open");
173 equal(actual, expected, "open is chainable");
175 element = $("<div></div>").dialog({ autoOpen: false });
176 ok(element.dialog("widget").is(":hidden") && !element.dialog("widget").is(":visible"), "dialog hidden before open method called");
177 element.dialog("open");
178 ok(element.dialog("widget").is(":visible") && !element.dialog("widget").is(":hidden"), "dialog visible after open method called");
181 test("#6137: dialog('open') causes form elements to reset on IE7", function() {
184 var d1 = $("<form><input type='radio' name='radio' id='a' value='a' checked='checked'></input>" +
185 "<input type='radio' name='radio' id='b' value='b'>b</input></form>").appendTo( "body" ).dialog({autoOpen: false});
187 d1.find("#b").prop( "checked", true );
188 equal(d1.find("input:checked").val(), "b", "checkbox b is checked");
191 equal(d1.find("input:checked").val(), "b", "checkbox b is checked");
196 asyncTest( "#8958: dialog can be opened while opening", function() {
199 var element = $( "<div>" ).dialog({
203 equal( $( ".ui-widget-overlay" ).length, 1 );
208 $( "#favorite-animal" )
209 // We focus the input to start the test. Once it receives focus, the
210 // dialog will open. Opening the dialog, will cause an element inside
211 // the dialog to gain focus, thus blurring the input.
212 .bind( "focus", function() {
213 element.dialog( "open" );
215 // When the input blurs, the dialog is in the process of opening. We
216 // try to open the dialog again, to make sure that dialogs properly
217 // handle a call to the open() method during the process of the dialog
219 .bind( "blur", function() {
220 element.dialog( "open" );
225 test("#5531: dialog width should be at least minWidth on creation", function () {
227 var element = $("<div></div>").dialog({
232 equal(element.dialog("option", "width"), 300, "width is minWidth");
233 element.dialog("option", "width", 200);
234 equal(element.dialog("option", "width"), 300, "width unchanged when set to < minWidth");
235 element.dialog("option", "width", 320);
236 equal(element.dialog("option", "width"), 320, "width changed if set to > minWidth");
239 element = $("<div></div>").dialog({
242 ok(element.dialog("option", "width") >= 300, "width is at least 300");