+ // Allow to peek clipboard content by redirecting the\r
+ // pasting content into a temporary bin and grab the content of it.\r
+ function getClipboardData( evt, mode, callback )\r
+ {\r
+ var doc = this.document;\r
+\r
+ // Avoid recursions on 'paste' event for IE.\r
+ if ( CKEDITOR.env.ie && doc.getById( 'cke_pastebin' ) )\r
+ return;\r
+\r
+ // If the browser supports it, get the data directly\r
+ if (mode == 'text' && evt.data && evt.data.$.clipboardData)\r
+ {\r
+ // evt.data.$.clipboardData.types contains all the flavours in Mac's Safari, but not on windows.\r
+ var plain = evt.data.$.clipboardData.getData( 'text/plain' );\r
+ if (plain)\r
+ {\r
+ evt.data.preventDefault();\r
+ callback( plain );\r
+ return;\r
+ }\r
+ }\r
+\r
+ var sel = this.getSelection(),\r
+ range = new CKEDITOR.dom.range( doc );\r
+\r
+ // Create container to paste into\r
+ var pastebin = new CKEDITOR.dom.element( mode == 'text' ? 'textarea' : CKEDITOR.env.webkit ? 'body' : 'div', doc );\r
+ pastebin.setAttribute( 'id', 'cke_pastebin' );\r
+ // Safari requires a filler node inside the div to have the content pasted into it. (#4882)\r
+ CKEDITOR.env.webkit && pastebin.append( doc.createText( '\xa0' ) );\r
+ doc.getBody().append( pastebin );\r
+\r
+ pastebin.setStyles(\r
+ {\r
+ position : 'absolute',\r
+ // Position the bin exactly at the position of the selected element\r
+ // to avoid any subsequent document scroll.\r
+ top : sel.getStartElement().getDocumentPosition().y + 'px',\r
+ width : '1px',\r
+ height : '1px',\r
+ overflow : 'hidden'\r
+ });\r
+\r
+ // It's definitely a better user experience if we make the paste-bin pretty unnoticed\r
+ // by pulling it off the screen.\r
+ pastebin.setStyle( this.config.contentsLangDirection == 'ltr' ? 'left' : 'right', '-1000px' );\r
+\r
+ var bms = sel.createBookmarks();\r
+\r
+ // Turn off design mode temporarily before give focus to the paste bin.\r
+ if ( mode == 'text' )\r
+ {\r
+ if ( CKEDITOR.env.ie )\r
+ {\r
+ var ieRange = doc.getBody().$.createTextRange();\r
+ ieRange.moveToElementText( pastebin.$ );\r
+ ieRange.execCommand( 'Paste' );\r
+ evt.data.preventDefault();\r
+ }\r
+ else\r
+ {\r
+ doc.$.designMode = 'off';\r
+ pastebin.$.focus();\r
+ }\r
+ }\r
+ else\r
+ {\r
+ range.setStartAt( pastebin, CKEDITOR.POSITION_AFTER_START );\r
+ range.setEndAt( pastebin, CKEDITOR.POSITION_BEFORE_END );\r
+ range.select( true );\r
+ }\r
+\r
+ // Wait a while and grab the pasted contents\r
+ window.setTimeout( function()\r
+ {\r
+ mode == 'text' && !CKEDITOR.env.ie && ( doc.$.designMode = 'on' );\r
+ pastebin.remove();\r
+\r
+ // Grab the HTML contents.\r
+ // We need to look for a apple style wrapper on webkit it also adds\r
+ // a div wrapper if you copy/paste the body of the editor.\r
+ // Remove hidden div and restore selection.\r
+ var bogusSpan;\r
+ pastebin = ( CKEDITOR.env.webkit\r
+ && ( bogusSpan = pastebin.getFirst() )\r
+ && ( bogusSpan.is && bogusSpan.hasClass( 'Apple-style-span' ) ) ?\r
+ bogusSpan : pastebin );\r
+\r
+ sel.selectBookmarks( bms );\r
+ callback( pastebin[ 'get' + ( mode == 'text' ? 'Value' : 'Html' ) ]() );\r
+ }, 0 );\r
+ }\r
+\r
+ // Cutting off control type element in IE standards breaks the selection entirely. (#4881)\r
+ function fixCut( editor )\r
+ {\r
+ if ( !CKEDITOR.env.ie || editor.document.$.compatMode == 'BackCompat' )\r
+ return;\r
+\r
+ var sel = editor.getSelection();\r
+ var control;\r
+ if( ( sel.getType() == CKEDITOR.SELECTION_ELEMENT ) && ( control = sel.getSelectedElement() ) )\r
+ {\r
+ var range = sel.getRanges()[ 0 ];\r
+ var dummy = editor.document.createText( '' );\r
+ dummy.insertBefore( control );\r
+ range.setStartBefore( dummy );\r
+ range.setEndAfter( control );\r
+ sel.selectRanges( [ range ] );\r
+\r
+ // Clear up the fix if the paste wasn't succeeded.\r
+ setTimeout( function()\r
+ {\r
+ // Element still online?\r
+ if ( control.getParent() )\r
+ {\r
+ dummy.remove();\r
+ sel.selectElement( control );\r
+ }\r
+ }, 0 );\r
+ }\r
+ }\r
+\r