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
// 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
\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