Plugins: Use plugin file rather than slug as identifier

The plugin file is unique while there can be more than one plugin with the
same slug. This also allows us to simplify the way updates from the plugin
detail iframe are executed.

See [36205].
Fixes #35350.


Built from https://develop.svn.wordpress.org/trunk@36221


git-svn-id: http://core.svn.wordpress.org/trunk@36188 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Konstantin Obenland 2016-01-08 17:48:28 +00:00
parent 07e9d22968
commit c252e77ce3
4 changed files with 23 additions and 25 deletions

View File

@ -651,7 +651,7 @@ function install_plugin_information() {
break; break;
case 'update_available': case 'update_available':
if ( $status['url'] ) { if ( $status['url'] ) {
echo '<a data-slug="' . esc_attr( $api->slug ) . '" id="plugin_update_from_iframe" class="button button-primary right" href="' . $status['url'] . '" target="_parent">' . __( 'Install Update Now' ) .'</a>'; echo '<a data-slug="' . esc_attr( $api->slug ) . '" data-plugin="' . esc_attr( $status['file'] ) . '" id="plugin_update_from_iframe" class="button button-primary right" href="' . $status['url'] . '" target="_parent">' . __( 'Install Update Now' ) .'</a>';
} }
break; break;
case 'newer_installed': case 'newer_installed':

View File

@ -150,7 +150,7 @@ window.wp = window.wp || {};
$card = $( '.plugin-card-' + slug ); $card = $( '.plugin-card-' + slug );
if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) { if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) {
$message = $( '[data-slug="' + slug + '"]' ).next().find( '.update-message' ); $message = $( '[data-plugin="' + plugin + '"]' ).next().find( '.update-message' );
} else if ( 'plugin-install' === pagenow ) { } else if ( 'plugin-install' === pagenow ) {
$message = $card.find( '.update-now' ); $message = $card.find( '.update-now' );
name = $message.data( 'name' ); name = $message.data( 'name' );
@ -207,7 +207,7 @@ window.wp = window.wp || {};
wp.updates.updateSuccess = function( response ) { wp.updates.updateSuccess = function( response ) {
var $updateMessage, name, $pluginRow, newText; var $updateMessage, name, $pluginRow, newText;
if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) { if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) {
$pluginRow = $( '[data-slug="' + response.slug + '"]' ).first(); $pluginRow = $( '[data-plugin="' + response.plugin + '"]' ).first();
$updateMessage = $pluginRow.next().find( '.update-message' ); $updateMessage = $pluginRow.next().find( '.update-message' );
$pluginRow.addClass( 'updated' ).removeClass( 'update' ); $pluginRow.addClass( 'updated' ).removeClass( 'update' );
@ -268,7 +268,7 @@ window.wp = window.wp || {};
error_message = wp.updates.l10n.updateFailed.replace( '%s', response.error ); error_message = wp.updates.l10n.updateFailed.replace( '%s', response.error );
if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) { if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) {
$message = $( '[data-slug="' + response.slug + '"]' ).next().find( '.update-message' ); $message = $( '[data-plugin="' + response.plugin + '"]' ).next().find( '.update-message' );
$message.html( error_message ).removeClass( 'updating-message' ); $message.html( error_message ).removeClass( 'updating-message' );
} else if ( 'plugin-install' === pagenow ) { } else if ( 'plugin-install' === pagenow ) {
$button = $card.find( '.update-now' ); $button = $card.find( '.update-now' );
@ -431,13 +431,13 @@ window.wp = window.wp || {};
*/ */
wp.updates.requestForCredentialsModalCancel = function() { wp.updates.requestForCredentialsModalCancel = function() {
// no updateLock and no updateQueue means we already have cleared things up // no updateLock and no updateQueue means we already have cleared things up
var slug, $message; var data, $message;
if( wp.updates.updateLock === false && wp.updates.updateQueue.length === 0 ){ if( wp.updates.updateLock === false && wp.updates.updateQueue.length === 0 ){
return; return;
} }
slug = wp.updates.updateQueue[0].data.slug, data = wp.updates.updateQueue[0].data;
// remove the lock, and clear the queue // remove the lock, and clear the queue
wp.updates.updateLock = false; wp.updates.updateLock = false;
@ -445,9 +445,9 @@ window.wp = window.wp || {};
wp.updates.requestForCredentialsModalClose(); wp.updates.requestForCredentialsModalClose();
if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) { if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) {
$message = $( '[data-slug="' + slug + '"]' ).next().find( '.update-message' ); $message = $( '[data-plugin="' + data.plugin + '"]' ).next().find( '.update-message' );
} else if ( 'plugin-install' === pagenow ) { } else if ( 'plugin-install' === pagenow ) {
$message = $( '.plugin-card-' + slug ).find( '.update-now' ); $message = $( '.plugin-card-' + data.slug ).find( '.update-now' );
} }
$message.removeClass( 'updating-message' ); $message.removeClass( 'updating-message' );
@ -516,7 +516,7 @@ window.wp = window.wp || {};
} }
var updateRow = $( e.target ).parents( '.plugin-update-tr' ); var updateRow = $( e.target ).parents( '.plugin-update-tr' );
// Return the user to the input box of the plugin's table row after closing the modal. // Return the user to the input box of the plugin's table row after closing the modal.
wp.updates.$elToReturnFocusToFromCredentialsModal = $( '#' + updateRow.data( 'slug' ) ).find( '.check-column input' ); wp.updates.$elToReturnFocusToFromCredentialsModal = updateRow.prev().find( '.check-column input' );
wp.updates.updatePlugin( updateRow.data( 'plugin' ), updateRow.data( 'slug' ) ); wp.updates.updatePlugin( updateRow.data( 'plugin' ), updateRow.data( 'slug' ) );
} ); } );
@ -532,7 +532,7 @@ window.wp = window.wp || {};
} ); } );
$( '#plugin_update_from_iframe' ).on( 'click' , function( e ) { $( '#plugin_update_from_iframe' ).on( 'click' , function( e ) {
var target, data; var target, job;
target = window.parent == window ? null : window.parent, target = window.parent == window ? null : window.parent,
$.support.postMessage = !! window.postMessage; $.support.postMessage = !! window.postMessage;
@ -542,12 +542,16 @@ window.wp = window.wp || {};
e.preventDefault(); e.preventDefault();
data = { job = {
'action' : 'updatePlugin', action: 'updatePlugin',
'slug' : $(this).data('slug') type: 'update-plugin',
data: {
plugin: $( this ).data( 'plugin' ),
slug: $( this ).data( 'slug' )
}
}; };
target.postMessage( JSON.stringify( data ), window.location.origin ); target.postMessage( JSON.stringify( job ), window.location.origin );
}); });
} ); } );
@ -574,15 +578,9 @@ window.wp = window.wp || {};
break; break;
case 'updatePlugin' : case 'updatePlugin' :
tb_remove(); tb_remove();
if ( 'plugins' === pagenow || 'plugins-network' === pagenow ) {
// Return the user to the input box of the plugin's table row after closing the modal. wp.updates.updateQueue.push( message );
$( '#' + message.slug ).find( '.check-column input' ).focus(); wp.updates.queueChecker();
// trigger the update
$( '.plugin-update-tr[data-slug="' + message.slug + '"]' ).find( '.update-link' ).trigger( 'click' );
} else if ( 'plugin-install' === pagenow ) {
$( '.plugin-card-' + message.slug ).find( '.column-name a' ).focus();
$( '.plugin-card-' + message.slug ).find( '[data-slug="' + message.slug + '"]' ).trigger( 'click' );
}
break; break;
} }

File diff suppressed because one or more lines are too long

View File

@ -4,7 +4,7 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '4.5-alpha-36220'; $wp_version = '4.5-alpha-36221';
/** /**
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema. * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.