JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
vanilla ckeditor-3.5.1
[ckeditor.git] / _source / plugins / dialog / plugin.js
index b5aab81..6849461 100644 (file)
@@ -1,5 +1,5 @@
 /*\r
-Copyright (c) 2003-2010, CKSource - Frederico Knabben. All rights reserved.\r
+Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved.\r
 For licensing, see LICENSE.html or http://ckeditor.com/license\r
 */\r
 \r
@@ -710,13 +710,6 @@ CKEDITOR.DIALOG_RESIZE_BOTH = 3;
                 */\r
                show : function()\r
                {\r
-                       var editor = this._.editor;\r
-                       if ( editor.mode == 'wysiwyg' && CKEDITOR.env.ie )\r
-                       {\r
-                               var selection = editor.getSelection();\r
-                               selection && selection.lock();\r
-                       }\r
-\r
                        // Insert the dialog's element to the root document.\r
                        var element = this._.element;\r
                        var definition = this.definition;\r
@@ -1706,7 +1699,9 @@ CKEDITOR.DIALOG_RESIZE_BOTH = 3;
                        return;\r
 \r
                var editor = dialog.getParentEditor();\r
-               var wrapperWidth, wrapperHeight, viewSize, origin, startSize;\r
+               var wrapperWidth, wrapperHeight,\r
+                               viewSize, origin, startSize,\r
+                               dialogCover;\r
 \r
                function positionDialog( right )\r
                {\r
@@ -1725,6 +1720,16 @@ CKEDITOR.DIALOG_RESIZE_BOTH = 3;
                {\r
                        startSize = dialog.getSize();\r
 \r
+                       var content = dialog.parts.contents,\r
+                               iframeDialog = content.$.getElementsByTagName( 'iframe' ).length;\r
+\r
+                       // Shim to help capturing "mousemove" over iframe.\r
+                       if ( iframeDialog )\r
+                       {\r
+                               dialogCover = CKEDITOR.dom.element.createFromHtml( '<div class="cke_dialog_resize_cover" style="height: 100%; position: absolute; width: 100%;"></div>' );\r
+                               content.append( dialogCover );\r
+                       }\r
+\r
                        // Calculate the offset between content and chrome size.\r
                        wrapperHeight = startSize.height - dialog.parts.contents.getSize( 'height',  ! ( CKEDITOR.env.gecko || CKEDITOR.env.opera || CKEDITOR.env.ie && CKEDITOR.env.quirks ) );\r
                        wrapperWidth = startSize.width - dialog.parts.contents.getSize( 'width', 1 );\r
@@ -1803,6 +1808,12 @@ CKEDITOR.DIALOG_RESIZE_BOTH = 3;
                        CKEDITOR.document.removeListener( 'mouseup', mouseUpHandler );\r
                        CKEDITOR.document.removeListener( 'mousemove', mouseMoveHandler );\r
 \r
+                       if ( dialogCover )\r
+                       {\r
+                               dialogCover.remove();\r
+                               dialogCover = null;\r
+                       }\r
+\r
                        if ( CKEDITOR.env.ie6Compat )\r
                        {\r
                                var coverDoc = currentCover.getChild( 0 ).getFrameDocument();\r
@@ -1852,7 +1863,7 @@ CKEDITOR.DIALOG_RESIZE_BOTH = 3;
                if ( !coverElement )\r
                {\r
                        var html = [\r
-                                       '<div style="position: ', ( CKEDITOR.env.ie6Compat ? 'absolute' : 'fixed' ),\r
+                                       '<div tabIndex="-1" style="position: ', ( CKEDITOR.env.ie6Compat ? 'absolute' : 'fixed' ),\r
                                        '; z-index: ', baseFloatZIndex,\r
                                        '; top: 0px; left: 0px; ',\r
                                        ( !CKEDITOR.env.ie6Compat ? 'background-color: ' + backgroundColorStyle : '' ),\r
@@ -1923,16 +1934,23 @@ CKEDITOR.DIALOG_RESIZE_BOTH = 3;
                                                top : pos.y + 'px'\r
                                        });\r
 \r
-                       do\r
+                       if ( cursor )\r
                        {\r
-                               var dialogPos = cursor.getPosition();\r
-                               cursor.move( dialogPos.x, dialogPos.y );\r
-                       } while ( ( cursor = cursor._.parentDialog ) );\r
+                               do\r
+                               {\r
+                                       var dialogPos = cursor.getPosition();\r
+                                       cursor.move( dialogPos.x, dialogPos.y );\r
+                               } while ( ( cursor = cursor._.parentDialog ) );\r
+                       }\r
                };\r
 \r
                resizeCover = resizeFunc;\r
                win.on( 'resize', resizeFunc );\r
                resizeFunc();\r
+               // Using Safari/Mac, focus must be kept where it is (#7027)\r
+               if ( !( CKEDITOR.env.mac && CKEDITOR.env.webkit ) )\r
+                       coverElement.focus();\r
+\r
                if ( CKEDITOR.env.ie6Compat )\r
                {\r
                        // IE BUG: win.$.onscroll assignment doesn't work.. it must be window.onscroll.\r
@@ -2896,78 +2914,81 @@ CKEDITOR.DIALOG_RESIZE_BOTH = 3;
        });\r
 \r
        })();\r
-})();\r
 \r
-// Extend the CKEDITOR.editor class with dialog specific functions.\r
-CKEDITOR.tools.extend( CKEDITOR.editor.prototype,\r
-       /** @lends CKEDITOR.editor.prototype */\r
-       {\r
-               /**\r
-                * Loads and opens a registered dialog.\r
-                * @param {String} dialogName The registered name of the dialog.\r
-                * @param {Function} callback The function to be invoked after dialog instance created.\r
-                * @see CKEDITOR.dialog.add\r
-                * @example\r
-                * CKEDITOR.instances.editor1.openDialog( 'smiley' );\r
-                * @returns {CKEDITOR.dialog} The dialog object corresponding to the dialog displayed. null if the dialog name is not registered.\r
-                */\r
-               openDialog : function( dialogName, callback )\r
+       // Extend the CKEDITOR.editor class with dialog specific functions.\r
+       CKEDITOR.tools.extend( CKEDITOR.editor.prototype,\r
+               /** @lends CKEDITOR.editor.prototype */\r
                {\r
-                       var dialogDefinitions = CKEDITOR.dialog._.dialogDefinitions[ dialogName ],\r
-                                       dialogSkin = this.skin.dialog;\r
-\r
-                       // If the dialogDefinition is already loaded, open it immediately.\r
-                       if ( typeof dialogDefinitions == 'function' && dialogSkin._isLoaded )\r
+                       /**\r
+                        * Loads and opens a registered dialog.\r
+                        * @param {String} dialogName The registered name of the dialog.\r
+                        * @param {Function} callback The function to be invoked after dialog instance created.\r
+                        * @see CKEDITOR.dialog.add\r
+                        * @example\r
+                        * CKEDITOR.instances.editor1.openDialog( 'smiley' );\r
+                        * @returns {CKEDITOR.dialog} The dialog object corresponding to the dialog displayed. null if the dialog name is not registered.\r
+                        */\r
+                       openDialog : function( dialogName, callback )\r
                        {\r
-                               var storedDialogs = this._.storedDialogs ||\r
-                                       ( this._.storedDialogs = {} );\r
+                               if ( this.mode == 'wysiwyg' && CKEDITOR.env.ie )\r
+                               {\r
+                                       var selection = this.getSelection();\r
+                                       selection && selection.lock();\r
+                               }\r
 \r
-                               var dialog = storedDialogs[ dialogName ] ||\r
-                                       ( storedDialogs[ dialogName ] = new CKEDITOR.dialog( this, dialogName ) );\r
+                               var dialogDefinitions = CKEDITOR.dialog._.dialogDefinitions[ dialogName ],\r
+                                               dialogSkin = this.skin.dialog;\r
 \r
-                               callback && callback.call( dialog, dialog );\r
-                               dialog.show();\r
+                               if ( CKEDITOR.dialog._.currentTop === null )\r
+                                       showCover( this );\r
 \r
-                               return dialog;\r
-                       }\r
-                       else if ( dialogDefinitions == 'failed' )\r
-                               throw new Error( '[CKEDITOR.dialog.openDialog] Dialog "' + dialogName + '" failed when loading definition.' );\r
+                               // If the dialogDefinition is already loaded, open it immediately.\r
+                               if ( typeof dialogDefinitions == 'function' && dialogSkin._isLoaded )\r
+                               {\r
+                                       var storedDialogs = this._.storedDialogs ||\r
+                                               ( this._.storedDialogs = {} );\r
 \r
-                       // Not loaded? Load the .js file first.\r
-                       var body = CKEDITOR.document.getBody(),\r
-                               cursor = body.$.style.cursor,\r
-                               me = this;\r
+                                       var dialog = storedDialogs[ dialogName ] ||\r
+                                               ( storedDialogs[ dialogName ] = new CKEDITOR.dialog( this, dialogName ) );\r
 \r
-                       body.setStyle( 'cursor', 'wait' );\r
+                                       callback && callback.call( dialog, dialog );\r
+                                       dialog.show();\r
 \r
-                       function onDialogFileLoaded( success )\r
-                       {\r
-                               var dialogDefinition = CKEDITOR.dialog._.dialogDefinitions[ dialogName ],\r
-                                               skin = me.skin.dialog;\r
+                                       return dialog;\r
+                               }\r
+                               else if ( dialogDefinitions == 'failed' )\r
+                                       throw new Error( '[CKEDITOR.dialog.openDialog] Dialog "' + dialogName + '" failed when loading definition.' );\r
 \r
-                               // Check if both skin part and definition is loaded.\r
-                               if ( !skin._isLoaded || loadDefinition && typeof success == 'undefined' )\r
-                                       return;\r
+                               var me = this;\r
 \r
-                               // In case of plugin error, mark it as loading failed.\r
-                               if ( typeof dialogDefinition != 'function' )\r
-                                       CKEDITOR.dialog._.dialogDefinitions[ dialogName ] = 'failed';\r
+                               function onDialogFileLoaded( success )\r
+                               {\r
+                                       var dialogDefinition = CKEDITOR.dialog._.dialogDefinitions[ dialogName ],\r
+                                                       skin = me.skin.dialog;\r
 \r
-                               me.openDialog( dialogName, callback );\r
-                               body.setStyle( 'cursor', cursor );\r
-                       }\r
+                                       // Check if both skin part and definition is loaded.\r
+                                       if ( !skin._isLoaded || loadDefinition && typeof success == 'undefined' )\r
+                                               return;\r
 \r
-                       if ( typeof dialogDefinitions == 'string' )\r
-                       {\r
-                               var loadDefinition = 1;\r
-                               CKEDITOR.scriptLoader.load( CKEDITOR.getUrl( dialogDefinitions ), onDialogFileLoaded );\r
-                       }\r
+                                       // In case of plugin error, mark it as loading failed.\r
+                                       if ( typeof dialogDefinition != 'function' )\r
+                                               CKEDITOR.dialog._.dialogDefinitions[ dialogName ] = 'failed';\r
 \r
-                       CKEDITOR.skins.load( this, 'dialog', onDialogFileLoaded );\r
+                                       me.openDialog( dialogName, callback );\r
+                               }\r
 \r
-                       return null;\r
-               }\r
-       });\r
+                               if ( typeof dialogDefinitions == 'string' )\r
+                               {\r
+                                       var loadDefinition = 1;\r
+                                       CKEDITOR.scriptLoader.load( CKEDITOR.getUrl( dialogDefinitions ), onDialogFileLoaded, null, 0, 1 );\r
+                               }\r
+\r
+                               CKEDITOR.skins.load( this, 'dialog', onDialogFileLoaded );\r
+\r
+                               return null;\r
+                       }\r
+               });\r
+})();\r
 \r
 CKEDITOR.plugins.add( 'dialog',\r
        {\r
@@ -3016,7 +3037,7 @@ CKEDITOR.plugins.add( 'dialog',
  */\r
 \r
 /**\r
- * The guildeline to follow when generating the dialog buttons. There are 3 possible options:\r
+ * The guideline to follow when generating the dialog buttons. There are 3 possible options:\r
  * <ul>\r
  *     <li>'OS' - the buttons will be displayed in the default order of the user's OS;</li>\r
  *     <li>'ltr' - for Left-To-Right order;</li>\r
@@ -3034,7 +3055,7 @@ CKEDITOR.plugins.add( 'dialog',
  * The dialog contents to removed. It's a string composed by dialog name and tab name with a colon between them.\r
  * Separate each pair with semicolon (see example).\r
  * <b>Note: All names are case-sensitive.</b>\r
- * <b>Note: Be cautious when specifying dialog tabs that are mandatory, like "info", dialog functionality might be broken because of this!<b>\r
+ * <b>Note: Be cautious when specifying dialog tabs that are mandatory, like "info", dialog functionality might be broken because of this!</b>\r
  * @name CKEDITOR.config.removeDialogTabs\r
  * @type String\r
  * @since 3.5\r
@@ -3060,8 +3081,58 @@ CKEDITOR.plugins.add( 'dialog',
 \r
 /**\r
  * Fired when a tab is going to be selected in a dialog\r
- * @name dialog#selectPage\r
+ * @name CKEDITOR.dialog#selectPage\r
+ * @event\r
+ * @param {String} page The id of the page that it's gonna be selected.\r
+ * @param {String} currentPage The id of the current page.\r
+ */\r
+\r
+/**\r
+ * Fired when the user tries to dismiss a dialog\r
+ * @name CKEDITOR.dialog#cancel\r
+ * @event\r
+ * @param {Boolean} hide Whether the event should proceed or not.\r
+ */\r
+\r
+/**\r
+ * Fired when the user tries to confirm a dialog\r
+ * @name CKEDITOR.dialog#ok\r
+ * @event\r
+ * @param {Boolean} hide Whether the event should proceed or not.\r
+ */\r
+\r
+/**\r
+ * Fired when a dialog is shown\r
+ * @name CKEDITOR.dialog#show\r
+ * @event\r
+ */\r
+\r
+/**\r
+ * Fired when a dialog is shown\r
+ * @name CKEDITOR.editor#dialogShow\r
+ * @event\r
+ */\r
+\r
+/**\r
+ * Fired when a dialog is hidden\r
+ * @name CKEDITOR.dialog#hide\r
+ * @event\r
+ */\r
+\r
+/**\r
+ * Fired when a dialog is hidden\r
+ * @name CKEDITOR.editor#dialogHide\r
+ * @event\r
+ */\r
+\r
+/**\r
+ * Fired when a dialog is being resized. The event is fired on\r
+ * the 'CKEDITOR.dialog' object, not a dialog instance.\r
+ * @name CKEDITOR.dialog#resize\r
+ * @since 3.5\r
  * @event\r
- * @param String page The id of the page that it's gonna be selected.\r
- * @param String currentPage The id of the current page.\r
+ * @param {CKEDITOR.dialog} dialog The dialog being resized.\r
+ * @param {String} skin The skin name.\r
+ * @param {Number} width The new width.\r
+ * @param {Number} height The new height.\r
  */\r