summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnthony G. Basile <blueness@gentoo.org>2020-02-17 11:55:41 -0500
committerAnthony G. Basile <blueness@gentoo.org>2020-02-17 11:55:41 -0500
commitdd791649a46b33fd7d5ea388fa42f1cf99c82884 (patch)
treeddc745e49425b01732343da42a19018b7dd737c4 /plugins/jetpack/modules/masterbar/masterbar.php
parentRemove extraneous .zip (diff)
downloadblogs-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.php65
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',
+ ),
+ )
+ );
+ }
+ }
}