TinyMCE windowManager打开带有翻译的HTML表单

时间:2016-03-14 05:58:32

标签: localization internationalization tinymce tinymce-4 tinymce-plugins

我正在将TinyMCE 3.x插件迁移到4.x

该插件使用由各个HTML文件定义的许多对话框。这些文件内部有国际化的字符串,例如,

<select id="reading" name="reading">
  <option value="corr">{#wce.correction}</option>
  <option value="comm">{#wce.commentary}</option>
  <option value="alt">{#wce.alternative}</option>
</select>

在TinyMCE 3.x中,似乎popup插件通过tinymce的翻译工具运行此内容,但使用4.x,调用:

tinymce.activeEditor.windowManager.open

字符串无法翻译。

有什么建议吗?

1 个答案:

答案 0 :(得分:1)

好的,所以看看3.x tinymce_popup代码,我已经抓住了相应的行,我现在正在我的对话框html文件中执行此操作:

$(document).ready(function() {
   translate();
 });
 function translate() {
   var c=document.body.innerHTML;
   var d=document.title;
   var a;
   if(top.tinymce.isIE){c=c.replace(/ (value|title|alt)=([^"][^\s>]+)/gi,' $1="$2"')}
   a=c.replace(/\{\#([^\}]+)\}/g, function(a, b) {
     var c=top.tinymce.translate(b); 
     return (c != b) ? c : '{#' + b + '}';
   });
   if(a!=c){document.body.innerHTML=a}
   a=d.replace(/\{\#([^\}]+)\}/g, function(a, b) {
     var c=top.tinymce.translate(b);
     return (c != b) ? c : '{#' + b + '}';
   });
   if(a!=d){document.title=d=a}
 }

我还必须编辑我的插件区域设置文件,以从字符串的注册中删除插件名称。例如,来自:

tinyMCE.addI18n('en.wce',{
  'key' : 'value',
  ...

tinymce.addI18n('en',{
  'key' : 'value',
  ...

和我所有的

 {#wce.tokens}

简单地

 {#tokens}

在我的HTML中。

这让我现在大部分都在工作。希望它对其他人有所帮助。