switchEditors = { mode : '', I : function(e) { return document.getElementById(e); }, edInit : function() { var h = tinymce.util.Cookie.getHash("TinyMCE_content_size"), H = this.I('edButtonHTML'), P = this.I('edButtonPreview'); // Activate TinyMCE if it's the user's default editor if ( getUserSetting( 'editor' ) == 'html' ) { if ( h ) try { this.I('content').style.height = h.ch - 30 + 'px'; } catch(e){}; } else { try { this.I('editorcontainer').style.padding = '0px'; this.I("quicktags").style.display = "none"; } catch(e){}; tinyMCE.execCommand("mceAddControl", false, "content"); } }, saveCallback : function(el, content, body) { this.I(el).style.color = '#fff'; if ( tinyMCE.activeEditor.isHidden() ) content = this.I(el).value; else content = this.pre_wpautop(content); return content; }, pre_wpautop : function(content) { // We have a TON of cleanup to do. Line breaks are already stripped. // Protect pre|script tags content = content.replace(/<(pre|script)[^>]*>[\s\S]+?<\/\1>/g, function(a) { a = a.replace(/
[\r\n]*/g, ''); return a.replace(/<\/?p( [^>]*)?>[\r\n]*/g, ''); }); // Pretty it up for the source editor var blocklist1 = 'blockquote|ul|ol|li|table|thead|tbody|tr|th|td|div|h[1-6]|p'; content = content.replace(new RegExp('\\s*\\s*', 'mg'), '\n'); content = content.replace(new RegExp('\\s*<(('+blocklist1+')[^>]*)>', 'mg'), '\n<$1>'); // Mark

if it has any attributes. content = content.replace(new RegExp('(

]+>.*?)

', 'mg'), '$1'); // Sepatate
containing

content = content.replace(new RegExp(']*)>\\s*

', 'mgi'), '\n\n'); // Remove

and
content = content.replace(new RegExp('\\s*

', 'mgi'), ''); content = content.replace(new RegExp('\\s*

\\s*', 'mgi'), '\n\n'); content = content.replace(new RegExp('\\n\\s*\\n', 'mgi'), '\n\n'); content = content.replace(new RegExp('\\s*
\\s*', 'gi'), '\n'); // Fix some block element newline issues content = content.replace(new RegExp('\\s*\\s*', 'mg'), '
\n'); content = content.replace(new RegExp('\\s*\\[caption([^\\[]+)\\[/caption\\]\\s*', 'gi'), '\n\n[caption$1[/caption]\n\n'); content = content.replace(new RegExp('caption\\]\\n\\n+\\[caption', 'g'), 'caption]\n\n[caption'); var blocklist2 = 'blockquote|ul|ol|li|table|thead|tr|th|td|h[1-6]|pre'; content = content.replace(new RegExp('\\s*<(('+blocklist2+') ?[^>]*)\\s*>', 'mg'), '\n<$1>'); content = content.replace(new RegExp('\\s*\\s*', 'mg'), '\n'); content = content.replace(new RegExp(']*)>', 'g'), '\t'); if ( content.indexOf(']*)>\\s*', 'mg'), ""); content = content.replace(new RegExp('\\s*\\s*', 'mg'), ''); } // Unmark special paragraph closing tags content = content.replace(new RegExp('', 'g'), '

\n'); content = content.replace(new RegExp('\\s*(

]+>.*

)', 'mg'), '\n$1'); // Trim whitespace content = content.replace(new RegExp('^\\s*', ''), ''); content = content.replace(new RegExp('[\\s\\u00a0]*$', ''), ''); // put back the line breaks in pre|script content = content.replace(//g, '\n'); // Hope. return content; }, go : function(id, mode) { id = id || 'content'; mode = mode || this.mode || ''; var ed = tinyMCE.get(id) || false; var qt = this.I('quicktags'); var H = this.I('edButtonHTML'); var P = this.I('edButtonPreview'); var ta = this.I(id); var ec = (ta.parentNode && ta.parentNode.nodeName == 'DIV') ? ta.parentNode : ''; if ( 'tinymce' == mode ) { if ( ed && ! ed.isHidden() ) return false; this.mode = 'html'; ta.style.color = '#fff'; P.className = 'active'; H.className = ''; edCloseAllTags(); // :-( qt.style.display = 'none'; ta.style.padding = '0px'; if ( ec ) ec.style.padding = '0px'; ta.value = this.wpautop(ta.value); if ( ed ) ed.show(); else tinyMCE.execCommand("mceAddControl", false, id); setUserSetting( 'editor', 'tinymce' ); } else { if ( ! ed || ed.isHidden() ) return false; this.mode = 'tinymce'; H.className = 'active'; P.className = ''; ta.style.height = ed.getContentAreaContainer().offsetHeight + 6 + 'px'; ed.hide(); qt.style.display = 'block'; if ( tinymce.isIE6 ) { ta.style.width = '98%'; if ( ec ) ec.style.padding = '0px'; ta.style.padding = '6px'; } else { ta.style.width = '100%'; if ( ec ) ec.style.padding = '6px'; } ta.style.color = ''; setUserSetting( 'editor', 'html' ); } return false; }, wpautop : function(pee) { var blocklist = 'table|thead|tfoot|caption|colgroup|tbody|tr|td|th|div|dl|dd|dt|ul|ol|li|pre|select|form|blockquote|address|math|p|h[1-6]'; pee = pee + "\n\n"; pee = pee.replace(new RegExp('
\\s*
', 'gi'), "\n\n"); pee = pee.replace(new RegExp('(<(?:'+blocklist+')[^>]*>)', 'gi'), "\n$1"); pee = pee.replace(new RegExp('()', 'gi'), "$1\n\n"); pee = pee.replace(new RegExp("\\r\\n|\\r", 'g'), "\n"); pee = pee.replace(new RegExp("\\n\\s*\\n+", 'g'), "\n\n"); pee = pee.replace(new RegExp('([\\s\\S]+?)\\n\\n', 'mg'), "

$1

\n"); pee = pee.replace(new RegExp('

\\s*?

', 'gi'), ''); pee = pee.replace(new RegExp('

\\s*(]*>)\\s*

', 'gi'), "$1"); pee = pee.replace(new RegExp("

(", 'gi'), "$1"); pee = pee.replace(new RegExp('

\\s*]*)>', 'gi'), "

"); pee = pee.replace(new RegExp('\\s*

', 'gi'), '

'); pee = pee.replace(new RegExp('

\\s*(]*>)', 'gi'), "$1"); pee = pee.replace(new RegExp('(]*>)\\s*

', 'gi'), "$1"); pee = pee.replace(new RegExp('\\s*\\n', 'gi'), "
\n"); pee = pee.replace(new RegExp('(]*>)\\s*
', 'gi'), "$1"); pee = pee.replace(new RegExp('
(\\s*)', 'gi'), '$1'); pee = pee.replace(new RegExp('(?:

|
)*\\s*\\[caption([^\\[]+)\\[/caption\\]\\s*(?:

|
)*', 'gi'), '[caption$1[/caption]'); // pee = pee.replace(new RegExp('^((?: )*)\\s', 'mg'), '$1 '); // Fix the pre|script tags pee = pee.replace(/<(pre|script)[^>]*>[\s\S]+?<\/\1>/g, function(a) { a = a.replace(/
[\r\n]*/g, '\n'); return a.replace(/<\/?p( [^>]*)?>[\r\n]*/g, '\n'); }); return pee; } }