Completed
Push — renovate/wordpress-monorepo ( 8cdadc...6203b6 )
by
unknown
552:54 queued 542:45
created

Jetpack_Admin_Menu::dequeue_scripts()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
nc 1
nop 0
dl 0
loc 3
rs 10
c 0
b 0
f 0
1
<?php
2
/**
3
 * Jetpack Admin Menu file.
4
 *
5
 * @package Jetpack
6
 */
7
8
namespace Automattic\Jetpack\Dashboard_Customizations;
9
10
require_once __DIR__ . '/class-admin-menu.php';
11
12
/**
13
 * Class Jetpack_Admin_Menu.
14
 */
15
class Jetpack_Admin_Menu extends Admin_Menu {
16
17
	/**
18
	 * Jetpack_Admin_Menu constructor.
19
	 */
20
	public function __construct() {
21
		parent::__construct();
22
23
		add_action( 'wp_enqueue_scripts', array( $this, 'dequeue_scripts' ), 20 );
24
		add_action( 'admin_enqueue_scripts', array( $this, 'dequeue_scripts' ), 20 );
25
	}
26
27
	/**
28
	 * Dequeues unnecessary scripts.
29
	 */
30
	public function dequeue_scripts() {
31
		wp_dequeue_script( 'a8c_wpcom_masterbar_overrides' ); // Initially loaded in modules/masterbar/masterbar/class-masterbar.php.
32
	}
33
34
	/**
35
	 * Create the desired menu output.
36
	 */
37
	public function reregister_menu_items() {
38
		global $menu, $submenu;
39
40
		// Change the menu only when rendered in Calypso.
41
		if ( $this->is_api_request || ( defined( 'REST_REQUEST' ) && REST_REQUEST ) ) {
42
			// Reset menus so there are no third-party plugin items.
43
			$menu    = array(); // phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited
44
			$submenu = array(); // phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited
45
46
			parent::reregister_menu_items();
47
48
			$this->add_feedback_menu();
49
			$this->add_wp_admin_menu();
50
51
			ksort( $GLOBALS['menu'] );
52
		}
53
	}
54
55
	/**
56
	 * Whether to use wp-admin pages rather than Calypso.
57
	 *
58
	 * @return bool
59
	 */
60
	public function should_link_to_wp_admin() {
61
		// Force Calypso links on Jetpack sites since Nav Unification is disabled on WP Admin.
62
		return false;
63
	}
64
65
	/**
66
	 * Adds Posts menu.
67
	 *
68
	 * @param bool $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
69
	 */
70
	public function add_posts_menu( $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
71
		$post = get_post_type_object( 'post' );
72
		add_menu_page( esc_attr( $post->labels->menu_name ), $post->labels->menu_name, $post->cap->edit_posts, 'https://wordpress.com/posts/' . $this->domain, null, 'dashicons-admin-post' );
73
	}
74
75
	/**
76
	 * Adds Media menu.
77
	 *
78
	 * @param bool $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
79
	 */
80
	public function add_media_menu( $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
81
		add_menu_page( __( 'Media', 'jetpack' ), __( 'Media', 'jetpack' ), 'upload_files', 'https://wordpress.com/media/' . $this->domain, null, 'dashicons-admin-media' );
82
	}
83
84
	/**
85
	 * Adds Page menu.
86
	 *
87
	 * @param bool $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
88
	 */
89
	public function add_page_menu( $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
90
		$page = get_post_type_object( 'page' );
91
		add_menu_page( esc_attr( $page->labels->menu_name ), $page->labels->menu_name, $page->cap->edit_posts, 'https://wordpress.com/pages/' . $this->domain, null, 'dashicons-admin-page' );
92
	}
93
94
	/**
95
	 * Adds a custom post type menu.
96
	 *
97
	 * @param string $post_type Custom post type.
98
	 * @param bool   $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
99
	 */
100
	public function add_custom_post_type_menu( $post_type, $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
101
		$ptype_obj = get_post_type_object( $post_type );
102
		if ( empty( $ptype_obj ) ) {
103
			return;
104
		}
105
106
		$menu_slug = 'https://wordpress.com/types/' . $post_type . '/' . $this->domain;
107
108
		// Menu icon.
109
		$menu_icon = 'dashicons-admin-post';
110
		if ( is_string( $ptype_obj->menu_icon ) ) {
111
			// Special handling for data:image/svg+xml and Dashicons.
112
			if ( 0 === strpos( $ptype_obj->menu_icon, 'data:image/svg+xml;base64,' ) || 0 === strpos( $ptype_obj->menu_icon, 'dashicons-' ) ) {
113
				$menu_icon = $ptype_obj->menu_icon;
114
			} else {
115
				$menu_icon = esc_url( $ptype_obj->menu_icon );
116
			}
117
		}
118
119
		add_menu_page( esc_attr( $ptype_obj->labels->menu_name ), $ptype_obj->labels->menu_name, $ptype_obj->cap->edit_posts, $menu_slug, null, $menu_icon );
120
	}
121
122
	/**
123
	 * Adds Comments menu.
124
	 *
125
	 * @param bool $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
126
	 */
127
	public function add_comments_menu( $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
128
		add_menu_page( esc_attr__( 'Comments', 'jetpack' ), __( 'Comments', 'jetpack' ), 'edit_posts', 'https://wordpress.com/comments/all/' . $this->domain, null, 'dashicons-admin-comments' );
129
	}
130
131
	/**
132
	 * Adds Feedback menu.
133
	 */
134
	public function add_feedback_menu() {
135
		$post_type = 'feedback';
136
137
		$ptype_obj = get_post_type_object( $post_type );
138
		if ( empty( $ptype_obj ) ) {
139
			return;
140
		}
141
142
		$slug       = 'edit.php?post_type=' . $post_type;
143
		$name       = $ptype_obj->labels->menu_name;
144
		$capability = $ptype_obj->cap->edit_posts;
145
		$icon       = $ptype_obj->menu_icon;
146
		$position   = 45; // Before Jetpack.
147
148
		add_menu_page( esc_attr( $name ), $name, $capability, $slug, null, $icon, $position );
149
	}
150
151
	/**
152
	 * Adds Jetpack menu.
153
	 */
154
	public function add_jetpack_menu() {
155
		parent::add_jetpack_menu();
156
157
		// Place "Scan" submenu after Backup.
158
		$position = 0;
159
		global $submenu;
160
		foreach ( $submenu['jetpack'] as $submenu_item ) {
161
			$position ++;
162
			if ( __( 'Backup', 'jetpack' ) === $submenu_item[3] ) {
163
				break;
164
			}
165
		}
166
		add_submenu_page( 'jetpack', esc_attr__( 'Scan', 'jetpack' ), __( 'Scan', 'jetpack' ), 'manage_options', 'https://wordpress.com/scan/' . $this->domain, null, $position );
167
	}
168
169
	/**
170
	 * Adds Appearance menu.
171
	 *
172
	 * @param bool $wp_admin_themes Optional. Whether Themes link should point to Calypso or wp-admin. Default false (Calypso).
173
	 * @param bool $wp_admin_customize Optional. Whether Customize link should point to Calypso or wp-admin. Default false (Calypso).
174
	 */
175
	public function add_appearance_menu( $wp_admin_themes = false, $wp_admin_customize = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
176
		add_menu_page( esc_attr__( 'Appearance', 'jetpack' ), __( 'Appearance', 'jetpack' ), 'switch_themes', 'https://wordpress.com/themes/' . $this->domain, null, 'dashicons-admin-appearance', 60 );
177
		add_submenu_page( 'themes.php', esc_attr__( 'Themes', 'jetpack' ), __( 'Themes', 'jetpack' ), 'switch_themes', 'https://wordpress.com/themes/' . $this->domain );
178
		// Customize on Jetpack sites is always done on WP Admin (unsupported by Calypso).
179
		add_submenu_page( 'themes.php', esc_attr__( 'Customize', 'jetpack' ), __( 'Customize', 'jetpack' ), 'customize', 'customize.php' );
180
	}
181
182
	/**
183
	 * Adds Plugins menu.
184
	 *
185
	 * @param bool $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
186
	 */
187
	public function add_plugins_menu( $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
188
		add_menu_page( esc_attr__( 'Plugins', 'jetpack' ), __( 'Plugins', 'jetpack' ), 'activate_plugins', 'https://wordpress.com/plugins/' . $this->domain, null, 'dashicons-admin-plugins', 65 );
189
	}
190
191
	/**
192
	 * Adds Users menu.
193
	 *
194
	 * @param bool $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
195
	 */
196 View Code Duplication
	public function add_users_menu( $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
197
		if ( current_user_can( 'list_users' ) ) {
198
			add_menu_page( esc_attr__( 'Users', 'jetpack' ), __( 'Users', 'jetpack' ), 'list_users', 'https://wordpress.com/people/team/' . $this->domain, null, 'dashicons-admin-users', 70 );
199
		} else {
200
			add_menu_page( esc_attr__( 'My Profile', 'jetpack' ), __( 'Profile', 'jetpack' ), 'read', 'https://wordpress.com/me', null, 'dashicons-admin-users', 70 );
201
		}
202
	}
203
204
	/**
205
	 * Adds Tools menu.
206
	 *
207
	 * @param bool $wp_admin_import Optional. Whether Import link should point to Calypso or wp-admin. Default false (Calypso).
208
	 * @param bool $wp_admin_export Optional. Whether Export link should point to Calypso or wp-admin. Default false (Calypso).
209
	 */
210
	public function add_tools_menu( $wp_admin_import = false, $wp_admin_export = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
211
		add_menu_page( esc_attr__( 'Tools', 'jetpack' ), __( 'Tools', 'jetpack' ), 'publish_posts', 'tools.php', null, 'dashicons-admin-tools', 75 );
212
213
		add_submenu_page( 'tools.php', esc_attr__( 'Marketing', 'jetpack' ), __( 'Marketing', 'jetpack' ), 'publish_posts', 'https://wordpress.com/marketing/tools/' . $this->domain );
214
		add_submenu_page( 'tools.php', esc_attr__( 'Earn', 'jetpack' ), __( 'Earn', 'jetpack' ), 'manage_options', 'https://wordpress.com/earn/' . $this->domain );
215
216
		// Import/Export on Jetpack sites is always handled on WP Admin.
217
		add_submenu_page( 'tools.php', esc_attr__( 'Import', 'jetpack' ), __( 'Import', 'jetpack' ), 'import', 'import.php' );
218
		add_submenu_page( 'tools.php', esc_attr__( 'Export', 'jetpack' ), __( 'Export', 'jetpack' ), 'export', 'export.php' );
219
220
		// Remove the submenu auto-created by Core.
221
		remove_submenu_page( 'tools.php', 'tools.php' );
222
	}
223
224
	/**
225
	 * Adds Settings menu.
226
	 *
227
	 * @param bool $wp_admin Optional. Whether links should point to Calypso or wp-admin. Default false (Calypso).
228
	 */
229
	public function add_options_menu( $wp_admin = false ) { // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
230
		add_menu_page( esc_attr__( 'Settings', 'jetpack' ), __( 'Settings', 'jetpack' ), 'manage_options', 'https://wordpress.com/settings/general/' . $this->domain, null, 'dashicons-admin-settings', 80 );
231
	}
232
233
	/**
234
	 * Adds WP Admin menu.
235
	 */
236
	public function add_wp_admin_menu() {
237
		global $menu;
238
239
		// Attempt to get last position.
240
		ksort( $menu );
241
		end( $menu );
242
		$position = key( $menu );
243
244
		$this->add_admin_menu_separator( ++ $position );
245
		add_menu_page( __( 'WP Admin', 'jetpack' ), __( 'WP Admin', 'jetpack' ), 'read', 'index.php', null, 'dashicons-wordpress-alt', $position );
246
	}
247
}
248