wpviews: whenever a view is updated or inserted, don't refresh ALL of the views.

Props avryl.
Fixes #28788.


git-svn-id: https://develop.svn.wordpress.org/trunk@29530 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Scott Taylor 2014-08-18 03:58:24 +00:00
parent 8691d31bdc
commit 36b5f034ab
2 changed files with 44 additions and 25 deletions

View File

@ -46,24 +46,30 @@ window.wp = window.wp || {};
'<div class="wpview-loading"><ins></ins></div>' + '<div class="wpview-loading"><ins></ins></div>' +
'</div>'; '</div>';
}, },
render: function() { render: function( force ) {
this.setContent( if ( force || ! this.rendered() ) {
'<p class="wpview-selection-before">\u00a0</p>' + this.unbind();
'<div class="wpview-body" contenteditable="false">' +
'<div class="toolbar">' +
( _.isFunction( views[ this.type ].edit ) ? '<div class="dashicons dashicons-edit edit"></div>' : '' ) +
'<div class="dashicons dashicons-no-alt remove"></div>' +
'</div>' +
'<div class="wpview-content wpview-type-' + this.type + '">' +
( this.getHtml() || this.loadingPlaceholder() ) +
'</div>' +
( this.overlay ? '<div class="wpview-overlay"></div>' : '' ) +
'</div>' +
'<p class="wpview-selection-after">\u00a0</p>',
'wrap'
);
$( this ).trigger( 'ready' ); this.setContent(
'<p class="wpview-selection-before">\u00a0</p>' +
'<div class="wpview-body" contenteditable="false">' +
'<div class="toolbar">' +
( _.isFunction( views[ this.type ].edit ) ? '<div class="dashicons dashicons-edit edit"></div>' : '' ) +
'<div class="dashicons dashicons-no-alt remove"></div>' +
'</div>' +
'<div class="wpview-content wpview-type-' + this.type + '">' +
( this.getHtml() || this.loadingPlaceholder() ) +
'</div>' +
( this.overlay ? '<div class="wpview-overlay"></div>' : '' ) +
'</div>' +
'<p class="wpview-selection-after">\u00a0</p>',
'wrap'
);
$( this ).trigger( 'ready' );
this.rendered( true );
}
}, },
unbind: function() {}, unbind: function() {},
getEditors: function( callback ) { getEditors: function( callback ) {
@ -190,6 +196,19 @@ window.wp = window.wp || {};
'<p>' + message + '</p>' + '<p>' + message + '</p>' +
'</div>' '</div>'
); );
},
rendered: function( value ) {
var notRendered;
this.getNodes( function( editor, node ) {
if ( value != null ) {
$( node ).data( 'rendered', value === true );
} else {
notRendered = notRendered || ! $( node ).data( 'rendered' );
}
} );
return ! notRendered;
} }
} ); } );
@ -390,7 +409,7 @@ window.wp = window.wp || {};
instances[ encodedText ] = instance; instances[ encodedText ] = instance;
} }
wp.mce.views.render(); instance.render();
}, },
getInstance: function( encodedText ) { getInstance: function( encodedText ) {
@ -406,9 +425,9 @@ window.wp = window.wp || {};
* To generate wrapper elements, pass your content through * To generate wrapper elements, pass your content through
* `wp.mce.view.toViews( content )`. * `wp.mce.view.toViews( content )`.
*/ */
render: function() { render: function( force ) {
_.each( instances, function( instance ) { _.each( instances, function( instance ) {
instance.render(); instance.render( force );
} ); } );
}, },
@ -438,8 +457,12 @@ window.wp = window.wp || {};
}, },
fetch: function() { fetch: function() {
var self = this;
this.attachments = wp.media.gallery.attachments( this.shortcode, this.postID ); this.attachments = wp.media.gallery.attachments( this.shortcode, this.postID );
this.dfd = this.attachments.more().done( _.bind( this.render, this ) ); this.dfd = this.attachments.more().done( function() {
self.render( true );
} );
}, },
getHtml: function() { getHtml: function() {

View File

@ -205,10 +205,6 @@ tinymce.PluginManager.add( 'wpview', function( editor ) {
removeView( selected ); removeView( selected );
} }
if ( ! event.initial ) {
wp.mce.views.unbind( editor );
}
node = editor.selection.getNode(); node = editor.selection.getNode();
// When a url is pasted, only try to embed it when pasted in an empty paragrapgh. // When a url is pasted, only try to embed it when pasted in an empty paragrapgh.