2009-02-02 14:36:08 +00:00
/ *
* dialog _options . js
* /
( function ( $ ) {
module ( "dialog: options" ) ;
2012-12-07 19:54:21 +00:00
test ( "appendTo" , function ( ) {
2013-01-26 10:03:14 +00:00
expect ( 16 ) ;
2012-12-07 19:54:21 +00:00
var detached = $ ( "<div>" ) ,
2013-01-26 10:03:14 +00:00
element = $ ( "#dialog1" ) . dialog ( {
modal : true
} ) ;
2012-12-07 19:54:21 +00:00
equal ( element . dialog ( "widget" ) . parent ( ) [ 0 ] , document . body , "defaults to body" ) ;
2013-01-26 10:03:14 +00:00
equal ( $ ( ".ui-widget-overlay" ) . parent ( ) [ 0 ] , document . body , "overlay defaults to body" ) ;
2012-12-07 19:54:21 +00:00
element . dialog ( "destroy" ) ;
element . dialog ( {
2013-01-26 10:03:14 +00:00
appendTo : ".wrap" ,
modal : true
2012-12-07 19:54:21 +00:00
} ) ;
equal ( element . dialog ( "widget" ) . parent ( ) [ 0 ] , $ ( "#wrap1" ) [ 0 ] , "first found element" ) ;
2013-01-26 10:03:14 +00:00
equal ( $ ( ".ui-widget-overlay" ) . parent ( ) [ 0 ] , $ ( "#wrap1" ) [ 0 ] , "overlay first found element" ) ;
2012-12-07 19:54:21 +00:00
equal ( $ ( "#wrap2 .ui-dialog" ) . length , 0 , "only appends to one element" ) ;
2013-01-26 10:03:14 +00:00
equal ( $ ( "#wrap2 .ui-widget-overlay" ) . length , 0 , "overlay only appends to one element" ) ;
2012-12-07 19:54:21 +00:00
element . dialog ( "destroy" ) ;
element . dialog ( {
2013-01-26 10:03:14 +00:00
appendTo : null ,
modal : true
2012-12-07 19:54:21 +00:00
} ) ;
equal ( element . dialog ( "widget" ) . parent ( ) [ 0 ] , document . body , "null" ) ;
2013-01-26 10:03:14 +00:00
equal ( $ ( ".ui-widget-overlay" ) . parent ( ) [ 0 ] , document . body , "overlay null" ) ;
2012-12-07 19:54:21 +00:00
element . dialog ( "destroy" ) ;
2013-01-26 10:03:14 +00:00
element . dialog ( {
autoOpen : false ,
modal : true
} ) . dialog ( "option" , "appendTo" , "#wrap1" ) . dialog ( "open" ) ;
2012-12-07 19:54:21 +00:00
equal ( element . dialog ( "widget" ) . parent ( ) [ 0 ] , $ ( "#wrap1" ) [ 0 ] , "modified after init" ) ;
2013-01-26 10:03:14 +00:00
equal ( $ ( ".ui-widget-overlay" ) . parent ( ) [ 0 ] , $ ( "#wrap1" ) [ 0 ] , "overlay modified after init" ) ;
2012-12-07 19:54:21 +00:00
element . dialog ( "destroy" ) ;
element . dialog ( {
2013-01-26 10:03:14 +00:00
appendTo : detached ,
modal : true
2012-12-07 19:54:21 +00:00
} ) ;
equal ( element . dialog ( "widget" ) . parent ( ) [ 0 ] , detached [ 0 ] , "detached jQuery object" ) ;
2013-01-26 10:03:14 +00:00
equal ( detached . find ( ".ui-widget-overlay" ) . parent ( ) [ 0 ] , detached [ 0 ] , "overlay detached jQuery object" ) ;
2012-12-07 19:54:21 +00:00
element . dialog ( "destroy" ) ;
element . dialog ( {
2013-01-26 10:03:14 +00:00
appendTo : detached [ 0 ] ,
modal : true
2012-12-07 19:54:21 +00:00
} ) ;
equal ( element . dialog ( "widget" ) . parent ( ) [ 0 ] , detached [ 0 ] , "detached DOM element" ) ;
2013-01-26 10:03:14 +00:00
equal ( detached . find ( ".ui-widget-overlay" ) . parent ( ) [ 0 ] , detached [ 0 ] , "overlay detached DOM element" ) ;
2012-12-07 19:54:21 +00:00
element . dialog ( "destroy" ) ;
2013-01-26 10:03:14 +00:00
element . dialog ( {
autoOpen : false ,
modal : true
} ) . dialog ( "option" , "appendTo" , detached ) ;
2012-12-07 19:54:21 +00:00
equal ( element . dialog ( "widget" ) . parent ( ) [ 0 ] , detached [ 0 ] , "detached DOM element via option()" ) ;
2013-01-26 10:03:14 +00:00
equal ( detached . find ( ".ui-widget-overlay" ) . length , 0 , "overlay detached DOM element via option()" ) ;
2012-12-07 19:54:21 +00:00
element . dialog ( "destroy" ) ;
} ) ;
2009-02-04 04:35:18 +00:00
test ( "autoOpen" , function ( ) {
expect ( 2 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( { autoOpen : false } ) ;
ok ( ! element . dialog ( "widget" ) . is ( ":visible" ) , ".dialog({ autoOpen: false })" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { autoOpen : true } ) ;
ok ( element . dialog ( "widget" ) . is ( ":visible" ) , ".dialog({ autoOpen: true })" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
2015-01-30 14:57:04 +00:00
test ( "buttons" , function ( assert ) {
2011-03-02 17:52:21 +00:00
expect ( 21 ) ;
2009-02-04 04:35:18 +00:00
2012-04-19 14:27:06 +00:00
var btn , i , newButtons ,
buttons = {
2012-11-03 20:17:16 +00:00
"Ok" : function ( ev ) {
ok ( true , "button click fires callback" ) ;
2013-01-31 05:38:20 +00:00
equal ( this , element [ 0 ] , "context of callback" ) ;
2012-11-03 20:17:16 +00:00
equal ( ev . target , btn [ 0 ] , "event target" ) ;
} ,
"Cancel" : function ( ev ) {
ok ( true , "button click fires callback" ) ;
2013-01-31 05:38:20 +00:00
equal ( this , element [ 0 ] , "context of callback" ) ;
2012-11-03 20:17:16 +00:00
equal ( ev . target , btn [ 1 ] , "event target" ) ;
}
2009-02-04 04:35:18 +00:00
} ,
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { buttons : buttons } ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
btn = element . dialog ( "widget" ) . find ( ".ui-dialog-buttonpane button" ) ;
2012-02-28 14:56:32 +00:00
equal ( btn . length , 2 , "number of buttons" ) ;
2009-02-04 04:35:18 +00:00
2012-04-19 14:27:06 +00:00
i = 0 ;
2012-10-23 14:36:42 +00:00
$ . each ( buttons , function ( key ) {
2012-02-28 14:56:32 +00:00
equal ( btn . eq ( i ) . text ( ) , key , "text of button " + ( i + 1 ) ) ;
2009-02-04 04:35:18 +00:00
i ++ ;
} ) ;
2015-01-30 14:57:04 +00:00
assert . hasClasses ( btn . parent ( ) , "ui-dialog-buttonset" ) ;
assert . hasClasses ( element . parent ( ) , "ui-dialog-buttons" ) ;
2012-02-28 14:56:32 +00:00
2009-02-04 04:35:18 +00:00
btn . trigger ( "click" ) ;
2012-04-19 14:27:06 +00:00
newButtons = {
2012-10-23 14:36:42 +00:00
"Close" : function ( ev ) {
2009-02-04 04:35:18 +00:00
ok ( true , "button click fires callback" ) ;
2013-01-31 05:38:20 +00:00
equal ( this , element [ 0 ] , "context of callback" ) ;
2012-02-28 14:56:32 +00:00
equal ( ev . target , btn [ 0 ] , "event target" ) ;
2009-02-04 04:35:18 +00:00
}
} ;
2013-01-31 05:38:20 +00:00
deepEqual ( element . dialog ( "option" , "buttons" ) , buttons , ".dialog('option', 'buttons') getter" ) ;
element . dialog ( "option" , "buttons" , newButtons ) ;
deepEqual ( element . dialog ( "option" , "buttons" ) , newButtons , ".dialog('option', 'buttons', ...) setter" ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
btn = element . dialog ( "widget" ) . find ( ".ui-dialog-buttonpane button" ) ;
2012-02-28 14:56:32 +00:00
equal ( btn . length , 1 , "number of buttons after setter" ) ;
2012-12-26 13:08:48 +00:00
btn . trigger ( "click" ) ;
2009-02-04 04:35:18 +00:00
i = 0 ;
2012-10-23 14:36:42 +00:00
$ . each ( newButtons , function ( key ) {
2012-02-28 14:56:32 +00:00
equal ( btn . eq ( i ) . text ( ) , key , "text of button " + ( i + 1 ) ) ;
2009-02-04 04:35:18 +00:00
i += 1 ;
} ) ;
2012-02-28 14:56:32 +00:00
2013-01-31 05:38:20 +00:00
element . dialog ( "option" , "buttons" , null ) ;
btn = element . dialog ( "widget" ) . find ( ".ui-dialog-buttonpane button" ) ;
2012-02-28 14:56:32 +00:00
equal ( btn . length , 0 , "all buttons have been removed" ) ;
2013-01-31 05:38:20 +00:00
equal ( element . find ( ".ui-dialog-buttonset" ) . length , 0 , "buttonset has been removed" ) ;
2015-01-30 14:57:04 +00:00
assert . lacksClasses ( element . parent ( ) , "ui-dialog-buttons" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
2015-01-30 14:57:04 +00:00
test ( "buttons - advanced" , function ( assert ) {
2012-11-16 18:26:22 +00:00
expect ( 7 ) ;
2010-08-31 14:17:53 +00:00
2012-11-03 20:17:16 +00:00
var buttons ,
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( {
2012-11-03 20:17:16 +00:00
buttons : [
{
text : "a button" ,
"class" : "additional-class" ,
id : "my-button-id" ,
click : function ( ) {
2013-01-31 05:38:20 +00:00
equal ( this , element [ 0 ] , "correct context" ) ;
2012-11-16 18:26:22 +00:00
} ,
icons : {
primary : "ui-icon-cancel"
} ,
showText : false
2010-08-31 14:17:53 +00:00
}
2012-11-03 20:17:16 +00:00
]
} ) ;
2013-01-31 05:38:20 +00:00
buttons = element . dialog ( "widget" ) . find ( ".ui-dialog-buttonpane button" ) ;
2012-02-28 14:56:32 +00:00
equal ( buttons . length , 1 , "correct number of buttons" ) ;
equal ( buttons . attr ( "id" ) , "my-button-id" , "correct id" ) ;
equal ( buttons . text ( ) , "a button" , "correct label" ) ;
2015-01-30 14:57:04 +00:00
assert . hasClasses ( buttons , "additional-class" ) ;
2012-11-16 18:26:22 +00:00
deepEqual ( buttons . button ( "option" , "icons" ) , { primary : "ui-icon-cancel" , secondary : null } ) ;
equal ( buttons . button ( "option" , "text" ) , false ) ;
2010-08-31 14:17:53 +00:00
buttons . click ( ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2010-08-31 14:17:53 +00:00
} ) ;
2013-02-01 13:59:55 +00:00
test ( "#9043: buttons with Array.prototype modification" , function ( ) {
expect ( 1 ) ;
Array . prototype . test = $ . noop ;
var element = $ ( "<div></div>" ) . dialog ( ) ;
equal ( element . dialog ( "widget" ) . find ( ".ui-dialog-buttonpane" ) . length , 0 ,
"no button pane" ) ;
element . remove ( ) ;
delete Array . prototype . test ;
} ) ;
2009-02-04 04:35:18 +00:00
test ( "closeOnEscape" , function ( ) {
2012-06-27 15:32:48 +00:00
expect ( 6 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( { closeOnEscape : false } ) ;
2012-12-26 13:08:48 +00:00
ok ( true , "closeOnEscape: false" ) ;
2013-01-31 05:38:20 +00:00
ok ( element . dialog ( "widget" ) . is ( ":visible" ) && ! element . dialog ( "widget" ) . is ( ":hidden" ) , "dialog is open before ESC" ) ;
element . simulate ( "keydown" , { keyCode : $ . ui . keyCode . ESCAPE } )
2012-12-26 13:08:48 +00:00
. simulate ( "keypress" , { keyCode : $ . ui . keyCode . ESCAPE } )
. simulate ( "keyup" , { keyCode : $ . ui . keyCode . ESCAPE } ) ;
2013-01-31 05:38:20 +00:00
ok ( element . dialog ( "widget" ) . is ( ":visible" ) && ! element . dialog ( "widget" ) . is ( ":hidden" ) , "dialog is open after ESC" ) ;
2012-12-26 13:08:48 +00:00
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2012-12-26 13:08:48 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { closeOnEscape : true } ) ;
2012-12-26 13:08:48 +00:00
ok ( true , "closeOnEscape: true" ) ;
2013-01-31 05:38:20 +00:00
ok ( element . dialog ( "widget" ) . is ( ":visible" ) && ! element . dialog ( "widget" ) . is ( ":hidden" ) , "dialog is open before ESC" ) ;
element . simulate ( "keydown" , { keyCode : $ . ui . keyCode . ESCAPE } )
2012-12-26 13:08:48 +00:00
. simulate ( "keypress" , { keyCode : $ . ui . keyCode . ESCAPE } )
. simulate ( "keyup" , { keyCode : $ . ui . keyCode . ESCAPE } ) ;
2013-01-31 05:38:20 +00:00
ok ( element . dialog ( "widget" ) . is ( ":hidden" ) && ! element . dialog ( "widget" ) . is ( ":visible" ) , "dialog is closed after ESC" ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "closeText" , function ( ) {
expect ( 3 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( ) ;
2013-08-15 20:56:49 +00:00
equal ( element . dialog ( "widget" ) . find ( ".ui-dialog-titlebar-close span" ) . text ( ) , "Close" ,
2012-12-26 13:08:48 +00:00
"default close text" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { closeText : "foo" } ) ;
equal ( element . dialog ( "widget" ) . find ( ".ui-dialog-titlebar-close span" ) . text ( ) , "foo" ,
2012-12-26 13:08:48 +00:00
"closeText on init" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( ) . dialog ( "option" , "closeText" , "bar" ) ;
equal ( element . dialog ( "widget" ) . find ( ".ui-dialog-titlebar-close span" ) . text ( ) , "bar" ,
2012-12-26 13:08:48 +00:00
"closeText via option method" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "draggable" , function ( ) {
expect ( 4 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( { draggable : false } ) ;
2012-11-03 20:17:16 +00:00
2013-01-31 05:38:20 +00:00
TestHelpers . dialog . testDrag ( element , 50 , - 50 , 0 , 0 ) ;
element . dialog ( "option" , "draggable" , true ) ;
TestHelpers . dialog . testDrag ( element , 50 , - 50 , 50 , - 50 ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { draggable : true } ) ;
TestHelpers . dialog . testDrag ( element , 50 , - 50 , 50 , - 50 ) ;
element . dialog ( "option" , "draggable" , false ) ;
TestHelpers . dialog . testDrag ( element , 50 , - 50 , 0 , 0 ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "height" , function ( ) {
2011-11-28 21:52:10 +00:00
expect ( 4 ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( ) ;
equal ( element . dialog ( "widget" ) . outerHeight ( ) , 150 , "default height" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { height : 237 } ) ;
equal ( element . dialog ( "widget" ) . outerHeight ( ) , 237 , "explicit height" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( ) ;
element . dialog ( "option" , "height" , 238 ) ;
equal ( element . dialog ( "widget" ) . outerHeight ( ) , 238 , "explicit height set after init" ) ;
element . remove ( ) ;
2012-02-28 14:56:32 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . css ( "padding" , "20px" )
2011-11-28 21:52:10 +00:00
. dialog ( { height : 240 } ) ;
2013-01-31 05:38:20 +00:00
equal ( element . dialog ( "widget" ) . outerHeight ( ) , 240 , "explicit height with padding" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "maxHeight" , function ( ) {
expect ( 3 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( { maxHeight : 200 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-s" , 1000 , 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . height ( ) , 200 , 1 , "maxHeight" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { maxHeight : 200 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-n" , - 1000 , - 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . height ( ) , 200 , 1 , "maxHeight" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { maxHeight : 200 } ) . dialog ( "option" , "maxHeight" , 300 ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-s" , 1000 , 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . height ( ) , 300 , 1 , "maxHeight" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "maxWidth" , function ( ) {
expect ( 3 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( { maxWidth : 200 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-e" , 1000 , 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 200 , 1 , "maxWidth" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { maxWidth : 200 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-w" , - 1000 , - 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 200 , 1 , "maxWidth" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { maxWidth : 200 } ) . dialog ( "option" , "maxWidth" , 300 ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-w" , - 1000 , - 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 300 , 1 , "maxWidth" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "minHeight" , function ( ) {
expect ( 3 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( { minHeight : 10 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-s" , - 1000 , - 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . height ( ) , 10 , 1 , "minHeight" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { minHeight : 10 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-n" , 1000 , 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . height ( ) , 10 , 1 , "minHeight" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { minHeight : 10 } ) . dialog ( "option" , "minHeight" , 30 ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-n" , 1000 , 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . height ( ) , 30 , 1 , "minHeight" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "minWidth" , function ( ) {
expect ( 3 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( { minWidth : 10 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-e" , - 1000 , - 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 10 , 1 , "minWidth" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { minWidth : 10 } ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-w" , 1000 , 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 10 , 1 , "minWidth" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { minWidth : 30 } ) . dialog ( "option" , "minWidth" , 30 ) ;
TestHelpers . dialog . drag ( element , ".ui-resizable-w" , 1000 , 1000 ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 30 , 1 , "minWidth" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
2012-12-22 20:46:57 +00:00
test ( "position, default center on window" , function ( ) {
2012-06-27 15:32:48 +00:00
expect ( 2 ) ;
2012-12-22 20:46:57 +00:00
2014-10-20 23:18:34 +00:00
// dialogs alter the window width and height in Firefox
2012-12-22 20:46:57 +00:00
// so we collect that information before creating the dialog
2014-10-20 23:18:34 +00:00
// Support: Firefox
2012-12-22 20:46:57 +00:00
var winWidth = $ ( window ) . width ( ) ,
winHeight = $ ( window ) . height ( ) ,
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( ) ,
dialog = element . dialog ( "widget" ) ,
2012-04-19 14:27:06 +00:00
offset = dialog . offset ( ) ;
2012-12-22 20:46:57 +00:00
closeEnough ( offset . left , Math . round ( winWidth / 2 - dialog . outerWidth ( ) / 2 ) + $ ( window ) . scrollLeft ( ) , 1 , "dialog left position of center on window on initilization" ) ;
closeEnough ( offset . top , Math . round ( winHeight / 2 - dialog . outerHeight ( ) / 2 ) + $ ( window ) . scrollTop ( ) , 1 , "dialog top position of center on window on initilization" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2009-09-19 14:03:53 +00:00
} ) ;
2012-12-22 20:46:57 +00:00
test ( "position, right bottom at right bottom via ui.position args" , function ( ) {
expect ( 2 ) ;
2012-11-09 20:02:12 +00:00
2014-10-20 23:18:34 +00:00
// dialogs alter the window width and height in Firefox
2012-12-22 20:46:57 +00:00
// so we collect that information before creating the dialog
2014-10-20 23:18:34 +00:00
// Support: Firefox
2012-12-22 20:46:57 +00:00
var winWidth = $ ( window ) . width ( ) ,
winHeight = $ ( window ) . height ( ) ,
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( {
2012-12-22 20:46:57 +00:00
position : {
my : "right bottom" ,
at : "right bottom"
}
} ) ,
2013-01-31 05:38:20 +00:00
dialog = element . dialog ( "widget" ) ,
2012-12-22 20:46:57 +00:00
offset = dialog . offset ( ) ;
closeEnough ( offset . left , winWidth - dialog . outerWidth ( ) + $ ( window ) . scrollLeft ( ) , 1 , "dialog left position of right bottom at right bottom on initilization" ) ;
closeEnough ( offset . top , winHeight - dialog . outerHeight ( ) + $ ( window ) . scrollTop ( ) , 1 , "dialog top position of right bottom at right bottom on initilization" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2012-12-22 20:46:57 +00:00
} ) ;
2010-06-06 22:00:49 +00:00
2012-12-22 20:46:57 +00:00
test ( "position, at another element" , function ( ) {
2012-06-27 15:32:48 +00:00
expect ( 4 ) ;
2012-12-26 13:08:48 +00:00
var parent = $ ( "<div></div>" ) . css ( {
position : "absolute" ,
2012-04-19 14:27:06 +00:00
top : 400 ,
left : 600 ,
height : 10 ,
width : 10
2012-12-22 20:46:57 +00:00
} ) . appendTo ( "body" ) ,
2012-04-19 14:27:06 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( {
2012-04-19 14:27:06 +00:00
position : {
my : "left top" ,
at : "left top" ,
2012-12-22 20:46:57 +00:00
of : parent ,
collision : "none"
2012-04-19 14:27:06 +00:00
}
} ) ,
2010-06-06 22:00:49 +00:00
2013-01-31 05:38:20 +00:00
dialog = element . dialog ( "widget" ) ,
2012-04-19 14:27:06 +00:00
offset = dialog . offset ( ) ;
2010-06-06 22:00:49 +00:00
2012-12-22 20:46:57 +00:00
closeEnough ( offset . left , 600 , 1 , "dialog left position at another element on initilization" ) ;
closeEnough ( offset . top , 400 , 1 , "dialog top position at another element on initilization" ) ;
2010-06-06 22:00:49 +00:00
2013-01-31 05:38:20 +00:00
element . dialog ( "option" , "position" , {
2010-06-06 22:00:49 +00:00
my : "left top" ,
at : "right bottom" ,
2012-12-22 20:46:57 +00:00
of : parent ,
collision : "none"
2010-06-06 22:00:49 +00:00
} ) ;
2012-04-19 14:27:06 +00:00
offset = dialog . offset ( ) ;
2010-07-16 12:50:40 +00:00
2012-12-22 20:46:57 +00:00
closeEnough ( offset . left , 610 , 1 , "dialog left position at another element via setting option" ) ;
closeEnough ( offset . top , 410 , 1 , "dialog top position at another element via setting option" ) ;
2010-06-06 22:00:49 +00:00
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2010-06-06 22:00:49 +00:00
parent . remove ( ) ;
} ) ;
2009-02-04 04:35:18 +00:00
test ( "resizable" , function ( ) {
expect ( 4 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( ) ;
TestHelpers . dialog . shouldResize ( element , 50 , 50 , "[default]" ) ;
element . dialog ( "option" , "resizable" , false ) ;
TestHelpers . dialog . shouldResize ( element , 0 , 0 , "disabled after init" ) ;
element . remove ( ) ;
element = $ ( "<div></div>" ) . dialog ( { resizable : false } ) ;
TestHelpers . dialog . shouldResize ( element , 0 , 0 , "disabled in init options" ) ;
element . dialog ( "option" , "resizable" , true ) ;
TestHelpers . dialog . shouldResize ( element , 50 , 50 , "enabled after init" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
2012-11-09 17:26:30 +00:00
test ( "title" , function ( ) {
expect ( 11 ) ;
2009-02-04 04:35:18 +00:00
function titleText ( ) {
2013-01-31 05:38:20 +00:00
return element . dialog ( "widget" ) . find ( ".ui-dialog-title" ) . html ( ) ;
2009-02-04 04:35:18 +00:00
}
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( ) ;
2010-09-07 13:49:58 +00:00
// some browsers return a non-breaking space and some return " "
2012-11-15 15:47:36 +00:00
// so we generate a non-breaking space for comparison
2012-11-09 17:26:30 +00:00
equal ( titleText ( ) , $ ( "<span> </span>" ) . html ( ) , "[default]" ) ;
2013-01-31 05:38:20 +00:00
equal ( element . dialog ( "option" , "title" ) , null , "option not changed" ) ;
element . remove ( ) ;
2012-11-09 17:26:30 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div title='foo'>" ) . dialog ( ) ;
2012-11-09 17:26:30 +00:00
equal ( titleText ( ) , "foo" , "title in element attribute" ) ;
2013-01-31 05:38:20 +00:00
equal ( element . dialog ( "option" , "title" ) , "foo" , "option updated from attribute" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { title : "foo" } ) ;
2012-11-09 17:26:30 +00:00
equal ( titleText ( ) , "foo" , "title in init options" ) ;
2013-01-31 05:38:20 +00:00
equal ( element . dialog ( "option" , "title" ) , "foo" , "opiton set from options hash" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div title='foo'>" ) . dialog ( { title : "bar" } ) ;
2012-11-09 17:26:30 +00:00
equal ( titleText ( ) , "bar" , "title in init options should override title in element attribute" ) ;
2013-01-31 05:38:20 +00:00
equal ( element . dialog ( "option" , "title" ) , "bar" , "opiton set from options hash" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( ) . dialog ( "option" , "title" , "foo" ) ;
2012-12-26 13:08:48 +00:00
equal ( titleText ( ) , "foo" , "title after init" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2012-11-09 17:26:30 +00:00
// make sure attroperties are properly ignored - #5742 - .attr() might return a DOMElement
2013-01-31 05:38:20 +00:00
element = $ ( "<form><input name='title'></form>" ) . dialog ( ) ;
2012-11-09 17:26:30 +00:00
// some browsers return a non-breaking space and some return " "
// so we get the text to normalize to the actual non-breaking space
equal ( titleText ( ) , $ ( "<span> </span>" ) . html ( ) , "[default]" ) ;
2013-01-31 05:38:20 +00:00
equal ( element . dialog ( "option" , "title" ) , null , "option not changed" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
} ) ;
test ( "width" , function ( ) {
expect ( 3 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 300 , 1 , "default width" ) ;
element . remove ( ) ;
2009-02-04 04:35:18 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { width : 437 } ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 437 , 1 , "explicit width" ) ;
element . dialog ( "option" , "width" , 438 ) ;
closeEnough ( element . dialog ( "widget" ) . width ( ) , 438 , 1 , "explicit width after init" ) ;
element . remove ( ) ;
2009-02-02 14:36:08 +00:00
} ) ;
2012-12-08 01:06:29 +00:00
test ( "#4826: setting resizable false toggles resizable on dialog" , function ( ) {
expect ( 6 ) ;
var i ,
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { resizable : false } ) ;
2012-12-08 01:06:29 +00:00
2013-01-31 05:38:20 +00:00
TestHelpers . dialog . shouldResize ( element , 0 , 0 , "[default]" ) ;
2012-12-08 01:06:29 +00:00
for ( i = 0 ; i < 2 ; i ++ ) {
2013-01-31 05:38:20 +00:00
element . dialog ( "close" ) . dialog ( "open" ) ;
TestHelpers . dialog . shouldResize ( element , 0 , 0 , "initialized with resizable false toggle (" + ( i + 1 ) + ")" ) ;
2012-12-08 01:06:29 +00:00
}
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2012-12-08 01:06:29 +00:00
2013-01-31 05:38:20 +00:00
element = $ ( "<div></div>" ) . dialog ( { resizable : true } ) ;
TestHelpers . dialog . shouldResize ( element , 50 , 50 , "[default]" ) ;
2012-12-08 01:06:29 +00:00
for ( i = 0 ; i < 2 ; i ++ ) {
2013-01-31 05:38:20 +00:00
element . dialog ( "close" ) . dialog ( "option" , "resizable" , false ) . dialog ( "open" ) ;
TestHelpers . dialog . shouldResize ( element , 0 , 0 , "set option resizable false toggle (" + ( i + 1 ) + ")" ) ;
2012-12-08 01:06:29 +00:00
}
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2012-12-08 01:06:29 +00:00
} ) ;
2013-01-30 18:30:37 +00:00
asyncTest ( "#8051 - 'Explode' dialog animation causes crash in IE 6, 7 and 8" , function ( ) {
expect ( 1 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( {
2013-01-30 18:30:37 +00:00
show : "explode" ,
focus : function ( ) {
ok ( true , "dialog opened with animation" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2013-01-30 18:30:37 +00:00
start ( ) ;
}
} ) ;
} ) ;
asyncTest ( "#4421 - Focus lost from dialog which uses show-effect" , function ( ) {
expect ( 1 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( {
2013-01-30 18:30:37 +00:00
show : "blind" ,
focus : function ( ) {
2013-12-02 20:54:29 +00:00
equal ( element . dialog ( "widget" ) . find ( document . activeElement ) . length , 1 , "dialog maintains focus" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2013-01-30 18:30:37 +00:00
start ( ) ;
}
} ) ;
} ) ;
asyncTest ( "Open followed by close during show effect" , function ( ) {
expect ( 1 ) ;
2013-01-31 05:38:20 +00:00
var element = $ ( "<div></div>" ) . dialog ( {
2013-01-30 18:30:37 +00:00
show : "blind" ,
close : function ( ) {
ok ( true , "dialog closed properly during animation" ) ;
2013-01-31 05:38:20 +00:00
element . remove ( ) ;
2013-01-30 18:30:37 +00:00
start ( ) ;
}
} ) ;
setTimeout ( function ( ) {
2013-01-31 05:38:20 +00:00
element . dialog ( "close" ) ;
2013-01-30 18:30:37 +00:00
} , 100 ) ;
} ) ;
2009-02-02 14:36:08 +00:00
} ) ( jQuery ) ;