2 Copyright (c) 2003-2011, CKSource - Frederico Knabben. All rights reserved.
3 For licensing, see LICENSE.html or http://ckeditor.com/license
6 CKEDITOR
.dialog
.add( 'scaytcheck', function( editor
)
10 doc
= CKEDITOR
.document
,
11 editorName
= editor
.name
,
12 tags
= CKEDITOR
.plugins
.scayt
.getUiTabs( editor
),
17 // [0] contains buttons for creating
18 "dic_create_" + editorName
+ ",dic_restore_" + editorName
,
19 // [1] contains buton for manipulation
20 "dic_rename_" + editorName
+ ",dic_delete_" + editorName
22 optionsIds
= [ 'mixedCase', 'mixedWithDigits', 'allCaps', 'ignoreDomainNames' ];
26 function getBOMAllOptions()
28 if (typeof document
.forms
["optionsbar_" + editorName
] != "undefined")
29 return document
.forms
["optionsbar_" + editorName
]["options"];
32 function getBOMAllLangs()
34 if (typeof document
.forms
["languagesbar_" + editorName
] != "undefined")
35 return document
.forms
["languagesbar_" + editorName
]["scayt_lang"];
39 function setCheckedValue( radioObj
, newValue
)
43 var radioLength
= radioObj
.length
;
44 if ( radioLength
== undefined )
46 radioObj
.checked
= radioObj
.value
== newValue
.toString();
49 for ( var i
= 0; i
< radioLength
; i
++ )
51 radioObj
[i
].checked
= false;
52 if ( radioObj
[i
].value
== newValue
.toString() )
53 radioObj
[i
].checked
= true;
57 var lang
= editor
.lang
.scayt
;
61 label
: lang
.optionsTab
,
66 html
: '<form name="optionsbar_' + editorName
+ '"><div class="inner_options">' +
67 ' <div class="messagebox"></div>' +
68 ' <div style="display:none;">' +
69 ' <input type="checkbox" name="options" id="allCaps_' + editorName
+ '" />' +
70 ' <label for="allCaps" id="label_allCaps_' + editorName
+ '"></label>' +
72 ' <div style="display:none;">' +
73 ' <input name="options" type="checkbox" id="ignoreDomainNames_' + editorName
+ '" />' +
74 ' <label for="ignoreDomainNames" id="label_ignoreDomainNames_' + editorName
+ '"></label>' +
76 ' <div style="display:none;">' +
77 ' <input name="options" type="checkbox" id="mixedCase_' + editorName
+ '" />' +
78 ' <label for="mixedCase" id="label_mixedCase_' + editorName
+ '"></label>' +
80 ' <div style="display:none;">' +
81 ' <input name="options" type="checkbox" id="mixedWithDigits_' + editorName
+ '" />' +
82 ' <label for="mixedWithDigits" id="label_mixedWithDigits_' + editorName
+ '"></label>' +
90 label
: lang
.languagesTab
,
95 html
: '<form name="languagesbar_' + editorName
+ '"><div class="inner_langs">' +
96 ' <div class="messagebox"></div> ' +
97 ' <div style="float:left;width:45%;margin-left:5px;" id="scayt_lcol_' + editorName
+ '" ></div>' +
98 ' <div style="float:left;width:45%;margin-left:15px;" id="scayt_rcol_' + editorName
+ '"></div>' +
105 label
: lang
.dictionariesTab
,
111 html
: '<form name="dictionarybar_' + editorName
+ '"><div class="inner_dictionary" style="text-align:left; white-space:normal; width:320px; overflow: hidden;">' +
112 ' <div style="margin:5px auto; width:80%;white-space:normal; overflow:hidden;" id="dic_message_' + editorName
+ '"> </div>' +
113 ' <div style="margin:5px auto; width:80%;white-space:normal;"> ' +
114 ' <span class="cke_dialog_ui_labeled_label" >Dictionary name</span><br>'+
115 ' <span class="cke_dialog_ui_labeled_content" >'+
116 ' <div class="cke_dialog_ui_input_text">'+
117 ' <input id="dic_name_' + editorName
+ '" type="text" class="cke_dialog_ui_input_text"/>'+
118 ' </div></span></div>'+
119 ' <div style="margin:5px auto; width:80%;white-space:normal;">'+
120 ' <a style="display:none;" class="cke_dialog_ui_button" href="javascript:void(0)" id="dic_create_' + editorName
+ '">'+
122 ' <a style="display:none;" class="cke_dialog_ui_button" href="javascript:void(0)" id="dic_delete_' + editorName
+ '">'+
124 ' <a style="display:none;" class="cke_dialog_ui_button" href="javascript:void(0)" id="dic_rename_' + editorName
+ '">'+
126 ' <a style="display:none;" class="cke_dialog_ui_button" href="javascript:void(0)" id="dic_restore_' + editorName
+ '">'+
129 ' <div style="margin:5px auto; width:95%;white-space:normal;" id="dic_info_' + editorName
+ '"></div>' +
136 label
: lang
.aboutTab
,
141 style
: 'margin: 5px 5px;',
142 html
: '<div id="scayt_about_' + editorName
+ '"></div>'
148 var dialogDefiniton
= {
155 dialog
.data
= editor
.fire( 'scaytDialog', {} );
156 dialog
.options
= dialog
.data
.scayt_control
.option();
157 dialog
.chosed_lang
= dialog
.sLang
= dialog
.data
.scayt_control
.sLang
;
159 if ( !dialog
.data
|| !dialog
.data
.scayt
|| !dialog
.data
.scayt_control
)
161 alert( 'Error loading application service' );
169 dialog
.data
.scayt
.getCaption( editor
.langCode
|| 'en', function( caps
)
171 if ( stop
++ > 0 ) // Once only
174 init_with_captions
.apply( dialog
);
175 reload
.apply( dialog
);
180 reload
.apply( dialog
);
182 dialog
.selectPage( dialog
.data
.tab
);
186 var scayt_control
= this.data
.scayt_control
;
187 scayt_control
.option( this.options
);
188 // Setup language if it was changed.
189 var csLang
= this.chosed_lang
;
190 scayt_control
.setLang( csLang
);
191 scayt_control
.refresh();
195 var o
= getBOMAllOptions();
197 o
[i
].checked
= false;
199 setCheckedValue( getBOMAllLangs(), "" );
204 var scayt_control
= CKEDITOR
.plugins
.scayt
.getScayt( editor
);
206 for ( i
= 0; i
< tags
.length
; i
++ )
208 if ( tags
[ i
] == 1 )
209 contents
[ contents
.length
] = tags_contents
[ i
];
214 var init_with_captions = function()
217 lang_list
= dialog
.data
.scayt
.getLangList(),
218 buttonCaptions
= [ 'dic_create', 'dic_delete', 'dic_rename', 'dic_restore' ],
224 // Add buttons titles
227 for ( i
= 0; i
< buttonCaptions
.length
; i
++ )
229 buttonIds
[ i
] = buttonCaptions
[ i
] + "_" + editorName
;
230 doc
.getById( buttonIds
[ i
] ).setHtml( '<span class="cke_dialog_ui_button">' + captions
[ 'button_' + buttonCaptions
[ i
]] +'</span>' );
232 doc
.getById( 'dic_info_' + editorName
).setHtml( captions
[ 'dic_info' ] );
235 // Fill options and dictionary labels.
240 var labelCaption
= 'label_' + labels
[ i
],
241 labelId
= labelCaption
+ '_' + editorName
,
242 labelElement
= doc
.getById( labelId
);
244 if ( 'undefined' != typeof labelElement
245 && 'undefined' != typeof captions
[ labelCaption
]
246 && 'undefined' != typeof dialog
.options
[labels
[ i
]] )
248 labelElement
.setHtml( captions
[ labelCaption
] );
249 var labelParent
= labelElement
.getParent();
250 labelParent
.$.style
.display
= "block";
255 var about
= '<p><img src="' + window
.scayt
.getAboutInfo().logoURL
+ '" /></p>' +
256 '<p>' + captions
[ 'version' ] + window
.scayt
.getAboutInfo().version
.toString() + '</p>' +
257 '<p>' + captions
[ 'about_throwt_copy' ] + '</p>';
259 doc
.getById( 'scayt_about_' + editorName
).setHtml( about
);
261 // Create languages tab.
262 var createOption = function( option
, list
)
264 var label
= doc
.createElement( 'label' );
265 label
.setAttribute( 'for', 'cke_option' + option
);
266 label
.setHtml( list
[ option
] );
268 if ( dialog
.sLang
== option
) // Current.
269 dialog
.chosed_lang
= option
;
271 var div
= doc
.createElement( 'div' );
272 var radio
= CKEDITOR
.dom
.element
.createFromHtml( '<input id="cke_option' +
273 option
+ '" type="radio" ' +
274 ( dialog
.sLang
== option
? 'checked="checked"' : '' ) +
275 ' value="' + option
+ '" name="scayt_lang" />' );
277 radio
.on( 'click', function()
279 this.$.checked
= true;
280 dialog
.chosed_lang
= option
;
287 lang
: list
[ option
],
295 for ( i
in lang_list
.rtl
)
296 langList
[ langList
.length
] = createOption( i
, lang_list
.ltr
);
298 for ( i
in lang_list
.ltr
)
299 langList
[ langList
.length
] = createOption( i
, lang_list
.ltr
);
301 langList
.sort( function( lang1
, lang2
)
303 return ( lang2
.lang
> lang1
.lang
) ? -1 : 1 ;
306 var fieldL
= doc
.getById( 'scayt_lcol_' + editorName
),
307 fieldR
= doc
.getById( 'scayt_rcol_' + editorName
);
308 for ( i
=0; i
< langList
.length
; i
++ )
310 var field
= ( i
< langList
.length
/ 2 ) ? fieldL
: fieldR
;
311 field
.append( langList
[ i
].radio
);
315 // user dictionary handlers
317 dic
.dic_create = function( el
, dic_name
, dic_buttons
)
319 // comma separated button's ids include repeats if exists
320 var all_buttons
= dic_buttons
[0] + ',' + dic_buttons
[1];
322 var err_massage
= captions
["err_dic_create"];
323 var suc_massage
= captions
["succ_dic_create"];
325 window
.scayt
.createUserDictionary( dic_name
,
328 hide_dic_buttons ( all_buttons
);
329 display_dic_buttons ( dic_buttons
[1] );
330 suc_massage
= suc_massage
.replace("%s" , arg
.dname
);
331 dic_success_message (suc_massage
);
335 err_massage
= err_massage
.replace("%s" ,arg
.dname
);
336 dic_error_message ( err_massage
+ "( "+ (arg
.message
|| "") +")");
341 dic
.dic_rename = function( el
, dic_name
)
344 // try to rename dictionary
345 var err_massage
= captions
["err_dic_rename"] || "";
346 var suc_massage
= captions
["succ_dic_rename"] || "";
347 window
.scayt
.renameUserDictionary( dic_name
,
350 suc_massage
= suc_massage
.replace("%s" , arg
.dname
);
351 set_dic_name( dic_name
);
352 dic_success_message ( suc_massage
);
356 err_massage
= err_massage
.replace("%s" , arg
.dname
);
357 set_dic_name( dic_name
);
358 dic_error_message( err_massage
+ "( " + ( arg
.message
|| "" ) + " )" );
362 dic
.dic_delete = function( el
, dic_name
, dic_buttons
)
364 var all_buttons
= dic_buttons
[0] + ',' + dic_buttons
[1];
365 var err_massage
= captions
["err_dic_delete"];
366 var suc_massage
= captions
["succ_dic_delete"];
368 // try to delete dictionary
369 window
.scayt
.deleteUserDictionary(
372 suc_massage
= suc_massage
.replace("%s" , arg
.dname
);
373 hide_dic_buttons ( all_buttons
);
374 display_dic_buttons ( dic_buttons
[0] );
375 set_dic_name( "" ); // empty input field
376 dic_success_message( suc_massage
);
380 err_massage
= err_massage
.replace("%s" , arg
.dname
);
381 dic_error_message(err_massage
);
385 dic
.dic_restore
= dialog
.dic_restore
|| function( el
, dic_name
, dic_buttons
)
387 // try to restore existing dictionary
388 var all_buttons
= dic_buttons
[0] + ',' + dic_buttons
[1];
389 var err_massage
= captions
["err_dic_restore"];
390 var suc_massage
= captions
["succ_dic_restore"];
392 window
.scayt
.restoreUserDictionary(dic_name
,
395 suc_massage
= suc_massage
.replace("%s" , arg
.dname
);
396 hide_dic_buttons ( all_buttons
);
397 display_dic_buttons(dic_buttons
[1]);
398 dic_success_message( suc_massage
);
402 err_massage
= err_massage
.replace("%s" , arg
.dname
);
403 dic_error_message( err_massage
);
407 function onDicButtonClick( ev
)
409 var dic_name
= doc
.getById('dic_name_' + editorName
).getValue();
412 dic_error_message(" Dictionary name should not be empty. ");
416 var el
= ev
.data
.getTarget().getParent();
417 var id
= /(dic_\w+)_[\w\d]+/.exec(el
.getId())[1];
418 dic
[ id
].apply( null, [ el
, dic_name
, dic_buttons
] );
422 dic_error_message(" Dictionary error. ");
428 // ** bind event listeners
429 var arr_buttons
= ( dic_buttons
[0] + ',' + dic_buttons
[1] ).split( ',' ),
432 for ( i
= 0, l
= arr_buttons
.length
; i
< l
; i
+= 1 )
434 var dic_button
= doc
.getById(arr_buttons
[i
]);
436 dic_button
.on( 'click', onDicButtonClick
, this );
440 var reload = function()
443 // for enabled options tab
445 var opto
= getBOMAllOptions();
448 for ( var k
=0,l
= opto
.length
; k
<l
;k
++ )
452 var checkbox
= doc
.getById( i
);
456 opto
[k
].checked
= false;
457 //alert (opto[k].removeAttribute)
458 if ( dialog
.options
[ i
.split("_")[0] ] == 1 )
460 opto
[k
].checked
= true;
464 // Bind events. Do it only once.
467 checkbox
.on( 'click', function()
469 dialog
.options
[ this.getId().split("_")[0] ] = this.$.checked
? 1 : 0 ;
476 //for enabled languages tab
479 var domLang
= doc
.getById("cke_option" + dialog
.sLang
);
480 setCheckedValue( domLang
.$,dialog
.sLang
);
486 window
.scayt
.getNameUserDictionary(
489 var dic_name
= o
.dname
;
490 hide_dic_buttons( dic_buttons
[0] + ',' + dic_buttons
[1] );
493 doc
.getById( 'dic_name_' + editorName
).setValue(dic_name
);
494 display_dic_buttons( dic_buttons
[1] );
497 display_dic_buttons( dic_buttons
[0] );
502 doc
.getById( 'dic_name_' + editorName
).setValue("");
504 dic_success_message("");
509 function dic_error_message( m
)
511 doc
.getById('dic_message_' + editorName
).setHtml('<span style="color:red;">' + m
+ '</span>' );
513 function dic_success_message( m
)
515 doc
.getById('dic_message_' + editorName
).setHtml('<span style="color:blue;">' + m
+ '</span>') ;
517 function display_dic_buttons( sIds
)
519 sIds
= String( sIds
);
520 var aIds
= sIds
.split(',');
521 for ( var i
=0, l
= aIds
.length
; i
< l
; i
+=1)
522 doc
.getById( aIds
[i
] ).$.style
.display
= "inline";
524 function hide_dic_buttons( sIds
)
526 sIds
= String( sIds
);
527 var aIds
= sIds
.split(',');
528 for ( var i
= 0, l
= aIds
.length
; i
< l
; i
+= 1 )
529 doc
.getById( aIds
[i
] ).$.style
.display
= "none";
531 function set_dic_name( dic_name
)
533 doc
.getById('dic_name_' + editorName
).$.value
= dic_name
;
536 return dialogDefiniton
;