From b8ae5093cc08fc7684aa087fb9dc1ce97fd49f5d Mon Sep 17 00:00:00 2001 From: alecpl Date: Wed, 5 Nov 2008 10:19:44 +0000 Subject: - Fix HTML editor initialization on IE (#1485304) - move back toggle_editor function to editor.js - merge identity and compose editor init functions --- program/js/app.js | 43 +++++------------------ program/js/editor.js | 99 ++++++++++++++++++++++++++++++++++++++++------------ 2 files changed, 85 insertions(+), 57 deletions(-) (limited to 'program/js') diff --git a/program/js/app.js b/program/js/app.js index 5c258f93b..d22b1fbfb 100644 --- a/program/js/app.js +++ b/program/js/app.js @@ -434,8 +434,12 @@ function rcube_webmail() this.init_address_input_events(input_bcc); // add signature according to selected identity - if (input_from && input_from.type=='select-one' && (!draftid || draftid.value=='')) + if (input_from && input_from.type=='select-one' && (!draftid || draftid.value=='') + // if we have HTML editor, signature is added in callback + && rcube_find_object('_is_html').value != '1') + { this.change_identity(input_from); + } if (input_to && input_to.value=='') input_to.focus(); @@ -2007,7 +2011,7 @@ function rcube_webmail() { if (this.env.spellcheck) { // stop spellchecking process - if (!vis && !this.spellcheck_ready) + if (!vis) this.stop_spellchecking(); this.env.spellcheck.check_link.style.visibility = vis ? 'visible' : 'hidden'; @@ -3622,37 +3626,6 @@ function rcube_webmail() this.enable_command('export', (this.contact_list.rowcount > 0)); }; - this.toggle_editor = function(ishtml, textAreaId, flagElement) - { - var composeElement = document.getElementById(textAreaId); - var flag; - - if (ishtml) - { - var existingPlainText = composeElement.value; - var htmlText = "
" + existingPlainText + "
"; - - this.display_spellcheck_controls(false); - composeElement.value = htmlText; - tinyMCE.execCommand('mceAddControl', true, textAreaId); - if (flagElement && (flag = rcube_find_object(flagElement))) - flag.value = '1'; - } - else - { - if (!confirm(rcmail.get_label('editorwarning'))) - return false; - - var thisMCE = tinyMCE.get(textAreaId); - var existingHtml = thisMCE.getContent(); - this.html2plain(existingHtml, textAreaId); - tinyMCE.execCommand('mceRemoveControl', true, textAreaId); - this.display_spellcheck_controls(true); - if (flagElement && (flag = rcube_find_object(flagElement))) - flag.value = '0'; - } - }; - this.toggle_prefer_html = function(checkbox) { var addrbook_show_images; @@ -4150,10 +4123,10 @@ function rcube_http_request() } // end class rcube_http_request - // helper function to call the init method with a delay function call_init(o) { window.setTimeout('if (window[\''+o+'\'] && window[\''+o+'\'].init) { '+o+'.init(); }', - bw.win ? 500 : 200); + bw.win ? 500 : 200); } + diff --git a/program/js/editor.js b/program/js/editor.js index 179d089fc..a3f0d3492 100644 --- a/program/js/editor.js +++ b/program/js/editor.js @@ -13,28 +13,83 @@ $Id: editor.js 000 2006-05-18 19:12:28Z roundcube $ */ -// Initialize the message editor +// Initialize HTML editor +function rcmail_editor_init(skin_path, editor_lang, spellcheck, mode) +{ + if (mode == 'identity') + tinyMCE.init({ mode : 'textareas', + editor_selector : 'mce_editor', + apply_source_formatting : true, + theme : 'advanced', + language : editor_lang, + content_css : skin_path + '/editor_content.css', + theme_advanced_toolbar_location : 'top', + theme_advanced_toolbar_align : 'left', + theme_advanced_buttons1 : 'bold,italic,underline,strikethrough,justifyleft,justifycenter,justifyright,justifyfull,separator,outdent,indent,charmap,hr,link,unlink,code,forecolor', + theme_advanced_buttons2 : ',fontselect,fontsizeselect', + theme_advanced_buttons3 : '', + gecko_spellcheck : true + }); + else // mail compose + tinyMCE.init({ + mode : 'textareas', + editor_selector : 'mce_editor', + accessibility_focus : false, + apply_source_formatting : true, + theme : 'advanced', + language : editor_lang, + plugins : 'emotions,media,nonbreaking,table,searchreplace,visualchars,directionality' + (spellcheck ? ',spellchecker' : ''), + theme_advanced_buttons1 : 'bold,italic,underline,separator,justifyleft,justifycenter,justifyright,justifyfull,separator,bullist,numlist,outdent,indent,separator,link,unlink,emotions,charmap,code,forecolor,backcolor,fontselect,fontsizeselect, separator' + (spellcheck ? ',spellchecker' : '') + ',undo,redo,image,media,ltr,rtl', + theme_advanced_buttons2 : '', + theme_advanced_buttons3 : '', + theme_advanced_toolbar_location : 'top', + theme_advanced_toolbar_align : 'left', + extended_valid_elements : 'font[face|size|color|style],span[id|class|align|style]', + content_css : skin_path + '/editor_content.css', + external_image_list_url : 'program/js/editor_images.js', + spellchecker_languages : (rcmail.env.spellcheck_langs ? rcmail.env.spellcheck_langs : 'Dansk=da,Deutsch=de,+English=en,Espanol=es,Francais=fr,Italiano=it,Nederlands=nl,Polski=pl,Portugues=pt,Suomi=fi,Svenska=sv'), + gecko_spellcheck : true, + rc_client: rcube_webmail_client, + oninit : 'rcmail_editor_callback' + }); +} -function rcmail_editor_init(skin_path, editor_lang, spellcheck) +// react to real individual tinyMCE editor init +function rcmail_editor_callback(editor) { - tinyMCE.init({ - mode : "textareas", - editor_selector : "mce_editor", - accessibility_focus : false, - apply_source_formatting : true, - theme : "advanced", - language : editor_lang, - plugins : "emotions,media,nonbreaking,table,searchreplace,visualchars,directionality" + (spellcheck ? ",spellchecker" : ""), - theme_advanced_buttons1 : "bold,italic,underline,separator,justifyleft,justifycenter,justifyright,justifyfull,separator,bullist,numlist,outdent,indent,separator,link,unlink,emotions,charmap,code,forecolor,backcolor,fontselect,fontsizeselect, separator" + (spellcheck ? ",spellchecker" : "") + ",undo,redo,image,media,ltr,rtl", - theme_advanced_buttons2 : "", - theme_advanced_buttons3 : "", - theme_advanced_toolbar_location : "top", - theme_advanced_toolbar_align : "left", - extended_valid_elements : "font[face|size|color|style],span[id|class|align|style]", - content_css : skin_path + "/editor_content.css", - external_image_list_url : "program/js/editor_images.js", - spellchecker_languages : (rcmail.env.spellcheck_langs ? rcmail.env.spellcheck_langs : "Dansk=da,Deutsch=de,+English=en,Espanol=es,Francais=fr,Italiano=it,Nederlands=nl,Polski=pl,Portugues=pt,Suomi=fi,Svenska=sv"), - gecko_spellcheck : true, - rc_client: rcube_webmail_client - }); + var input_from = rcube_find_object('_from'); + if(input_from && input_from.type=='select-one') + rcmail.change_identity(input_from); } + +// switch html/plain mode +function rcmail_toggle_editor(ishtml, textAreaId, flagElement) +{ + var composeElement = document.getElementById(textAreaId); + var flag; + + if (ishtml) + { + var existingPlainText = composeElement.value; + var htmlText = "
" + existingPlainText + "
"; + + rcmail.display_spellcheck_controls(false); + composeElement.value = htmlText; + tinyMCE.execCommand('mceAddControl', true, textAreaId); + if (flagElement && (flag = rcube_find_object(flagElement))) + flag.value = '1'; + } + else + { + if (!confirm(rcmail.get_label('editorwarning'))) + return false; + + var thisMCE = tinyMCE.get(textAreaId); + var existingHtml = thisMCE.getContent(); + rcmail.html2plain(existingHtml, textAreaId); + tinyMCE.execCommand('mceRemoveControl', true, textAreaId); + rcmail.display_spellcheck_controls(true); + if (flagElement && (flag = rcube_find_object(flagElement))) + flag.value = '0'; + } +}; -- cgit v1.2.3