diff options
author | alecpl <alec@alec.pl> | 2008-11-03 14:26:23 +0000 |
---|---|---|
committer | alecpl <alec@alec.pl> | 2008-11-03 14:26:23 +0000 |
commit | 79af0bb1ba370bd5f194afb692e7ed59a26b02af (patch) | |
tree | 3b070c6afaa03e0a9d26d6afdaff8bc9d767b678 /program/js/app.js | |
parent | 3d54e6e9b7f65dcb01688d3933f7c6e4aac25a18 (diff) |
- Add warning when switching editor mode from html to plain (#1485488)
- Unified editor switching functions
Diffstat (limited to 'program/js/app.js')
-rw-r--r-- | program/js/app.js | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/program/js/app.js b/program/js/app.js index d8a7eed4b..5c258f93b 100644 --- a/program/js/app.js +++ b/program/js/app.js @@ -3622,24 +3622,34 @@ function rcube_webmail() this.enable_command('export', (this.contact_list.rowcount > 0)); }; - this.toggle_editor = function(checkbox, textAreaId) + this.toggle_editor = function(ishtml, textAreaId, flagElement) { - var ischecked = checkbox.checked; var composeElement = document.getElementById(textAreaId); - - if (ischecked) + var flag; + + if (ishtml) { var existingPlainText = composeElement.value; var htmlText = "<pre>" + existingPlainText + "</pre>"; + + 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'; } }; |