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:
parent
8691d31bdc
commit
36b5f034ab
@ -46,24 +46,30 @@ window.wp = window.wp || {};
|
||||
'<div class="wpview-loading"><ins></ins></div>' +
|
||||
'</div>';
|
||||
},
|
||||
render: function() {
|
||||
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'
|
||||
);
|
||||
render: function( force ) {
|
||||
if ( force || ! this.rendered() ) {
|
||||
this.unbind();
|
||||
|
||||
$( 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() {},
|
||||
getEditors: function( callback ) {
|
||||
@ -190,6 +196,19 @@ window.wp = window.wp || {};
|
||||
'<p>' + message + '</p>' +
|
||||
'</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;
|
||||
}
|
||||
|
||||
wp.mce.views.render();
|
||||
instance.render();
|
||||
},
|
||||
|
||||
getInstance: function( encodedText ) {
|
||||
@ -406,9 +425,9 @@ window.wp = window.wp || {};
|
||||
* To generate wrapper elements, pass your content through
|
||||
* `wp.mce.view.toViews( content )`.
|
||||
*/
|
||||
render: function() {
|
||||
render: function( force ) {
|
||||
_.each( instances, function( instance ) {
|
||||
instance.render();
|
||||
instance.render( force );
|
||||
} );
|
||||
},
|
||||
|
||||
@ -438,8 +457,12 @@ window.wp = window.wp || {};
|
||||
},
|
||||
|
||||
fetch: function() {
|
||||
var self = this;
|
||||
|
||||
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() {
|
||||
|
@ -205,10 +205,6 @@ tinymce.PluginManager.add( 'wpview', function( editor ) {
|
||||
removeView( selected );
|
||||
}
|
||||
|
||||
if ( ! event.initial ) {
|
||||
wp.mce.views.unbind( editor );
|
||||
}
|
||||
|
||||
node = editor.selection.getNode();
|
||||
|
||||
// When a url is pasted, only try to embed it when pasted in an empty paragrapgh.
|
||||
|
Loading…
Reference in New Issue
Block a user