TinyMCE wpView: decode HTML entities before trying to match the wpView text string. Props iseulde. See #31412.

git-svn-id: https://develop.svn.wordpress.org/trunk@31689 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Ozz 2015-03-09 19:08:05 +00:00
parent 5bbb7dd80d
commit 64e63da3f6
1 changed files with 13 additions and 14 deletions

View File

@ -91,6 +91,7 @@ window.wp = window.wp || {};
setMarkers: function( content ) {
var pieces = [ { content: content } ],
self = this,
instance,
current;
_.each( views, function( view, type ) {
@ -115,11 +116,11 @@ window.wp = window.wp || {};
pieces.push( { content: remaining.substring( 0, result.index ) } );
}
self.createInstance( type, result.content, result.options );
instance = self.createInstance( type, result.content, result.options );
// Add the processed piece for the match.
pieces.push( {
content: '<p data-wpview-marker="' + encodeURIComponent( result.content ) + '">' + result.content + '</p>',
content: '<p data-wpview-marker="' + instance.encodedText + '">' + instance.text + '</p>',
processed: true
} );
@ -149,8 +150,12 @@ window.wp = window.wp || {};
*/
createInstance: function( type, text, options ) {
var View = this.get( type ),
encodedText = encodeURIComponent( text ),
instance = this.getInstance( encodedText );
encodedText,
instance;
text = tinymce.DOM.decode( text ),
encodedText = encodeURIComponent( text ),
instance = this.getInstance( encodedText );
if ( instance ) {
return instance;
@ -754,7 +759,7 @@ window.wp = window.wp || {};
if ( this.url ) {
this.loader = false;
this.shortcode = wp.media.embed.shortcode( {
url: this.url
url: this.text
} );
}
@ -804,7 +809,7 @@ window.wp = window.wp || {};
edit: function( text, update ) {
var media = wp.media.embed,
frame = media.edit( text, !! this.url ),
frame = media.edit( text, this.url ),
self = this,
events = 'change:url change:width change:height';
@ -819,13 +824,7 @@ window.wp = window.wp || {};
frame.state( 'embed' ).on( 'select', function() {
var data = frame.state( 'embed' ).metadata;
if ( data.width ) {
delete self.url;
} else {
self.url = data.url;
}
if ( self.url ) {
if ( self.url && ! data.width ) {
update( data.url );
} else {
update( media.shortcode( data ).string() );
@ -866,7 +865,7 @@ window.wp = window.wp || {};
index: match.index + match[1].length,
content: match[2],
options: {
url: match[2]
url: true
}
};
}