Consolidate update count code into wp_get_update_data(). Props mitchoyoshitaka. fixes #17694
git-svn-id: http://svn.automattic.com/wordpress/trunk@18468 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
3000ee7664
commit
c2d37a3d65
|
@ -30,45 +30,13 @@ if ( is_multisite() ) {
|
||||||
$submenu[ 'index.php' ][5] = array( __('My Sites'), 'read', 'my-sites.php' );
|
$submenu[ 'index.php' ][5] = array( __('My Sites'), 'read', 'my-sites.php' );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( ! is_multisite() || is_super_admin() ) {
|
if ( ! is_multisite() || is_super_admin() )
|
||||||
$plugin_update_count = $theme_update_count = $wordpress_update_count = 0;
|
$update_data = wp_get_update_data();
|
||||||
|
|
||||||
if ( current_user_can( 'update_plugins' ) ) {
|
|
||||||
$update_plugins = get_site_transient( 'update_plugins' );
|
|
||||||
if ( ! empty( $update_plugins->response ) )
|
|
||||||
$plugin_update_count = count( $update_plugins->response );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( current_user_can( 'update_themes' ) ) {
|
|
||||||
$update_themes = get_site_transient( 'update_themes' );
|
|
||||||
if ( !empty($update_themes->response) )
|
|
||||||
$theme_update_count = count( $update_themes->response );
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( current_user_can( 'update_core' ) ) {
|
|
||||||
$update_wordpress = get_core_updates( array('dismissed' => false) );
|
|
||||||
if ( !empty($update_wordpress) && !in_array( $update_wordpress[0]->response, array('development', 'latest') ) && current_user_can('update_core') )
|
|
||||||
$wordpress_update_count = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$total_update_count = $plugin_update_count + $theme_update_count + $wordpress_update_count;
|
|
||||||
$update_title = array();
|
|
||||||
if ( $wordpress_update_count )
|
|
||||||
$update_title[] = sprintf(__('%d WordPress Update'), $wordpress_update_count);
|
|
||||||
if ( $plugin_update_count )
|
|
||||||
$update_title[] = sprintf(_n('%d Plugin Update', '%d Plugin Updates', $plugin_update_count), $plugin_update_count);
|
|
||||||
if ( $theme_update_count )
|
|
||||||
$update_title[] = sprintf(_n('%d Theme Update', '%d Theme Updates', $theme_update_count), $theme_update_count);
|
|
||||||
|
|
||||||
$update_title = !empty($update_title) ? esc_attr(implode(', ', $update_title)) : '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( ! is_multisite() ) {
|
if ( ! is_multisite() ) {
|
||||||
$submenu[ 'index.php' ][10] = array( sprintf( __('Updates %s'), "<span class='update-plugins count-$total_update_count' title='$update_title'><span class='update-count'>" . number_format_i18n($total_update_count) . "</span></span>" ), 'update_core', 'update-core.php');
|
$submenu[ 'index.php' ][10] = array( sprintf( __('Updates %s'), "<span class='update-plugins count-{$update_data['counts']['total']}' title='{$update_data['title']}'><span class='update-count'>" . number_format_i18n($update_data['counts']['total']) . "</span></span>" ), 'update_core', 'update-core.php');
|
||||||
}
|
}
|
||||||
|
|
||||||
unset($theme_update_count, $wordpress_update_count, $update_themes, $update_plugins, $update_wordpress);
|
|
||||||
|
|
||||||
$menu[4] = array( '', 'read', 'separator1', '', 'wp-menu-separator' );
|
$menu[4] = array( '', 'read', 'separator1', '', 'wp-menu-separator' );
|
||||||
|
|
||||||
$menu[5] = array( __('Posts'), 'edit_posts', 'edit.php', '', 'open-if-no-js menu-top menu-icon-post', 'menu-posts', 'div' );
|
$menu[5] = array( __('Posts'), 'edit_posts', 'edit.php', '', 'open-if-no-js menu-top menu-icon-post', 'menu-posts', 'div' );
|
||||||
|
@ -176,9 +144,12 @@ function _add_themes_utility_last() {
|
||||||
|
|
||||||
$menu_perms = get_site_option( 'menu_items', array() );
|
$menu_perms = get_site_option( 'menu_items', array() );
|
||||||
if ( ! is_multisite() || is_super_admin() || ! empty( $menu_perms['plugins'] ) ) {
|
if ( ! is_multisite() || is_super_admin() || ! empty( $menu_perms['plugins'] ) ) {
|
||||||
|
if ( ! isset( $update_data ) )
|
||||||
|
$update_data = wp_get_update_data();
|
||||||
|
|
||||||
$count = '';
|
$count = '';
|
||||||
if ( ! is_multisite() && current_user_can( 'update_plugins' ) )
|
if ( ! is_multisite() && current_user_can( 'update_plugins' ) )
|
||||||
$count = "<span class='update-plugins count-$plugin_update_count'><span class='plugin-count'>" . number_format_i18n($plugin_update_count) . "</span></span>";
|
$count = "<span class='update-plugins count-{$update_data['counts']['plugins']}'><span class='plugin-count'>" . number_format_i18n($update_data['counts']['plugins']) . "</span></span>";
|
||||||
|
|
||||||
$menu[65] = array( sprintf( __('Plugins %s'), $count ), 'activate_plugins', 'plugins.php', '', 'menu-top menu-icon-plugins', 'menu-plugins', 'div' );
|
$menu[65] = array( sprintf( __('Plugins %s'), $count ), 'activate_plugins', 'plugins.php', '', 'menu-top menu-icon-plugins', 'menu-plugins', 'div' );
|
||||||
|
|
||||||
|
@ -190,7 +161,7 @@ if ( ! is_multisite() || is_super_admin() || ! empty( $menu_perms['plugins'] ) )
|
||||||
$submenu['plugins.php'][15] = array( _x('Editor', 'plugin editor'), 'edit_plugins', 'plugin-editor.php' );
|
$submenu['plugins.php'][15] = array( _x('Editor', 'plugin editor'), 'edit_plugins', 'plugin-editor.php' );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
unset($menu_perms, $update_plugins, $plugin_update_count);
|
unset($menu_perms, $update_data);
|
||||||
|
|
||||||
if ( current_user_can('list_users') )
|
if ( current_user_can('list_users') )
|
||||||
$menu[70] = array( __('Users'), 'list_users', 'users.php', '', 'menu-top menu-icon-users', 'menu-users', 'div' );
|
$menu[70] = array( __('Users'), 'list_users', 'users.php', '', 'menu-top menu-icon-users', 'menu-users', 'div' );
|
||||||
|
|
|
@ -21,12 +21,10 @@ $menu[10] = array(__('Users'), 'manage_network_users', 'users.php', '', 'menu-to
|
||||||
$submenu['users.php'][5] = array( __('All Users'), 'manage_network_users', 'users.php' );
|
$submenu['users.php'][5] = array( __('All Users'), 'manage_network_users', 'users.php' );
|
||||||
$submenu['users.php'][10] = array( _x('Add New', 'user'), 'create_users', 'user-new.php' );
|
$submenu['users.php'][10] = array( _x('Add New', 'user'), 'create_users', 'user-new.php' );
|
||||||
|
|
||||||
if ( current_user_can( 'update_themes' ) ) {
|
$update_data = wp_get_update_data();
|
||||||
$plugin_update_count = $theme_update_count = $wordpress_update_count = 0;
|
|
||||||
$update_themes = get_site_transient( 'update_themes' );
|
if ( $update_data['counts']['themes'] ) {
|
||||||
if ( !empty($update_themes->response) )
|
$menu[15] = array(sprintf( __( 'Themes %s' ), "<span class='update-plugins count-{$update_data['counts']['themes']}'><span class='theme-count'>" . number_format_i18n( $update_data['counts']['themes'] ) . "</span></span>" ), 'manage_network_themes', 'themes.php', '', 'menu-top menu-icon-appearance', 'menu-appearance', 'div' );
|
||||||
$theme_update_count = count( $update_themes->response );
|
|
||||||
$menu[15] = array(sprintf( __( 'Themes %s' ), "<span class='update-plugins count-$theme_update_count'><span class='theme-count'>" . number_format_i18n( $theme_update_count ) . "</span></span>" ), 'manage_network_themes', 'themes.php', '', 'menu-top menu-icon-appearance', 'menu-appearance', 'div' );
|
|
||||||
} else {
|
} else {
|
||||||
$menu[15] = array( __( 'Themes' ), 'manage_network_themes', 'themes.php', '', 'menu-top menu-icon-appearance', 'menu-appearance', 'div' );
|
$menu[15] = array( __( 'Themes' ), 'manage_network_themes', 'themes.php', '', 'menu-top menu-icon-appearance', 'menu-appearance', 'div' );
|
||||||
}
|
}
|
||||||
|
@ -35,10 +33,7 @@ $submenu['themes.php'][10] = array( _x('Add New', 'theme'), 'install_themes', 't
|
||||||
$submenu['themes.php'][15] = array( _x('Editor', 'theme editor'), 'edit_themes', 'theme-editor.php' );
|
$submenu['themes.php'][15] = array( _x('Editor', 'theme editor'), 'edit_themes', 'theme-editor.php' );
|
||||||
|
|
||||||
if ( current_user_can( 'update_plugins' ) ) {
|
if ( current_user_can( 'update_plugins' ) ) {
|
||||||
$update_plugins = get_site_transient( 'update_plugins' );
|
$menu[20] = array( sprintf( __( 'Plugins %s' ), "<span class='update-plugins count-{$update_data['counts']['plugins']}'><span class='plugin-count'>" . number_format_i18n( $update_data['counts']['plugins'] ) . "</span></span>" ), 'manage_network_plugins', 'plugins.php', '', 'menu-top menu-icon-plugins', 'menu-plugins', 'div');
|
||||||
if ( !empty($update_plugins->response) )
|
|
||||||
$plugin_update_count = count( $update_plugins->response );
|
|
||||||
$menu[20] = array( sprintf( __( 'Plugins %s' ), "<span class='update-plugins count-$plugin_update_count'><span class='plugin-count'>" . number_format_i18n( $plugin_update_count ) . "</span></span>" ), 'manage_network_plugins', 'plugins.php', '', 'menu-top menu-icon-plugins', 'menu-plugins', 'div');
|
|
||||||
} else {
|
} else {
|
||||||
$menu[20] = array( __('Plugins'), 'manage_network_plugins', 'plugins.php', '', 'menu-top menu-icon-plugins', 'menu-plugins', 'div' );
|
$menu[20] = array( __('Plugins'), 'manage_network_plugins', 'plugins.php', '', 'menu-top menu-icon-plugins', 'menu-plugins', 'div' );
|
||||||
}
|
}
|
||||||
|
@ -53,31 +48,16 @@ if ( defined( 'MULTISITE' ) && defined( 'WP_ALLOW_MULTISITE' ) && WP_ALLOW_MULTI
|
||||||
$submenu['settings.php'][10] = array( __('Network Setup'), 'manage_network_options', 'setup.php' );
|
$submenu['settings.php'][10] = array( __('Network Setup'), 'manage_network_options', 'setup.php' );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( current_user_can( 'update_core' ) ) {
|
if ( $update_data['counts']['total'] ) {
|
||||||
$update_wordpress = get_core_updates( array('dismissed' => false) );
|
$menu[30] = array( sprintf( __( 'Updates %s' ), "<span class='update-plugins count-{$update_data['counts']['total']}' title='{$update_data['title']}'><span class='update-count'>" . number_format_i18n($update_data['counts']['total']) . "</span></span>" ), 'manage_network', 'upgrade.php', '', 'menu-top menu-icon-tools', 'menu-update', 'div' );
|
||||||
if ( !empty($update_wordpress) && !in_array( $update_wordpress[0]->response, array('development', 'latest') ) )
|
|
||||||
$wordpress_update_count = 1;
|
|
||||||
|
|
||||||
$update_count = $plugin_update_count + $theme_update_count + $wordpress_update_count;
|
|
||||||
$update_title = array();
|
|
||||||
if ( $wordpress_update_count )
|
|
||||||
$update_title[] = sprintf(__('%d WordPress Update'), $wordpress_update_count);
|
|
||||||
if ( $plugin_update_count )
|
|
||||||
$update_title[] = sprintf(_n('%d Plugin Update', '%d Plugin Updates', $plugin_update_count), $plugin_update_count);
|
|
||||||
if ( $theme_update_count )
|
|
||||||
$update_title[] = sprintf(_n('%d Theme Update', '%d Theme Updates', $theme_update_count), $theme_update_count);
|
|
||||||
|
|
||||||
$update_title = !empty($update_title) ? esc_attr(implode(', ', $update_title)) : '';
|
|
||||||
|
|
||||||
$menu[30] = array( sprintf( __( 'Updates %s' ), "<span class='update-plugins count-$update_count' title='$update_title'><span class='update-count'>" . number_format_i18n($update_count) . "</span></span>" ), 'manage_network', 'upgrade.php', '', 'menu-top menu-icon-tools', 'menu-update', 'div' );
|
|
||||||
} else {
|
} else {
|
||||||
$menu[30] = array( __( 'Updates' ), 'manage_network', 'upgrade.php', '', 'menu-top menu-icon-tools', 'menu-update', 'div' );
|
$menu[30] = array( __( 'Updates' ), 'manage_network', 'upgrade.php', '', 'menu-top menu-icon-tools', 'menu-update', 'div' );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unset($update_data);
|
||||||
|
|
||||||
$submenu[ 'upgrade.php' ][10] = array( __( 'Available Updates' ), 'update_core', 'update-core.php' );
|
$submenu[ 'upgrade.php' ][10] = array( __( 'Available Updates' ), 'update_core', 'update-core.php' );
|
||||||
$submenu[ 'upgrade.php' ][15] = array( __( 'Update Network' ), 'manage_network', 'upgrade.php' );
|
$submenu[ 'upgrade.php' ][15] = array( __( 'Update Network' ), 'manage_network', 'upgrade.php' );
|
||||||
unset($plugin_update_count, $theme_update_count, $wordpress_update_count, $update_count, $update_title, $update_themes, $update_plugins, $update_wordpress);
|
|
||||||
|
|
||||||
|
|
||||||
$menu[99] = array( '', 'read', 'separator-last', '', 'wp-menu-separator-last' );
|
$menu[99] = array( '', 'read', 'separator-last', '', 'wp-menu-separator-last' );
|
||||||
|
|
||||||
|
|
|
@ -323,39 +323,14 @@ function wp_admin_bar_appearance_menu( $wp_admin_bar ) {
|
||||||
* @since 3.1.0
|
* @since 3.1.0
|
||||||
*/
|
*/
|
||||||
function wp_admin_bar_updates_menu( $wp_admin_bar ) {
|
function wp_admin_bar_updates_menu( $wp_admin_bar ) {
|
||||||
if ( !current_user_can('install_plugins') )
|
|
||||||
|
$update_data = wp_get_update_data();
|
||||||
|
|
||||||
|
if ( !$update_data['counts']['total'] )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
$plugin_update_count = $theme_update_count = $wordpress_update_count = 0;
|
$update_title = "<span title='{$update_data['title']}'>";
|
||||||
$update_plugins = get_site_transient( 'update_plugins' );
|
$update_title .= sprintf( __('Updates %s'), "<span id='ab-updates' class='update-count'>" . number_format_i18n($update_data['counts']['total']) . '</span>' );
|
||||||
if ( !empty($update_plugins->response) )
|
|
||||||
$plugin_update_count = count( $update_plugins->response );
|
|
||||||
$update_themes = get_site_transient( 'update_themes' );
|
|
||||||
if ( !empty($update_themes->response) )
|
|
||||||
$theme_update_count = count( $update_themes->response );
|
|
||||||
/* @todo get_core_updates() is only available on admin page loads
|
|
||||||
$update_wordpress = get_core_updates( array('dismissed' => false) );
|
|
||||||
if ( !empty($update_wordpress) && !in_array( $update_wordpress[0]->response, array('development', 'latest') ) )
|
|
||||||
$wordpress_update_count = 1;
|
|
||||||
*/
|
|
||||||
|
|
||||||
$update_count = $plugin_update_count + $theme_update_count + $wordpress_update_count;
|
|
||||||
|
|
||||||
if ( !$update_count )
|
|
||||||
return;
|
|
||||||
|
|
||||||
$update_title = array();
|
|
||||||
if ( $wordpress_update_count )
|
|
||||||
$update_title[] = sprintf(__('%d WordPress Update'), $wordpress_update_count);
|
|
||||||
if ( $plugin_update_count )
|
|
||||||
$update_title[] = sprintf(_n('%d Plugin Update', '%d Plugin Updates', $plugin_update_count), $plugin_update_count);
|
|
||||||
if ( $theme_update_count )
|
|
||||||
$update_title[] = sprintf(_n('%d Theme Update', '%d Theme Updates', $theme_update_count), $theme_update_count);
|
|
||||||
|
|
||||||
$update_title = !empty($update_title) ? esc_attr(implode(', ', $update_title)) : '';
|
|
||||||
|
|
||||||
$update_title = "<span title='$update_title'>";
|
|
||||||
$update_title .= sprintf( __('Updates %s'), "<span id='ab-updates' class='update-count'>" . number_format_i18n($update_count) . '</span>' );
|
|
||||||
$update_title .= '</span>';
|
$update_title .= '</span>';
|
||||||
|
|
||||||
$wp_admin_bar->add_menu( array( 'id' => 'updates', 'title' => $update_title, 'href' => network_admin_url( 'update-core.php' ) ) );
|
$wp_admin_bar->add_menu( array( 'id' => 'updates', 'title' => $update_title, 'href' => network_admin_url( 'update-core.php' ) ) );
|
||||||
|
|
|
@ -280,6 +280,48 @@ function wp_update_themes() {
|
||||||
set_site_transient( 'update_themes', $new_update );
|
set_site_transient( 'update_themes', $new_update );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Collect counts and UI strings for available updates
|
||||||
|
*
|
||||||
|
* @since 3.3.0
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
function wp_get_update_data() {
|
||||||
|
$counts = array( 'plugins' => 0, 'themes' => 0, 'wordpress' => 0 );
|
||||||
|
|
||||||
|
if ( current_user_can( 'update_plugins' ) ) {
|
||||||
|
$update_plugins = get_site_transient( 'update_plugins' );
|
||||||
|
if ( ! empty( $update_plugins->response ) )
|
||||||
|
$counts['plugins'] = count( $update_plugins->response );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( current_user_can( 'update_themes' ) ) {
|
||||||
|
$update_themes = get_site_transient( 'update_themes' );
|
||||||
|
if ( ! empty( $update_themes->response ) )
|
||||||
|
$counts['themes'] = count( $update_themes->response );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( function_exists( 'get_core_updates' ) && current_user_can( 'update_core' ) ) {
|
||||||
|
$update_wordpress = get_core_updates( array('dismissed' => false) );
|
||||||
|
if ( ! empty( $update_wordpress ) && ! in_array( $update_wordpress[0]->response, array('development', 'latest') ) && current_user_can('update_core') )
|
||||||
|
$counts['wordpress'] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
$counts['total'] = $counts['plugins'] + $counts['themes'] + $counts['wordpress'];
|
||||||
|
$update_title = array();
|
||||||
|
if ( $counts['wordpress'] )
|
||||||
|
$update_title[] = sprintf(__('%d WordPress Update'), $counts['wordpress']);
|
||||||
|
if ( $counts['plugins'] )
|
||||||
|
$update_title[] = sprintf(_n('%d Plugin Update', '%d Plugin Updates', $counts['plugins']), $counts['plugins']);
|
||||||
|
if ( $counts['themes'] )
|
||||||
|
$update_title[] = sprintf(_n('%d Theme Update', '%d Theme Updates', $counts['themes']), $counts['themes']);
|
||||||
|
|
||||||
|
$update_title = ! empty( $update_title ) ? esc_attr( implode( ', ', $update_title ) ) : '';
|
||||||
|
|
||||||
|
return array( 'counts' => $counts, 'title' => $update_title );
|
||||||
|
}
|
||||||
|
|
||||||
function _maybe_update_core() {
|
function _maybe_update_core() {
|
||||||
include ABSPATH . WPINC . '/version.php'; // include an unmodified $wp_version
|
include ABSPATH . WPINC . '/version.php'; // include an unmodified $wp_version
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue