Administration: Make sure auto-update counts properly update when bulk deleting plugins or themes.
Props pbiron, noisysocks, desrosj, audrasjb, hellofromTonya. Fixes #50870. Built from https://develop.svn.wordpress.org/trunk@49582 git-svn-id: http://core.svn.wordpress.org/trunk@49320 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
d5fd3bd452
commit
f2364f163b
|
@ -207,8 +207,10 @@ class WP_MS_Themes_List_Table extends WP_List_Table {
|
||||||
}
|
}
|
||||||
|
|
||||||
$totals = array();
|
$totals = array();
|
||||||
|
$js_themes = array();
|
||||||
foreach ( $themes as $type => $list ) {
|
foreach ( $themes as $type => $list ) {
|
||||||
$totals[ $type ] = count( $list );
|
$totals[ $type ] = count( $list );
|
||||||
|
$js_themes[ $type ] = array_keys( $list );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( empty( $themes[ $status ] ) && ! in_array( $status, array( 'all', 'search' ), true ) ) {
|
if ( empty( $themes[ $status ] ) && ! in_array( $status, array( 'all', 'search' ), true ) ) {
|
||||||
|
@ -225,7 +227,7 @@ class WP_MS_Themes_List_Table extends WP_List_Table {
|
||||||
'updates',
|
'updates',
|
||||||
'_wpUpdatesItemCounts',
|
'_wpUpdatesItemCounts',
|
||||||
array(
|
array(
|
||||||
'themes' => $totals,
|
'themes' => $js_themes,
|
||||||
'totals' => wp_get_update_data(),
|
'totals' => wp_get_update_data(),
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
|
@ -317,7 +317,7 @@ class WP_Plugins_List_Table extends WP_List_Table {
|
||||||
|
|
||||||
$js_plugins = array();
|
$js_plugins = array();
|
||||||
foreach ( $plugins as $key => $list ) {
|
foreach ( $plugins as $key => $list ) {
|
||||||
$js_plugins[ $key ] = array_keys( (array) $list );
|
$js_plugins[ $key ] = array_keys( $list );
|
||||||
}
|
}
|
||||||
|
|
||||||
wp_localize_script(
|
wp_localize_script(
|
||||||
|
|
|
@ -18,10 +18,14 @@
|
||||||
* @param {Array} settings.plugins.inactive Base names of inactive plugins.
|
* @param {Array} settings.plugins.inactive Base names of inactive plugins.
|
||||||
* @param {Array} settings.plugins.upgrade Base names of plugins with updates available.
|
* @param {Array} settings.plugins.upgrade Base names of plugins with updates available.
|
||||||
* @param {Array} settings.plugins.recently_activated Base names of recently activated plugins.
|
* @param {Array} settings.plugins.recently_activated Base names of recently activated plugins.
|
||||||
* @param {object=} settings.themes Plugin/theme status information or null.
|
* @param {Array} settings.plugins['auto-update-enabled'] Base names of plugins set to auto-update.
|
||||||
* @param {number} settings.themes.all Amount of all themes.
|
* @param {Array} settings.plugins['auto-update-disabled'] Base names of plugins set to not auto-update.
|
||||||
* @param {number} settings.themes.upgrade Amount of themes with updates available.
|
* @param {object=} settings.themes Slugs of themes in their different states.
|
||||||
* @param {number} settings.themes.disabled Amount of disabled themes.
|
* @param {Array} settings.themes.all Slugs of all themes.
|
||||||
|
* @param {Array} settings.themes.upgrade Slugs of themes with updates available.
|
||||||
|
* @param {Arrat} settings.themes.disabled Slugs of disabled themes.
|
||||||
|
* @param {Array} settings.themes['auto-update-enabled'] Slugs of themes set to auto-update.
|
||||||
|
* @param {Array} settings.themes['auto-update-disabled'] Slugs of themes set to not auto-update.
|
||||||
* @param {object=} settings.totals Combined information for available update counts.
|
* @param {object=} settings.totals Combined information for available update counts.
|
||||||
* @param {number} settings.totals.count Holds the amount of available updates.
|
* @param {number} settings.totals.count Holds the amount of available updates.
|
||||||
*/
|
*/
|
||||||
|
@ -1007,6 +1011,24 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( -1 !== _.indexOf( plugins['auto-update-enabled'], response.plugin ) ) {
|
||||||
|
plugins['auto-update-enabled'] = _.without( plugins['auto-update-enabled'], response.plugin );
|
||||||
|
if ( plugins['auto-update-enabled'].length ) {
|
||||||
|
$views.find( '.auto-update-enabled .count' ).text( '(' + plugins['auto-update-enabled'].length + ')' );
|
||||||
|
} else {
|
||||||
|
$views.find( '.auto-update-enabled' ).remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( -1 !== _.indexOf( plugins['auto-update-disabled'], response.plugin ) ) {
|
||||||
|
plugins['auto-update-disabled'] = _.without( plugins['auto-update-disabled'], response.plugin );
|
||||||
|
if ( plugins['auto-update-disabled'].length ) {
|
||||||
|
$views.find( '.auto-update-disabled .count' ).text( '(' + plugins['auto-update-disabled'].length + ')' );
|
||||||
|
} else {
|
||||||
|
$views.find( '.auto-update-disabled' ).remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
plugins.all = _.without( plugins.all, response.plugin );
|
plugins.all = _.without( plugins.all, response.plugin );
|
||||||
|
|
||||||
if ( plugins.all.length ) {
|
if ( plugins.all.length ) {
|
||||||
|
@ -1505,7 +1527,7 @@
|
||||||
$themeRows.css( { backgroundColor: '#faafaa' } ).fadeOut( 350, function() {
|
$themeRows.css( { backgroundColor: '#faafaa' } ).fadeOut( 350, function() {
|
||||||
var $views = $( '.subsubsub' ),
|
var $views = $( '.subsubsub' ),
|
||||||
$themeRow = $( this ),
|
$themeRow = $( this ),
|
||||||
totals = settings.themes,
|
themes = settings.themes,
|
||||||
deletedRow = wp.template( 'item-deleted-row' );
|
deletedRow = wp.template( 'item-deleted-row' );
|
||||||
|
|
||||||
if ( ! $themeRow.hasClass( 'plugin-update-tr' ) ) {
|
if ( ! $themeRow.hasClass( 'plugin-update-tr' ) ) {
|
||||||
|
@ -1521,23 +1543,43 @@
|
||||||
$themeRow.remove();
|
$themeRow.remove();
|
||||||
|
|
||||||
// Remove theme from update count.
|
// Remove theme from update count.
|
||||||
if ( $themeRow.hasClass( 'update' ) ) {
|
if ( -1 !== _.indexOf( themes.upgrade, response.slug ) ) {
|
||||||
totals.upgrade--;
|
themes.upgrade = _.without( themes.upgrade, response.slug );
|
||||||
wp.updates.decrementCount( 'theme' );
|
wp.updates.decrementCount( 'theme' );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Remove from views.
|
// Remove from views.
|
||||||
if ( $themeRow.hasClass( 'inactive' ) ) {
|
if ( -1 !== _.indexOf( themes.disabled, response.slug ) ) {
|
||||||
totals.disabled--;
|
themes.disabled = _.without( themes.disabled, response.slug );
|
||||||
if ( totals.disabled ) {
|
if ( themes.disabled.length ) {
|
||||||
$views.find( '.disabled .count' ).text( '(' + totals.disabled + ')' );
|
$views.find( '.disabled .count' ).text( '(' + themes.disabled.length + ')' );
|
||||||
} else {
|
} else {
|
||||||
$views.find( '.disabled' ).remove();
|
$views.find( '.disabled' ).remove();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ( -1 !== _.indexOf( themes['auto-update-enabled'], response.slug ) ) {
|
||||||
|
themes['auto-update-enabled'] = _.without( themes['auto-update-enabled'], response.slug );
|
||||||
|
if ( themes['auto-update-enabled'].length ) {
|
||||||
|
$views.find( '.auto-update-enabled .count' ).text( '(' + themes['auto-update-enabled'].length + ')' );
|
||||||
|
} else {
|
||||||
|
$views.find( '.auto-update-enabled' ).remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( -1 !== _.indexOf( themes['auto-update-disabled'], response.slug ) ) {
|
||||||
|
themes['auto-update-disabled'] = _.without( themes['auto-update-disabled'], response.slug );
|
||||||
|
if ( themes['auto-update-disabled'].length ) {
|
||||||
|
$views.find( '.auto-update-disabled .count' ).text( '(' + themes['auto-update-disabled'].length + ')' );
|
||||||
|
} else {
|
||||||
|
$views.find( '.auto-update-disabled' ).remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
themes.all = _.without( themes.all, response.slug );
|
||||||
|
|
||||||
// There is always at least one theme available.
|
// There is always at least one theme available.
|
||||||
$views.find( '.all .count' ).text( '(' + --totals.all + ')' );
|
$views.find( '.all .count' ).text( '(' + themes.all.length + ')' );
|
||||||
} );
|
} );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -13,7 +13,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '5.6-beta3-49581';
|
$wp_version = '5.6-beta3-49582';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 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.
|
||||||
|
|
Loading…
Reference in New Issue