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