2 Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved.
3 For licensing, see LICENSE.html or http://ckeditor.com/license
5 CKEDITOR.dialog.add( 'select', function( editor )
7 // Add a new option to a SELECT object (combo or list).
8 function addOption( combo, optionText, optionValue, documentObject, index )
10 combo = getSelect( combo );
13 oOption = documentObject.createElement( "OPTION" );
15 oOption = document.createElement( "OPTION" );
17 if ( combo && oOption && oOption.getName() == 'option' )
19 if ( CKEDITOR.env.ie ) {
20 if ( !isNaN( parseInt( index, 10) ) )
21 combo.$.options.add( oOption.$, index );
23 combo.$.options.add( oOption.$ );
25 oOption.$.innerHTML = optionText.length > 0 ? optionText : '';
26 oOption.$.value = optionValue;
30 if ( index !== null && index < combo.getChildCount() )
31 combo.getChild( index < 0 ? 0 : index ).insertBeforeMe( oOption );
33 combo.append( oOption );
35 oOption.setText( optionText.length > 0 ? optionText : '' );
36 oOption.setValue( optionValue );
44 // Remove all selected options from a SELECT object.
45 function removeSelectedOptions( combo )
47 combo = getSelect( combo );
49 // Save the selected index
50 var iSelectedIndex = getSelectedIndex( combo );
52 // Remove all selected options.
53 for ( var i = combo.getChildren().count() - 1 ; i >= 0 ; i-- )
55 if ( combo.getChild( i ).$.selected )
56 combo.getChild( i ).remove();
59 // Reset the selection based on the original selected index.
60 setSelectedIndex( combo, iSelectedIndex );
62 //Modify option from a SELECT object.
63 function modifyOption( combo, index, title, value )
65 combo = getSelect( combo );
68 var child = combo.getChild( index );
69 child.setText( title );
70 child.setValue( value );
73 function removeAllOptions( combo )
75 combo = getSelect( combo );
76 while ( combo.getChild( 0 ) && combo.getChild( 0 ).remove() )
79 // Moves the selected option by a number of steps (also negative).
80 function changeOptionPosition( combo, steps, documentObject )
82 combo = getSelect( combo );
83 var iActualIndex = getSelectedIndex( combo );
84 if ( iActualIndex < 0 )
87 var iFinalIndex = iActualIndex + steps;
88 iFinalIndex = ( iFinalIndex < 0 ) ? 0 : iFinalIndex;
89 iFinalIndex = ( iFinalIndex >= combo.getChildCount() ) ? combo.getChildCount() - 1 : iFinalIndex;
91 if ( iActualIndex == iFinalIndex )
94 var oOption = combo.getChild( iActualIndex ),
95 sText = oOption.getText(),
96 sValue = oOption.getValue();
100 oOption = addOption( combo, sText, sValue, ( !documentObject ) ? null : documentObject, iFinalIndex );
101 setSelectedIndex( combo, iFinalIndex );
104 function getSelectedIndex( combo )
106 combo = getSelect( combo );
107 return combo ? combo.$.selectedIndex : -1;
109 function setSelectedIndex( combo, index )
111 combo = getSelect( combo );
114 var count = combo.getChildren().count();
115 combo.$.selectedIndex = ( index >= count ) ? ( count - 1 ) : index;
118 function getOptions( combo )
120 combo = getSelect( combo );
121 return combo ? combo.getChildren() : false;
123 function getSelect( obj )
125 if ( obj && obj.domId && obj.getInputElement().$ ) // Dialog element.
126 return obj.getInputElement();
127 else if ( obj && obj.$ )
133 title : editor.lang.select.title,
134 minWidth : CKEDITOR.env.ie ? 460 : 395,
135 minHeight : CKEDITOR.env.ie ? 320 : 300,
138 delete this.selectBox;
139 this.setupContent( 'clear' );
140 var element = this.getParentEditor().getSelection().getSelectedElement();
141 if ( element && element.getName() == "select" )
143 this.selectBox = element;
144 this.setupContent( element.getName(), element );
146 // Load Options into dialog.
147 var objOptions = getOptions( element );
148 for ( var i = 0 ; i < objOptions.count() ; i++ )
149 this.setupContent( 'option', objOptions.getItem( i ) );
154 var editor = this.getParentEditor(),
155 element = this.selectBox,
156 isInsertMode = !element;
159 element = editor.document.createElement( 'select' );
160 this.commitContent( element );
164 editor.insertElement( element );
165 if ( CKEDITOR.env.ie )
167 var sel = editor.getSelection(),
168 bms = sel.createBookmarks();
169 setTimeout(function()
171 sel.selectBookmarks( bms );
179 label : editor.lang.select.selectInfo,
180 title : editor.lang.select.selectInfo,
186 widths : [ '25%','75%' ],
187 labelLayout : 'horizontal',
188 label : editor.lang.common.name,
192 style : 'width:350px',
193 setup : function( name, element )
195 if ( name == 'clear' )
196 this.setValue( this[ 'default' ] || '' );
197 else if ( name == 'select' )
200 element.data( 'cke-saved-name' ) ||
201 element.getAttribute( 'name' ) ||
205 commit : function( element )
207 if ( this.getValue() )
208 element.data( 'cke-saved-name', this.getValue() );
211 element.data( 'cke-saved-name', false );
212 element.removeAttribute( 'name' );
219 widths : [ '25%','75%' ],
220 labelLayout : 'horizontal',
221 label : editor.lang.select.value,
222 style : 'width:350px',
224 className : 'cke_disabled',
227 this.getInputElement().setAttribute( 'readOnly', true );
229 setup : function( name, element )
231 if ( name == 'clear' )
233 else if ( name == 'option' && element.getAttribute( 'selected' ) )
234 this.setValue( element.$.value );
239 widths : [ '175px', '170px' ],
247 labelLayout : 'horizontal',
248 label : editor.lang.select.size,
251 style : 'width:175px',
254 var func = CKEDITOR.dialog.validate.integer( editor.lang.common.validateNumberFailed );
255 return ( ( this.getValue() === '' ) || func.apply( this ) );
257 setup : function( name, element )
259 if ( name == 'select' )
260 this.setValue( element.getAttribute( 'size' ) || '' );
261 if ( CKEDITOR.env.webkit )
262 this.getInputElement().setStyle( 'width', '86px' );
264 commit : function( element )
266 if ( this.getValue() )
267 element.setAttribute( 'size', this.getValue() );
269 element.removeAttribute( 'size' );
274 html : '<span>' + CKEDITOR.tools.htmlEncode( editor.lang.select.lines ) + '</span>'
280 html : '<span>' + CKEDITOR.tools.htmlEncode( editor.lang.select.opAvail ) + '</span>'
284 widths : [ '115px', '115px' ,'100px' ],
295 label : editor.lang.select.opText,
296 style : 'width:115px',
297 setup : function( name, element )
299 if ( name == 'clear' )
309 style : 'width:115px;height:75px',
311 onChange : function()
313 var dialog = this.getDialog(),
314 values = dialog.getContentElement( 'info', 'cmbValue' ),
315 optName = dialog.getContentElement( 'info', 'txtOptName' ),
316 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
317 iIndex = getSelectedIndex( this );
319 setSelectedIndex( values, iIndex );
320 optName.setValue( this.getValue() );
321 optValue.setValue( values.getValue() );
323 setup : function( name, element )
325 if ( name == 'clear' )
326 removeAllOptions( this );
327 else if ( name == 'option' )
328 addOption( this, element.getText(), element.getText(),
329 this.getDialog().getParentEditor().document );
331 commit : function( element )
333 var dialog = this.getDialog(),
334 optionsNames = getOptions( this ),
335 optionsValues = getOptions( dialog.getContentElement( 'info', 'cmbValue' ) ),
336 selectValue = dialog.getContentElement( 'info', 'txtValue' ).getValue();
338 removeAllOptions( element );
340 for ( var i = 0 ; i < optionsNames.count() ; i++ )
342 var oOption = addOption( element, optionsNames.getItem( i ).getValue(),
343 optionsValues.getItem( i ).getValue(), dialog.getParentEditor().document );
344 if ( optionsValues.getItem( i ).getValue() == selectValue )
346 oOption.setAttribute( 'selected', 'selected' );
347 oOption.selected = true;
361 label : editor.lang.select.opValue,
362 style : 'width:115px',
363 setup : function( name, element )
365 if ( name == 'clear' )
374 style : 'width:115px;height:75px',
376 onChange : function()
378 var dialog = this.getDialog(),
379 names = dialog.getContentElement( 'info', 'cmbName' ),
380 optName = dialog.getContentElement( 'info', 'txtOptName' ),
381 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
382 iIndex = getSelectedIndex( this );
384 setSelectedIndex( names, iIndex );
385 optName.setValue( names.getValue() );
386 optValue.setValue( this.getValue() );
388 setup : function( name, element )
390 if ( name == 'clear' )
391 removeAllOptions( this );
392 else if ( name == 'option' )
394 var oValue = element.getValue();
395 addOption( this, oValue, oValue,
396 this.getDialog().getParentEditor().document );
397 if ( element.getAttribute( 'selected' ) == 'selected' )
398 this.getDialog().getContentElement( 'info', 'txtValue' ).setValue( oValue );
412 label : editor.lang.select.btnAdd,
413 title : editor.lang.select.btnAdd,
414 style : 'width:100%;',
418 var dialog = this.getDialog(),
419 parentEditor = dialog.getParentEditor(),
420 optName = dialog.getContentElement( 'info', 'txtOptName' ),
421 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
422 names = dialog.getContentElement( 'info', 'cmbName' ),
423 values = dialog.getContentElement( 'info', 'cmbValue' );
425 addOption(names, optName.getValue(), optName.getValue(), dialog.getParentEditor().document );
426 addOption(values, optValue.getValue(), optValue.getValue(), dialog.getParentEditor().document );
428 optName.setValue( "" );
429 optValue.setValue( "" );
434 label : editor.lang.select.btnModify,
435 title : editor.lang.select.btnModify,
436 style : 'width:100%;',
439 //Modify selected option.
440 var dialog = this.getDialog(),
441 optName = dialog.getContentElement( 'info', 'txtOptName' ),
442 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
443 names = dialog.getContentElement( 'info', 'cmbName' ),
444 values = dialog.getContentElement( 'info', 'cmbValue' ),
445 iIndex = getSelectedIndex( names );
449 modifyOption( names, iIndex, optName.getValue(), optName.getValue() );
450 modifyOption( values, iIndex, optValue.getValue(), optValue.getValue() );
456 style : 'width:100%;',
457 label : editor.lang.select.btnUp,
458 title : editor.lang.select.btnUp,
462 var dialog = this.getDialog(),
463 names = dialog.getContentElement( 'info', 'cmbName' ),
464 values = dialog.getContentElement( 'info', 'cmbValue' );
466 changeOptionPosition( names, -1, dialog.getParentEditor().document );
467 changeOptionPosition( values, -1, dialog.getParentEditor().document );
472 style : 'width:100%;',
473 label : editor.lang.select.btnDown,
474 title : editor.lang.select.btnDown,
478 var dialog = this.getDialog(),
479 names = dialog.getContentElement( 'info', 'cmbName' ),
480 values = dialog.getContentElement( 'info', 'cmbValue' );
482 changeOptionPosition( names, 1, dialog.getParentEditor().document );
483 changeOptionPosition( values, 1, dialog.getParentEditor().document );
492 widths : [ '40%', '20%', '40%' ],
497 label : editor.lang.select.btnSetValue,
498 title : editor.lang.select.btnSetValue,
501 //Set as default value.
502 var dialog = this.getDialog(),
503 values = dialog.getContentElement( 'info', 'cmbValue' ),
504 txtValue = dialog.getContentElement( 'info', 'txtValue' );
505 txtValue.setValue( values.getValue() );
510 label : editor.lang.select.btnDelete,
511 title : editor.lang.select.btnDelete,
515 var dialog = this.getDialog(),
516 names = dialog.getContentElement( 'info', 'cmbName' ),
517 values = dialog.getContentElement( 'info', 'cmbValue' ),
518 optName = dialog.getContentElement( 'info', 'txtOptName' ),
519 optValue = dialog.getContentElement( 'info', 'txtOptValue' );
521 removeSelectedOptions( names );
522 removeSelectedOptions( values );
524 optName.setValue( "" );
525 optValue.setValue( "" );
531 label : editor.lang.select.chkMulti,
535 setup : function( name, element )
537 if ( name == 'select' )
538 this.setValue( element.getAttribute( 'multiple' ) );
539 if ( CKEDITOR.env.webkit )
540 this.getElement().getParent().setStyle( 'vertical-align', 'middle' );
542 commit : function( element )
544 if ( this.getValue() )
545 element.setAttribute( 'multiple', this.getValue() );
547 element.removeAttribute( 'multiple' );