diff options
author | Silvio Rhatto <rhatto@riseup.net> | 2014-03-15 15:05:42 -0300 |
---|---|---|
committer | Silvio Rhatto <rhatto@riseup.net> | 2014-03-15 15:05:42 -0300 |
commit | 20f9884f9a52e810d7e3cdbdd92eabc64812e097 (patch) | |
tree | f01dbe4db567b7bebb38274286ca2b3fc02a6d66 /vendors/ckeditor/plugins/autogrow/plugin.js | |
download | elgg-20f9884f9a52e810d7e3cdbdd92eabc64812e097.tar.gz elgg-20f9884f9a52e810d7e3cdbdd92eabc64812e097.tar.bz2 |
Squashed 'mod/ckeditor/' content from commit 9f4ede0
git-subtree-dir: mod/ckeditor
git-subtree-split: 9f4ede06562e229a26d7ae8d32ebb23453c293e7
Diffstat (limited to 'vendors/ckeditor/plugins/autogrow/plugin.js')
-rw-r--r-- | vendors/ckeditor/plugins/autogrow/plugin.js | 178 |
1 files changed, 178 insertions, 0 deletions
diff --git a/vendors/ckeditor/plugins/autogrow/plugin.js b/vendors/ckeditor/plugins/autogrow/plugin.js new file mode 100644 index 000000000..3ff8d277e --- /dev/null +++ b/vendors/ckeditor/plugins/autogrow/plugin.js @@ -0,0 +1,178 @@ +/** + * @license Copyright (c) 2003-2013, CKSource - Frederico Knabben. All rights reserved. + * For licensing, see LICENSE.html or http://ckeditor.com/license + */ + +/** + * @fileOverview AutoGrow plugin. + */ + +(function() { + + // Actual content height, figured out by appending check the last element's document position. + function contentHeight( scrollable ) { + var overflowY = scrollable.getStyle( 'overflow-y' ); + + var doc = scrollable.getDocument(); + // Create a temporary marker element. + var marker = CKEDITOR.dom.element.createFromHtml( '<span style="margin:0;padding:0;border:0;clear:both;width:1px;height:1px;display:block;">' + ( CKEDITOR.env.webkit ? ' ' : '' ) + '</span>', doc ); + doc[ CKEDITOR.env.ie ? 'getBody' : 'getDocumentElement' ]().append( marker ); + + var height = marker.getDocumentPosition( doc ).y + marker.$.offsetHeight; + marker.remove(); + scrollable.setStyle( 'overflow-y', overflowY ); + return height; + } + + function getScrollable( editor ) { + var doc = editor.document, + body = doc.getBody(), + htmlElement = doc.getDocumentElement(); + + // Quirks mode overflows body, standards overflows document element + return doc.$.compatMode == 'BackCompat' ? body : htmlElement; + } + + var resizeEditor = function( editor ) { + if ( !editor.window ) + return; + + var maximize = editor.getCommand( 'maximize' ); + // Disable autogrow when the editor is maximized .(#6339) + if( maximize && maximize.state == CKEDITOR.TRISTATE_ON ) + return; + + var scrollable = getScrollable( editor ), + currentHeight = editor.window.getViewPaneSize().height, + newHeight = contentHeight( scrollable ); + + // Additional space specified by user. + newHeight += ( editor.config.autoGrow_bottomSpace || 0 ); + + var min = editor.config.autoGrow_minHeight != undefined ? editor.config.autoGrow_minHeight : 200, + max = editor.config.autoGrow_maxHeight || Infinity; + + newHeight = Math.max( newHeight, min ); + newHeight = Math.min( newHeight, max ); + + if ( newHeight != currentHeight ) { + newHeight = editor.fire( 'autoGrow', { currentHeight: currentHeight, newHeight: newHeight } ).newHeight; + editor.resize( editor.container.getStyle( 'width' ), newHeight, true ); + } + + if ( scrollable.$.scrollHeight > scrollable.$.clientHeight && newHeight < max ) + scrollable.setStyle( 'overflow-y', 'hidden' ); + else + scrollable.removeStyle( 'overflow-y' ); + + + }; + + CKEDITOR.plugins.add( 'autogrow', { + init: function( editor ) { + + // This feature is available only for themed ui instance. + if ( editor.elementMode == CKEDITOR.ELEMENT_MODE_INLINE ) + return; + + editor.on( 'instanceReady', function() { + + var editable = editor.editable(); + + // Simply set auto height with div wysiwyg. + if ( editable.isInline() ) + editor.ui.space( 'contents' ).setStyle( 'height', 'auto' ); + // For framed wysiwyg we need to resize the editor. + else + { + editor.addCommand( 'autogrow', { + exec:resizeEditor, + modes:{ wysiwyg:1 }, + readOnly: 1, + canUndo: false, + editorFocus: false + } ); + + var eventsList = { contentDom:1,key:1,selectionChange:1,insertElement:1,mode:1 }; + for ( var eventName in eventsList ) { + editor.on( eventName, function( evt ) { + // Some time is required for insertHtml, and it gives other events better performance as well. + if ( evt.editor.mode == 'wysiwyg' ) { + setTimeout( function() { + resizeEditor( evt.editor ); + // Second pass to make correction upon + // the first resize, e.g. scrollbar. + resizeEditor( evt.editor ); + }, 100 ); + } + }); + } + + // Coordinate with the "maximize" plugin. (#9311) + editor.on( 'afterCommandExec', function( evt ) { + if ( evt.data.name == 'maximize' && evt.editor.mode == 'wysiwyg' ) { + if ( evt.data.command.state == CKEDITOR.TRISTATE_ON ) { + var scrollable = getScrollable( editor ); + scrollable.removeStyle( 'overflow' ); + } + else + resizeEditor( editor ); + } + }); + + editor.config.autoGrow_onStartup && editor.execCommand( 'autogrow' ); + } + }); + } + }); +})(); + +/** + * The minimum height that the editor can reach using the AutoGrow feature. + * + * config.autoGrow_minHeight = 300; + * + * @since 3.4 + * @cfg {Number} [autoGrow_minHeight=200] + * @member CKEDITOR.config + */ + +/** + * The maximum height that the editor can reach using the AutoGrow feature. Zero means unlimited. + * + * config.autoGrow_maxHeight = 400; + * + * @since 3.4 + * @cfg {Number} [autoGrow_maxHeight=0] + * @member CKEDITOR.config + */ + +/** + * Whether to have the auto grow happen on editor creation. + * + * config.autoGrow_onStartup = true; + * + * @since 3.6.2 + * @cfg {Boolean} [autoGrow_onStartup=false] + * @member CKEDITOR.config + */ + +/** + * Extra height in pixel to leave between the bottom boundary of content with document size when auto resizing. + * + * @since 3.6.2 + * @cfg {Number} [autoGrow_bottomSpace=0] + * @member CKEDITOR.config + */ + +/** + * Fired when the AutoGrow plugin is about to change the size of the editor. + * + * @event autogrow + * @member CKEDITOR.editor + * @param {CKEDITOR.editor} editor This editor instance. + * @param data + * @param {Number} data.currentHeight The current height of the editor (before resizing). + * @param {Number} data.newHeight The new height of the editor (after resizing). It can be changed + * to determine a different height value to be used instead. + */ |