diff --git a/modules/masterbar/masterbar.php b/modules/masterbar/masterbar.php
index 6a378b892c5ec..55e00143dcba2 100644
--- a/modules/masterbar/masterbar.php
+++ b/modules/masterbar/masterbar.php
@@ -141,6 +141,30 @@ public function __construct() {
// Override Notification module to include RTL styles.
add_action( 'a8c_wpcom_masterbar_enqueue_rtl_notification_styles', '__return_true' );
}
+
+ add_action( 'wp_logout', array( $this, 'maybe_logout_user_from_wpcom' ) );
+ }
+
+ /**
+ * Log out from WordPress.com when logging out of the local site.
+ */
+ public function maybe_logout_user_from_wpcom() {
+ /**
+ * Whether we should sign out from wpcom too when signing out from the masterbar.
+ *
+ * @since 5.9.0
+ *
+ * @param bool $masterbar_should_logout_from_wpcom True by default.
+ */
+ $masterbar_should_logout_from_wpcom = apply_filters( 'jetpack_masterbar_should_logout_from_wpcom', true );
+ if (
+ // No need to check for a nonce here, it happens further up.
+ isset( $_GET['context'] ) // phpcs:ignore WordPress.Security.NonceVerification.Recommended
+ && 'masterbar' === $_GET['context'] // phpcs:ignore WordPress.Security.NonceVerification.Recommended
+ && $masterbar_should_logout_from_wpcom
+ ) {
+ do_action( 'wp_masterbar_logout' );
+ }
}
/**
@@ -287,9 +311,6 @@ public function build_wpcom_masterbar( $wp_admin_bar ) {
$this->add_me_submenu( $wp_admin_bar );
$this->add_write_button( $wp_admin_bar );
-
- // Add a sidebar toggle on mobile.
- wp_admin_bar_sidebar_toggle( $wp_admin_bar );
}
/**
@@ -344,45 +365,140 @@ public function add_notifications( $wp_admin_bar ) {
}
/**
- * Add the "My Site" menu item in the root default group.
+ * Add the "Reader" menu item in the root default group.
*
* @param WP_Admin_Bar $wp_admin_bar Admin Bar instance.
*/
- public function add_my_sites_submenu( $wp_admin_bar ) {
+ public function add_reader_submenu( $wp_admin_bar ) {
$wp_admin_bar->add_menu(
array(
'parent' => 'root-default',
- 'id' => 'blog',
- 'title' => _n( 'My Site', 'My Sites', $this->user_site_count, 'jetpack' ),
- 'href' => 'https://wordpress.com/stats/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'newdash',
+ 'title' => esc_html__( 'Reader', 'jetpack' ),
+ 'href' => '#',
'meta' => array(
- 'class' => 'my-sites mb-trackable',
+ 'class' => 'mb-trackable',
),
)
);
- }
- /**
- * Add the "Reader" menu item in the root default group.
- *
- * @param WP_Admin_Bar $wp_admin_bar Admin Bar instance.
- */
- public function add_reader_submenu( $wp_admin_bar ) {
$wp_admin_bar->add_menu(
array(
- 'parent' => 'root-default',
- 'id' => 'newdash',
- 'title' => esc_html__( 'Reader', 'jetpack' ),
- 'href' => 'https://wordpress.com/',
+ 'parent' => 'newdash',
+ 'id' => 'streams-header',
+ 'title' => esc_html_x(
+ 'Streams',
+ 'Title for Reader sub-menu that contains followed sites, likes, and recommendations',
+ 'jetpack'
+ ),
'meta' => array(
- 'class' => 'mb-trackable',
+ 'class' => 'ab-submenu-header',
+ ),
+ )
+ );
+
+ $following_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/',
+ 'id' => 'wp-admin-bar-followed-sites',
+ 'label' => esc_html__( 'Followed Sites', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/following/edit',
+ 'id' => 'wp-admin-bar-reader-followed-sites-manage',
+ 'label' => esc_html__( 'Manage', 'jetpack' ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'newdash',
+ 'id' => 'following',
+ 'title' => $following_title,
+ 'meta' => array( 'class' => 'inline-action' ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'newdash',
+ 'id' => 'discover-discover',
+ 'title' => esc_html__( 'Discover', 'jetpack' ),
+ 'href' => 'https://wordpress.com/discover',
+ 'meta' => array(
+ 'class' => 'mb-icon-spacer',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'newdash',
+ 'id' => 'discover-search',
+ 'title' => esc_html__( 'Search', 'jetpack' ),
+ 'href' => 'https://wordpress.com/read/search',
+ 'meta' => array(
+ 'class' => 'mb-icon-spacer',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'newdash',
+ 'id' => 'discover-recommended-blogs',
+ 'title' => esc_html__( 'Recommendations', 'jetpack' ),
+ 'href' => 'https://wordpress.com/recommendations',
+ 'meta' => array(
+ 'class' => 'mb-icon-spacer',
),
)
);
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'newdash',
+ 'id' => 'my-activity-my-likes',
+ 'title' => esc_html__( 'My Likes', 'jetpack' ),
+ 'href' => 'https://wordpress.com/activities/likes',
+ 'meta' => array(
+ 'class' => 'mb-icon-spacer',
+ ),
+ )
+ );
+
+ }
+
+ /**
+ * Merge 2 menu items together into 2 link tags.
+ *
+ * @param array $primary Array of menu information.
+ * @param array $secondary Array of menu information.
+ */
+ public function create_menu_item_pair( $primary, $secondary ) {
+ $primary_class = 'ab-item ab-primary mb-icon';
+ $secondary_class = 'ab-secondary';
+
+ $primary_anchor = $this->create_menu_item_anchor( $primary_class, $primary['url'], $primary['label'], $primary['id'] );
+ $secondary_anchor = $this->create_menu_item_anchor( $secondary_class, $secondary['url'], $secondary['label'], $secondary['id'] );
+
+ return $primary_anchor . $secondary_anchor;
}
/**
- * Define main groups used in our admin bar.
+ * Create a link tag based on information about a menu item.
+ *
+ * @param string $class Menu item CSS class.
+ * @param string $url URL you go to when clicking on the menu item.
+ * @param string $label Menu item title.
+ * @param string $id Menu item slug.
+ */
+ public function create_menu_item_anchor( $class, $url, $label, $id ) {
+ return '' . $label . '';
+ }
+
+ /**
+ * Add Secondary groups for submenu items.
*
* @param WP_Admin_Bar $wp_admin_bar Admin Bar instance.
*/
@@ -396,6 +512,16 @@ public function wpcom_adminbar_add_secondary_groups( $wp_admin_bar ) {
)
);
+ $wp_admin_bar->add_group(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'blog-secondary',
+ 'meta' => array(
+ 'class' => 'ab-sub-secondary',
+ ),
+ )
+ );
+
$wp_admin_bar->add_group(
array(
'id' => 'top-secondary',
@@ -426,12 +552,163 @@ public function add_me_submenu( $wp_admin_bar ) {
'id' => 'my-account',
'parent' => 'top-secondary',
'title' => $avatar . '' . esc_html__( 'Me', 'jetpack' ) . '',
- 'href' => 'https://wordpress.com/me/account',
+ 'href' => '#',
'meta' => array(
'class' => $class,
),
)
);
+
+ $id = 'user-actions';
+ $wp_admin_bar->add_group(
+ array(
+ 'parent' => 'my-account',
+ 'id' => $id,
+ )
+ );
+
+ $settings_url = 'https://wordpress.com/me/account';
+
+ $logout_url = wp_logout_url();
+ $logout_url = add_query_arg( 'context', 'masterbar', $logout_url );
+
+ $user_info = get_avatar( $this->user_email, 128, 'mm', '', array( 'force_display' => true ) );
+ $user_info .= '' . $this->display_name . '';
+ $user_info .= '@' . $this->user_login . '';
+
+ $user_info .= sprintf(
+ '
',
+ $logout_url,
+ esc_html__( 'Sign Out', 'jetpack' )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'user-info',
+ 'title' => $user_info,
+ 'meta' => array(
+ 'class' => 'user-info user-info-item',
+ 'tabindex' => -1,
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'profile-header',
+ 'title' => esc_html__( 'Profile', 'jetpack' ),
+ 'meta' => array(
+ 'class' => 'ab-submenu-header',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'my-profile',
+ 'title' => esc_html__( 'My Profile', 'jetpack' ),
+ 'href' => 'https://wordpress.com/me',
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'account-settings',
+ 'title' => esc_html__( 'Account Settings', 'jetpack' ),
+ 'href' => $settings_url,
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'billing',
+ 'title' => esc_html__( 'Manage Purchases', 'jetpack' ),
+ 'href' => 'https://wordpress.com/me/purchases',
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'security',
+ 'title' => esc_html__( 'Security', 'jetpack' ),
+ 'href' => 'https://wordpress.com/me/security',
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'notifications',
+ 'title' => esc_html__( 'Notifications', 'jetpack' ),
+ 'href' => 'https://wordpress.com/me/notifications',
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'special-header',
+ 'title' => esc_html_x(
+ 'Special',
+ 'Title for Me sub-menu that contains Get Apps, Next Steps, and Help options',
+ 'jetpack'
+ ),
+ 'meta' => array(
+ 'class' => 'ab-submenu-header',
+ ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'get-apps',
+ 'title' => esc_html__( 'Get Apps', 'jetpack' ),
+ 'href' => 'https://wordpress.com/me/get-apps',
+ 'meta' => array(
+ 'class' => 'mb-icon user-info-item',
+ ),
+ )
+ );
+
+ $help_link = 'https://jetpack.com/support/';
+
+ if ( jetpack_is_atomic_site() ) {
+ $help_link = 'https://wordpress.com/help';
+ }
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => $id,
+ 'id' => 'help',
+ 'title' => esc_html__( 'Help', 'jetpack' ),
+ 'href' => $help_link,
+ 'meta' => array(
+ 'class' => 'mb-icon user-info-item',
+ ),
+ )
+ );
}
/**
@@ -467,4 +744,557 @@ public function add_write_button( $wp_admin_bar ) {
)
);
}
+
+ /**
+ * Add the "My Site" menu item in the root default group.
+ *
+ * @param WP_Admin_Bar $wp_admin_bar Admin Bar instance.
+ */
+ public function add_my_sites_submenu( $wp_admin_bar ) {
+ $current_user = wp_get_current_user();
+
+ $blog_name = get_bloginfo( 'name' );
+ if ( empty( $blog_name ) ) {
+ $blog_name = $this->primary_site_slug;
+ }
+
+ if ( mb_strlen( $blog_name ) > 20 ) {
+ $blog_name = mb_substr( html_entity_decode( $blog_name, ENT_QUOTES ), 0, 20 ) . '…';
+ }
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'root-default',
+ 'id' => 'blog',
+ 'title' => _n( 'My Site', 'My Sites', $this->user_site_count, 'jetpack' ),
+ 'href' => '#',
+ 'meta' => array(
+ 'class' => 'my-sites mb-trackable',
+ ),
+ )
+ );
+
+ if ( $this->user_site_count > 1 ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'switch-site',
+ 'title' => esc_html__( 'Switch Site', 'jetpack' ),
+ 'href' => 'https://wordpress.com/sites',
+ )
+ );
+ } else {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'new-site',
+ 'title' => esc_html__( '+ Add New WordPress', 'jetpack' ),
+ 'href' => 'https://wordpress.com/start?ref=admin-bar-logged-in',
+ )
+ );
+ }
+
+ if ( is_user_member_of_blog( $current_user->ID ) ) {
+ $blavatar = '';
+ $class = 'current-site';
+
+ if ( has_site_icon() ) {
+ $src = get_site_icon_url();
+ $blavatar = '
';
+ $class = 'has-blavatar';
+ }
+
+ $blog_info = '' . $blavatar . '
';
+ $blog_info .= '' . esc_html( $blog_name ) . '';
+ $blog_info .= '' . esc_html( $this->primary_site_url ) . '';
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'blog-info',
+ 'title' => $blog_info,
+ 'href' => esc_url( trailingslashit( $this->primary_site_url ) ),
+ 'meta' => array(
+ 'class' => $class,
+ ),
+ )
+ );
+ }
+
+ // Site Preview.
+ if ( is_admin() ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'site-view',
+ 'title' => __( 'View Site', 'jetpack' ),
+ 'href' => home_url(),
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ 'target' => '_blank',
+ ),
+ )
+ );
+ }
+
+ // Stats.
+ if ( Jetpack::is_module_active( 'stats' ) ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'blog-stats',
+ 'title' => esc_html__( 'Stats', 'jetpack' ),
+ 'href' => 'https://wordpress.com/stats/' . esc_attr( $this->primary_site_slug ),
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+ }
+
+ if ( current_user_can( 'manage_options' ) ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'activity',
+ 'title' => esc_html__( 'Activity', 'jetpack' ),
+ 'href' => 'https://wordpress.com/activity-log/' . esc_attr( $this->primary_site_slug ),
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+ }
+
+ // Add Calypso plans link and plan type indicator.
+ if ( is_user_member_of_blog( $current_user->ID ) ) {
+ $plans_url = 'https://wordpress.com/plans/' . esc_attr( $this->primary_site_slug );
+ $label = esc_html__( 'Plan', 'jetpack' );
+ $plan = Jetpack_Plan::get();
+
+ $plan_title = $this->create_menu_item_pair(
+ array(
+ 'url' => $plans_url,
+ 'id' => 'wp-admin-bar-plan',
+ 'label' => $label,
+ ),
+ array(
+ 'url' => $plans_url,
+ 'id' => 'wp-admin-bar-plan-badge',
+ 'label' => $plan['product_name_short'],
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'plan',
+ 'title' => $plan_title,
+ 'meta' => array(
+ 'class' => 'inline-action',
+ ),
+ )
+ );
+ }
+
+ // Publish group.
+ $wp_admin_bar->add_group(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'publish',
+ )
+ );
+
+ // Publish header.
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'publish',
+ 'id' => 'publish-header',
+ 'title' => esc_html_x( 'Manage', 'admin bar menu group label', 'jetpack' ),
+ 'meta' => array(
+ 'class' => 'ab-submenu-header',
+ ),
+ )
+ );
+
+ // Pages.
+ $pages_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/pages/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-edit-page',
+ 'label' => esc_html__( 'Site Pages', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/page/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-new-page-badge',
+ 'label' => esc_html_x( 'Add', 'admin bar menu new item label', 'jetpack' ),
+ )
+ );
+
+ if ( ! current_user_can( 'edit_pages' ) ) {
+ $pages_title = $this->create_menu_item_anchor(
+ 'ab-item ab-primary mb-icon',
+ 'https://wordpress.com/pages/' . esc_attr( $this->primary_site_slug ),
+ esc_html__( 'Site Pages', 'jetpack' ),
+ 'wp-admin-bar-edit-page'
+ );
+ }
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'publish',
+ 'id' => 'new-page',
+ 'title' => $pages_title,
+ 'meta' => array(
+ 'class' => 'inline-action',
+ ),
+ )
+ );
+
+ // Blog Posts.
+ $posts_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/posts/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-edit-post',
+ 'label' => esc_html__( 'Blog Posts', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/post/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-new-post-badge',
+ 'label' => esc_html_x( 'Add', 'admin bar menu new item label', 'jetpack' ),
+ )
+ );
+
+ if ( ! current_user_can( 'edit_posts' ) ) {
+ $posts_title = $this->create_menu_item_anchor(
+ 'ab-item ab-primary mb-icon',
+ 'https://wordpress.com/posts/' . esc_attr( $this->primary_site_slug ),
+ esc_html__( 'Blog Posts', 'jetpack' ),
+ 'wp-admin-bar-edit-post'
+ );
+ }
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'publish',
+ 'id' => 'new-post',
+ 'title' => $posts_title,
+ 'meta' => array(
+ 'class' => 'inline-action mb-trackable',
+ ),
+ )
+ );
+
+ // Comments.
+ if ( current_user_can( 'moderate_comments' ) ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'publish',
+ 'id' => 'comments',
+ 'title' => __( 'Comments', 'jetpack' ),
+ 'href' => 'https://wordpress.com/comments/' . esc_attr( $this->primary_site_slug ),
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+ }
+
+ // Testimonials.
+ if ( Jetpack::is_module_active( 'custom-content-types' ) && get_option( 'jetpack_testimonial' ) ) {
+ $testimonials_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/types/jetpack-testimonial/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-edit-testimonial',
+ 'label' => esc_html__( 'Testimonials', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/edit/jetpack-testimonial/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-new-testimonial',
+ 'label' => esc_html_x( 'Add', 'Button label for adding a new item via the toolbar menu', 'jetpack' ),
+ )
+ );
+
+ if ( ! current_user_can( 'edit_pages' ) ) {
+ $testimonials_title = $this->create_menu_item_anchor(
+ 'ab-item ab-primary mb-icon',
+ 'https://wordpress.com/types/jetpack-testimonial/' . esc_attr( $this->primary_site_slug ),
+ esc_html__( 'Testimonials', 'jetpack' ),
+ 'wp-admin-bar-edit-testimonial'
+ );
+ }
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'publish',
+ 'id' => 'new-jetpack-testimonial',
+ 'title' => $testimonials_title,
+ 'meta' => array(
+ 'class' => 'inline-action',
+ ),
+ )
+ );
+ }
+
+ // Portfolio.
+ if ( Jetpack::is_module_active( 'custom-content-types' ) && get_option( 'jetpack_portfolio' ) ) {
+ $portfolios_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/types/jetpack-portfolio/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-edit-portfolio',
+ 'label' => esc_html__( 'Portfolio', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/edit/jetpack-portfolio/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-new-portfolio',
+ 'label' => esc_html_x( 'Add', 'Button label for adding a new item via the toolbar menu', 'jetpack' ),
+ )
+ );
+
+ if ( ! current_user_can( 'edit_pages' ) ) {
+ $portfolios_title = $this->create_menu_item_anchor(
+ 'ab-item ab-primary mb-icon',
+ 'https://wordpress.com/types/jetpack-portfolio/' . esc_attr( $this->primary_site_slug ),
+ esc_html__( 'Portfolio', 'jetpack' ),
+ 'wp-admin-bar-edit-portfolio'
+ );
+ }
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'publish',
+ 'id' => 'new-jetpack-portfolio',
+ 'title' => $portfolios_title,
+ 'meta' => array(
+ 'class' => 'inline-action',
+ ),
+ )
+ );
+ }
+
+ if ( current_user_can( 'edit_theme_options' ) ) {
+ // Look and Feel group.
+ $wp_admin_bar->add_group(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'look-and-feel',
+ )
+ );
+
+ // Look and Feel header.
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'look-and-feel',
+ 'id' => 'look-and-feel-header',
+ 'title' => esc_html_x( 'Personalize', 'admin bar menu group label', 'jetpack' ),
+ 'meta' => array(
+ 'class' => 'ab-submenu-header',
+ ),
+ )
+ );
+
+ if ( is_admin() ) {
+ // In wp-admin the `return` query arg will return to that page after closing the Customizer.
+ $customizer_url = add_query_arg(
+ array(
+ 'return' => rawurlencode( site_url( $_SERVER['REQUEST_URI'] ) ),
+ ),
+ wp_customize_url()
+ );
+ } else {
+ /*
+ * On the frontend the `url` query arg will load that page in the Customizer
+ * and also return to it after closing
+ * non-home URLs won't work unless we undo domain mapping
+ * since the Customizer preview is unmapped to always have HTTPS.
+ */
+ $current_page = '//' . $this->primary_site_slug . $_SERVER['REQUEST_URI'];
+ $customizer_url = add_query_arg( array( 'url' => rawurlencode( $current_page ) ), wp_customize_url() );
+ }
+
+ $theme_title = $this->create_menu_item_pair(
+ array(
+ 'url' => $customizer_url,
+ 'id' => 'wp-admin-bar-cmz',
+ 'label' => esc_html_x( 'Customize', 'admin bar customize item label', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/themes/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-themes',
+ 'label' => esc_html__( 'Themes', 'jetpack' ),
+ )
+ );
+ $meta = array(
+ 'class' => 'mb-icon',
+ 'class' => 'inline-action',
+ );
+ $href = false;
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'look-and-feel',
+ 'id' => 'themes',
+ 'title' => $theme_title,
+ 'href' => $href,
+ 'meta' => $meta,
+ )
+ );
+ }
+
+ if ( current_user_can( 'manage_options' ) ) {
+ // Configuration group.
+ $wp_admin_bar->add_group(
+ array(
+ 'parent' => 'blog',
+ 'id' => 'configuration',
+ )
+ );
+
+ // Configuration header.
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'configuration',
+ 'id' => 'configuration-header',
+ 'title' => esc_html_x( 'Configure', 'admin bar menu group label', 'jetpack' ),
+ 'meta' => array(
+ 'class' => 'ab-submenu-header',
+ ),
+ )
+ );
+
+ if ( Jetpack::is_module_active( 'publicize' ) || Jetpack::is_module_active( 'sharedaddy' ) ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'configuration',
+ 'id' => 'sharing',
+ 'title' => esc_html__( 'Sharing', 'jetpack' ),
+ 'href' => 'https://wordpress.com/sharing/' . esc_attr( $this->primary_site_slug ),
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+ }
+
+ $people_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/people/team/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-people',
+ 'label' => esc_html__( 'People', 'jetpack' ),
+ ),
+ array(
+ 'url' => admin_url( 'user-new.php' ),
+ 'id' => 'wp-admin-bar-people-add',
+ 'label' => esc_html_x( 'Add', 'admin bar people item label', 'jetpack' ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'configuration',
+ 'id' => 'users-toolbar',
+ 'title' => $people_title,
+ 'href' => false,
+ 'meta' => array(
+ 'class' => 'inline-action',
+ ),
+ )
+ );
+
+ $plugins_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/plugins/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-plugins',
+ 'label' => esc_html__( 'Plugins', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/plugins/manage/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-plugins-add',
+ 'label' => esc_html_x( 'Manage', 'Label for the button on the Masterbar to manage plugins', 'jetpack' ),
+ )
+ );
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'configuration',
+ 'id' => 'plugins',
+ 'title' => $plugins_title,
+ 'href' => false,
+ 'meta' => array(
+ 'class' => 'inline-action',
+ ),
+ )
+ );
+
+ if ( jetpack_is_atomic_site() ) {
+ $domain_title = $this->create_menu_item_pair(
+ array(
+ 'url' => 'https://wordpress.com/domains/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-domains',
+ 'label' => esc_html__( 'Domains', 'jetpack' ),
+ ),
+ array(
+ 'url' => 'https://wordpress.com/domains/add/' . esc_attr( $this->primary_site_slug ),
+ 'id' => 'wp-admin-bar-domains-add',
+ 'label' => esc_html_x( 'Add', 'Label for the button on the Masterbar to add a new domain', 'jetpack' ),
+ )
+ );
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'configuration',
+ 'id' => 'domains',
+ 'title' => $domain_title,
+ 'href' => false,
+ 'meta' => array(
+ 'class' => 'inline-action',
+ ),
+ )
+ );
+ }
+
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'configuration',
+ 'id' => 'blog-settings',
+ 'title' => esc_html__( 'Settings', 'jetpack' ),
+ 'href' => 'https://wordpress.com/settings/general/' . esc_attr( $this->primary_site_slug ),
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+
+ if ( ! is_admin() ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'parent' => 'configuration',
+ 'id' => 'legacy-dashboard',
+ 'title' => esc_html__( 'Dashboard', 'jetpack' ),
+ 'href' => admin_url(),
+ 'meta' => array(
+ 'class' => 'mb-icon',
+ ),
+ )
+ );
+ }
+
+ // Restore dashboard menu toggle that is needed on mobile views.
+ if ( is_admin() ) {
+ $wp_admin_bar->add_menu(
+ array(
+ 'id' => 'menu-toggle',
+ 'title' => '' . esc_html__( 'Menu', 'jetpack' ) . '',
+ 'href' => '#',
+ )
+ );
+ }
+
+ /**
+ * Fires when menu items are added to the masterbar "My Sites" menu.
+ *
+ * @since 5.4.0
+ */
+ do_action( 'jetpack_masterbar' );
+ }
+ }
}
diff --git a/modules/masterbar/tracks-events.js b/modules/masterbar/tracks-events.js
index 8364266cfd26c..a8993999f8e6c 100644
--- a/modules/masterbar/tracks-events.js
+++ b/modules/masterbar/tracks-events.js
@@ -9,6 +9,55 @@
'wp-admin-bar-ab-new-post': 'write_button',
'wp-admin-bar-my-account': 'my_account',
'wp-admin-bar-notes': 'notifications',
+ //my sites - top items
+ 'wp-admin-bar-switch-site': 'my_sites_switch_site',
+ 'wp-admin-bar-blog-info': 'my_sites_blog_info',
+ 'wp-admin-bar-site-view': 'my_sites_view_site',
+ 'wp-admin-bar-blog-stats': 'my_sites_blog_stats',
+ 'wp-admin-bar-activity': 'my_sites_activity',
+ 'wp-admin-bar-plan': 'my_sites_plan',
+ 'wp-admin-bar-plan-badge': 'my_sites_plan_badge',
+ //my sites - manage
+ 'wp-admin-bar-edit-page': 'my_sites_manage_site_pages',
+ 'wp-admin-bar-new-page-badge': 'my_sites_manage_add_page',
+ 'wp-admin-bar-edit-post': 'my_sites_manage_blog_posts',
+ 'wp-admin-bar-new-post-badge': 'my_sites_manage_add_new_post',
+ 'wp-admin-bar-edit-attachment': 'my_sites_manage_media',
+ 'wp-admin-bar-new-attachment-badge': 'my_sites_manage_add_media',
+ 'wp-admin-bar-comments': 'my_sites_manage_comments',
+ 'wp-admin-bar-edit-testimonial': 'my_sites_manage_testimonials',
+ 'wp-admin-bar-new-testimonial': 'my_sites_manage_add_testimonial',
+ 'wp-admin-bar-edit-portfolio': 'my_sites_manage_portfolio',
+ 'wp-admin-bar-new-portfolio': 'my_sites_manage_add_portfolio',
+ //my sites - personalize
+ 'wp-admin-bar-themes': 'my_sites_personalize_themes',
+ 'wp-admin-bar-cmz': 'my_sites_personalize_themes_customize',
+ //my sites - configure
+ 'wp-admin-bar-sharing': 'my_sites_configure_sharing',
+ 'wp-admin-bar-people': 'my_sites_configure_people',
+ 'wp-admin-bar-people-add': 'my_sites_configure_people_add_button',
+ 'wp-admin-bar-plugins': 'my_sites_configure_plugins',
+ 'wp-admin-bar-plugins-add': 'my_sites_configure_manage_plugins',
+ 'wp-admin-bar-blog-settings': 'my_sites_configure_settings',
+ //reader
+ 'wp-admin-bar-followed-sites': 'reader_followed_sites',
+ 'wp-admin-bar-reader-followed-sites-manage': 'reader_manage_followed_sites',
+ 'wp-admin-bar-discover-discover': 'reader_discover',
+ 'wp-admin-bar-discover-search': 'reader_search',
+ 'wp-admin-bar-discover-recommended-blogs': 'reader_recommendations',
+ 'wp-admin-bar-my-activity-my-likes': 'reader_my_likes',
+ //account
+ 'wp-admin-bar-user-info': 'my_account_user_name',
+ // account - profile
+ 'wp-admin-bar-my-profile': 'my_account_profile_my_profile',
+ 'wp-admin-bar-account-settings': 'my_account_profile_account_settings',
+ 'wp-admin-bar-billing': 'my_account_profile_manage_purchases',
+ 'wp-admin-bar-security': 'my_account_profile_security',
+ 'wp-admin-bar-notifications': 'my_account_profile_notifications',
+ //account - special
+ 'wp-admin-bar-get-apps': 'my_account_special_get_apps',
+ 'wp-admin-bar-next-steps': 'my_account_special_next_steps',
+ 'wp-admin-bar-help': 'my_account_special_help',
};
var notesTracksEvents = {
diff --git a/sync/class.jetpack-sync-module-users.php b/sync/class.jetpack-sync-module-users.php
index e74d7116c6328..f1cb47325c9bd 100644
--- a/sync/class.jetpack-sync-module-users.php
+++ b/sync/class.jetpack-sync-module-users.php
@@ -55,6 +55,7 @@ public function init_listeners( $callable ) {
add_action( 'jetpack_wp_login', $callable, 10, 3 );
add_action( 'wp_logout', $callable, 10, 0 );
+ add_action( 'wp_masterbar_logout', $callable, 10, 0 );
// Add on init
add_filter( 'jetpack_sync_before_enqueue_jetpack_sync_add_user', array( $this, 'expand_action' ) );