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 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() {
|
||||||
|
@ -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.
|
||||||
|
Loading…
Reference in New Issue
Block a user