| 
									
										
										
										
											2018-06-17 16:07:19 +00:00
										 |  |  |  | // jscs:disable disallowMixedSpacesAndTabs
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * @license Copyright (c) 2003-2018, CKSource - Frederico Knabben. All rights reserved. | 
					
						
							|  |  |  |  |  * For licensing, see LICENSE.md or https://ckeditor.com/legal/ckeditor-oss-license
 | 
					
						
							| 
									
										
										
										
											2014-04-11 20:07:18 +00:00
										 |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * @fileOverview Defines the "virtual" dialog, dialog content and dialog button | 
					
						
							|  |  |  |  |  * definition classes. | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a dialog window. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create dialogs. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		CKEDITOR.dialog.add( 'testOnly', function( editor ) { | 
					
						
							|  |  |  |  |  *			return { | 
					
						
							|  |  |  |  |  *				title:			'Test Dialog', | 
					
						
							|  |  |  |  |  *				resizable:		CKEDITOR.DIALOG_RESIZE_BOTH, | 
					
						
							|  |  |  |  |  *				minWidth:		500, | 
					
						
							|  |  |  |  |  *				minHeight:		400, | 
					
						
							|  |  |  |  |  *				contents: [ | 
					
						
							|  |  |  |  |  *					{ | 
					
						
							|  |  |  |  |  *						id:			'tab1', | 
					
						
							|  |  |  |  |  *						label:		'First Tab', | 
					
						
							|  |  |  |  |  *						title:		'First Tab Title', | 
					
						
							|  |  |  |  |  *						accessKey:	'Q', | 
					
						
							|  |  |  |  |  *						elements: [ | 
					
						
							|  |  |  |  |  *							{ | 
					
						
							|  |  |  |  |  *								type:			'text', | 
					
						
							|  |  |  |  |  *								label:			'Test Text 1', | 
					
						
							|  |  |  |  |  *								id:				'testText1', | 
					
						
							|  |  |  |  |  *								'default':		'hello world!' | 
					
						
							|  |  |  |  |  *							} | 
					
						
							|  |  |  |  |  *						] | 
					
						
							|  |  |  |  |  *					} | 
					
						
							|  |  |  |  |  *				] | 
					
						
							|  |  |  |  |  *			}; | 
					
						
							|  |  |  |  |  *		} ); | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The dialog title, displayed in the dialog's header. Required. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} title | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * How the dialog can be resized, must be one of the four contents defined below. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * * {@link CKEDITOR#DIALOG_RESIZE_NONE} | 
					
						
							|  |  |  |  |  * * {@link CKEDITOR#DIALOG_RESIZE_WIDTH} | 
					
						
							|  |  |  |  |  * * {@link CKEDITOR#DIALOG_RESIZE_HEIGHT} | 
					
						
							|  |  |  |  |  * * {@link CKEDITOR#DIALOG_RESIZE_BOTH} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} [resizable=CKEDITOR.DIALOG_RESIZE_NONE] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The minimum width of the dialog, in pixels. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} [minWidth=600] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The minimum height of the dialog, in pixels. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} [minHeight=400] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The initial width of the dialog, in pixels. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @since 3.5.3 | 
					
						
							|  |  |  |  |  * @property {Number} [width=CKEDITOR.dialog.definition#minWidth] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The initial height of the dialog, in pixels. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @since 3.5.3 | 
					
						
							|  |  |  |  |  * @property {Number} [height=CKEDITOR.dialog.definition.minHeight] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The buttons in the dialog, defined as an array of | 
					
						
							|  |  |  |  |  * {@link CKEDITOR.dialog.definition.button} objects. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} [buttons=[ CKEDITOR.dialog.okButton, CKEDITOR.dialog.cancelButton ]] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The contents in the dialog, defined as an array of | 
					
						
							|  |  |  |  |  * {@link CKEDITOR.dialog.definition.content} objects. Required. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} contents | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The function to execute when OK is pressed. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} onOk | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The function to execute when Cancel is pressed. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} onCancel | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The function to execute when the dialog is displayed for the first time. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} onLoad | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The function to execute when the dialog is loaded (executed every time the dialog is opened). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} onShow | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create dialog content pages. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.content. | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The id of the content page. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} id | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The tab label of the content page. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} label | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The popup message of the tab label. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} title | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The CTRL hotkey for switching to the tab. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		contentDefinition.accessKey = 'Q'; // Switch to this page when CTRL-Q is pressed.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} accessKey | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The UI elements contained in this content page, defined as an array of | 
					
						
							|  |  |  |  |  * {@link CKEDITOR.dialog.definition.uiElement} objects. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} elements | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of user interface element (textarea, radio etc). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create dialog UI elements. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  * @see CKEDITOR.ui.dialog.uiElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The id of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} id | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The type of the UI element. Required. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} type | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The popup label of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} title | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The content that needs to be allowed to enable this UI element. | 
					
						
							|  |  |  |  |  * All formats accepted by {@link CKEDITOR.filter#check} may be used. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * When all UI elements in a tab are disabled, this tab will be disabled automatically. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String/Object/CKEDITOR.style} requiredContent | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * CSS class names to append to the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} className | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Inline CSS classes to append to the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} style | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Horizontal alignment (in container) of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} align | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Function to execute the first time the UI element is displayed. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} onLoad | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Function to execute whenever the UI element's parent dialog is displayed. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} onShow | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Function to execute whenever the UI element's parent dialog is closed. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} onHide | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Function to execute whenever the UI element's parent | 
					
						
							|  |  |  |  |  * dialog's {@link CKEDITOR.dialog#setupContent} method is executed. | 
					
						
							|  |  |  |  |  * It usually takes care of the respective UI element as a standalone element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} setup | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Function to execute whenever the UI element's parent | 
					
						
							|  |  |  |  |  * dialog's {@link CKEDITOR.dialog#commitContent} method is executed. | 
					
						
							|  |  |  |  |  * It usually takes care of the respective UI element as a standalone element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} commit | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- hbox -----------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Horizontal layout box for dialog UI elements, auto-expends to available width of container. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create horizontal layouts. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.hbox} object and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'hbox', | 
					
						
							|  |  |  |  |  *			widths: [ '25%', '25%', '50%' ], | 
					
						
							|  |  |  |  |  *			children: [ | 
					
						
							|  |  |  |  |  *				{ | 
					
						
							|  |  |  |  |  *					type: 'text', | 
					
						
							|  |  |  |  |  *					id: 'id1', | 
					
						
							|  |  |  |  |  *					width: '40px', | 
					
						
							|  |  |  |  |  *				}, | 
					
						
							|  |  |  |  |  *				{ | 
					
						
							|  |  |  |  |  *					type: 'text', | 
					
						
							|  |  |  |  |  *					id: 'id2', | 
					
						
							|  |  |  |  |  *					width: '40px', | 
					
						
							|  |  |  |  |  *				}, | 
					
						
							|  |  |  |  |  *				{ | 
					
						
							|  |  |  |  |  *					type: 'text', | 
					
						
							|  |  |  |  |  *					id: 'id3' | 
					
						
							|  |  |  |  |  *				} | 
					
						
							|  |  |  |  |  *			] | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.hbox | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Array of {@link CKEDITOR.ui.dialog.uiElement} objects inside this container. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} children | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The widths of child cells. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} widths | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The height of the layout. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} height | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The CSS styles to apply to this element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} styles | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The padding width inside child cells. Example: 0, 1. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} padding | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The alignment of the whole layout. Example: center, top. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} align | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- vbox -----------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Vertical layout box for dialog UI elements. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create vertical layouts. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.vbox} object and can | 
					
						
							|  |  |  |  |  * be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'vbox', | 
					
						
							|  |  |  |  |  *			align: 'right', | 
					
						
							|  |  |  |  |  *			width: '200px', | 
					
						
							|  |  |  |  |  *			children: [ | 
					
						
							|  |  |  |  |  *				{ | 
					
						
							|  |  |  |  |  *					type: 'text', | 
					
						
							|  |  |  |  |  *					id: 'age', | 
					
						
							|  |  |  |  |  *					label: 'Age' | 
					
						
							|  |  |  |  |  *				}, | 
					
						
							|  |  |  |  |  *				{ | 
					
						
							|  |  |  |  |  *					type: 'text', | 
					
						
							|  |  |  |  |  *					id: 'sex', | 
					
						
							|  |  |  |  |  *					label: 'Sex' | 
					
						
							|  |  |  |  |  *				}, | 
					
						
							|  |  |  |  |  *				{ | 
					
						
							|  |  |  |  |  *					type: 'text', | 
					
						
							|  |  |  |  |  *					id: 'nationality', | 
					
						
							|  |  |  |  |  *					label: 'Nationality' | 
					
						
							|  |  |  |  |  *				} | 
					
						
							|  |  |  |  |  *			] | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.vbox | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Array of {@link CKEDITOR.ui.dialog.uiElement} objects inside this container. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} children | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The width of the layout. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} width | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The heights of individual cells. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} heights | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The CSS styles to apply to this element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} styles | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The padding width inside child cells. Example: 0, 1. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} padding | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The alignment of the whole layout. Example: center, top. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} align | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) Whether the layout should expand vertically to fill its container. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Boolean} expand | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- labeled element ------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of labeled user interface element (textarea, textInput etc). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create dialog UI elements. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.labeledElement | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  * @see CKEDITOR.ui.dialog.labeledElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The label of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'text', | 
					
						
							|  |  |  |  |  *			label: 'My Label' | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} label | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) Specify the layout of the label. Set to `'horizontal'` for horizontal layout. | 
					
						
							|  |  |  |  |  * The default layout is vertical. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'text', | 
					
						
							|  |  |  |  |  *			label: 'My Label', | 
					
						
							|  |  |  |  |  *			labelLayout: 'horizontal' | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} labelLayout | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) Applies only to horizontal layouts: a two elements array of lengths to specify the widths of the | 
					
						
							|  |  |  |  |  * label and the content element. See also {@link CKEDITOR.dialog.definition.labeledElement#labelLayout}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'text', | 
					
						
							|  |  |  |  |  *			label: 'My Label', | 
					
						
							|  |  |  |  |  *			labelLayout: 'horizontal', | 
					
						
							|  |  |  |  |  *			widths: [100, 200] | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} widths | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Specify the inline style of the uiElement label. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'text', | 
					
						
							|  |  |  |  |  *			label: 'My Label', | 
					
						
							|  |  |  |  |  *			labelStyle: 'color: red' | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} labelStyle | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Specify the inline style of the input element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'text', | 
					
						
							|  |  |  |  |  *			label: 'My Label', | 
					
						
							|  |  |  |  |  *			inputStyle: 'text-align: center' | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @since 3.6.1 | 
					
						
							|  |  |  |  |  * @property {String} inputStyle | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Specify the inline style of the input element container. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'text', | 
					
						
							|  |  |  |  |  *			label: 'My Label', | 
					
						
							|  |  |  |  |  *			controlStyle: 'width: 3em' | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @since 3.6.1 | 
					
						
							|  |  |  |  |  * @property {String} controlStyle | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- button ---------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a button. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create buttons. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.button} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'button', | 
					
						
							|  |  |  |  |  *			id: 'buttonId', | 
					
						
							|  |  |  |  |  *			label: 'Click me', | 
					
						
							|  |  |  |  |  *			title: 'My title', | 
					
						
							|  |  |  |  |  *			onClick: function() { | 
					
						
							|  |  |  |  |  *				// this = CKEDITOR.ui.dialog.button
 | 
					
						
							|  |  |  |  |  *				alert( 'Clicked: ' + this.id ); | 
					
						
							|  |  |  |  |  *			} | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.button | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Whether the button is disabled. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Boolean} disabled | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The label of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} label | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- checkbox ------
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a checkbox element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create groups of checkbox buttons. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.checkbox} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'checkbox', | 
					
						
							|  |  |  |  |  *			id: 'agree', | 
					
						
							|  |  |  |  |  *			label: 'I agree', | 
					
						
							|  |  |  |  |  *			'default': 'checked', | 
					
						
							|  |  |  |  |  *			onClick: function() { | 
					
						
							|  |  |  |  |  *				// this = CKEDITOR.ui.dialog.checkbox
 | 
					
						
							|  |  |  |  |  *				alert( 'Checked: ' + this.getValue() ); | 
					
						
							|  |  |  |  |  *			} | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.checkbox | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The validation function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} validate | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The label of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} label | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The default state. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} [default='' (unchecked)] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- file -----------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a file upload input. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create file upload elements. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.file} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'file', | 
					
						
							|  |  |  |  |  *			id: 'upload', | 
					
						
							|  |  |  |  |  *			label: 'Select file from your computer', | 
					
						
							|  |  |  |  |  *			size: 38 | 
					
						
							|  |  |  |  |  *		}, | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'fileButton', | 
					
						
							|  |  |  |  |  *			id: 'fileId', | 
					
						
							|  |  |  |  |  *			label: 'Upload file', | 
					
						
							|  |  |  |  |  *			'for': [ 'tab1', 'upload' ], | 
					
						
							|  |  |  |  |  *			filebrowser: { | 
					
						
							|  |  |  |  |  *				onSelect: function( fileUrl, data ) { | 
					
						
							|  |  |  |  |  *					alert( 'Successfully uploaded: ' + fileUrl ); | 
					
						
							|  |  |  |  |  *				} | 
					
						
							|  |  |  |  |  *			} | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.file | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.labeledElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The validation function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} validate | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The action attribute of the form element associated with this file upload input. | 
					
						
							|  |  |  |  |  * If empty, CKEditor will use path to server connector for currently opened folder. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} action | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The size of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} size | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- fileButton -----------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a button for submitting the file in a file upload input. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create a button for submitting the file in a file upload input. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.fileButton} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.fileButton | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The validation function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} validate | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The label of the UI element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} label | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The instruction for CKEditor how to deal with file upload. | 
					
						
							|  |  |  |  |  * By default, the file and fileButton elements will not work "as expected" if this attribute is not set. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Update field with id 'txtUrl' in the 'tab1' tab when file is uploaded.
 | 
					
						
							|  |  |  |  |  *		filebrowser: 'tab1:txtUrl' | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Call custom onSelect function when file is successfully uploaded.
 | 
					
						
							|  |  |  |  |  *		filebrowser: { | 
					
						
							|  |  |  |  |  *			onSelect: function( fileUrl, data ) { | 
					
						
							|  |  |  |  |  *				alert( 'Successfully uploaded: ' + fileUrl ); | 
					
						
							|  |  |  |  |  *			} | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} filebrowser/Object | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * An array that contains pageId and elementId of the file upload input element for which this button is created. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		[ pageId, elementId ] | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} for | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- html -----------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a raw HTML element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create elements made from raw HTML code. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.html} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * To access HTML elements use {@link CKEDITOR.dom.document#getById}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example 1:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'html', | 
					
						
							|  |  |  |  |  *			html: '<h3>This is some sample HTML content.</h3>' | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example 2:
 | 
					
						
							|  |  |  |  |  *		// Complete sample with document.getById() call when the "Ok" button is clicked.
 | 
					
						
							|  |  |  |  |  *		var dialogDefinition = { | 
					
						
							|  |  |  |  |  *			title: 'Sample dialog', | 
					
						
							|  |  |  |  |  *			minWidth: 300, | 
					
						
							|  |  |  |  |  *			minHeight: 200, | 
					
						
							|  |  |  |  |  *			onOk: function() { | 
					
						
							|  |  |  |  |  *				// "this" is now a CKEDITOR.dialog object.
 | 
					
						
							|  |  |  |  |  *				var document = this.getElement().getDocument(); | 
					
						
							|  |  |  |  |  *				// document = CKEDITOR.dom.document
 | 
					
						
							|  |  |  |  |  *				var element = <b>document.getById( 'myDiv' );</b> | 
					
						
							|  |  |  |  |  *				if ( element ) | 
					
						
							|  |  |  |  |  *					alert( element.getHtml() ); | 
					
						
							|  |  |  |  |  *			}, | 
					
						
							|  |  |  |  |  *			contents: [ | 
					
						
							|  |  |  |  |  *				{ | 
					
						
							|  |  |  |  |  *					id: 'tab1', | 
					
						
							|  |  |  |  |  *					label: '', | 
					
						
							|  |  |  |  |  *					title: '', | 
					
						
							|  |  |  |  |  *					elements: [ | 
					
						
							|  |  |  |  |  *						{ | 
					
						
							|  |  |  |  |  *							type: 'html', | 
					
						
							|  |  |  |  |  *							html: '<div id="myDiv">Sample <b>text</b>.</div><div id="otherId">Another div.</div>' | 
					
						
							|  |  |  |  |  *						} | 
					
						
							|  |  |  |  |  *					] | 
					
						
							|  |  |  |  |  *				} | 
					
						
							|  |  |  |  |  *			], | 
					
						
							|  |  |  |  |  *			buttons: [ CKEDITOR.dialog.cancelButton, CKEDITOR.dialog.okButton ] | 
					
						
							|  |  |  |  |  *		}; | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.html | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.uiElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Required) HTML code of this element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} html | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- radio ----------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a radio group. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create groups of radio buttons. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.radio} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'radio', | 
					
						
							|  |  |  |  |  *			id: 'country', | 
					
						
							|  |  |  |  |  *			label: 'Which country is bigger', | 
					
						
							|  |  |  |  |  *			items: [ [ 'France', 'FR' ], [ 'Germany', 'DE' ] ], | 
					
						
							|  |  |  |  |  *			style: 'color: green', | 
					
						
							|  |  |  |  |  *			'default': 'DE', | 
					
						
							|  |  |  |  |  *			onClick: function() { | 
					
						
							|  |  |  |  |  *				// this = CKEDITOR.ui.dialog.radio
 | 
					
						
							|  |  |  |  |  *				alert( 'Current value: ' + this.getValue() ); | 
					
						
							|  |  |  |  |  *			} | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.radio | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.labeledElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The default value. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} default | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The validation function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} validate | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * An array of options. Each option is a 1- or 2-item array of format `[ 'Description', 'Value' ]`. | 
					
						
							|  |  |  |  |  * If `'Value'` is missing, then the value would be assumed to be the same as the description. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} items | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- selectElement --------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a select element. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create select elements. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.select} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// Example:
 | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'select', | 
					
						
							|  |  |  |  |  *			id: 'sport', | 
					
						
							|  |  |  |  |  *			label: 'Select your favourite sport', | 
					
						
							|  |  |  |  |  *			items: [ [ 'Basketball' ], [ 'Baseball' ], [ 'Hockey' ], [ 'Football' ] ], | 
					
						
							|  |  |  |  |  *			'default': 'Football', | 
					
						
							|  |  |  |  |  *			onChange: function( api ) { | 
					
						
							|  |  |  |  |  *				// this = CKEDITOR.ui.dialog.select
 | 
					
						
							|  |  |  |  |  *				alert( 'Current value: ' + this.getValue() ); | 
					
						
							|  |  |  |  |  *			} | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.select | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.labeledElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The default value. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} default | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The validation function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} validate | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * An array of options. Each option is a 1- or 2-item array of format `[ 'Description', 'Value' ]`. | 
					
						
							|  |  |  |  |  * If `'Value'` is missing, then the value would be assumed to be the same as the description. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Array} items | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) Set this to true if you'd like to have a multiple-choice select box. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Boolean} [multiple=false] | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The number of items to display in the select box. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} size | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | // ----- textInput ------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a text field (single line). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create text fields. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.textInput} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  |  *		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  *		{ | 
					
						
							|  |  |  |  |  *			type: 'text', | 
					
						
							|  |  |  |  |  *			id: 'name', | 
					
						
							|  |  |  |  |  *			label: 'Your name', | 
					
						
							|  |  |  |  |  *			'default': '', | 
					
						
							|  |  |  |  |  *			validate: function() { | 
					
						
							|  |  |  |  |  *				if ( !this.getValue() ) { | 
					
						
							|  |  |  |  |  *					api.openMsgDialog( '', 'Name cannot be empty.' ); | 
					
						
							|  |  |  |  |  *					return false; | 
					
						
							|  |  |  |  |  *				} | 
					
						
							|  |  |  |  |  *			} | 
					
						
							|  |  |  |  |  *		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.textInput | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.labeledElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The default value. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} default | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The maximum length. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} maxLength | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The size of the input field. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} size | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The validation function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} validate | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-17 16:07:19 +00:00
										 |  |  |  | /** | 
					
						
							|  |  |  |  |  * @property bidi | 
					
						
							|  |  |  |  |  * @inheritdoc CKEDITOR.dialog.definition.textarea#bidi | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-11 20:07:18 +00:00
										 |  |  |  | // ----- textarea -------------------------------------------------------------
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The definition of a text field (multiple lines). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This class is not really part of the API. It just illustrates the properties | 
					
						
							|  |  |  |  |  * that developers can use to define and create textarea. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Once the dialog is opened, the created element becomes a {@link CKEDITOR.ui.dialog.textarea} object | 
					
						
							|  |  |  |  |  * and can be accessed with {@link CKEDITOR.dialog#getContentElement}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * For a complete example of dialog definition, please check {@link CKEDITOR.dialog#add}. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  | * 		// There is no constructor for this class, the user just has to define an
 | 
					
						
							|  |  |  |  | * 		// object with the appropriate properties.
 | 
					
						
							|  |  |  |  | * | 
					
						
							|  |  |  |  | * 		// Example:
 | 
					
						
							|  |  |  |  | * 		{ | 
					
						
							|  |  |  |  | * 			type: 'textarea', | 
					
						
							|  |  |  |  | * 			id: 'message', | 
					
						
							|  |  |  |  | * 			label: 'Your comment', | 
					
						
							|  |  |  |  | * 			'default': '', | 
					
						
							|  |  |  |  | * 			validate: function() { | 
					
						
							|  |  |  |  | * 				if ( this.getValue().length < 5 ) { | 
					
						
							|  |  |  |  | * 					api.openMsgDialog( 'The comment is too short.' ); | 
					
						
							|  |  |  |  | * 					return false; | 
					
						
							|  |  |  |  | * 				} | 
					
						
							|  |  |  |  | * 			} | 
					
						
							|  |  |  |  | * 		} | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @class CKEDITOR.dialog.definition.textarea | 
					
						
							|  |  |  |  |  * @extends CKEDITOR.dialog.definition.labeledElement | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The number of rows. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} rows | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The number of columns. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Number} cols | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * (Optional) The validation function. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {Function} validate | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * The default value. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @property {String} default | 
					
						
							|  |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-06-17 16:07:19 +00:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | /** | 
					
						
							|  |  |  |  |  * Whether the text direction of this input should be togglable using the following keystrokes: | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * * *Shift+Alt+End* – switch to Right-To-Left, | 
					
						
							|  |  |  |  |  * * *Shift+Alt+Home* – switch to Left-To-Right. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * By default the input will be loaded without any text direction set, which means that | 
					
						
							|  |  |  |  |  * the direction will be inherited from the editor's text direction. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the direction was set, a marker will be prepended to every non-empty value of this input: | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * * [`\u202A`](http://unicode.org/cldr/utility/character.jsp?a=202A) – for Right-To-Left,
 | 
					
						
							|  |  |  |  |  * * [`\u202B`](http://unicode.org/cldr/utility/character.jsp?a=202B) – for Left-To-Right.
 | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This marker allows for restoring the same text direction upon the next dialog opening. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * @since 4.5 | 
					
						
							|  |  |  |  |  * @property {Boolean} bidi | 
					
						
							|  |  |  |  |  */ |