diff -r 2f6f6f7551ca -r 32102edaa81b web/wp-admin/js/editor.dev.js --- a/web/wp-admin/js/editor.dev.js Thu Sep 16 15:45:36 2010 +0000 +++ b/web/wp-admin/js/editor.dev.js Mon Nov 19 18:26:13 2012 +0100 @@ -1,46 +1,96 @@ - -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 = { - mode : '', + 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'; + } + + if ( 'tmce' == mode || 'tinymce' == mode ) { + if ( ed && ! ed.isHidden() ) + return false; + + if ( typeof(QTags) != 'undefined' ) + QTags.closeAllTags(id); - I : function(e) { - return document.getElementById(e); + if ( tinyMCEPreInit.mceInit[id] && tinyMCEPreInit.mceInit[id].wpautop ) + txtarea_el.value = t.wpautop( txtarea_el.value ); + + 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; + var blocklist1, blocklist2, preserve_linebreaks = false, preserve_br = false; // 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, ''); + }); + } + + // keep
tags inside captions and remove line breaks + if ( content.indexOf('[caption') != -1 ) { + preserve_br = true; + content = content.replace(/\[caption[\s\S]+?\[\/caption\]/g, function(a) { + return a.replace(/]*)>/g, '').replace(/[\r\n\t]+/, ''); + }); + } // 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 +105,14 @@ 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, ''); @@ -74,62 +128,19 @@ content = content.replace(/[\s\u00a0]+$/, ''); // put back the line breaks in pre|script - content = content.replace(//g, '\n'); + if ( preserve_linebreaks ) + content = content.replace(//g, '\n'); + + // and the
tags in captions + if ( preserve_br ) + content = content.replace(/]*)>/g, ''); 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 preserve_linebreaks = false, preserve_br = false, + 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 +152,89 @@ 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, ''); + }); + } + + // keep
tags inside captions and convert line breaks + if ( pee.indexOf('[caption') != -1 ) { + preserve_br = true; + pee = pee.replace(/\[caption[\s\S]+?\[\/caption\]/g, function(a) { + // keep existing
+ a = a.replace(/]*)>/g, ''); + // no line breaks inside HTML tags + a = a.replace(/<[a-zA-Z0-9]+( [^<>]+)?>/g, function(b){ + return b.replace(/[\r\n\t]+/, ' '); + }); + // convert remaining line breaks to
+ return a.replace(/\s*\n\s*/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 + if ( preserve_linebreaks ) + pee = pee.replace(//g, '\n'); + + if ( preserve_br ) + pee = pee.replace(/]*)>/g, ''); 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; } -}; +}