/* Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved. For licensing, see LICENSE.html or http://ckeditor.com/license */ CKEDITOR.plugins.add( 'devtools', { lang : [ 'en' ], init : function( editor ) { editor._.showDialogDefinitionTooltips = 1; }, onLoad : function() { CKEDITOR.document.appendStyleText( CKEDITOR.config.devtools_styles || '#cke_tooltip { padding: 5px; border: 2px solid #333; background: #ffffff }' + '#cke_tooltip h2 { font-size: 1.1em; border-bottom: 1px solid; margin: 0; padding: 1px; }' + '#cke_tooltip ul { padding: 0pt; list-style-type: none; }' ); } }); (function() { function defaultCallback( editor, dialog, element, tabName ) { var lang = editor.lang.devTools, link = '' + ( element ? element.type : 'content' ) + '', str = '

' + lang.title + '

' + ''; } function showTooltip( callback, el, editor, dialog, obj, tabName ) { var pos = el.getDocumentPosition(), styles = { 'z-index' : CKEDITOR.dialog._.currentZIndex + 10, top : ( pos.y + el.getSize( 'height' ) ) + 'px' }; tooltip.setHtml( callback( editor, dialog, obj, tabName ) ); tooltip.show(); // Translate coordinate for RTL. if ( editor.lang.dir == 'rtl' ) { var viewPaneSize = CKEDITOR.document.getWindow().getViewPaneSize(); styles.right = ( viewPaneSize.width - pos.x - el.getSize( 'width' ) ) + 'px'; } else styles.left = pos.x + 'px'; tooltip.setStyles( styles ); } var tooltip; CKEDITOR.on( 'reset', function() { tooltip && tooltip.remove(); tooltip = null; }); CKEDITOR.on( 'dialogDefinition', function( evt ) { var editor = evt.editor; if ( editor._.showDialogDefinitionTooltips ) { if ( !tooltip ) { tooltip = CKEDITOR.dom.element.createFromHtml( '
', CKEDITOR.document ); tooltip.hide(); tooltip.on( 'mouseover', function(){ this.show(); } ); tooltip.on( 'mouseout', function(){ this.hide(); } ); tooltip.appendTo( CKEDITOR.document.getBody() ); } var dialog = evt.data.definition.dialog, callback = editor.config.devtools_textCallback || defaultCallback; dialog.on( 'load', function() { var tabs = dialog.parts.tabs.getChildren(), tab; for ( var i = 0, len = tabs.count(); i < len; i++ ) { tab = tabs.getItem( i ); tab.on( 'mouseover', function() { var id = this.$.id; showTooltip( callback, this, editor, dialog, null, id.substring( 4, id.lastIndexOf( '_' ) ) ); }); tab.on( 'mouseout', function() { tooltip.hide(); }); } dialog.foreach( function( obj ) { if ( obj.type in { hbox : 1, vbox : 1 } ) return; var el = obj.getElement(); if ( el ) { el.on( 'mouseover', function() { showTooltip( callback, this, editor, dialog, obj, dialog._.currentTabId ); }); el.on( 'mouseout', function() { tooltip.hide(); }); } }); }); } }); })(); /** * A function that returns the text to be displayed inside the Developer Tools tooltip when hovering over a dialog UI element. * There are 4 parameters that are being passed into the function: editor, dialog window, element, tab name. * @name editor.config.devtools_textCallback * @since 3.6 * @type Function * @default (see example) * @example * // This is actually the default value. * // Show dialog window name, tab ID, and element ID. * config.devtools_textCallback = function( editor, dialog, element, tabName ) * { * var lang = editor.lang.devTools, * link = '' + ( element ? element.type : 'content' ) + '', * str = * '

' + lang.title + '

' + * ''; * } */ /** * A setting that stores CSS rules to be injected into the page with styles to be applied to the tooltip element. * @name CKEDITOR.config.devtools_styles * @since 3.6 * @type String * @default (see example) * @example * // This is actually the default value. * CKEDITOR.config.devtools_styles = " * #cke_tooltip { padding: 5px; border: 2px solid #333; background: #ffffff } * #cke_tooltip h2 { font-size: 1.1em; border-bottom: 1px solid; margin: 0; padding: 1px; } * #cke_tooltip ul { padding: 0pt; list-style-type: none; } * "; */