diff -r c72b545f1304 -r 67bd3121a12e includes/clientside/tinymce/plugins/visualchars/editor_plugin_src.js --- a/includes/clientside/tinymce/plugins/visualchars/editor_plugin_src.js Wed Dec 26 00:37:26 2007 -0500 +++ b/includes/clientside/tinymce/plugins/visualchars/editor_plugin_src.js Thu Dec 27 22:09:33 2007 -0500 @@ -1,89 +1,73 @@ /** - * $Id: editor_plugin_src.js 42 2006-08-08 14:32:24Z spocke $ + * $Id: editor_plugin_src.js 201 2007-02-12 15:56:56Z spocke $ * * @author Moxiecode * @copyright Copyright © 2004-2007, Moxiecode Systems AB, All rights reserved. */ -/* Import plugin specific language pack */ -tinyMCE.importPluginLanguagePack('visualchars'); +(function() { + tinymce.create('tinymce.plugins.VisualChars', { + init : function(ed, url) { + var t = this; -var TinyMCE_VisualCharsPlugin = { - getInfo : function() { - return { - longname : 'Visual characters', - author : 'Moxiecode Systems AB', - authorurl : 'http://tinymce.moxiecode.com', - infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/visualchars', - version : tinyMCE.majorVersion + "." + tinyMCE.minorVersion - }; - }, + t.editor = ed; - initInstance : function(inst) { - inst.visualChars = { - state : false - }; - }, + // Register commands + ed.addCommand('mceVisualChars', t._toggleVisualChars, t); + + // Register buttons + ed.addButton('visualchars', {title : 'visualchars.desc', cmd : 'mceVisualChars'}); - getControlHTML : function(cn) { - switch (cn) { - case "visualchars": - return tinyMCE.getButtonHTML(cn, 'lang_visualchars_desc', '{$pluginurl}/images/visualchars.gif', 'mceVisualChars', false); - } - - return ""; - }, + ed.onBeforeGetContent.add(function(ed, o) { + if (t.state) { + t.state = true; + t._toggleVisualChars(); + } + }); + }, - execCommand : function(editor_id, element, command, user_interface, value) { - var inst = tinyMCE.getInstanceById(editor_id); + getInfo : function() { + return { + longname : 'Visual characters', + author : 'Moxiecode Systems AB', + authorurl : 'http://tinymce.moxiecode.com', + infourl : 'http://wiki.moxiecode.com/index.php/TinyMCE:Plugins/visualchars', + version : tinymce.majorVersion + "." + tinymce.minorVersion + }; + }, - switch (command) { - case "mceVisualChars": - this._toggleVisualChars(editor_id, inst); - return true; - } - - return false; - }, + // Private methods - cleanup : function(type, content, inst) { - if (type == "insert_to_editor_dom" || type == "get_from_editor_dom") { - inst.visualChars.state = true; - this._toggleVisualChars(inst.editorId, inst); - } + _toggleVisualChars : function() { + var t = this, ed = t.editor, nl, i, h, d = ed.getDoc(), b = ed.getBody(), nv, s = ed.selection, bo; - return content; - }, + t.state = !t.state; + ed.controlManager.setActive('visualchars', t.state); - // Private plugin internal methods - - _toggleVisualChars : function(editor_id, inst) { - var nl, i, h, d = inst.getDoc(), b = inst.getBody(), nv, s = inst.selection, bo; - - inst.visualChars.state = !inst.visualChars.state; - - bo = s.getBookmark(true); - - tinyMCE.switchClass(editor_id + '_visualchars', inst.visualChars.state ? 'mceButtonSelected' : 'mceButtonNormal'); + if (t.state) { + nl = []; + tinymce.walk(b, function(n) { + if (n.nodeType == 3 && n.nodeValue && n.nodeValue.indexOf('\u00a0') != -1) + nl.push(n); + }, 'childNodes'); - if (inst.visualChars.state) { - nl = tinyMCE.selectNodes(b, function(n) {return n.nodeType == 3 && n.nodeValue && n.nodeValue.indexOf('\u00a0') != -1;}); + for (i=0; i$1'); + nv = nv.replace(/\u00a0/g, '\u00b7'); + ed.dom.setOuterHTML(nl[i], nv, d); + } + } else { + nl = tinymce.grep(ed.dom.select('span', b), function(n) { + return ed.dom.hasClass(n, 'mceItemHiddenVisualChar'); + }); - for (i=0; i$1'); - nv = nv.replace(/\u00a0/g, '\u00b7'); - tinyMCE.setOuterHTML(nl[i], nv, d); + for (i=0; i