initial commit
[namibia] / public / scripts / ckeditor / _source / plugins / forms / dialogs / select.js
1 /*
2 Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved.
3 For licensing, see LICENSE.html or http://ckeditor.com/license
4 */
5 CKEDITOR.dialog.add( 'select', function( editor )
6 {
7         // Add a new option to a SELECT object (combo or list).
8         function addOption( combo, optionText, optionValue, documentObject, index )
9         {
10                 combo = getSelect( combo );
11                 var oOption;
12                 if ( documentObject )
13                         oOption = documentObject.createElement( "OPTION" );
14                 else
15                         oOption = document.createElement( "OPTION" );
16
17                 if ( combo && oOption && oOption.getName() == 'option' )
18                 {
19                         if ( CKEDITOR.env.ie ) {
20                                 if ( !isNaN( parseInt( index, 10) ) )
21                                         combo.$.options.add( oOption.$, index );
22                                 else
23                                         combo.$.options.add( oOption.$ );
24
25                                 oOption.$.innerHTML = optionText.length > 0 ? optionText : '';
26                                 oOption.$.value     = optionValue;
27                         }
28                         else
29                         {
30                                 if ( index !== null && index < combo.getChildCount() )
31                                         combo.getChild( index < 0 ? 0 : index ).insertBeforeMe( oOption );
32                                 else
33                                         combo.append( oOption );
34
35                                 oOption.setText( optionText.length > 0 ? optionText : '' );
36                                 oOption.setValue( optionValue );
37                         }
38                 }
39                 else
40                         return false;
41
42                 return oOption;
43         }
44         // Remove all selected options from a SELECT object.
45         function removeSelectedOptions( combo )
46         {
47                 combo = getSelect( combo );
48
49                 // Save the selected index
50                 var iSelectedIndex = getSelectedIndex( combo );
51
52                 // Remove all selected options.
53                 for ( var i = combo.getChildren().count() - 1 ; i >= 0 ; i-- )
54                 {
55                         if ( combo.getChild( i ).$.selected )
56                                 combo.getChild( i ).remove();
57                 }
58
59                 // Reset the selection based on the original selected index.
60                 setSelectedIndex( combo, iSelectedIndex );
61         }
62         //Modify option  from a SELECT object.
63         function modifyOption( combo, index, title, value )
64         {
65                 combo = getSelect( combo );
66                 if ( index < 0 )
67                         return false;
68                 var child = combo.getChild( index );
69                 child.setText( title );
70                 child.setValue( value );
71                 return child;
72         }
73         function removeAllOptions( combo )
74         {
75                 combo = getSelect( combo );
76                 while ( combo.getChild( 0 ) && combo.getChild( 0 ).remove() )
77                 { /*jsl:pass*/ }
78         }
79         // Moves the selected option by a number of steps (also negative).
80         function changeOptionPosition( combo, steps, documentObject )
81         {
82                 combo = getSelect( combo );
83                 var iActualIndex = getSelectedIndex( combo );
84                 if ( iActualIndex < 0 )
85                         return false;
86
87                 var iFinalIndex = iActualIndex + steps;
88                 iFinalIndex = ( iFinalIndex < 0 ) ? 0 : iFinalIndex;
89                 iFinalIndex = ( iFinalIndex >= combo.getChildCount() ) ? combo.getChildCount() - 1 : iFinalIndex;
90
91                 if ( iActualIndex == iFinalIndex )
92                         return false;
93
94                 var oOption = combo.getChild( iActualIndex ),
95                         sText   = oOption.getText(),
96                         sValue  = oOption.getValue();
97
98                 oOption.remove();
99
100                 oOption = addOption( combo, sText, sValue, ( !documentObject ) ? null : documentObject, iFinalIndex );
101                 setSelectedIndex( combo, iFinalIndex );
102                 return oOption;
103         }
104         function getSelectedIndex( combo )
105         {
106                 combo = getSelect( combo );
107                 return combo ? combo.$.selectedIndex : -1;
108         }
109         function setSelectedIndex( combo, index )
110         {
111                 combo = getSelect( combo );
112                 if ( index < 0 )
113                         return null;
114                 var count = combo.getChildren().count();
115                 combo.$.selectedIndex = ( index >= count ) ? ( count - 1 ) : index;
116                 return combo;
117         }
118         function getOptions( combo )
119         {
120                 combo = getSelect( combo );
121                 return combo ? combo.getChildren() : false;
122         }
123         function getSelect( obj )
124         {
125                 if ( obj && obj.domId && obj.getInputElement().$ )                              // Dialog element.
126                         return  obj.getInputElement();
127                 else if ( obj && obj.$ )
128                         return obj;
129                 return false;
130         }
131
132         return {
133                 title : editor.lang.select.title,
134                 minWidth : CKEDITOR.env.ie ? 460 : 395,
135                 minHeight : CKEDITOR.env.ie ? 320 : 300,
136                 onShow : function()
137                 {
138                         delete this.selectBox;
139                         this.setupContent( 'clear' );
140                         var element = this.getParentEditor().getSelection().getSelectedElement();
141                         if ( element && element.getName() == "select" )
142                         {
143                                 this.selectBox = element;
144                                 this.setupContent( element.getName(), element );
145
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 ) );
150                         }
151                 },
152                 onOk : function()
153                 {
154                         var editor = this.getParentEditor(),
155                                 element = this.selectBox,
156                                 isInsertMode = !element;
157
158                         if ( isInsertMode )
159                                 element = editor.document.createElement( 'select' );
160                         this.commitContent( element );
161
162                         if ( isInsertMode )
163                         {
164                                 editor.insertElement( element );
165                                 if ( CKEDITOR.env.ie )
166                                 {
167                                         var sel = editor.getSelection(),
168                                                 bms = sel.createBookmarks();
169                                         setTimeout(function()
170                                         {
171                                                 sel.selectBookmarks( bms );
172                                         }, 0 );
173                                 }
174                         }
175                 },
176                 contents : [
177                         {
178                                 id : 'info',
179                                 label : editor.lang.select.selectInfo,
180                                 title : editor.lang.select.selectInfo,
181                                 accessKey : '',
182                                 elements : [
183                                         {
184                                                 id : 'txtName',
185                                                 type : 'text',
186                                                 widths : [ '25%','75%' ],
187                                                 labelLayout : 'horizontal',
188                                                 label : editor.lang.common.name,
189                                                 'default' : '',
190                                                 accessKey : 'N',
191                                                 style : 'width:350px',
192                                                 setup : function( name, element )
193                                                 {
194                                                         if ( name == 'clear' )
195                                                                 this.setValue( this[ 'default' ] || '' );
196                                                         else if ( name == 'select' )
197                                                         {
198                                                                 this.setValue(
199                                                                                 element.data( 'cke-saved-name' ) ||
200                                                                                 element.getAttribute( 'name' ) ||
201                                                                                 '' );
202                                                         }
203                                                 },
204                                                 commit : function( element )
205                                                 {
206                                                         if ( this.getValue() )
207                                                                 element.data( 'cke-saved-name', this.getValue() );
208                                                         else
209                                                         {
210                                                                 element.data( 'cke-saved-name', false );
211                                                                 element.removeAttribute( 'name' );
212                                                         }
213                                                 }
214                                         },
215                                         {
216                                                 id : 'txtValue',
217                                                 type : 'text',
218                                                 widths : [ '25%','75%' ],
219                                                 labelLayout : 'horizontal',
220                                                 label : editor.lang.select.value,
221                                                 style : 'width:350px',
222                                                 'default' : '',
223                                                 className : 'cke_disabled',
224                                                 onLoad : function()
225                                                 {
226                                                         this.getInputElement().setAttribute( 'readOnly', true );
227                                                 },
228                                                 setup : function( name, element )
229                                                 {
230                                                         if ( name == 'clear' )
231                                                                 this.setValue( '' );
232                                                         else if ( name == 'option' && element.getAttribute( 'selected' ) )
233                                                                 this.setValue( element.$.value );
234                                                 }
235                                         },
236                                         {
237                                                 type : 'hbox',
238                                                 widths : [ '175px', '170px' ],
239                                                 children :
240                                                 [
241                                                         {
242                                                                 id : 'txtSize',
243                                                                 type : 'text',
244                                                                 labelLayout : 'horizontal',
245                                                                 label : editor.lang.select.size,
246                                                                 'default' : '',
247                                                                 accessKey : 'S',
248                                                                 style : 'width:175px',
249                                                                 validate: function()
250                                                                 {
251                                                                         var func = CKEDITOR.dialog.validate.integer( editor.lang.common.validateNumberFailed );
252                                                                         return ( ( this.getValue() === '' ) || func.apply( this ) );
253                                                                 },
254                                                                 setup : function( name, element )
255                                                                 {
256                                                                         if ( name == 'select' )
257                                                                                 this.setValue( element.getAttribute( 'size' ) || '' );
258                                                                         if ( CKEDITOR.env.webkit )
259                                                                                 this.getInputElement().setStyle( 'width', '86px' );
260                                                                 },
261                                                                 commit : function( element )
262                                                                 {
263                                                                         if ( this.getValue() )
264                                                                                 element.setAttribute( 'size', this.getValue() );
265                                                                         else
266                                                                                 element.removeAttribute( 'size' );
267                                                                 }
268                                                         },
269                                                         {
270                                                                 type : 'html',
271                                                                 html : '<span>' + CKEDITOR.tools.htmlEncode( editor.lang.select.lines ) + '</span>'
272                                                         }
273                                                 ]
274                                         },
275                                         {
276                                                 type : 'html',
277                                                 html : '<span>' + CKEDITOR.tools.htmlEncode( editor.lang.select.opAvail ) + '</span>'
278                                         },
279                                         {
280                                                 type : 'hbox',
281                                                 widths : [ '115px', '115px' ,'100px' ],
282                                                 children :
283                                                 [
284                                                         {
285                                                                 type : 'vbox',
286                                                                 children :
287                                                                 [
288                                                                         {
289                                                                                 id : 'txtOptName',
290                                                                                 type : 'text',
291                                                                                 label : editor.lang.select.opText,
292                                                                                 style : 'width:115px',
293                                                                                 setup : function( name, element )
294                                                                                 {
295                                                                                         if ( name == 'clear' )
296                                                                                                 this.setValue( "" );
297                                                                                 }
298                                                                         },
299                                                                         {
300                                                                                 type : 'select',
301                                                                                 id : 'cmbName',
302                                                                                 label : '',
303                                                                                 title : '',
304                                                                                 size : 5,
305                                                                                 style : 'width:115px;height:75px',
306                                                                                 items : [],
307                                                                                 onChange : function()
308                                                                                 {
309                                                                                         var dialog = this.getDialog(),
310                                                                                                 values = dialog.getContentElement( 'info', 'cmbValue' ),
311                                                                                                 optName = dialog.getContentElement( 'info', 'txtOptName' ),
312                                                                                                 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
313                                                                                                 iIndex = getSelectedIndex( this );
314
315                                                                                         setSelectedIndex( values, iIndex );
316                                                                                         optName.setValue( this.getValue() );
317                                                                                         optValue.setValue( values.getValue() );
318                                                                                 },
319                                                                                 setup : function( name, element )
320                                                                                 {
321                                                                                         if ( name == 'clear' )
322                                                                                                 removeAllOptions( this );
323                                                                                         else if ( name == 'option' )
324                                                                                                 addOption( this, element.getText(), element.getText(),
325                                                                                                         this.getDialog().getParentEditor().document );
326                                                                                 },
327                                                                                 commit : function( element )
328                                                                                 {
329                                                                                         var dialog = this.getDialog(),
330                                                                                                 optionsNames = getOptions( this ),
331                                                                                                 optionsValues = getOptions( dialog.getContentElement( 'info', 'cmbValue' ) ),
332                                                                                                 selectValue = dialog.getContentElement( 'info', 'txtValue' ).getValue();
333
334                                                                                         removeAllOptions( element );
335
336                                                                                         for ( var i = 0 ; i < optionsNames.count() ; i++ )
337                                                                                         {
338                                                                                                 var oOption = addOption( element, optionsNames.getItem( i ).getValue(),
339                                                                                                         optionsValues.getItem( i ).getValue(), dialog.getParentEditor().document );
340                                                                                                 if ( optionsValues.getItem( i ).getValue() == selectValue )
341                                                                                                 {
342                                                                                                         oOption.setAttribute( 'selected', 'selected' );
343                                                                                                         oOption.selected = true;
344                                                                                                 }
345                                                                                         }
346                                                                                 }
347                                                                         }
348                                                                 ]
349                                                         },
350                                                         {
351                                                                 type : 'vbox',
352                                                                 children :
353                                                                 [
354                                                                         {
355                                                                                 id : 'txtOptValue',
356                                                                                 type : 'text',
357                                                                                 label : editor.lang.select.opValue,
358                                                                                 style : 'width:115px',
359                                                                                 setup : function( name, element )
360                                                                                 {
361                                                                                         if ( name == 'clear' )
362                                                                                                 this.setValue( "" );
363                                                                                 }
364                                                                         },
365                                                                         {
366                                                                                 type : 'select',
367                                                                                 id : 'cmbValue',
368                                                                                 label : '',
369                                                                                 size : 5,
370                                                                                 style : 'width:115px;height:75px',
371                                                                                 items : [],
372                                                                                 onChange : function()
373                                                                                 {
374                                                                                         var dialog = this.getDialog(),
375                                                                                                 names = dialog.getContentElement( 'info', 'cmbName' ),
376                                                                                                 optName = dialog.getContentElement( 'info', 'txtOptName' ),
377                                                                                                 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
378                                                                                                 iIndex = getSelectedIndex( this );
379
380                                                                                         setSelectedIndex( names, iIndex );
381                                                                                         optName.setValue( names.getValue() );
382                                                                                         optValue.setValue( this.getValue() );
383                                                                                 },
384                                                                                 setup : function( name, element )
385                                                                                 {
386                                                                                         if ( name == 'clear' )
387                                                                                                 removeAllOptions( this );
388                                                                                         else if ( name == 'option' )
389                                                                                         {
390                                                                                                 var oValue      = element.getValue();
391                                                                                                 addOption( this, oValue, oValue,
392                                                                                                         this.getDialog().getParentEditor().document );
393                                                                                                 if ( element.getAttribute( 'selected' ) == 'selected' )
394                                                                                                         this.getDialog().getContentElement( 'info', 'txtValue' ).setValue( oValue );
395                                                                                         }
396                                                                                 }
397                                                                         }
398                                                                 ]
399                                                         },
400                                                         {
401                                                                 type : 'vbox',
402                                                                 padding : 5,
403                                                                 children :
404                                                                 [
405                                                                         {
406                                                                                 type : 'button',
407                                                                                 id : 'btnAdd',
408                                                                                 style : '',
409                                                                                 label : editor.lang.select.btnAdd,
410                                                                                 title : editor.lang.select.btnAdd,
411                                                                                 style : 'width:100%;',
412                                                                                 onClick : function()
413                                                                                 {
414                                                                                         //Add new option.
415                                                                                         var dialog = this.getDialog(),
416                                                                                                 parentEditor = dialog.getParentEditor(),
417                                                                                                 optName = dialog.getContentElement( 'info', 'txtOptName' ),
418                                                                                                 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
419                                                                                                 names = dialog.getContentElement( 'info', 'cmbName' ),
420                                                                                                 values = dialog.getContentElement( 'info', 'cmbValue' );
421
422                                                                                         addOption(names, optName.getValue(), optName.getValue(), dialog.getParentEditor().document );
423                                                                                         addOption(values, optValue.getValue(), optValue.getValue(), dialog.getParentEditor().document );
424
425                                                                                         optName.setValue( "" );
426                                                                                         optValue.setValue( "" );
427                                                                                 }
428                                                                         },
429                                                                         {
430                                                                                 type : 'button',
431                                                                                 id : 'btnModify',
432                                                                                 label : editor.lang.select.btnModify,
433                                                                                 title : editor.lang.select.btnModify,
434                                                                                 style : 'width:100%;',
435                                                                                 onClick : function()
436                                                                                 {
437                                                                                         //Modify selected option.
438                                                                                         var dialog = this.getDialog(),
439                                                                                                 optName = dialog.getContentElement( 'info', 'txtOptName' ),
440                                                                                                 optValue = dialog.getContentElement( 'info', 'txtOptValue' ),
441                                                                                                 names = dialog.getContentElement( 'info', 'cmbName' ),
442                                                                                                 values = dialog.getContentElement( 'info', 'cmbValue' ),
443                                                                                                 iIndex = getSelectedIndex( names );
444
445                                                                                         if ( iIndex >= 0 )
446                                                                                         {
447                                                                                                 modifyOption( names, iIndex, optName.getValue(), optName.getValue() );
448                                                                                                 modifyOption( values, iIndex, optValue.getValue(), optValue.getValue() );
449                                                                                         }
450                                                                                 }
451                                                                         },
452                                                                         {
453                                                                                 type : 'button',
454                                                                                 id : 'btnUp',
455                                                                                 style : 'width:100%;',
456                                                                                 label : editor.lang.select.btnUp,
457                                                                                 title : editor.lang.select.btnUp,
458                                                                                 onClick : function()
459                                                                                 {
460                                                                                         //Move up.
461                                                                                         var dialog = this.getDialog(),
462                                                                                                 names = dialog.getContentElement( 'info', 'cmbName' ),
463                                                                                                 values = dialog.getContentElement( 'info', 'cmbValue' );
464
465                                                                                         changeOptionPosition( names, -1, dialog.getParentEditor().document );
466                                                                                         changeOptionPosition( values, -1, dialog.getParentEditor().document );
467                                                                                 }
468                                                                         },
469                                                                         {
470                                                                                 type : 'button',
471                                                                                 id : 'btnDown',
472                                                                                 style : 'width:100%;',
473                                                                                 label : editor.lang.select.btnDown,
474                                                                                 title : editor.lang.select.btnDown,
475                                                                                 onClick : function()
476                                                                                 {
477                                                                                         //Move down.
478                                                                                         var dialog = this.getDialog(),
479                                                                                                 names = dialog.getContentElement( 'info', 'cmbName' ),
480                                                                                                 values = dialog.getContentElement( 'info', 'cmbValue' );
481
482                                                                                         changeOptionPosition( names, 1, dialog.getParentEditor().document );
483                                                                                         changeOptionPosition( values, 1, dialog.getParentEditor().document );
484                                                                                 }
485                                                                         }
486                                                                 ]
487                                                         }
488                                                 ]
489                                         },
490                                         {
491                                                 type : 'hbox',
492                                                 widths : [ '40%', '20%', '40%' ],
493                                                 children :
494                                                 [
495                                                         {
496                                                                 type : 'button',
497                                                                 id : 'btnSetValue',
498                                                                 label : editor.lang.select.btnSetValue,
499                                                                 title : editor.lang.select.btnSetValue,
500                                                                 onClick : function()
501                                                                 {
502                                                                         //Set as default value.
503                                                                         var dialog = this.getDialog(),
504                                                                                 values = dialog.getContentElement( 'info', 'cmbValue' ),
505                                                                                 txtValue = dialog.getContentElement( 'info', 'txtValue' );
506                                                                         txtValue.setValue( values.getValue() );
507                                                                 }
508                                                         },
509                                                         {
510                                                                 type : 'button',
511                                                                 id : 'btnDelete',
512                                                                 label : editor.lang.select.btnDelete,
513                                                                 title : editor.lang.select.btnDelete,
514                                                                 onClick : function()
515                                                                 {
516                                                                         // Delete option.
517                                                                         var dialog = this.getDialog(),
518                                                                                 names = dialog.getContentElement( 'info', 'cmbName' ),
519                                                                                 values = dialog.getContentElement( 'info', 'cmbValue' ),
520                                                                                 optName = dialog.getContentElement( 'info', 'txtOptName' ),
521                                                                                 optValue = dialog.getContentElement( 'info', 'txtOptValue' );
522
523                                                                         removeSelectedOptions( names );
524                                                                         removeSelectedOptions( values );
525
526                                                                         optName.setValue( "" );
527                                                                         optValue.setValue( "" );
528                                                                 }
529                                                         },
530                                                         {
531                                                                 id : 'chkMulti',
532                                                                 type : 'checkbox',
533                                                                 label : editor.lang.select.chkMulti,
534                                                                 'default' : '',
535                                                                 accessKey : 'M',
536                                                                 value : "checked",
537                                                                 setup : function( name, element )
538                                                                 {
539                                                                         if ( name == 'select' )
540                                                                                 this.setValue( element.getAttribute( 'multiple' ) );
541                                                                         if ( CKEDITOR.env.webkit )
542                                                                                 this.getElement().getParent().setStyle( 'vertical-align', 'middle' );
543                                                                 },
544                                                                 commit : function( element )
545                                                                 {
546                                                                         if ( this.getValue() )
547                                                                                 element.setAttribute( 'multiple', this.getValue() );
548                                                                         else
549                                                                                 element.removeAttribute( 'multiple' );
550                                                                 }
551                                                         }
552                                                 ]
553                                         }
554                                 ]
555                         }
556                 ]
557         };
558 });