mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-09 18:08:09 +01:00
e2b4009e66
git-svn-id: http://svn.automattic.com/wordpress/trunk@8784 1a063a9b-81f0-0310-95a4-ce76da25c4cd
180 lines
6.5 KiB
JavaScript
180 lines
6.5 KiB
JavaScript
|
|
switchEditors = {
|
|
|
|
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', 'tinymce' ) == 'tinymce' ) {
|
|
try { P.onclick = ''; P.className = 'active'; } catch(e){};
|
|
try { this.I('editorcontainer').style.padding = '0px'; } catch(e){};
|
|
try { this.I("quicktags").style.display = "none"; } catch(e){};
|
|
tinyMCE.execCommand("mceAddControl", false, "content");
|
|
} else {
|
|
try { H.onclick = ''; H.className = 'active'; } catch(e){};
|
|
if ( h )
|
|
try { this.I('content').style.height = h.ch - 30 + 'px'; } catch(e){};
|
|
}
|
|
},
|
|
|
|
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(/<br ?\/?>[\r\n]*/g, '<wp_temp>');
|
|
return a.replace(/<\/?p( [^>]*)?>[\r\n]*/g, '<wp_temp>');
|
|
});
|
|
|
|
// 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*</('+blocklist1+')>\\s*', 'mg'), '</$1>\n');
|
|
content = content.replace(new RegExp('\\s*<(('+blocklist1+')[^>]*)>', 'mg'), '\n<$1>');
|
|
|
|
// Mark </p> if it has any attributes.
|
|
content = content.replace(new RegExp('(<p [^>]+>.*?)</p>', 'mg'), '$1</p#>');
|
|
|
|
// Sepatate <div> containing <p>
|
|
content = content.replace(new RegExp('<div([^>]*)>\\s*<p>', 'mgi'), '<div$1>\n\n');
|
|
|
|
// Remove <p> and <br />
|
|
content = content.replace(new RegExp('\\s*<p>', 'mgi'), '');
|
|
content = content.replace(new RegExp('\\s*</p>\\s*', 'mgi'), '\n\n');
|
|
content = content.replace(new RegExp('\\n\\s*\\n', 'mgi'), '\n\n');
|
|
content = content.replace(new RegExp('\\s*<br ?/?>\\s*', 'gi'), '\n');
|
|
|
|
// Fix some block element newline issues
|
|
content = content.replace(new RegExp('\\s*<div', 'mg'), '\n<div');
|
|
content = content.replace(new RegExp('</div>\\s*', 'mg'), '</div>\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*</('+blocklist2+')>\\s*', 'mg'), '</$1>\n');
|
|
content = content.replace(new RegExp('<li([^>]*)>', 'g'), '\t<li$1>');
|
|
|
|
if ( content.indexOf('<object') != -1 ) {
|
|
content = content.replace(new RegExp('\\s*<param([^>]*)>\\s*', 'mg'), "<param$1>");
|
|
content = content.replace(new RegExp('\\s*</embed>\\s*', 'mg'), '</embed>');
|
|
}
|
|
|
|
// Unmark special paragraph closing tags
|
|
content = content.replace(new RegExp('</p#>', 'g'), '</p>\n');
|
|
content = content.replace(new RegExp('\\s*(<p [^>]+>.*</p>)', '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(/<wp_temp>/g, '\n');
|
|
|
|
// Hope.
|
|
return content;
|
|
},
|
|
|
|
go : function(id) {
|
|
var ed = tinyMCE.get(id);
|
|
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 ( ! ed || ed.isHidden() ) {
|
|
ta.style.color = '#fff';
|
|
|
|
this.edToggle(P, H);
|
|
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 {
|
|
this.edToggle(H, P);
|
|
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' );
|
|
}
|
|
},
|
|
|
|
edToggle : function(A, B) {
|
|
A.className = 'active';
|
|
B.className = '';
|
|
|
|
B.onclick = A.onclick;
|
|
A.onclick = null;
|
|
},
|
|
|
|
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('<br />\\s*<br />', 'gi'), "\n\n");
|
|
pee = pee.replace(new RegExp('(<(?:'+blocklist+')[^>]*>)', 'gi'), "\n$1");
|
|
pee = pee.replace(new RegExp('(</(?:'+blocklist+')>)', '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'), "<p>$1</p>\n");
|
|
pee = pee.replace(new RegExp('<p>\\s*?</p>', 'gi'), '');
|
|
pee = pee.replace(new RegExp('<p>\\s*(</?(?:'+blocklist+')[^>]*>)\\s*</p>', 'gi'), "$1");
|
|
pee = pee.replace(new RegExp("<p>(<li.+?)</p>", 'gi'), "$1");
|
|
pee = pee.replace(new RegExp('<p>\\s*<blockquote([^>]*)>', 'gi'), "<blockquote$1><p>");
|
|
pee = pee.replace(new RegExp('</blockquote>\\s*</p>', 'gi'), '</p></blockquote>');
|
|
pee = pee.replace(new RegExp('<p>\\s*(</?(?:'+blocklist+')[^>]*>)', 'gi'), "$1");
|
|
pee = pee.replace(new RegExp('(</?(?:'+blocklist+')[^>]*>)\\s*</p>', 'gi'), "$1");
|
|
pee = pee.replace(new RegExp('\\s*\\n', 'gi'), "<br />\n");
|
|
pee = pee.replace(new RegExp('(</?(?:'+blocklist+')[^>]*>)\\s*<br />', 'gi'), "$1");
|
|
pee = pee.replace(new RegExp('<br />(\\s*</?(?:p|li|div|dl|dd|dt|th|pre|td|ul|ol)>)', 'gi'), '$1');
|
|
pee = pee.replace(new RegExp('(?:<p>|<br ?/?>)*\\s*\\[caption([^\\[]+)\\[/caption\\]\\s*(?:</p>|<br ?/?>)*', '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(/<br ?\/?>[\r\n]*/g, '\n');
|
|
return a.replace(/<\/?p( [^>]*)?>[\r\n]*/g, '\n');
|
|
});
|
|
|
|
return pee;
|
|
}
|
|
}
|