X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/3f5685912e89eb3b0534acd85aa0946b1ca2bbe3..refs/tags/wordpress-3.3:/wp-admin/js/editor.dev.js diff --git a/wp-admin/js/editor.dev.js b/wp-admin/js/editor.dev.js index ce6f835d..37c79278 100644 --- a/wp-admin/js/editor.dev.js +++ b/wp-admin/js/editor.dev.js @@ -1,46 +1,87 @@ -jQuery(document).ready(function($){ - var h = wpCookies.getHash('TinyMCE_content_size'); - - if ( getUserSetting( 'editor' ) == 'html' ) { - if ( h ) - $('#content').css('height', h.ch - 15 + 'px'); - } else { - if ( typeof tinyMCE != 'object' ) { - $('#content').css('color', '#000'); - } else { - $('#quicktags').hide(); +var switchEditors = { + + switchto: function(el) { + var aid = el.id, l = aid.length, id = aid.substr(0, l - 5), mode = aid.substr(l - 4); + + this.go(id, mode); + }, + + go: function(id, mode) { // mode can be 'html', 'tmce', or 'toggle' + id = id || 'content'; + mode = mode || 'toggle'; + + var t = this, ed = tinyMCE.get(id), wrap_id, txtarea_el, dom = tinymce.DOM; + + wrap_id = 'wp-'+id+'-wrap'; + txtarea_el = dom.get(id); + + if ( 'toggle' == mode ) { + if ( ed && !ed.isHidden() ) + mode = 'html'; + else + mode = 'tmce'; } - } -}); -var switchEditors = { + if ( 'tmce' == mode || 'tinymce' == mode ) { + if ( ed && ! ed.isHidden() ) + return false; + + if ( typeof(QTags) != 'undefined' ) + QTags.closeAllTags(id); - mode : '', + if ( tinyMCEPreInit.mceInit[id] && tinyMCEPreInit.mceInit[id].wpautop ) + txtarea_el.value = t.wpautop( txtarea_el.value ); - I : function(e) { - return document.getElementById(e); + if ( ed ) { + ed.show(); + } else { + ed = new tinymce.Editor(id, tinyMCEPreInit.mceInit[id]); + ed.render(); + } + + dom.removeClass(wrap_id, 'html-active'); + dom.addClass(wrap_id, 'tmce-active'); + setUserSetting('editor', 'tinymce'); + + } else if ( 'html' == mode ) { + + if ( ed && ed.isHidden() ) + return false; + + if ( ed ) { + txtarea_el.style.height = ed.getContentAreaContainer().offsetHeight + 20 + 'px'; + ed.hide(); + } + + dom.removeClass(wrap_id, 'tmce-active'); + dom.addClass(wrap_id, 'html-active'); + setUserSetting('editor', 'html'); + } + return false; }, _wp_Nop : function(content) { var blocklist1, blocklist2; // 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, ''); - }); + if ( content.indexOf(']*>[\s\S]+?<\/\1>/g, function(a) { + a = a.replace(/
(\r\n|\n)?/g, ''); + return a.replace(/<\/?p( [^>]*)?>(\r\n|\n)?/g, ''); + }); + } // Pretty it up for the source editor blocklist1 = 'blockquote|ul|ol|li|table|thead|tbody|tfoot|tr|th|td|div|h[1-6]|p|fieldset'; content = content.replace(new RegExp('\\s*\\s*', 'g'), '\n'); - content = content.replace(new RegExp('\\s*<(('+blocklist1+')[^>]*)>', 'g'), '\n<$1>'); + content = content.replace(new RegExp('\\s*<((?:'+blocklist1+')(?: [^>]*)?)>', 'g'), '\n<$1>'); // Mark

if it has any attributes. content = content.replace(/(

]+>.*?)<\/p>/g, '$1'); // Sepatate

containing

- content = content.replace(/]*)>\s*

/gi, '\n\n'); + content = content.replace(/]*)?>\s*

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

and
content = content.replace(/\s*

/gi, ''); @@ -55,10 +96,14 @@ var switchEditors = { content = content.replace(/caption\]\n\n+\[caption/g, 'caption]\n\n[caption'); blocklist2 = 'blockquote|ul|ol|li|table|thead|tbody|tfoot|tr|th|td|h[1-6]|pre|fieldset'; - content = content.replace(new RegExp('\\s*<(('+blocklist2+') ?[^>]*)\\s*>', 'g'), '\n<$1>'); + content = content.replace(new RegExp('\\s*<((?:'+blocklist2+')(?: [^>]*)?)\\s*>', 'g'), '\n<$1>'); content = content.replace(new RegExp('\\s*\\s*', 'g'), '\n'); content = content.replace(/]*)>/g, '\t'); + if ( content.indexOf(']*)?>\s*/g, '\n\n\n\n'); + } + if ( content.indexOf('/g, function(a){ return a.replace(/[\r\n]+/g, ''); @@ -79,57 +124,8 @@ var switchEditors = { return content; }, - go : function(id, mode) { - id = id || 'content'; - mode = mode || this.mode || ''; - - var ed, qt = this.I('quicktags'), H = this.I('edButtonHTML'), P = this.I('edButtonPreview'), ta = this.I(id); - - try { ed = tinyMCE.get(id); } - catch(e) { ed = false; } - - if ( 'tinymce' == mode ) { - if ( ed && ! ed.isHidden() ) - return false; - - setUserSetting( 'editor', 'tinymce' ); - this.mode = 'html'; - - P.className = 'active'; - H.className = ''; - edCloseAllTags(); // :-( - qt.style.display = 'none'; - - ta.style.color = '#FFF'; - ta.value = this.wpautop(ta.value); - - try { - if ( ed ) - ed.show(); - else - tinyMCE.execCommand("mceAddControl", false, id); - } catch(e) {} - - ta.style.color = '#000'; - } else { - setUserSetting( 'editor', 'html' ); - ta.style.color = '#000'; - this.mode = 'tinymce'; - H.className = 'active'; - P.className = ''; - - if ( ed && !ed.isHidden() ) { - ta.style.height = ed.getContentAreaContainer().offsetHeight + 24 + 'px'; - ed.hide(); - } - - qt.style.display = 'block'; - } - return false; - }, - _wp_Autop : function(pee) { - var blocklist = 'table|thead|tfoot|caption|col|colgroup|tbody|tr|td|th|div|dl|dd|dt|ul|ol|li|pre|select|form|blockquote|address|math|p|h[1-6]|fieldset|legend'; + var blocklist = 'table|thead|tfoot|tbody|tr|td|th|caption|col|colgroup|div|dl|dd|dt|ul|ol|li|pre|select|form|blockquote|address|math|p|h[1-6]|fieldset|legend|hr|noscript|menu|samp|header|footer|article|section|hgroup|nav|aside|details|summary'; if ( pee.indexOf('/g, function(a){ @@ -141,56 +137,70 @@ var switchEditors = { return a.replace(/[\r\n]+/g, ' '); }); + // Protect pre|script tags + if ( pee.indexOf(']*>[\s\S]+?<\/\1>/g, function(a) { + return a.replace(/(\r\n|\n)/g, ''); + }); + } + pee = pee + '\n\n'; pee = pee.replace(/
\s*
/gi, '\n\n'); - pee = pee.replace(new RegExp('(<(?:'+blocklist+')[^>]*>)', 'gi'), '\n$1'); + pee = pee.replace(new RegExp('(<(?:'+blocklist+')(?: [^>]*)?>)', 'gi'), '\n$1'); pee = pee.replace(new RegExp('()', 'gi'), '$1\n\n'); + pee = pee.replace(/]*)?>/gi, '\n\n'); // hr is self closing block element pee = pee.replace(/\r\n|\r/g, '\n'); pee = pee.replace(/\n\s*\n+/g, '\n\n'); pee = pee.replace(/([\s\S]+?)\n\n/g, '

$1

\n'); pee = pee.replace(/

\s*?<\/p>/gi, ''); - pee = pee.replace(new RegExp('

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

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

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

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

(/gi, '$1'); pee = pee.replace(/

\s*]*)>/gi, '

'); pee = pee.replace(/<\/blockquote>\s*<\/p>/gi, '

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

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

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

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

', 'gi'), "$1"); pee = pee.replace(/\s*\n/gi, '
\n'); pee = pee.replace(new RegExp('(]*>)\\s*
', 'gi'), "$1"); pee = pee.replace(/
(\s*<\/?(?:p|li|div|dl|dd|dt|th|pre|td|ul|ol)>)/gi, '$1'); pee = pee.replace(/(?:

|
)*\s*\[caption([^\[]+)\[\/caption\]\s*(?:<\/p>|
)*/gi, '[caption$1[/caption]'); pee = pee.replace(/(<(?:div|th|td|form|fieldset|dd)[^>]*>)(.*?)<\/p>/g, function(a, b, c) { - if ( c.match(/]+)?>/) ) + if ( c.match(/]*)?>/) ) return a; return b + '

' + c + '

'; }); - // 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'); - }); + // put back the line breaks in pre|script + pee = pee.replace(//g, '\n'); return pee; }, pre_wpautop : function(content) { - var t = this, o = { o: t, data: content, unfiltered: content }; + var t = this, o = { o: t, data: content, unfiltered: content }, + q = typeof(jQuery) != 'undefined'; - jQuery('body').trigger('beforePreWpautop', [o]); + if ( q ) + jQuery('body').trigger('beforePreWpautop', [o]); o.data = t._wp_Nop(o.data); - jQuery('body').trigger('afterPreWpautop', [o]); + if ( q ) + jQuery('body').trigger('afterPreWpautop', [o]); + return o.data; }, wpautop : function(pee) { - var t = this, o = { o: t, data: pee, unfiltered: pee }; + var t = this, o = { o: t, data: pee, unfiltered: pee }, + q = typeof(jQuery) != 'undefined'; - jQuery('body').trigger('beforeWpautop', [o]); + if ( q ) + jQuery('body').trigger('beforeWpautop', [o]); o.data = t._wp_Autop(o.data); - jQuery('body').trigger('afterWpautop', [o]); + if ( q ) + jQuery('body').trigger('afterWpautop', [o]); + return o.data; } -}; +} +