/** * The code of this function comes from the WordPress source code, * from file `wp-admin/js/editor.js`, so we can get 100% consistent results * with wp-admin. */ // Ensure the global `wp` object exists. window.wp = window.wp || {}; (function(){ /** * @brief Performs multiple transformations to the post source code when * loading, replacing newlines with pargraph elements. * * @param pee The string to transform * * @return Returns the transformed string */ wp.loadText = function( pee ) { if ( pee == null || !pee.trim() ) { // Just whitespace, null, or undefined return ''; } var preserve_linebreaks = false, preserve_br = false, blocklist = 'table|thead|tfoot|caption|col|colgroup|tbody|tr|td|th|div|dl|dd|dt|ul|ol|li|pre' + '|form|map|area|blockquote|address|math|style|p|h[1-6]|hr|fieldset|legend|section' + '|article|aside|hgroup|header|footer|nav|figure|details|menu|summary'; if ( pee.indexOf( '/g, function( a ) { return a.replace( /[\r\n]+/g, '' ); }); } pee = pee.replace( /<[^<>]+>/g, function( a ){ 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( '()', 'gi' ), '$1\n\n' ); pee = pee.replace( /]*)?>/gi, '\n\n' ); // hr is self closing block element pee = pee.replace( /\s*' ); 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( /

(/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( /\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( /]*)?>/ ) ) { return a; } return b + '

' + c + '

'; }); // 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; } }());