JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
vanilla ckeditor-3.0.1
[ckeditor.git] / _source / plugins / maximize / plugin.js
index 2b7ffe3..4c40544 100644 (file)
@@ -111,7 +111,7 @@ For licensing, see LICENSE.html or http://ckeditor.com/license
                        editor.addCommand( 'maximize',\r
                                {\r
                                        modes : { wysiwyg : 1, source : 1 },\r
-\r
+                                       editorFocus : false,\r
                                        exec : function()\r
                                        {\r
                                                var container = editor.container.getChild( [ 0, 0 ] );\r
@@ -120,7 +120,8 @@ For licensing, see LICENSE.html or http://ckeditor.com/license
                                                // Save current selection and scroll position in editing area.\r
                                                if ( editor.mode == 'wysiwyg' )\r
                                                {\r
-                                                       savedSelection = editor.getSelection().getRanges();\r
+                                                       var selection = editor.getSelection();\r
+                                                       savedSelection = selection && selection.getRanges();\r
                                                        savedScroll = mainWindow.getScrollPosition();\r
                                                }\r
                                                else\r
@@ -223,14 +224,25 @@ For licensing, see LICENSE.html or http://ckeditor.com/license
 \r
                                                this.toggleState();\r
 \r
+                                               // Toggle button label.\r
+                                               var button = this.uiItems[ 0 ];\r
+                                               var label = ( this.state == CKEDITOR.TRISTATE_OFF )\r
+                                                       ? lang.maximize : lang.minimize;\r
+                                               var buttonNode = editor.element.getDocument().getById( button._.id );\r
+                                               buttonNode.getChild( 1 ).setHtml( label );\r
+                                               buttonNode.setAttribute( 'title', label );\r
+                                               buttonNode.setAttribute( 'href', 'javascript:void("' + label + '");' );\r
+\r
                                                // Restore selection and scroll position in editing area.\r
                                                if ( editor.mode == 'wysiwyg' )\r
                                                {\r
-                                                       editor.getSelection().selectRanges( savedSelection );\r
+                                                       if ( savedSelection )\r
+                                                       {\r
+                                                               editor.getSelection().selectRanges(savedSelection);\r
+                                                               var element = editor.getSelection().getStartElement();\r
+                                                               element && element.scrollIntoView( true );\r
+                                                       }\r
 \r
-                                                       var element = editor.getSelection().getStartElement();\r
-                                                       if ( element )\r
-                                                               element.scrollIntoView( true );\r
                                                        else\r
                                                                mainWindow.$.scrollTo( savedScroll.x, savedScroll.y );\r
                                                }\r