1410 lines
		
	
	
		
			49 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
		
		
			
		
	
	
			1410 lines
		
	
	
		
			49 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| 
								 | 
							
								/**
							 | 
						|||
| 
								 | 
							
								 * @license Copyright (c) 2003-2014, CKSource - Frederico Knabben. All rights reserved.
							 | 
						|||
| 
								 | 
							
								 * For licensing, see LICENSE.md or http://ckeditor.com/license
							 | 
						|||
| 
								 | 
							
								 */
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								/**
							 | 
						|||
| 
								 | 
							
								 * @fileOverview The "dialogui" plugin.
							 | 
						|||
| 
								 | 
							
								 */
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								CKEDITOR.plugins.add( 'dialogui', {
							 | 
						|||
| 
								 | 
							
									onLoad: function() {
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										var initPrivateObject = function( elementDefinition ) {
							 | 
						|||
| 
								 | 
							
												this._ || ( this._ = {} );
							 | 
						|||
| 
								 | 
							
												this._[ 'default' ] = this._.initValue = elementDefinition[ 'default' ] || '';
							 | 
						|||
| 
								 | 
							
												this._.required = elementDefinition[ 'required' ] || false;
							 | 
						|||
| 
								 | 
							
												var args = [ this._ ];
							 | 
						|||
| 
								 | 
							
												for ( var i = 1; i < arguments.length; i++ )
							 | 
						|||
| 
								 | 
							
													args.push( arguments[ i ] );
							 | 
						|||
| 
								 | 
							
												args.push( true );
							 | 
						|||
| 
								 | 
							
												CKEDITOR.tools.extend.apply( CKEDITOR.tools, args );
							 | 
						|||
| 
								 | 
							
												return this._;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
											textBuilder = {
							 | 
						|||
| 
								 | 
							
												build: function( dialog, elementDefinition, output ) {
							 | 
						|||
| 
								 | 
							
													return new CKEDITOR.ui.dialog.textInput( dialog, elementDefinition, output );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
											commonBuilder = {
							 | 
						|||
| 
								 | 
							
												build: function( dialog, elementDefinition, output ) {
							 | 
						|||
| 
								 | 
							
													return new CKEDITOR.ui.dialog[ elementDefinition.type ]( dialog, elementDefinition, output );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
											containerBuilder = {
							 | 
						|||
| 
								 | 
							
												build: function( dialog, elementDefinition, output ) {
							 | 
						|||
| 
								 | 
							
													var children = elementDefinition.children,
							 | 
						|||
| 
								 | 
							
														child,
							 | 
						|||
| 
								 | 
							
														childHtmlList = [],
							 | 
						|||
| 
								 | 
							
														childObjList = [];
							 | 
						|||
| 
								 | 
							
													for ( var i = 0;
							 | 
						|||
| 
								 | 
							
													( i < children.length && ( child = children[ i ] ) ); i++ ) {
							 | 
						|||
| 
								 | 
							
														var childHtml = [];
							 | 
						|||
| 
								 | 
							
														childHtmlList.push( childHtml );
							 | 
						|||
| 
								 | 
							
														childObjList.push( CKEDITOR.dialog._.uiElementBuilders[ child.type ].build( dialog, child, childHtml ) );
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
													return new CKEDITOR.ui.dialog[ elementDefinition.type ]( dialog, childObjList, childHtmlList, output, elementDefinition );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
											commonPrototype = {
							 | 
						|||
| 
								 | 
							
												isChanged: function() {
							 | 
						|||
| 
								 | 
							
													return this.getValue() != this.getInitValue();
							 | 
						|||
| 
								 | 
							
												},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												reset: function( noChangeEvent ) {
							 | 
						|||
| 
								 | 
							
													this.setValue( this.getInitValue(), noChangeEvent );
							 | 
						|||
| 
								 | 
							
												},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												setInitValue: function() {
							 | 
						|||
| 
								 | 
							
													this._.initValue = this.getValue();
							 | 
						|||
| 
								 | 
							
												},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												resetInitValue: function() {
							 | 
						|||
| 
								 | 
							
													this._.initValue = this._[ 'default' ];
							 | 
						|||
| 
								 | 
							
												},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												getInitValue: function() {
							 | 
						|||
| 
								 | 
							
													return this._.initValue;
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
											commonEventProcessors = CKEDITOR.tools.extend( {}, CKEDITOR.ui.dialog.uiElement.prototype.eventProcessors, {
							 | 
						|||
| 
								 | 
							
												onChange: function( dialog, func ) {
							 | 
						|||
| 
								 | 
							
													if ( !this._.domOnChangeRegistered ) {
							 | 
						|||
| 
								 | 
							
														dialog.on( 'load', function() {
							 | 
						|||
| 
								 | 
							
															this.getInputElement().on( 'change', function() {
							 | 
						|||
| 
								 | 
							
																// Make sure 'onchange' doesn't get fired after dialog closed. (#5719)
							 | 
						|||
| 
								 | 
							
																if ( !dialog.parts.dialog.isVisible() )
							 | 
						|||
| 
								 | 
							
																	return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
																this.fire( 'change', { value: this.getValue() } );
							 | 
						|||
| 
								 | 
							
															}, this );
							 | 
						|||
| 
								 | 
							
														}, this );
							 | 
						|||
| 
								 | 
							
														this._.domOnChangeRegistered = true;
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													this.on( 'change', func );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											}, true ),
							 | 
						|||
| 
								 | 
							
											eventRegex = /^on([A-Z]\w+)/,
							 | 
						|||
| 
								 | 
							
											cleanInnerDefinition = function( def ) {
							 | 
						|||
| 
								 | 
							
												// An inner UI element should not have the parent's type, title or events.
							 | 
						|||
| 
								 | 
							
												for ( var i in def ) {
							 | 
						|||
| 
								 | 
							
													if ( eventRegex.test( i ) || i == 'title' || i == 'type' )
							 | 
						|||
| 
								 | 
							
														delete def[ i ];
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
												return def;
							 | 
						|||
| 
								 | 
							
											};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										CKEDITOR.tools.extend( CKEDITOR.ui.dialog, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Base class for all dialog elements with a textual label on the left.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.labeledElement
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.uiElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a labeledElement class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `label` (Required) The label string.
							 | 
						|||
| 
								 | 
							
											 * * `labelLayout` (Optional) Put 'horizontal' here if the
							 | 
						|||
| 
								 | 
							
											 *     label element is to be layed out horizontally. Otherwise a vertical
							 | 
						|||
| 
								 | 
							
											 *     layout will be used.
							 | 
						|||
| 
								 | 
							
											 * * `widths` (Optional) This applies only for horizontal
							 | 
						|||
| 
								 | 
							
											 *     layouts - an 2-element array of lengths to specify the widths of the
							 | 
						|||
| 
								 | 
							
											 *     label and the content element.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 * @param {Function} contentHtml
							 | 
						|||
| 
								 | 
							
											 * A function returning the HTML code string to be added inside the content
							 | 
						|||
| 
								 | 
							
											 * cell.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											labeledElement: function( dialog, elementDefinition, htmlList, contentHtml ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 4 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var _ = initPrivateObject.call( this, elementDefinition );
							 | 
						|||
| 
								 | 
							
												_.labelId = CKEDITOR.tools.getNextId() + '_label';
							 | 
						|||
| 
								 | 
							
												var children = this._.children = [];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
														var html = [],
							 | 
						|||
| 
								 | 
							
															requiredClass = elementDefinition.required ? ' cke_required' : '';
							 | 
						|||
| 
								 | 
							
														if ( elementDefinition.labelLayout != 'horizontal' ) {
							 | 
						|||
| 
								 | 
							
															html.push(
							 | 
						|||
| 
								 | 
							
																'<label class="cke_dialog_ui_labeled_label' + requiredClass + '" ', ' id="' + _.labelId + '"',
							 | 
						|||
| 
								 | 
							
																	( _.inputId ? ' for="' + _.inputId + '"' : '' ),
							 | 
						|||
| 
								 | 
							
																	( elementDefinition.labelStyle ? ' style="' + elementDefinition.labelStyle + '"' : '' ) + '>',
							 | 
						|||
| 
								 | 
							
																	elementDefinition.label,
							 | 
						|||
| 
								 | 
							
																'</label>',
							 | 
						|||
| 
								 | 
							
																'<div class="cke_dialog_ui_labeled_content"',
							 | 
						|||
| 
								 | 
							
																	( elementDefinition.controlStyle ? ' style="' + elementDefinition.controlStyle + '"' : '' ),
							 | 
						|||
| 
								 | 
							
																	' role="radiogroup" aria-labelledby="' + _.labelId + '">',
							 | 
						|||
| 
								 | 
							
																	contentHtml.call( this, dialog, elementDefinition ),
							 | 
						|||
| 
								 | 
							
																'</div>' );
							 | 
						|||
| 
								 | 
							
														} else {
							 | 
						|||
| 
								 | 
							
															var hboxDefinition = {
							 | 
						|||
| 
								 | 
							
																type: 'hbox',
							 | 
						|||
| 
								 | 
							
																widths: elementDefinition.widths,
							 | 
						|||
| 
								 | 
							
																padding: 0,
							 | 
						|||
| 
								 | 
							
																children: [
							 | 
						|||
| 
								 | 
							
																	{
							 | 
						|||
| 
								 | 
							
																	type: 'html',
							 | 
						|||
| 
								 | 
							
																	html: '<label class="cke_dialog_ui_labeled_label' + requiredClass + '"' +
							 | 
						|||
| 
								 | 
							
																		' id="' + _.labelId + '"' +
							 | 
						|||
| 
								 | 
							
																		' for="' + _.inputId + '"' +
							 | 
						|||
| 
								 | 
							
																		( elementDefinition.labelStyle ? ' style="' + elementDefinition.labelStyle + '"' : '' ) + '>' +
							 | 
						|||
| 
								 | 
							
																			CKEDITOR.tools.htmlEncode( elementDefinition.label ) +
							 | 
						|||
| 
								 | 
							
																		'</span>'
							 | 
						|||
| 
								 | 
							
																},
							 | 
						|||
| 
								 | 
							
																	{
							 | 
						|||
| 
								 | 
							
																	type: 'html',
							 | 
						|||
| 
								 | 
							
																	html: '<span class="cke_dialog_ui_labeled_content"' + ( elementDefinition.controlStyle ? ' style="' + elementDefinition.controlStyle + '"' : '' ) + '>' +
							 | 
						|||
| 
								 | 
							
																		contentHtml.call( this, dialog, elementDefinition ) +
							 | 
						|||
| 
								 | 
							
																		'</span>'
							 | 
						|||
| 
								 | 
							
																}
							 | 
						|||
| 
								 | 
							
																]
							 | 
						|||
| 
								 | 
							
															};
							 | 
						|||
| 
								 | 
							
															CKEDITOR.dialog._.uiElementBuilders.hbox.build( dialog, hboxDefinition, html );
							 | 
						|||
| 
								 | 
							
														}
							 | 
						|||
| 
								 | 
							
														return html.join( '' );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.uiElement.call( this, dialog, elementDefinition, htmlList, 'div', null, { role: 'presentation' }, innerHTML );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A text input with a label. This UI element class represents both the
							 | 
						|||
| 
								 | 
							
											 * single-line text inputs and password inputs in dialog boxes.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.textInput
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.labeledElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a textInput class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `default` (Optional) The default value.
							 | 
						|||
| 
								 | 
							
											 * * `validate` (Optional) The validation function.
							 | 
						|||
| 
								 | 
							
											 * * `maxLength` (Optional) The maximum length of text box contents.
							 | 
						|||
| 
								 | 
							
											 * * `size` (Optional) The size of the text box. This is
							 | 
						|||
| 
								 | 
							
											 *     usually overridden by the size defined by the skin, however.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											textInput: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												initPrivateObject.call( this, elementDefinition );
							 | 
						|||
| 
								 | 
							
												var domId = this._.inputId = CKEDITOR.tools.getNextId() + '_textInput',
							 | 
						|||
| 
								 | 
							
													attributes = { 'class': 'cke_dialog_ui_input_' + elementDefinition.type, id: domId, type: elementDefinition.type },
							 | 
						|||
| 
								 | 
							
													i;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// Set the validator, if any.
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.validate )
							 | 
						|||
| 
								 | 
							
													this.validate = elementDefinition.validate;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// Set the max length and size.
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.maxLength )
							 | 
						|||
| 
								 | 
							
													attributes.maxlength = elementDefinition.maxLength;
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.size )
							 | 
						|||
| 
								 | 
							
													attributes.size = elementDefinition.size;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.inputStyle )
							 | 
						|||
| 
								 | 
							
													attributes.style = elementDefinition.inputStyle;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// If user presses Enter in a text box, it implies clicking OK for the dialog.
							 | 
						|||
| 
								 | 
							
												var me = this,
							 | 
						|||
| 
								 | 
							
													keyPressedOnMe = false;
							 | 
						|||
| 
								 | 
							
												dialog.on( 'load', function() {
							 | 
						|||
| 
								 | 
							
													me.getInputElement().on( 'keydown', function( evt ) {
							 | 
						|||
| 
								 | 
							
														if ( evt.data.getKeystroke() == 13 )
							 | 
						|||
| 
								 | 
							
															keyPressedOnMe = true;
							 | 
						|||
| 
								 | 
							
													} );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													// Lower the priority this 'keyup' since 'ok' will close the dialog.(#3749)
							 | 
						|||
| 
								 | 
							
													me.getInputElement().on( 'keyup', function( evt ) {
							 | 
						|||
| 
								 | 
							
														if ( evt.data.getKeystroke() == 13 && keyPressedOnMe ) {
							 | 
						|||
| 
								 | 
							
															dialog.getButton( 'ok' ) && setTimeout( function() {
							 | 
						|||
| 
								 | 
							
																dialog.getButton( 'ok' ).click();
							 | 
						|||
| 
								 | 
							
															}, 0 );
							 | 
						|||
| 
								 | 
							
															keyPressedOnMe = false;
							 | 
						|||
| 
								 | 
							
														}
							 | 
						|||
| 
								 | 
							
													}, null, null, 1000 );
							 | 
						|||
| 
								 | 
							
												} );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
														// IE BUG: Text input fields in IE at 100% would exceed a <td> or inline
							 | 
						|||
| 
								 | 
							
														// container's width, so need to wrap it inside a <div>.
							 | 
						|||
| 
								 | 
							
														var html = [ '<div class="cke_dialog_ui_input_', elementDefinition.type, '" role="presentation"' ];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														if ( elementDefinition.width )
							 | 
						|||
| 
								 | 
							
															html.push( 'style="width:' + elementDefinition.width + '" ' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														html.push( '><input ' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														attributes[ 'aria-labelledby' ] = this._.labelId;
							 | 
						|||
| 
								 | 
							
														this._.required && ( attributes[ 'aria-required' ] = this._.required );
							 | 
						|||
| 
								 | 
							
														for ( var i in attributes )
							 | 
						|||
| 
								 | 
							
															html.push( i + '="' + attributes[ i ] + '" ' );
							 | 
						|||
| 
								 | 
							
														html.push( ' /></div>' );
							 | 
						|||
| 
								 | 
							
														return html.join( '' );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.labeledElement.call( this, dialog, elementDefinition, htmlList, innerHTML );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A text area with a label on the top or left.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.textarea
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.labeledElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a textarea class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `rows` (Optional) The number of rows displayed.
							 | 
						|||
| 
								 | 
							
											 *     Defaults to 5 if not defined.
							 | 
						|||
| 
								 | 
							
											 * * `cols` (Optional) The number of cols displayed.
							 | 
						|||
| 
								 | 
							
											 *     Defaults to 20 if not defined. Usually overridden by skins.
							 | 
						|||
| 
								 | 
							
											 * * `default` (Optional) The default value.
							 | 
						|||
| 
								 | 
							
											 * * `validate` (Optional) The validation function.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											textarea: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												initPrivateObject.call( this, elementDefinition );
							 | 
						|||
| 
								 | 
							
												var me = this,
							 | 
						|||
| 
								 | 
							
													domId = this._.inputId = CKEDITOR.tools.getNextId() + '_textarea',
							 | 
						|||
| 
								 | 
							
													attributes = {};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.validate )
							 | 
						|||
| 
								 | 
							
													this.validate = elementDefinition.validate;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// Generates the essential attributes for the textarea tag.
							 | 
						|||
| 
								 | 
							
												attributes.rows = elementDefinition.rows || 5;
							 | 
						|||
| 
								 | 
							
												attributes.cols = elementDefinition.cols || 20;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												attributes[ 'class' ] = 'cke_dialog_ui_input_textarea ' + ( elementDefinition[ 'class' ] || '' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( typeof elementDefinition.inputStyle != 'undefined' )
							 | 
						|||
| 
								 | 
							
													attributes.style = elementDefinition.inputStyle;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.dir )
							 | 
						|||
| 
								 | 
							
													attributes.dir = elementDefinition.dir;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
														attributes[ 'aria-labelledby' ] = this._.labelId;
							 | 
						|||
| 
								 | 
							
														this._.required && ( attributes[ 'aria-required' ] = this._.required );
							 | 
						|||
| 
								 | 
							
														var html = [ '<div class="cke_dialog_ui_input_textarea" role="presentation"><textarea id="', domId, '" ' ];
							 | 
						|||
| 
								 | 
							
														for ( var i in attributes )
							 | 
						|||
| 
								 | 
							
															html.push( i + '="' + CKEDITOR.tools.htmlEncode( attributes[ i ] ) + '" ' );
							 | 
						|||
| 
								 | 
							
														html.push( '>', CKEDITOR.tools.htmlEncode( me._[ 'default' ] ), '</textarea></div>' );
							 | 
						|||
| 
								 | 
							
														return html.join( '' );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.labeledElement.call( this, dialog, elementDefinition, htmlList, innerHTML );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A single checkbox with a label on the right.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.checkbox
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.uiElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a checkbox class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `checked` (Optional) Whether the checkbox is checked
							 | 
						|||
| 
								 | 
							
											 *     on instantiation. Defaults to false.
							 | 
						|||
| 
								 | 
							
											 * * `validate` (Optional) The validation function.
							 | 
						|||
| 
								 | 
							
											 * * `label` (Optional) The checkbox label.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											checkbox: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var _ = initPrivateObject.call( this, elementDefinition, { 'default': !!elementDefinition[ 'default' ] } );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.validate )
							 | 
						|||
| 
								 | 
							
													this.validate = elementDefinition.validate;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
														var myDefinition = CKEDITOR.tools.extend( {}, elementDefinition, {
							 | 
						|||
| 
								 | 
							
															id: elementDefinition.id ? elementDefinition.id + '_checkbox' : CKEDITOR.tools.getNextId() + '_checkbox'
							 | 
						|||
| 
								 | 
							
														}, true ),
							 | 
						|||
| 
								 | 
							
															html = [];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														var labelId = CKEDITOR.tools.getNextId() + '_label';
							 | 
						|||
| 
								 | 
							
														var attributes = { 'class': 'cke_dialog_ui_checkbox_input', type: 'checkbox', 'aria-labelledby': labelId };
							 | 
						|||
| 
								 | 
							
														cleanInnerDefinition( myDefinition );
							 | 
						|||
| 
								 | 
							
														if ( elementDefinition[ 'default' ] )
							 | 
						|||
| 
								 | 
							
															attributes.checked = 'checked';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														if ( typeof myDefinition.inputStyle != 'undefined' )
							 | 
						|||
| 
								 | 
							
															myDefinition.style = myDefinition.inputStyle;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														_.checkbox = new CKEDITOR.ui.dialog.uiElement( dialog, myDefinition, html, 'input', null, attributes );
							 | 
						|||
| 
								 | 
							
														html.push( ' <label id="', labelId, '" for="', attributes.id, '"' + ( elementDefinition.labelStyle ? ' style="' + elementDefinition.labelStyle + '"' : '' ) + '>', CKEDITOR.tools.htmlEncode( elementDefinition.label ), '</label>' );
							 | 
						|||
| 
								 | 
							
														return html.join( '' );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.uiElement.call( this, dialog, elementDefinition, htmlList, 'span', null, null, innerHTML );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A group of radio buttons.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.radio
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.labeledElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a radio class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `default` (Required) The default value.
							 | 
						|||
| 
								 | 
							
											 * * `validate` (Optional) The validation function.
							 | 
						|||
| 
								 | 
							
											 * * `items` (Required) 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.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											radio: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												initPrivateObject.call( this, elementDefinition );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( !this._[ 'default' ] )
							 | 
						|||
| 
								 | 
							
													this._[ 'default' ] = this._.initValue = elementDefinition.items[ 0 ][ 1 ];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.validate )
							 | 
						|||
| 
								 | 
							
													this.validate = elementDefinition.valdiate;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var children = [],
							 | 
						|||
| 
								 | 
							
													me = this;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
													var inputHtmlList = [],
							 | 
						|||
| 
								 | 
							
														html = [],
							 | 
						|||
| 
								 | 
							
														commonName = ( elementDefinition.id ? elementDefinition.id : CKEDITOR.tools.getNextId() ) + '_radio';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													for ( var i = 0; i < elementDefinition.items.length; i++ ) {
							 | 
						|||
| 
								 | 
							
														var item = elementDefinition.items[ i ],
							 | 
						|||
| 
								 | 
							
															title = item[ 2 ] !== undefined ? item[ 2 ] : item[ 0 ],
							 | 
						|||
| 
								 | 
							
															value = item[ 1 ] !== undefined ? item[ 1 ] : item[ 0 ],
							 | 
						|||
| 
								 | 
							
															inputId = CKEDITOR.tools.getNextId() + '_radio_input',
							 | 
						|||
| 
								 | 
							
															labelId = inputId + '_label',
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
															inputDefinition = CKEDITOR.tools.extend( {}, elementDefinition, {
							 | 
						|||
| 
								 | 
							
																id: inputId,
							 | 
						|||
| 
								 | 
							
																title: null,
							 | 
						|||
| 
								 | 
							
																type: null
							 | 
						|||
| 
								 | 
							
															}, true ),
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
															labelDefinition = CKEDITOR.tools.extend( {}, inputDefinition, {
							 | 
						|||
| 
								 | 
							
																title: title
							 | 
						|||
| 
								 | 
							
															}, true ),
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
															inputAttributes = {
							 | 
						|||
| 
								 | 
							
																type: 'radio',
							 | 
						|||
| 
								 | 
							
																'class': 'cke_dialog_ui_radio_input',
							 | 
						|||
| 
								 | 
							
																name: commonName,
							 | 
						|||
| 
								 | 
							
																value: value,
							 | 
						|||
| 
								 | 
							
																'aria-labelledby': labelId
							 | 
						|||
| 
								 | 
							
															},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
															inputHtml = [];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														if ( me._[ 'default' ] == value )
							 | 
						|||
| 
								 | 
							
															inputAttributes.checked = 'checked';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														cleanInnerDefinition( inputDefinition );
							 | 
						|||
| 
								 | 
							
														cleanInnerDefinition( labelDefinition );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														if ( typeof inputDefinition.inputStyle != 'undefined' )
							 | 
						|||
| 
								 | 
							
															inputDefinition.style = inputDefinition.inputStyle;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														// Make inputs of radio type focusable (#10866).
							 | 
						|||
| 
								 | 
							
														inputDefinition.keyboardFocusable = true;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														children.push( new CKEDITOR.ui.dialog.uiElement( dialog, inputDefinition, inputHtml, 'input', null, inputAttributes ) );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														inputHtml.push( ' ' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														new CKEDITOR.ui.dialog.uiElement( dialog, labelDefinition, inputHtml, 'label', null, {
							 | 
						|||
| 
								 | 
							
															id: labelId,
							 | 
						|||
| 
								 | 
							
															'for': inputAttributes.id
							 | 
						|||
| 
								 | 
							
														}, item[ 0 ] );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														inputHtmlList.push( inputHtml.join( '' ) );
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													new CKEDITOR.ui.dialog.hbox( dialog, children, inputHtmlList, html );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													return html.join( '' );
							 | 
						|||
| 
								 | 
							
												};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.labeledElement.call( this, dialog, elementDefinition, htmlList, innerHTML );
							 | 
						|||
| 
								 | 
							
												this._.children = children;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A button with a label inside.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.button
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.uiElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a button class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `label` (Required) The button label.
							 | 
						|||
| 
								 | 
							
											 * * `disabled` (Optional) Set to true if you want the
							 | 
						|||
| 
								 | 
							
											 *     button to appear in disabled state.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											button: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( !arguments.length )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( typeof elementDefinition == 'function' )
							 | 
						|||
| 
								 | 
							
													elementDefinition = elementDefinition( dialog.getParentEditor() );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												initPrivateObject.call( this, elementDefinition, { disabled: elementDefinition.disabled || false } );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// Add OnClick event to this input.
							 | 
						|||
| 
								 | 
							
												CKEDITOR.event.implementOn( this );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var me = this;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// Register an event handler for processing button clicks.
							 | 
						|||
| 
								 | 
							
												dialog.on( 'load', function( eventInfo ) {
							 | 
						|||
| 
								 | 
							
													var element = this.getElement();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													( function() {
							 | 
						|||
| 
								 | 
							
														element.on( 'click', function( evt ) {
							 | 
						|||
| 
								 | 
							
															me.click();
							 | 
						|||
| 
								 | 
							
															// #9958
							 | 
						|||
| 
								 | 
							
															evt.data.preventDefault();
							 | 
						|||
| 
								 | 
							
														} );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														element.on( 'keydown', function( evt ) {
							 | 
						|||
| 
								 | 
							
															if ( evt.data.getKeystroke() in { 32: 1 } ) {
							 | 
						|||
| 
								 | 
							
																me.click();
							 | 
						|||
| 
								 | 
							
																evt.data.preventDefault();
							 | 
						|||
| 
								 | 
							
															}
							 | 
						|||
| 
								 | 
							
														} );
							 | 
						|||
| 
								 | 
							
													} )();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													element.unselectable();
							 | 
						|||
| 
								 | 
							
												}, this );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var outerDefinition = CKEDITOR.tools.extend( {}, elementDefinition );
							 | 
						|||
| 
								 | 
							
												delete outerDefinition.style;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var labelId = CKEDITOR.tools.getNextId() + '_label';
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.uiElement.call( this, dialog, outerDefinition, htmlList, 'a', null, {
							 | 
						|||
| 
								 | 
							
													style: elementDefinition.style,
							 | 
						|||
| 
								 | 
							
													href: 'javascript:void(0)',
							 | 
						|||
| 
								 | 
							
													title: elementDefinition.label,
							 | 
						|||
| 
								 | 
							
													hidefocus: 'true',
							 | 
						|||
| 
								 | 
							
													'class': elementDefinition[ 'class' ],
							 | 
						|||
| 
								 | 
							
													role: 'button',
							 | 
						|||
| 
								 | 
							
													'aria-labelledby': labelId
							 | 
						|||
| 
								 | 
							
												}, '<span id="' + labelId + '" class="cke_dialog_ui_button">' +
							 | 
						|||
| 
								 | 
							
																			CKEDITOR.tools.htmlEncode( elementDefinition.label ) +
							 | 
						|||
| 
								 | 
							
																		'</span>' );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A select box.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.select
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.uiElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a button class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `default` (Required) The default value.
							 | 
						|||
| 
								 | 
							
											 * * `validate` (Optional) The validation function.
							 | 
						|||
| 
								 | 
							
											 * * `items` (Required) 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.
							 | 
						|||
| 
								 | 
							
											 * * `multiple` (Optional) Set this to true if you'd like
							 | 
						|||
| 
								 | 
							
											 *     to have a multiple-choice select box.
							 | 
						|||
| 
								 | 
							
											 * * `size` (Optional) The number of items to display in
							 | 
						|||
| 
								 | 
							
											 *     the select box.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											select: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var _ = initPrivateObject.call( this, elementDefinition );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.validate )
							 | 
						|||
| 
								 | 
							
													this.validate = elementDefinition.validate;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												_.inputId = CKEDITOR.tools.getNextId() + '_select';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
														var myDefinition = CKEDITOR.tools.extend( {}, elementDefinition, {
							 | 
						|||
| 
								 | 
							
															id: elementDefinition.id ? elementDefinition.id + '_select' : CKEDITOR.tools.getNextId() + '_select'
							 | 
						|||
| 
								 | 
							
														}, true ),
							 | 
						|||
| 
								 | 
							
															html = [],
							 | 
						|||
| 
								 | 
							
															innerHTML = [],
							 | 
						|||
| 
								 | 
							
															attributes = { 'id': _.inputId, 'class': 'cke_dialog_ui_input_select', 'aria-labelledby': this._.labelId };
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														html.push( '<div class="cke_dialog_ui_input_', elementDefinition.type, '" role="presentation"' );
							 | 
						|||
| 
								 | 
							
														if ( elementDefinition.width )
							 | 
						|||
| 
								 | 
							
															html.push( 'style="width:' + elementDefinition.width + '" ' );
							 | 
						|||
| 
								 | 
							
														html.push( '>' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														// Add multiple and size attributes from element definition.
							 | 
						|||
| 
								 | 
							
														if ( elementDefinition.size != undefined )
							 | 
						|||
| 
								 | 
							
															attributes.size = elementDefinition.size;
							 | 
						|||
| 
								 | 
							
														if ( elementDefinition.multiple != undefined )
							 | 
						|||
| 
								 | 
							
															attributes.multiple = elementDefinition.multiple;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														cleanInnerDefinition( myDefinition );
							 | 
						|||
| 
								 | 
							
														for ( var i = 0, item; i < elementDefinition.items.length && ( item = elementDefinition.items[ i ] ); i++ ) {
							 | 
						|||
| 
								 | 
							
															innerHTML.push( '<option value="', CKEDITOR.tools.htmlEncode( item[ 1 ] !== undefined ? item[ 1 ] : item[ 0 ] ).replace( /"/g, '"' ), '" /> ', CKEDITOR.tools.htmlEncode( item[ 0 ] ) );
							 | 
						|||
| 
								 | 
							
														}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														if ( typeof myDefinition.inputStyle != 'undefined' )
							 | 
						|||
| 
								 | 
							
															myDefinition.style = myDefinition.inputStyle;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														_.select = new CKEDITOR.ui.dialog.uiElement( dialog, myDefinition, html, 'select', null, attributes, innerHTML.join( '' ) );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														html.push( '</div>' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														return html.join( '' );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.labeledElement.call( this, dialog, elementDefinition, htmlList, innerHTML );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A file upload input.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.file
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.labeledElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a file class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `validate` (Optional) The validation function.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											file: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition[ 'default' ] === undefined )
							 | 
						|||
| 
								 | 
							
													elementDefinition[ 'default' ] = '';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var _ = CKEDITOR.tools.extend( initPrivateObject.call( this, elementDefinition ), { definition: elementDefinition, buttons: [] } );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.validate )
							 | 
						|||
| 
								 | 
							
													this.validate = elementDefinition.validate;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												/** @ignore */
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
														_.frameId = CKEDITOR.tools.getNextId() + '_fileInput';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														var html = [
							 | 
						|||
| 
								 | 
							
															'<iframe' +
							 | 
						|||
| 
								 | 
							
																' frameborder="0"' +
							 | 
						|||
| 
								 | 
							
																' allowtransparency="0"' +
							 | 
						|||
| 
								 | 
							
																' class="cke_dialog_ui_input_file"' +
							 | 
						|||
| 
								 | 
							
																' role="presentation"' +
							 | 
						|||
| 
								 | 
							
																' id="', _.frameId, '"' +
							 | 
						|||
| 
								 | 
							
																' title="', elementDefinition.label, '"' +
							 | 
						|||
| 
								 | 
							
																' src="javascript:void(' ];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														// Support for custom document.domain on IE. (#10165)
							 | 
						|||
| 
								 | 
							
														html.push( CKEDITOR.env.ie ?
							 | 
						|||
| 
								 | 
							
															'(function(){' + encodeURIComponent(
							 | 
						|||
| 
								 | 
							
																'document.open();' +
							 | 
						|||
| 
								 | 
							
																'(' + CKEDITOR.tools.fixDomain + ')();' +
							 | 
						|||
| 
								 | 
							
																'document.close();'
							 | 
						|||
| 
								 | 
							
															) + '})()'
							 | 
						|||
| 
								 | 
							
															:
							 | 
						|||
| 
								 | 
							
															'0' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														html.push( ')">' +
							 | 
						|||
| 
								 | 
							
															'</iframe>' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
														return html.join( '' );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// IE BUG: Parent container does not resize to contain the iframe automatically.
							 | 
						|||
| 
								 | 
							
												dialog.on( 'load', function() {
							 | 
						|||
| 
								 | 
							
													var iframe = CKEDITOR.document.getById( _.frameId ),
							 | 
						|||
| 
								 | 
							
														contentDiv = iframe.getParent();
							 | 
						|||
| 
								 | 
							
													contentDiv.addClass( 'cke_dialog_ui_input_file' );
							 | 
						|||
| 
								 | 
							
												} );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.labeledElement.call( this, dialog, elementDefinition, htmlList, innerHTML );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * A button for submitting the file in a file upload input.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.fileButton
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.button
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a fileButton class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `for` (Required) The file input's page and element Id
							 | 
						|||
| 
								 | 
							
											 *     to associate to, in a 2-item array format: `[ 'page_id', 'element_id' ]`.
							 | 
						|||
| 
								 | 
							
											 * * `validate` (Optional) The validation function.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList List of HTML code to output to.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											fileButton: function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
												if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
													return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var _ = initPrivateObject.call( this, elementDefinition ),
							 | 
						|||
| 
								 | 
							
													me = this;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												if ( elementDefinition.validate )
							 | 
						|||
| 
								 | 
							
													this.validate = elementDefinition.validate;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var myDefinition = CKEDITOR.tools.extend( {}, elementDefinition );
							 | 
						|||
| 
								 | 
							
												var onClick = myDefinition.onClick;
							 | 
						|||
| 
								 | 
							
												myDefinition.className = ( myDefinition.className ? myDefinition.className + ' ' : '' ) + 'cke_dialog_ui_button';
							 | 
						|||
| 
								 | 
							
												myDefinition.onClick = function( evt ) {
							 | 
						|||
| 
								 | 
							
													var target = elementDefinition[ 'for' ]; // [ pageId, elementId ]
							 | 
						|||
| 
								 | 
							
													if ( !onClick || onClick.call( this, evt ) !== false ) {
							 | 
						|||
| 
								 | 
							
														dialog.getContentElement( target[ 0 ], target[ 1 ] ).submit();
							 | 
						|||
| 
								 | 
							
														this.disable();
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
												};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												dialog.on( 'load', function() {
							 | 
						|||
| 
								 | 
							
													dialog.getContentElement( elementDefinition[ 'for' ][ 0 ], elementDefinition[ 'for' ][ 1 ] )._.buttons.push( me );
							 | 
						|||
| 
								 | 
							
												} );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.button.call( this, dialog, myDefinition, htmlList );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											html: ( function() {
							 | 
						|||
| 
								 | 
							
												var myHtmlRe = /^\s*<[\w:]+\s+([^>]*)?>/,
							 | 
						|||
| 
								 | 
							
													theirHtmlRe = /^(\s*<[\w:]+(?:\s+[^>]*)?)((?:.|\r|\n)+)$/,
							 | 
						|||
| 
								 | 
							
													emptyTagRe = /\/$/;
							 | 
						|||
| 
								 | 
							
												/**
							 | 
						|||
| 
								 | 
							
												 * A dialog element made from raw HTML code.
							 | 
						|||
| 
								 | 
							
												 *
							 | 
						|||
| 
								 | 
							
												 * @class CKEDITOR.ui.dialog.html
							 | 
						|||
| 
								 | 
							
												 * @extends CKEDITOR.ui.dialog.uiElement
							 | 
						|||
| 
								 | 
							
												 * @constructor Creates a html class instance.
							 | 
						|||
| 
								 | 
							
												 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
												 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition Element definition.
							 | 
						|||
| 
								 | 
							
												 * Accepted fields:
							 | 
						|||
| 
								 | 
							
												 *
							 | 
						|||
| 
								 | 
							
												 * * `html` (Required) HTML code of this element.
							 | 
						|||
| 
								 | 
							
												 *
							 | 
						|||
| 
								 | 
							
												 * @param {Array} htmlList List of HTML code to be added to the dialog's content area.
							 | 
						|||
| 
								 | 
							
												 */
							 | 
						|||
| 
								 | 
							
												return function( dialog, elementDefinition, htmlList ) {
							 | 
						|||
| 
								 | 
							
													if ( arguments.length < 3 )
							 | 
						|||
| 
								 | 
							
														return;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													var myHtmlList = [],
							 | 
						|||
| 
								 | 
							
														myHtml,
							 | 
						|||
| 
								 | 
							
														theirHtml = elementDefinition.html,
							 | 
						|||
| 
								 | 
							
														myMatch, theirMatch;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													// If the HTML input doesn't contain any tags at the beginning, add a <span> tag around it.
							 | 
						|||
| 
								 | 
							
													if ( theirHtml.charAt( 0 ) != '<' )
							 | 
						|||
| 
								 | 
							
														theirHtml = '<span>' + theirHtml + '</span>';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													// Look for focus function in definition.
							 | 
						|||
| 
								 | 
							
													var focus = elementDefinition.focus;
							 | 
						|||
| 
								 | 
							
													if ( focus ) {
							 | 
						|||
| 
								 | 
							
														var oldFocus = this.focus;
							 | 
						|||
| 
								 | 
							
														this.focus = function() {
							 | 
						|||
| 
								 | 
							
															( typeof focus == 'function' ? focus : oldFocus ).call( this );
							 | 
						|||
| 
								 | 
							
															this.fire( 'focus' );
							 | 
						|||
| 
								 | 
							
														};
							 | 
						|||
| 
								 | 
							
														if ( elementDefinition.isFocusable ) {
							 | 
						|||
| 
								 | 
							
															var oldIsFocusable = this.isFocusable;
							 | 
						|||
| 
								 | 
							
															this.isFocusable = oldIsFocusable;
							 | 
						|||
| 
								 | 
							
														}
							 | 
						|||
| 
								 | 
							
														this.keyboardFocusable = true;
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													CKEDITOR.ui.dialog.uiElement.call( this, dialog, elementDefinition, myHtmlList, 'span', null, null, '' );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													// Append the attributes created by the uiElement call to the real HTML.
							 | 
						|||
| 
								 | 
							
													myHtml = myHtmlList.join( '' );
							 | 
						|||
| 
								 | 
							
													myMatch = myHtml.match( myHtmlRe );
							 | 
						|||
| 
								 | 
							
													theirMatch = theirHtml.match( theirHtmlRe ) || [ '', '', '' ];
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													if ( emptyTagRe.test( theirMatch[ 1 ] ) ) {
							 | 
						|||
| 
								 | 
							
														theirMatch[ 1 ] = theirMatch[ 1 ].slice( 0, -1 );
							 | 
						|||
| 
								 | 
							
														theirMatch[ 2 ] = '/' + theirMatch[ 2 ];
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													htmlList.push( [ theirMatch[ 1 ], ' ', myMatch[ 1 ] || '', theirMatch[ 2 ] ].join( '' ) );
							 | 
						|||
| 
								 | 
							
												};
							 | 
						|||
| 
								 | 
							
											} )(),
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Form fieldset for grouping dialog UI elements.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @class CKEDITOR.ui.dialog.fieldset
							 | 
						|||
| 
								 | 
							
											 * @extends CKEDITOR.ui.dialog.uiElement
							 | 
						|||
| 
								 | 
							
											 * @constructor Creates a fieldset class instance.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog} dialog Parent dialog object.
							 | 
						|||
| 
								 | 
							
											 * @param {Array} childObjList
							 | 
						|||
| 
								 | 
							
											 * Array of {@link CKEDITOR.ui.dialog.uiElement} objects inside this container.
							 | 
						|||
| 
								 | 
							
											 * @param {Array} childHtmlList Array of HTML code that correspond to the HTML output of all the
							 | 
						|||
| 
								 | 
							
											 * objects in childObjList.
							 | 
						|||
| 
								 | 
							
											 * @param {Array} htmlList Array of HTML code that this element will output to.
							 | 
						|||
| 
								 | 
							
											 * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition
							 | 
						|||
| 
								 | 
							
											 * The element definition. Accepted fields:
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * * `label` (Optional) The legend of the this fieldset.
							 | 
						|||
| 
								 | 
							
											 * * `children` (Required) An array of dialog field definitions which will be grouped inside this fieldset.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											fieldset: function( dialog, childObjList, childHtmlList, htmlList, elementDefinition ) {
							 | 
						|||
| 
								 | 
							
												var legendLabel = elementDefinition.label;
							 | 
						|||
| 
								 | 
							
												/** @ignore */
							 | 
						|||
| 
								 | 
							
												var innerHTML = function() {
							 | 
						|||
| 
								 | 
							
														var html = [];
							 | 
						|||
| 
								 | 
							
														legendLabel && html.push( '<legend' +
							 | 
						|||
| 
								 | 
							
															( elementDefinition.labelStyle ? ' style="' + elementDefinition.labelStyle + '"' : '' ) +
							 | 
						|||
| 
								 | 
							
															'>' + legendLabel + '</legend>' );
							 | 
						|||
| 
								 | 
							
														for ( var i = 0; i < childHtmlList.length; i++ )
							 | 
						|||
| 
								 | 
							
															html.push( childHtmlList[ i ] );
							 | 
						|||
| 
								 | 
							
														return html.join( '' );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												this._ = { children: childObjList };
							 | 
						|||
| 
								 | 
							
												CKEDITOR.ui.dialog.uiElement.call( this, dialog, elementDefinition, htmlList, 'fieldset', null, null, innerHTML );
							 | 
						|||
| 
								 | 
							
											}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										}, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.html.prototype = new CKEDITOR.ui.dialog.uiElement;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										/** @class CKEDITOR.ui.dialog.labeledElement */
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.labeledElement.prototype = CKEDITOR.tools.extend( new CKEDITOR.ui.dialog.uiElement, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Sets the label text of the element.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {String} label The new label text.
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.ui.dialog.labeledElement} The current labeled element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											setLabel: function( label ) {
							 | 
						|||
| 
								 | 
							
												var node = CKEDITOR.document.getById( this._.labelId );
							 | 
						|||
| 
								 | 
							
												if ( node.getChildCount() < 1 )
							 | 
						|||
| 
								 | 
							
												( new CKEDITOR.dom.text( label, CKEDITOR.document ) ).appendTo( node );
							 | 
						|||
| 
								 | 
							
												else
							 | 
						|||
| 
								 | 
							
													node.getChild( 0 ).$.nodeValue = label;
							 | 
						|||
| 
								 | 
							
												return this;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Retrieves the current label text of the elment.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {String} The current label text.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getLabel: function() {
							 | 
						|||
| 
								 | 
							
												var node = CKEDITOR.document.getById( this._.labelId );
							 | 
						|||
| 
								 | 
							
												if ( !node || node.getChildCount() < 1 )
							 | 
						|||
| 
								 | 
							
													return '';
							 | 
						|||
| 
								 | 
							
												else
							 | 
						|||
| 
								 | 
							
													return node.getChild( 0 ).getText();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Defines the onChange event for UI element definitions.
							 | 
						|||
| 
								 | 
							
											 * @property {Object}
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											eventProcessors: commonEventProcessors
							 | 
						|||
| 
								 | 
							
										}, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										/** @class CKEDITOR.ui.dialog.button */
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.button.prototype = CKEDITOR.tools.extend( new CKEDITOR.ui.dialog.uiElement, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Simulates a click to the button.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {Object} Return value of the `click` event.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											click: function() {
							 | 
						|||
| 
								 | 
							
												if ( !this._.disabled )
							 | 
						|||
| 
								 | 
							
													return this.fire( 'click', { dialog: this._.dialog } );
							 | 
						|||
| 
								 | 
							
												return false;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Enables the button.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											enable: function() {
							 | 
						|||
| 
								 | 
							
												this._.disabled = false;
							 | 
						|||
| 
								 | 
							
												var element = this.getElement();
							 | 
						|||
| 
								 | 
							
												element && element.removeClass( 'cke_disabled' );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Disables the button.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											disable: function() {
							 | 
						|||
| 
								 | 
							
												this._.disabled = true;
							 | 
						|||
| 
								 | 
							
												this.getElement().addClass( 'cke_disabled' );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * @todo
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											isVisible: function() {
							 | 
						|||
| 
								 | 
							
												return this.getElement().getFirst().isVisible();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * @todo
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											isEnabled: function() {
							 | 
						|||
| 
								 | 
							
												return !this._.disabled;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Defines the onChange event and onClick for button element definitions.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @property {Object}
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											eventProcessors: CKEDITOR.tools.extend( {}, CKEDITOR.ui.dialog.uiElement.prototype.eventProcessors, {
							 | 
						|||
| 
								 | 
							
												onClick: function( dialog, func ) {
							 | 
						|||
| 
								 | 
							
													this.on( 'click', function() {
							 | 
						|||
| 
								 | 
							
														func.apply( this, arguments );
							 | 
						|||
| 
								 | 
							
													} );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											}, true ),
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Handler for the element's access key up event. Simulates a click to
							 | 
						|||
| 
								 | 
							
											 * the button.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											accessKeyUp: function() {
							 | 
						|||
| 
								 | 
							
												this.click();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Handler for the element's access key down event. Simulates a mouse
							 | 
						|||
| 
								 | 
							
											 * down to the button.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											accessKeyDown: function() {
							 | 
						|||
| 
								 | 
							
												this.focus();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											keyboardFocusable: true
							 | 
						|||
| 
								 | 
							
										}, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										/** @class CKEDITOR.ui.dialog.textInput */
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.textInput.prototype = CKEDITOR.tools.extend( new CKEDITOR.ui.dialog.labeledElement, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Gets the text input DOM element under this UI object.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.dom.element} The DOM element of the text input.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getInputElement: function() {
							 | 
						|||
| 
								 | 
							
												return CKEDITOR.document.getById( this._.inputId );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Puts focus into the text input.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											focus: function() {
							 | 
						|||
| 
								 | 
							
												var me = this.selectParentTab();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// GECKO BUG: setTimeout() is needed to workaround invisible selections.
							 | 
						|||
| 
								 | 
							
												setTimeout( function() {
							 | 
						|||
| 
								 | 
							
													var element = me.getInputElement();
							 | 
						|||
| 
								 | 
							
													element && element.$.focus();
							 | 
						|||
| 
								 | 
							
												}, 0 );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Selects all the text in the text input.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											select: function() {
							 | 
						|||
| 
								 | 
							
												var me = this.selectParentTab();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// GECKO BUG: setTimeout() is needed to workaround invisible selections.
							 | 
						|||
| 
								 | 
							
												setTimeout( function() {
							 | 
						|||
| 
								 | 
							
													var e = me.getInputElement();
							 | 
						|||
| 
								 | 
							
													if ( e ) {
							 | 
						|||
| 
								 | 
							
														e.$.focus();
							 | 
						|||
| 
								 | 
							
														e.$.select();
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
												}, 0 );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Handler for the text input's access key up event. Makes a `select()`
							 | 
						|||
| 
								 | 
							
											 * call to the text input.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											accessKeyUp: function() {
							 | 
						|||
| 
								 | 
							
												this.select();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Sets the value of this text input object.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 *		uiElement.setValue( 'Blamo' );
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Object} value The new value.
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.ui.dialog.textInput} The current UI element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											setValue: function( value ) {
							 | 
						|||
| 
								 | 
							
												!value && ( value = '' );
							 | 
						|||
| 
								 | 
							
												return CKEDITOR.ui.dialog.uiElement.prototype.setValue.apply( this, arguments );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											keyboardFocusable: true
							 | 
						|||
| 
								 | 
							
										}, commonPrototype, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.textarea.prototype = new CKEDITOR.ui.dialog.textInput();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										/** @class CKEDITOR.ui.dialog.select */
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.select.prototype = CKEDITOR.tools.extend( new CKEDITOR.ui.dialog.labeledElement, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Gets the DOM element of the select box.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.dom.element} The `<select>` element of this UI element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getInputElement: function() {
							 | 
						|||
| 
								 | 
							
												return this._.select.getElement();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Adds an option to the select box.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {String} label Option label.
							 | 
						|||
| 
								 | 
							
											 * @param {String} value (Optional) Option value, if not defined it'll be
							 | 
						|||
| 
								 | 
							
											 * assumed to be the same as the label.
							 | 
						|||
| 
								 | 
							
											 * @param {Number} index (Optional) Position of the option to be inserted
							 | 
						|||
| 
								 | 
							
											 * to. If not defined the new option will be inserted to the end of list.
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.ui.dialog.select} The current select UI element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											add: function( label, value, index ) {
							 | 
						|||
| 
								 | 
							
												var option = new CKEDITOR.dom.element( 'option', this.getDialog().getParentEditor().document ),
							 | 
						|||
| 
								 | 
							
													selectElement = this.getInputElement().$;
							 | 
						|||
| 
								 | 
							
												option.$.text = label;
							 | 
						|||
| 
								 | 
							
												option.$.value = ( value === undefined || value === null ) ? label : value;
							 | 
						|||
| 
								 | 
							
												if ( index === undefined || index === null ) {
							 | 
						|||
| 
								 | 
							
													if ( CKEDITOR.env.ie )
							 | 
						|||
| 
								 | 
							
														selectElement.add( option.$ );
							 | 
						|||
| 
								 | 
							
													else
							 | 
						|||
| 
								 | 
							
														selectElement.add( option.$, null );
							 | 
						|||
| 
								 | 
							
												} else
							 | 
						|||
| 
								 | 
							
													selectElement.add( option.$, index );
							 | 
						|||
| 
								 | 
							
												return this;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Removes an option from the selection list.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Number} index Index of the option to be removed.
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.ui.dialog.select} The current select UI element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											remove: function( index ) {
							 | 
						|||
| 
								 | 
							
												var selectElement = this.getInputElement().$;
							 | 
						|||
| 
								 | 
							
												selectElement.remove( index );
							 | 
						|||
| 
								 | 
							
												return this;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Clears all options out of the selection list.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.ui.dialog.select} The current select UI element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											clear: function() {
							 | 
						|||
| 
								 | 
							
												var selectElement = this.getInputElement().$;
							 | 
						|||
| 
								 | 
							
												while ( selectElement.length > 0 )
							 | 
						|||
| 
								 | 
							
													selectElement.remove( 0 );
							 | 
						|||
| 
								 | 
							
												return this;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											keyboardFocusable: true
							 | 
						|||
| 
								 | 
							
										}, commonPrototype, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										/** @class CKEDITOR.ui.dialog.checkbox */
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.checkbox.prototype = CKEDITOR.tools.extend( new CKEDITOR.ui.dialog.uiElement, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Gets the checkbox DOM element.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.dom.element} The DOM element of the checkbox.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getInputElement: function() {
							 | 
						|||
| 
								 | 
							
												return this._.checkbox.getElement();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Sets the state of the checkbox.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {Boolean} checked `true` to tick the checkbox, `false` to untick it.
							 | 
						|||
| 
								 | 
							
											 * @param {Boolean} noChangeEvent Internal commit, to supress `change` event on this element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											setValue: function( checked, noChangeEvent ) {
							 | 
						|||
| 
								 | 
							
												this.getInputElement().$.checked = checked;
							 | 
						|||
| 
								 | 
							
												!noChangeEvent && this.fire( 'change', { value: checked } );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Gets the state of the checkbox.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {Boolean} true means the checkbox is ticked, false means it's not ticked.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getValue: function() {
							 | 
						|||
| 
								 | 
							
												return this.getInputElement().$.checked;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Handler for the access key up event. Toggles the checkbox.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											accessKeyUp: function() {
							 | 
						|||
| 
								 | 
							
												this.setValue( !this.getValue() );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Defines the onChange event for UI element definitions.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @property {Object}
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											eventProcessors: {
							 | 
						|||
| 
								 | 
							
												onChange: function( dialog, func ) {
							 | 
						|||
| 
								 | 
							
													if ( !CKEDITOR.env.ie || ( CKEDITOR.env.version > 8 ) )
							 | 
						|||
| 
								 | 
							
														return commonEventProcessors.onChange.apply( this, arguments );
							 | 
						|||
| 
								 | 
							
													else {
							 | 
						|||
| 
								 | 
							
														dialog.on( 'load', function() {
							 | 
						|||
| 
								 | 
							
															var element = this._.checkbox.getElement();
							 | 
						|||
| 
								 | 
							
															element.on( 'propertychange', function( evt ) {
							 | 
						|||
| 
								 | 
							
																evt = evt.data.$;
							 | 
						|||
| 
								 | 
							
																if ( evt.propertyName == 'checked' )
							 | 
						|||
| 
								 | 
							
																	this.fire( 'change', { value: element.$.checked } );
							 | 
						|||
| 
								 | 
							
															}, this );
							 | 
						|||
| 
								 | 
							
														}, this );
							 | 
						|||
| 
								 | 
							
														this.on( 'change', func );
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
													return null;
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											keyboardFocusable: true
							 | 
						|||
| 
								 | 
							
										}, commonPrototype, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										/** @class CKEDITOR.ui.dialog.radio */
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.radio.prototype = CKEDITOR.tools.extend( new CKEDITOR.ui.dialog.uiElement, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Checks one of the radio buttons in this button group.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @param {String} value The value of the button to be chcked.
							 | 
						|||
| 
								 | 
							
											 * @param {Boolean} noChangeEvent Internal commit, to supress `change` event on this element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											setValue: function( value, noChangeEvent ) {
							 | 
						|||
| 
								 | 
							
												var children = this._.children,
							 | 
						|||
| 
								 | 
							
													item;
							 | 
						|||
| 
								 | 
							
												for ( var i = 0;
							 | 
						|||
| 
								 | 
							
												( i < children.length ) && ( item = children[ i ] ); i++ )
							 | 
						|||
| 
								 | 
							
													item.getElement().$.checked = ( item.getValue() == value );
							 | 
						|||
| 
								 | 
							
												!noChangeEvent && this.fire( 'change', { value: value } );
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Gets the value of the currently checked radio button.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {String} The currently checked button's value.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getValue: function() {
							 | 
						|||
| 
								 | 
							
												var children = this._.children;
							 | 
						|||
| 
								 | 
							
												for ( var i = 0; i < children.length; i++ ) {
							 | 
						|||
| 
								 | 
							
													if ( children[ i ].getElement().$.checked )
							 | 
						|||
| 
								 | 
							
														return children[ i ].getValue();
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
												return null;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Handler for the access key up event. Focuses the currently
							 | 
						|||
| 
								 | 
							
											 * selected radio button, or the first radio button if none is selected.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											accessKeyUp: function() {
							 | 
						|||
| 
								 | 
							
												var children = this._.children,
							 | 
						|||
| 
								 | 
							
													i;
							 | 
						|||
| 
								 | 
							
												for ( i = 0; i < children.length; i++ ) {
							 | 
						|||
| 
								 | 
							
													if ( children[ i ].getElement().$.checked ) {
							 | 
						|||
| 
								 | 
							
														children[ i ].getElement().focus();
							 | 
						|||
| 
								 | 
							
														return;
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
												children[ 0 ].getElement().focus();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Defines the onChange event for UI element definitions.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @property {Object}
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											eventProcessors: {
							 | 
						|||
| 
								 | 
							
												onChange: function( dialog, func ) {
							 | 
						|||
| 
								 | 
							
													if ( !CKEDITOR.env.ie )
							 | 
						|||
| 
								 | 
							
														return commonEventProcessors.onChange.apply( this, arguments );
							 | 
						|||
| 
								 | 
							
													else {
							 | 
						|||
| 
								 | 
							
														dialog.on( 'load', function() {
							 | 
						|||
| 
								 | 
							
															var children = this._.children,
							 | 
						|||
| 
								 | 
							
																me = this;
							 | 
						|||
| 
								 | 
							
															for ( var i = 0; i < children.length; i++ ) {
							 | 
						|||
| 
								 | 
							
																var element = children[ i ].getElement();
							 | 
						|||
| 
								 | 
							
																element.on( 'propertychange', function( evt ) {
							 | 
						|||
| 
								 | 
							
																	evt = evt.data.$;
							 | 
						|||
| 
								 | 
							
																	if ( evt.propertyName == 'checked' && this.$.checked )
							 | 
						|||
| 
								 | 
							
																		me.fire( 'change', { value: this.getAttribute( 'value' ) } );
							 | 
						|||
| 
								 | 
							
																} );
							 | 
						|||
| 
								 | 
							
															}
							 | 
						|||
| 
								 | 
							
														}, this );
							 | 
						|||
| 
								 | 
							
														this.on( 'change', func );
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
													return null;
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											}
							 | 
						|||
| 
								 | 
							
										}, commonPrototype, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										/** @class CKEDITOR.ui.dialog.file */
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.file.prototype = CKEDITOR.tools.extend( new CKEDITOR.ui.dialog.labeledElement, commonPrototype, {
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Gets the `<input>` element of this file input.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.dom.element} The file input element.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getInputElement: function() {
							 | 
						|||
| 
								 | 
							
												var frameDocument = CKEDITOR.document.getById( this._.frameId ).getFrameDocument();
							 | 
						|||
| 
								 | 
							
												return frameDocument.$.forms.length > 0 ? new CKEDITOR.dom.element( frameDocument.$.forms[ 0 ].elements[ 0 ] ) : this.getElement();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Uploads the file in the file input.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {CKEDITOR.ui.dialog.file} This object.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											submit: function() {
							 | 
						|||
| 
								 | 
							
												this.getInputElement().getParent().$.submit();
							 | 
						|||
| 
								 | 
							
												return this;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Get the action assigned to the form.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @returns {String} The value of the action.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											getAction: function() {
							 | 
						|||
| 
								 | 
							
												return this.getInputElement().getParent().$.action;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * The events must be applied on the inner input element, and
							 | 
						|||
| 
								 | 
							
											 * that must be done when the iframe & form has been loaded.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											registerEvents: function( definition ) {
							 | 
						|||
| 
								 | 
							
												var regex = /^on([A-Z]\w+)/,
							 | 
						|||
| 
								 | 
							
													match;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												var registerDomEvent = function( uiElement, dialog, eventName, func ) {
							 | 
						|||
| 
								 | 
							
														uiElement.on( 'formLoaded', function() {
							 | 
						|||
| 
								 | 
							
															uiElement.getInputElement().on( eventName, func, uiElement );
							 | 
						|||
| 
								 | 
							
														} );
							 | 
						|||
| 
								 | 
							
													};
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												for ( var i in definition ) {
							 | 
						|||
| 
								 | 
							
													if ( !( match = i.match( regex ) ) )
							 | 
						|||
| 
								 | 
							
														continue;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													if ( this.eventProcessors[ i ] )
							 | 
						|||
| 
								 | 
							
														this.eventProcessors[ i ].call( this, this._.dialog, definition[ i ] );
							 | 
						|||
| 
								 | 
							
													else
							 | 
						|||
| 
								 | 
							
														registerDomEvent( this, this._.dialog, match[ 1 ].toLowerCase(), definition[ i ] );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												return this;
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Redraws the file input and resets the file path in the file input.
							 | 
						|||
| 
								 | 
							
											 * The redraw logic is necessary because non-IE browsers tend to clear
							 | 
						|||
| 
								 | 
							
											 * the `<iframe>` containing the file input after closing the dialog.
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											reset: function() {
							 | 
						|||
| 
								 | 
							
												var _ = this._,
							 | 
						|||
| 
								 | 
							
													frameElement = CKEDITOR.document.getById( _.frameId ),
							 | 
						|||
| 
								 | 
							
													frameDocument = frameElement.getFrameDocument(),
							 | 
						|||
| 
								 | 
							
													elementDefinition = _.definition,
							 | 
						|||
| 
								 | 
							
													buttons = _.buttons,
							 | 
						|||
| 
								 | 
							
													callNumber = this.formLoadedNumber,
							 | 
						|||
| 
								 | 
							
													unloadNumber = this.formUnloadNumber,
							 | 
						|||
| 
								 | 
							
													langDir = _.dialog._.editor.lang.dir,
							 | 
						|||
| 
								 | 
							
													langCode = _.dialog._.editor.langCode;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// The callback function for the iframe, but we must call tools.addFunction only once
							 | 
						|||
| 
								 | 
							
												// so we store the function number in this.formLoadedNumber
							 | 
						|||
| 
								 | 
							
												if ( !callNumber ) {
							 | 
						|||
| 
								 | 
							
													callNumber = this.formLoadedNumber = CKEDITOR.tools.addFunction( function() {
							 | 
						|||
| 
								 | 
							
														// Now we can apply the events to the input type=file
							 | 
						|||
| 
								 | 
							
														this.fire( 'formLoaded' );
							 | 
						|||
| 
								 | 
							
													}, this );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													// Remove listeners attached to the content of the iframe (the file input)
							 | 
						|||
| 
								 | 
							
													unloadNumber = this.formUnloadNumber = CKEDITOR.tools.addFunction( function() {
							 | 
						|||
| 
								 | 
							
														this.getInputElement().clearCustomData();
							 | 
						|||
| 
								 | 
							
													}, this );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													this.getDialog()._.editor.on( 'destroy', function() {
							 | 
						|||
| 
								 | 
							
														CKEDITOR.tools.removeFunction( callNumber );
							 | 
						|||
| 
								 | 
							
														CKEDITOR.tools.removeFunction( unloadNumber );
							 | 
						|||
| 
								 | 
							
													} );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												function generateFormField() {
							 | 
						|||
| 
								 | 
							
													frameDocument.$.open();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													var size = '';
							 | 
						|||
| 
								 | 
							
													if ( elementDefinition.size )
							 | 
						|||
| 
								 | 
							
														size = elementDefinition.size - ( CKEDITOR.env.ie ? 7 : 0 ); // "Browse" button is bigger in IE.
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													var inputId = _.frameId + '_input';
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													frameDocument.$.write( [
							 | 
						|||
| 
								 | 
							
														'<html dir="' + langDir + '" lang="' + langCode + '"><head><title></title></head><body style="margin: 0; overflow: hidden; background: transparent;">',
							 | 
						|||
| 
								 | 
							
															'<form enctype="multipart/form-data" method="POST" dir="' + langDir + '" lang="' + langCode + '" action="',
							 | 
						|||
| 
								 | 
							
																CKEDITOR.tools.htmlEncode( elementDefinition.action ),
							 | 
						|||
| 
								 | 
							
															'">',
							 | 
						|||
| 
								 | 
							
																// Replicate the field label inside of iframe.
							 | 
						|||
| 
								 | 
							
																'<label id="', _.labelId, '" for="', inputId, '" style="display:none">',
							 | 
						|||
| 
								 | 
							
																	CKEDITOR.tools.htmlEncode( elementDefinition.label ),
							 | 
						|||
| 
								 | 
							
																'</label>',
							 | 
						|||
| 
								 | 
							
																// Set width to make sure that input is not clipped by the iframe (#11253).
							 | 
						|||
| 
								 | 
							
																'<input style="width:100%" id="', inputId, '" aria-labelledby="', _.labelId, '" type="file" name="',
							 | 
						|||
| 
								 | 
							
																	CKEDITOR.tools.htmlEncode( elementDefinition.id || 'cke_upload' ),
							 | 
						|||
| 
								 | 
							
																	'" size="',
							 | 
						|||
| 
								 | 
							
																	CKEDITOR.tools.htmlEncode( size > 0 ? size : "" ),
							 | 
						|||
| 
								 | 
							
																'" />',
							 | 
						|||
| 
								 | 
							
															'</form>',
							 | 
						|||
| 
								 | 
							
														'</body></html>',
							 | 
						|||
| 
								 | 
							
														'<script>',
							 | 
						|||
| 
								 | 
							
															// Support for custom document.domain in IE.
							 | 
						|||
| 
								 | 
							
															CKEDITOR.env.ie ? '(' + CKEDITOR.tools.fixDomain + ')();' : '',
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
															'window.parent.CKEDITOR.tools.callFunction(' + callNumber + ');',
							 | 
						|||
| 
								 | 
							
															'window.onbeforeunload = function() {window.parent.CKEDITOR.tools.callFunction(' + unloadNumber + ')}',
							 | 
						|||
| 
								 | 
							
														'</script>'
							 | 
						|||
| 
								 | 
							
													].join( '' ) );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													frameDocument.$.close();
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													for ( var i = 0; i < buttons.length; i++ )
							 | 
						|||
| 
								 | 
							
														buttons[ i ].enable();
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
												// #3465: Wait for the browser to finish rendering the dialog first.
							 | 
						|||
| 
								 | 
							
												if ( CKEDITOR.env.gecko )
							 | 
						|||
| 
								 | 
							
													setTimeout( generateFormField, 500 );
							 | 
						|||
| 
								 | 
							
												else
							 | 
						|||
| 
								 | 
							
													generateFormField();
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											getValue: function() {
							 | 
						|||
| 
								 | 
							
												return this.getInputElement().$.value || '';
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/***
							 | 
						|||
| 
								 | 
							
											 * The default value of input `type="file"` is an empty string, but during initialization
							 | 
						|||
| 
								 | 
							
											 * of this UI element, the iframe still isn't ready so it can't be read from that object
							 | 
						|||
| 
								 | 
							
											 * Setting it manually prevents later issues about the current value (`''`) being different
							 | 
						|||
| 
								 | 
							
											 * of the initial value (undefined as it asked for `.value` of a div).
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											setInitValue: function() {
							 | 
						|||
| 
								 | 
							
												this._.initValue = '';
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											/**
							 | 
						|||
| 
								 | 
							
											 * Defines the onChange event for UI element definitions.
							 | 
						|||
| 
								 | 
							
											 *
							 | 
						|||
| 
								 | 
							
											 * @property {Object}
							 | 
						|||
| 
								 | 
							
											 */
							 | 
						|||
| 
								 | 
							
											eventProcessors: {
							 | 
						|||
| 
								 | 
							
												onChange: function( dialog, func ) {
							 | 
						|||
| 
								 | 
							
													// If this method is called several times (I'm not sure about how this can happen but the default
							 | 
						|||
| 
								 | 
							
													// onChange processor includes this protection)
							 | 
						|||
| 
								 | 
							
													// In order to reapply to the new element, the property is deleted at the beggining of the registerEvents method
							 | 
						|||
| 
								 | 
							
													if ( !this._.domOnChangeRegistered ) {
							 | 
						|||
| 
								 | 
							
														// By listening for the formLoaded event, this handler will get reapplied when a new
							 | 
						|||
| 
								 | 
							
														// form is created
							 | 
						|||
| 
								 | 
							
														this.on( 'formLoaded', function() {
							 | 
						|||
| 
								 | 
							
															this.getInputElement().on( 'change', function() {
							 | 
						|||
| 
								 | 
							
																this.fire( 'change', { value: this.getValue() } );
							 | 
						|||
| 
								 | 
							
															}, this );
							 | 
						|||
| 
								 | 
							
														}, this );
							 | 
						|||
| 
								 | 
							
														this._.domOnChangeRegistered = true;
							 | 
						|||
| 
								 | 
							
													}
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
													this.on( 'change', func );
							 | 
						|||
| 
								 | 
							
												}
							 | 
						|||
| 
								 | 
							
											},
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
											keyboardFocusable: true
							 | 
						|||
| 
								 | 
							
										}, true );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.fileButton.prototype = new CKEDITOR.ui.dialog.button;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										CKEDITOR.ui.dialog.fieldset.prototype = CKEDITOR.tools.clone( CKEDITOR.ui.dialog.hbox.prototype );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'text', textBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'password', textBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'textarea', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'checkbox', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'radio', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'button', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'select', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'file', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'fileButton', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'html', commonBuilder );
							 | 
						|||
| 
								 | 
							
										CKEDITOR.dialog.addUIElement( 'fieldset', containerBuilder );
							 | 
						|||
| 
								 | 
							
									}
							 | 
						|||
| 
								 | 
							
								} );
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								/**
							 | 
						|||
| 
								 | 
							
								 * Fired when the value of the uiElement is changed.
							 | 
						|||
| 
								 | 
							
								 *
							 | 
						|||
| 
								 | 
							
								 * @event change
							 | 
						|||
| 
								 | 
							
								 * @member CKEDITOR.ui.dialog.uiElement
							 | 
						|||
| 
								 | 
							
								 */
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								/**
							 | 
						|||
| 
								 | 
							
								 * Fired when the inner frame created by the element is ready.
							 | 
						|||
| 
								 | 
							
								 * Each time the button is used or the dialog is loaded a new
							 | 
						|||
| 
								 | 
							
								 * form might be created.
							 | 
						|||
| 
								 | 
							
								 *
							 | 
						|||
| 
								 | 
							
								 * @event formLoaded
							 | 
						|||
| 
								 | 
							
								 * @member CKEDITOR.ui.dialog.fileButton
							 | 
						|||
| 
								 | 
							
								 */
							 |