diff options
author | Anthony G. Basile <blueness@gentoo.org> | 2020-02-17 11:55:41 -0500 |
---|---|---|
committer | Anthony G. Basile <blueness@gentoo.org> | 2020-02-17 11:55:41 -0500 |
commit | dd791649a46b33fd7d5ea388fa42f1cf99c82884 (patch) | |
tree | ddc745e49425b01732343da42a19018b7dd737c4 /plugins/jetpack/modules/masterbar/masterbar.php | |
parent | Remove extraneous .zip (diff) | |
download | blogs-gentoo-dd791649a46b33fd7d5ea388fa42f1cf99c82884.tar.gz blogs-gentoo-dd791649a46b33fd7d5ea388fa42f1cf99c82884.tar.bz2 blogs-gentoo-dd791649a46b33fd7d5ea388fa42f1cf99c82884.zip |
update jetpack 8.2.1
Signed-off-by: Anthony G. Basile <blueness@gentoo.org>
Diffstat (limited to 'plugins/jetpack/modules/masterbar/masterbar.php')
-rw-r--r-- | plugins/jetpack/modules/masterbar/masterbar.php | 65 |
1 files changed, 64 insertions, 1 deletions
diff --git a/plugins/jetpack/modules/masterbar/masterbar.php b/plugins/jetpack/modules/masterbar/masterbar.php index e782468f..72c27800 100644 --- a/plugins/jetpack/modules/masterbar/masterbar.php +++ b/plugins/jetpack/modules/masterbar/masterbar.php @@ -1,6 +1,7 @@ <?php // phpcs:ignore WordPress.Files.FileName.InvalidClassFileName use Automattic\Jetpack\Assets; +use Automattic\Jetpack\Connection\Client; require_once dirname( __FILE__ ) . '/rtl-admin-bar.php'; @@ -428,7 +429,7 @@ class A8C_WPCOM_Masterbar { $following_title = $this->create_menu_item_pair( array( - 'url' => 'https://wordpress.com/', + 'url' => 'https://wordpress.com/read', 'id' => 'wp-admin-bar-followed-sites', 'label' => esc_html__( 'Followed Sites', 'jetpack' ), ), @@ -866,6 +867,8 @@ class A8C_WPCOM_Masterbar { ); } + $this->add_my_home_submenu_item( $wp_admin_bar ); + // Stats. if ( Jetpack::is_module_active( 'stats' ) && current_user_can( 'view_stats' ) ) { $wp_admin_bar->add_menu( @@ -1326,4 +1329,64 @@ class A8C_WPCOM_Masterbar { do_action( 'jetpack_masterbar' ); } } + + /** + * Calls the wpcom API to get the creation date of the site + * and determine if it's eligible for the 'My Home' page. + * + * @return bool Whether the site has 'My Home' enabled. + */ + private function is_my_home_enabled() { + $my_home_enabled = get_transient( 'jetpack_my_home_enabled' ); + + if ( false === $my_home_enabled ) { + $site_id = Jetpack_Options::get_option( 'id' ); + $site_response = Client::wpcom_json_api_request_as_blog( + sprintf( '/sites/%d', $site_id ) . '?force=wpcom&options=created_at', + '1.1' + ); + + if ( is_wp_error( $site_response ) ) { + return false; + } + + $site_data = json_decode( wp_remote_retrieve_body( $site_response ) ); + + $my_home_enabled = $site_data && + isset( $site_data->options->created_at ) && + ( new Datetime( '2019-08-06 00:00:00.000' ) ) <= ( new Datetime( $site_data->options->created_at ) ) + ? 1 + : 0; + + set_transient( 'jetpack_my_home_enabled', $my_home_enabled ); + } + + return (bool) $my_home_enabled; + } + + /** + * Adds "My Home" submenu item to sites that are eligible. + * + * @param WP_Admin_Bar $wp_admin_bar Admin Bar instance. + * @return void + */ + private function add_my_home_submenu_item( &$wp_admin_bar ) { + if ( ! current_user_can( 'manage_options' ) || ! jetpack_is_atomic_site() ) { + return; + } + + if ( $this->is_my_home_enabled() ) { + $wp_admin_bar->add_menu( + array( + 'parent' => 'blog', + 'id' => 'my-home', + 'title' => __( 'My Home', 'jetpack' ), + 'href' => 'https://wordpress.com/home/' . esc_attr( $this->primary_site_slug ), + 'meta' => array( + 'class' => 'mb-icon', + ), + ) + ); + } + } } |