Completed
Pull Request — master (#37)
by
unknown
02:21 queued 34s
created
includes/wp-api-menus-v2.php 2 patches
Indentation   +337 added lines, -337 removed lines patch added patch discarded remove patch
@@ -6,269 +6,269 @@  discard block
 block discarded – undo
6 6
  */
7 7
 
8 8
 if ( ! defined( 'ABSPATH' ) ) {
9
-    exit; // Exit if accessed directly
9
+	exit; // Exit if accessed directly
10 10
 }
11 11
 
12 12
 if ( ! class_exists( 'WP_REST_Menus' ) ) :
13 13
 
14 14
 
15
-    /**
16
-     * WP REST Menus class.
17
-     *
18
-     * WP API Menus support for WP API v2.
19
-     *
20
-     * @package WP_API_Menus
21
-     * @since 1.2.0
22
-     */
23
-    class WP_REST_Menus {
24
-
25
-
26
-	    /**
27
-	     * Get WP API namespace.
28
-	     *
29
-	     * @since 1.2.0
30
-	     * @return string
31
-	     */
32
-        public static function get_api_namespace() {
33
-            return 'wp/v2';
34
-        }
35
-
36
-
37
-	    /**
38
-	     * Get WP API Menus namespace.
39
-	     *
40
-	     * @since 1.2.1
41
-	     * @return string
42
-	     */
43
-	    public static function get_plugin_namespace() {
44
-		    return 'wp-api-menus/v2';
45
-	    }
46
-
47
-
48
-        /**
49
-         * Register menu routes for WP API v2.
50
-         *
51
-         * @since  1.2.0
52
-         */
53
-        public function register_routes() {
54
-
55
-            register_rest_route( self::get_plugin_namespace(), '/menus', array(
56
-                array(
57
-                    'methods'  => WP_REST_Server::READABLE,
58
-                    'callback' => array( $this, 'get_menus' ),
59
-                )
60
-            ) );
61
-
62
-            register_rest_route( self::get_plugin_namespace(), '/menus/(?P<id>\d+)', array(
63
-                array(
64
-                    'methods'  => WP_REST_Server::READABLE,
65
-                    'callback' => array( $this, 'get_menu' ),
66
-                    'args'     => array(
67
-                        'context' => array(
68
-                        'default' => 'view',
69
-                        ),
70
-                    ),
71
-                )
72
-            ) );
73
-
74
-            register_rest_route( self::get_plugin_namespace(), '/menu-locations', array(
75
-                array(
76
-                    'methods'  => WP_REST_Server::READABLE,
77
-                    'callback' => array( $this, 'get_menu_locations' ),
78
-                )
79
-            ) );
80
-
81
-            register_rest_route( self::get_plugin_namespace(), '/menu-locations/(?P<location>[a-zA-Z0-9_-]+)', array(
82
-                array(
83
-                    'methods'  => WP_REST_Server::READABLE,
84
-                    'callback' => array( $this, 'get_menu_location' ),
85
-                )
86
-            ) );
87
-        }
88
-
89
-
90
-        /**
91
-         * Get menus.
92
-         *
93
-         * @since  1.2.0
94
-         * @return array All registered menus
95
-         */
96
-        public static function get_menus() {
97
-
98
-            $rest_url = trailingslashit( get_rest_url() . self::get_plugin_namespace() . '/menus/' );
99
-            $wp_menus = wp_get_nav_menus();
100
-
101
-            $i = 0;
102
-            $rest_menus = array();
103
-            foreach ( $wp_menus as $wp_menu ) :
104
-
105
-                $menu = (array) $wp_menu;
106
-
107
-                $rest_menus[ $i ]                = $menu;
108
-                $rest_menus[ $i ]['ID']          = $menu['term_id'];
109
-                $rest_menus[ $i ]['name']        = $menu['name'];
110
-                $rest_menus[ $i ]['slug']        = $menu['slug'];
111
-                $rest_menus[ $i ]['description'] = $menu['description'];
112
-                $rest_menus[ $i ]['count']       = $menu['count'];
113
-
114
-                $rest_menus[ $i ]['meta']['links']['collection'] = $rest_url;
115
-                $rest_menus[ $i ]['meta']['links']['self']       = $rest_url . $menu['term_id'];
116
-
117
-                $i ++;
118
-            endforeach;
119
-
120
-            return apply_filters( 'rest_menus_format_menus', $rest_menus );
121
-        }
122
-
123
-
124
-        /**
125
-         * Get a menu.
126
-         *
127
-         * @since  1.2.0
128
-         * @param  $request
129
-         * @return array Menu data
130
-         */
131
-        public function get_menu( $request ) {
132
-
133
-            $id             = (int) $request['id'];
134
-            $rest_url       = get_rest_url() . self::get_api_namespace() . '/menus/';
135
-            $wp_menu_object = $id ? wp_get_nav_menu_object( $id ) : array();
136
-            $wp_menu_items  = $id ? wp_get_nav_menu_items( $id ) : array();
137
-
138
-            $rest_menu = array();
139
-
140
-            if ( $wp_menu_object ) :
141
-
142
-                $menu = (array) $wp_menu_object;
143
-                $rest_menu['ID']          = abs( $menu['term_id'] );
144
-                $rest_menu['name']        = $menu['name'];
145
-                $rest_menu['slug']        = $menu['slug'];
146
-                $rest_menu['description'] = $menu['description'];
147
-                $rest_menu['count']       = abs( $menu['count'] );
148
-
149
-                $rest_menu_items = array();
150
-                foreach ( $wp_menu_items as $item_object ) {
151
-	                $rest_menu_items[] = $this->format_menu_item( $item_object );
152
-                }
153
-
154
-                $rest_menu_items = $this->nested_menu_items($rest_menu_items, 0);
155
-
156
-                $rest_menu['items']                       = $rest_menu_items;
157
-                $rest_menu['meta']['links']['collection'] = $rest_url;
158
-                $rest_menu['meta']['links']['self']       = $rest_url . $id;
159
-
160
-            endif;
161
-
162
-            return apply_filters( 'rest_menus_format_menu', $rest_menu );
163
-        }
164
-
165
-
166
-        /**
167
-         * Handle nested menu items.
168
-         *
169
-         * Given a flat array of menu items, split them into parent/child items
170
-         * and recurse over them to return children nested in their parent.
171
-         *
172
-         * @since  1.2.0
173
-         * @param  $menu_items
174
-         * @param  $parent
175
-         * @return array
176
-         */
177
-        private function nested_menu_items( &$menu_items, $parent = null ) {
178
-
179
-            $parents = array();
180
-            $children = array();
181
-
182
-            // Separate menu_items into parents & children.
183
-            array_map( function( $i ) use ( $parent, &$children, &$parents ){
184
-                if ( $i['id'] != $parent && $i['parent'] == $parent ) {
185
-                    $parents[] = $i;
186
-                } else {
187
-                    $children[] = $i;
188
-                }
189
-            }, $menu_items );
190
-
191
-            foreach ( $parents as &$parent ) {
192
-
193
-                if ( $this->has_children( $children, $parent['id'] ) ) {
194
-                    $parent['children'] = $this->nested_menu_items( $children, $parent['id'] );
195
-                }
196
-            }
197
-
198
-            return $parents;
199
-        }
200
-
201
-
202
-        /**
203
-         * Check if a collection of menu items contains an item that is the parent id of 'id'.
204
-         *
205
-         * @since  1.2.0
206
-         * @param  array $items
207
-         * @param  int $id
208
-         * @return array
209
-         */
210
-        private function has_children( $items, $id ) {
211
-            return array_filter( $items, function( $i ) use ( $id ) {
212
-                return $i['parent'] == $id;
213
-            } );
214
-        }
215
-
216
-
217
-        /**
218
-         * Get menu locations.
219
-         *
220
-         * @since 1.2.0
221
-         * @param  $request
222
-         * @return array All registered menus locations
223
-         */
224
-        public static function get_menu_locations( $request ) {
225
-
226
-            $locations        = get_nav_menu_locations();
227
-            $registered_menus = get_registered_nav_menus();
228
-	        $rest_url         = get_rest_url() . self::get_api_namespace() . '/menu-locations/';
229
-            $rest_menus       = array();
230
-
231
-            if ( $locations && $registered_menus ) :
232
-
233
-                foreach ( $registered_menus as $slug => $label ) :
234
-
235
-	                // Sanity check
236
-	                if ( ! isset( $locations[ $slug ] ) ) {
237
-		                continue;
238
-	                }
239
-
240
-	                $rest_menus[ $slug ]['ID']                          = $locations[ $slug ];
241
-                    $rest_menus[ $slug ]['label']                       = $label;
242
-                    $rest_menus[ $slug ]['meta']['links']['collection'] = $rest_url;
243
-                    $rest_menus[ $slug ]['meta']['links']['self']       = $rest_url . $slug;
244
-
245
-                endforeach;
246
-
247
-            endif;
248
-
249
-            return $rest_menus;
250
-        }
251
-
252
-
253
-        /**
254
-         * Get menu for location.
255
-         *
256
-         * @since 1.2.0
257
-         * @param  $request
258
-         * @return array The menu for the corresponding location
259
-         */
260
-        public function get_menu_location( $request ) {
261
-
262
-            $params     = $request->get_params();
263
-            $location   = $params['location'];
264
-            $locations  = get_nav_menu_locations();
265
-
266
-            if ( ! isset( $locations[ $location ] ) ) {
267
-	            return array();
268
-            }
269
-
270
-            $wp_menu = wp_get_nav_menu_object( $locations[ $location ] );
271
-            $menu_items = wp_get_nav_menu_items( $wp_menu->term_id );
15
+	/**
16
+	 * WP REST Menus class.
17
+	 *
18
+	 * WP API Menus support for WP API v2.
19
+	 *
20
+	 * @package WP_API_Menus
21
+	 * @since 1.2.0
22
+	 */
23
+	class WP_REST_Menus {
24
+
25
+
26
+		/**
27
+		 * Get WP API namespace.
28
+		 *
29
+		 * @since 1.2.0
30
+		 * @return string
31
+		 */
32
+		public static function get_api_namespace() {
33
+			return 'wp/v2';
34
+		}
35
+
36
+
37
+		/**
38
+		 * Get WP API Menus namespace.
39
+		 *
40
+		 * @since 1.2.1
41
+		 * @return string
42
+		 */
43
+		public static function get_plugin_namespace() {
44
+			return 'wp-api-menus/v2';
45
+		}
46
+
47
+
48
+		/**
49
+		 * Register menu routes for WP API v2.
50
+		 *
51
+		 * @since  1.2.0
52
+		 */
53
+		public function register_routes() {
54
+
55
+			register_rest_route( self::get_plugin_namespace(), '/menus', array(
56
+				array(
57
+					'methods'  => WP_REST_Server::READABLE,
58
+					'callback' => array( $this, 'get_menus' ),
59
+				)
60
+			) );
61
+
62
+			register_rest_route( self::get_plugin_namespace(), '/menus/(?P<id>\d+)', array(
63
+				array(
64
+					'methods'  => WP_REST_Server::READABLE,
65
+					'callback' => array( $this, 'get_menu' ),
66
+					'args'     => array(
67
+						'context' => array(
68
+						'default' => 'view',
69
+						),
70
+					),
71
+				)
72
+			) );
73
+
74
+			register_rest_route( self::get_plugin_namespace(), '/menu-locations', array(
75
+				array(
76
+					'methods'  => WP_REST_Server::READABLE,
77
+					'callback' => array( $this, 'get_menu_locations' ),
78
+				)
79
+			) );
80
+
81
+			register_rest_route( self::get_plugin_namespace(), '/menu-locations/(?P<location>[a-zA-Z0-9_-]+)', array(
82
+				array(
83
+					'methods'  => WP_REST_Server::READABLE,
84
+					'callback' => array( $this, 'get_menu_location' ),
85
+				)
86
+			) );
87
+		}
88
+
89
+
90
+		/**
91
+		 * Get menus.
92
+		 *
93
+		 * @since  1.2.0
94
+		 * @return array All registered menus
95
+		 */
96
+		public static function get_menus() {
97
+
98
+			$rest_url = trailingslashit( get_rest_url() . self::get_plugin_namespace() . '/menus/' );
99
+			$wp_menus = wp_get_nav_menus();
100
+
101
+			$i = 0;
102
+			$rest_menus = array();
103
+			foreach ( $wp_menus as $wp_menu ) :
104
+
105
+				$menu = (array) $wp_menu;
106
+
107
+				$rest_menus[ $i ]                = $menu;
108
+				$rest_menus[ $i ]['ID']          = $menu['term_id'];
109
+				$rest_menus[ $i ]['name']        = $menu['name'];
110
+				$rest_menus[ $i ]['slug']        = $menu['slug'];
111
+				$rest_menus[ $i ]['description'] = $menu['description'];
112
+				$rest_menus[ $i ]['count']       = $menu['count'];
113
+
114
+				$rest_menus[ $i ]['meta']['links']['collection'] = $rest_url;
115
+				$rest_menus[ $i ]['meta']['links']['self']       = $rest_url . $menu['term_id'];
116
+
117
+				$i ++;
118
+			endforeach;
119
+
120
+			return apply_filters( 'rest_menus_format_menus', $rest_menus );
121
+		}
122
+
123
+
124
+		/**
125
+		 * Get a menu.
126
+		 *
127
+		 * @since  1.2.0
128
+		 * @param  $request
129
+		 * @return array Menu data
130
+		 */
131
+		public function get_menu( $request ) {
132
+
133
+			$id             = (int) $request['id'];
134
+			$rest_url       = get_rest_url() . self::get_api_namespace() . '/menus/';
135
+			$wp_menu_object = $id ? wp_get_nav_menu_object( $id ) : array();
136
+			$wp_menu_items  = $id ? wp_get_nav_menu_items( $id ) : array();
137
+
138
+			$rest_menu = array();
139
+
140
+			if ( $wp_menu_object ) :
141
+
142
+				$menu = (array) $wp_menu_object;
143
+				$rest_menu['ID']          = abs( $menu['term_id'] );
144
+				$rest_menu['name']        = $menu['name'];
145
+				$rest_menu['slug']        = $menu['slug'];
146
+				$rest_menu['description'] = $menu['description'];
147
+				$rest_menu['count']       = abs( $menu['count'] );
148
+
149
+				$rest_menu_items = array();
150
+				foreach ( $wp_menu_items as $item_object ) {
151
+					$rest_menu_items[] = $this->format_menu_item( $item_object );
152
+				}
153
+
154
+				$rest_menu_items = $this->nested_menu_items($rest_menu_items, 0);
155
+
156
+				$rest_menu['items']                       = $rest_menu_items;
157
+				$rest_menu['meta']['links']['collection'] = $rest_url;
158
+				$rest_menu['meta']['links']['self']       = $rest_url . $id;
159
+
160
+			endif;
161
+
162
+			return apply_filters( 'rest_menus_format_menu', $rest_menu );
163
+		}
164
+
165
+
166
+		/**
167
+		 * Handle nested menu items.
168
+		 *
169
+		 * Given a flat array of menu items, split them into parent/child items
170
+		 * and recurse over them to return children nested in their parent.
171
+		 *
172
+		 * @since  1.2.0
173
+		 * @param  $menu_items
174
+		 * @param  $parent
175
+		 * @return array
176
+		 */
177
+		private function nested_menu_items( &$menu_items, $parent = null ) {
178
+
179
+			$parents = array();
180
+			$children = array();
181
+
182
+			// Separate menu_items into parents & children.
183
+			array_map( function( $i ) use ( $parent, &$children, &$parents ){
184
+				if ( $i['id'] != $parent && $i['parent'] == $parent ) {
185
+					$parents[] = $i;
186
+				} else {
187
+					$children[] = $i;
188
+				}
189
+			}, $menu_items );
190
+
191
+			foreach ( $parents as &$parent ) {
192
+
193
+				if ( $this->has_children( $children, $parent['id'] ) ) {
194
+					$parent['children'] = $this->nested_menu_items( $children, $parent['id'] );
195
+				}
196
+			}
197
+
198
+			return $parents;
199
+		}
200
+
201
+
202
+		/**
203
+		 * Check if a collection of menu items contains an item that is the parent id of 'id'.
204
+		 *
205
+		 * @since  1.2.0
206
+		 * @param  array $items
207
+		 * @param  int $id
208
+		 * @return array
209
+		 */
210
+		private function has_children( $items, $id ) {
211
+			return array_filter( $items, function( $i ) use ( $id ) {
212
+				return $i['parent'] == $id;
213
+			} );
214
+		}
215
+
216
+
217
+		/**
218
+		 * Get menu locations.
219
+		 *
220
+		 * @since 1.2.0
221
+		 * @param  $request
222
+		 * @return array All registered menus locations
223
+		 */
224
+		public static function get_menu_locations( $request ) {
225
+
226
+			$locations        = get_nav_menu_locations();
227
+			$registered_menus = get_registered_nav_menus();
228
+			$rest_url         = get_rest_url() . self::get_api_namespace() . '/menu-locations/';
229
+			$rest_menus       = array();
230
+
231
+			if ( $locations && $registered_menus ) :
232
+
233
+				foreach ( $registered_menus as $slug => $label ) :
234
+
235
+					// Sanity check
236
+					if ( ! isset( $locations[ $slug ] ) ) {
237
+						continue;
238
+					}
239
+
240
+					$rest_menus[ $slug ]['ID']                          = $locations[ $slug ];
241
+					$rest_menus[ $slug ]['label']                       = $label;
242
+					$rest_menus[ $slug ]['meta']['links']['collection'] = $rest_url;
243
+					$rest_menus[ $slug ]['meta']['links']['self']       = $rest_url . $slug;
244
+
245
+				endforeach;
246
+
247
+			endif;
248
+
249
+			return $rest_menus;
250
+		}
251
+
252
+
253
+		/**
254
+		 * Get menu for location.
255
+		 *
256
+		 * @since 1.2.0
257
+		 * @param  $request
258
+		 * @return array The menu for the corresponding location
259
+		 */
260
+		public function get_menu_location( $request ) {
261
+
262
+			$params     = $request->get_params();
263
+			$location   = $params['location'];
264
+			$locations  = get_nav_menu_locations();
265
+
266
+			if ( ! isset( $locations[ $location ] ) ) {
267
+				return array();
268
+			}
269
+
270
+			$wp_menu = wp_get_nav_menu_object( $locations[ $location ] );
271
+			$menu_items = wp_get_nav_menu_items( $wp_menu->term_id );
272 272
 
273 273
 			/**
274 274
 			 * wp_get_nav_menu_items() outputs a list that's already sequenced correctly.
@@ -281,14 +281,14 @@  discard block
 block discarded – undo
281 281
 
282 282
 			foreach ( $rev_items as $item ) :
283 283
 
284
-                $post_id = url_to_postid( $item->url );
284
+				$post_id = url_to_postid( $item->url );
285 285
 				$formatted = array(
286 286
 					'ID'          => abs( $item->ID ),
287 287
 					'order'       => (int) $item->menu_order,
288 288
 					'parent'      => abs( $item->menu_item_parent ),
289 289
 					'title'       => $item->title,
290 290
 					'url'         => $item->url,
291
-                    'thumbnail'   => has_post_thumbnail( $post_id ) ? get_the_post_thumbnail_url( $post_id ) : '',
291
+					'thumbnail'   => has_post_thumbnail( $post_id ) ? get_the_post_thumbnail_url( $post_id ) : '',
292 292
 					'attr'        => $item->attr_title,
293 293
 					'target'      => $item->target,
294 294
 					'classes'     => implode( ' ', $item->classes ),
@@ -305,7 +305,7 @@  discard block
 block discarded – undo
305 305
 					$formatted['children'] = array_reverse( $cache[ $item->ID ] );
306 306
 				}
307 307
 
308
-            	$formatted = apply_filters( 'rest_menus_format_menu_item', $formatted );
308
+				$formatted = apply_filters( 'rest_menus_format_menu_item', $formatted );
309 309
 
310 310
 				if ( $item->menu_item_parent != 0 ) {
311 311
 
@@ -323,82 +323,82 @@  discard block
 block discarded – undo
323 323
 			endforeach;
324 324
 
325 325
 			return array_reverse ( $rev_menu );
326
-        }
327
-
328
-
329
-        /**
330
-         * Returns all child nav_menu_items under a specific parent.
331
-         *
332
-         * @since   1.2.0
333
-         * @param int   $parent_id      The parent nav_menu_item ID
334
-         * @param array $nav_menu_items Navigation menu items
335
-         * @param bool  $depth          Gives all children or direct children only
336
-         * @return array	returns filtered array of nav_menu_items
337
-         */
338
-        public function get_nav_menu_item_children( $parent_id, $nav_menu_items, $depth = true ) {
339
-
340
-            $nav_menu_item_list = array();
341
-
342
-            foreach ( (array) $nav_menu_items as $nav_menu_item ) :
343
-
344
-                if ( $nav_menu_item->menu_item_parent == $parent_id ) :
345
-
346
-                    $nav_menu_item_list[] = $this->format_menu_item( $nav_menu_item, true, $nav_menu_items );
347
-
348
-                    if ( $depth ) {
349
-                        if ( $children = $this->get_nav_menu_item_children( $nav_menu_item->ID, $nav_menu_items ) ) {
350
-                            $nav_menu_item_list = array_merge( $nav_menu_item_list, $children );
351
-                        }
352
-                    }
353
-
354
-                endif;
355
-
356
-            endforeach;
357
-
358
-            return $nav_menu_item_list;
359
-        }
360
-
361
-
362
-        /**
363
-         * Format a menu item for REST API consumption.
364
-         *
365
-         * @since  1.2.0
366
-         * @param  object|array $menu_item  The menu item
367
-         * @param  bool         $children   Get menu item children (default false)
368
-         * @param  array        $menu       The menu the item belongs to (used when $children is set to true)
369
-         * @return array	a formatted menu item for REST
370
-         */
371
-        public function format_menu_item( $menu_item, $children = false, $menu = array() ) {
372
-
373
-            $item = (array) $menu_item;
374
-
375
-            $menu_item = array(
376
-                'id'          => abs( $item['ID'] ),
377
-                'order'       => (int) $item['menu_order'],
378
-                'parent'      => abs( $item['menu_item_parent'] ),
379
-                'title'       => $item['title'],
380
-                'url'         => $item['url'],
381
-                'attr'        => $item['attr_title'],
382
-                'target'      => $item['target'],
383
-                'classes'     => implode( ' ', $item['classes'] ),
384
-                'xfn'         => $item['xfn'],
385
-                'description' => $item['description'],
386
-                'object_id'   => abs( $item['object_id'] ),
387
-                'object'      => $item['object'],
388
-                'object_slug' => get_post( $item['object_id'] )->post_name,
389
-                'type'        => $item['type'],
390
-                'type_label'  => $item['type_label'],
391
-            );
392
-
393
-            if ( $children === true && ! empty( $menu ) ) {
394
-	            $menu_item['children'] = $this->get_nav_menu_item_children( $item['ID'], $menu );
395
-            }
396
-
397
-            return apply_filters( 'rest_menus_format_menu_item', $menu_item );
398
-        }
399
-
400
-
401
-    }
326
+		}
327
+
328
+
329
+		/**
330
+		 * Returns all child nav_menu_items under a specific parent.
331
+		 *
332
+		 * @since   1.2.0
333
+		 * @param int   $parent_id      The parent nav_menu_item ID
334
+		 * @param array $nav_menu_items Navigation menu items
335
+		 * @param bool  $depth          Gives all children or direct children only
336
+		 * @return array	returns filtered array of nav_menu_items
337
+		 */
338
+		public function get_nav_menu_item_children( $parent_id, $nav_menu_items, $depth = true ) {
339
+
340
+			$nav_menu_item_list = array();
341
+
342
+			foreach ( (array) $nav_menu_items as $nav_menu_item ) :
343
+
344
+				if ( $nav_menu_item->menu_item_parent == $parent_id ) :
345
+
346
+					$nav_menu_item_list[] = $this->format_menu_item( $nav_menu_item, true, $nav_menu_items );
347
+
348
+					if ( $depth ) {
349
+						if ( $children = $this->get_nav_menu_item_children( $nav_menu_item->ID, $nav_menu_items ) ) {
350
+							$nav_menu_item_list = array_merge( $nav_menu_item_list, $children );
351
+						}
352
+					}
353
+
354
+				endif;
355
+
356
+			endforeach;
357
+
358
+			return $nav_menu_item_list;
359
+		}
360
+
361
+
362
+		/**
363
+		 * Format a menu item for REST API consumption.
364
+		 *
365
+		 * @since  1.2.0
366
+		 * @param  object|array $menu_item  The menu item
367
+		 * @param  bool         $children   Get menu item children (default false)
368
+		 * @param  array        $menu       The menu the item belongs to (used when $children is set to true)
369
+		 * @return array	a formatted menu item for REST
370
+		 */
371
+		public function format_menu_item( $menu_item, $children = false, $menu = array() ) {
372
+
373
+			$item = (array) $menu_item;
374
+
375
+			$menu_item = array(
376
+				'id'          => abs( $item['ID'] ),
377
+				'order'       => (int) $item['menu_order'],
378
+				'parent'      => abs( $item['menu_item_parent'] ),
379
+				'title'       => $item['title'],
380
+				'url'         => $item['url'],
381
+				'attr'        => $item['attr_title'],
382
+				'target'      => $item['target'],
383
+				'classes'     => implode( ' ', $item['classes'] ),
384
+				'xfn'         => $item['xfn'],
385
+				'description' => $item['description'],
386
+				'object_id'   => abs( $item['object_id'] ),
387
+				'object'      => $item['object'],
388
+				'object_slug' => get_post( $item['object_id'] )->post_name,
389
+				'type'        => $item['type'],
390
+				'type_label'  => $item['type_label'],
391
+			);
392
+
393
+			if ( $children === true && ! empty( $menu ) ) {
394
+				$menu_item['children'] = $this->get_nav_menu_item_children( $item['ID'], $menu );
395
+			}
396
+
397
+			return apply_filters( 'rest_menus_format_menu_item', $menu_item );
398
+		}
399
+
400
+
401
+	}
402 402
 
403 403
 
404 404
 endif;
Please login to merge, or discard this patch.
Spacing   +92 added lines, -92 removed lines patch added patch discarded remove patch
@@ -5,11 +5,11 @@  discard block
 block discarded – undo
5 5
  * @package WP_API_Menus
6 6
  */
7 7
 
8
-if ( ! defined( 'ABSPATH' ) ) {
8
+if ( ! defined('ABSPATH')) {
9 9
     exit; // Exit if accessed directly
10 10
 }
11 11
 
12
-if ( ! class_exists( 'WP_REST_Menus' ) ) :
12
+if ( ! class_exists('WP_REST_Menus')) :
13 13
 
14 14
 
15 15
     /**
@@ -52,38 +52,38 @@  discard block
 block discarded – undo
52 52
          */
53 53
         public function register_routes() {
54 54
 
55
-            register_rest_route( self::get_plugin_namespace(), '/menus', array(
55
+            register_rest_route(self::get_plugin_namespace(), '/menus', array(
56 56
                 array(
57 57
                     'methods'  => WP_REST_Server::READABLE,
58
-                    'callback' => array( $this, 'get_menus' ),
58
+                    'callback' => array($this, 'get_menus'),
59 59
                 )
60
-            ) );
60
+            ));
61 61
 
62
-            register_rest_route( self::get_plugin_namespace(), '/menus/(?P<id>\d+)', array(
62
+            register_rest_route(self::get_plugin_namespace(), '/menus/(?P<id>\d+)', array(
63 63
                 array(
64 64
                     'methods'  => WP_REST_Server::READABLE,
65
-                    'callback' => array( $this, 'get_menu' ),
65
+                    'callback' => array($this, 'get_menu'),
66 66
                     'args'     => array(
67 67
                         'context' => array(
68 68
                         'default' => 'view',
69 69
                         ),
70 70
                     ),
71 71
                 )
72
-            ) );
72
+            ));
73 73
 
74
-            register_rest_route( self::get_plugin_namespace(), '/menu-locations', array(
74
+            register_rest_route(self::get_plugin_namespace(), '/menu-locations', array(
75 75
                 array(
76 76
                     'methods'  => WP_REST_Server::READABLE,
77
-                    'callback' => array( $this, 'get_menu_locations' ),
77
+                    'callback' => array($this, 'get_menu_locations'),
78 78
                 )
79
-            ) );
79
+            ));
80 80
 
81
-            register_rest_route( self::get_plugin_namespace(), '/menu-locations/(?P<location>[a-zA-Z0-9_-]+)', array(
81
+            register_rest_route(self::get_plugin_namespace(), '/menu-locations/(?P<location>[a-zA-Z0-9_-]+)', array(
82 82
                 array(
83 83
                     'methods'  => WP_REST_Server::READABLE,
84
-                    'callback' => array( $this, 'get_menu_location' ),
84
+                    'callback' => array($this, 'get_menu_location'),
85 85
                 )
86
-            ) );
86
+            ));
87 87
         }
88 88
 
89 89
 
@@ -95,29 +95,29 @@  discard block
 block discarded – undo
95 95
          */
96 96
         public static function get_menus() {
97 97
 
98
-            $rest_url = trailingslashit( get_rest_url() . self::get_plugin_namespace() . '/menus/' );
98
+            $rest_url = trailingslashit(get_rest_url().self::get_plugin_namespace().'/menus/');
99 99
             $wp_menus = wp_get_nav_menus();
100 100
 
101 101
             $i = 0;
102 102
             $rest_menus = array();
103
-            foreach ( $wp_menus as $wp_menu ) :
103
+            foreach ($wp_menus as $wp_menu) :
104 104
 
105 105
                 $menu = (array) $wp_menu;
106 106
 
107
-                $rest_menus[ $i ]                = $menu;
108
-                $rest_menus[ $i ]['ID']          = $menu['term_id'];
109
-                $rest_menus[ $i ]['name']        = $menu['name'];
110
-                $rest_menus[ $i ]['slug']        = $menu['slug'];
111
-                $rest_menus[ $i ]['description'] = $menu['description'];
112
-                $rest_menus[ $i ]['count']       = $menu['count'];
107
+                $rest_menus[$i]                = $menu;
108
+                $rest_menus[$i]['ID']          = $menu['term_id'];
109
+                $rest_menus[$i]['name']        = $menu['name'];
110
+                $rest_menus[$i]['slug']        = $menu['slug'];
111
+                $rest_menus[$i]['description'] = $menu['description'];
112
+                $rest_menus[$i]['count']       = $menu['count'];
113 113
 
114
-                $rest_menus[ $i ]['meta']['links']['collection'] = $rest_url;
115
-                $rest_menus[ $i ]['meta']['links']['self']       = $rest_url . $menu['term_id'];
114
+                $rest_menus[$i]['meta']['links']['collection'] = $rest_url;
115
+                $rest_menus[$i]['meta']['links']['self']       = $rest_url.$menu['term_id'];
116 116
 
117
-                $i ++;
117
+                $i++;
118 118
             endforeach;
119 119
 
120
-            return apply_filters( 'rest_menus_format_menus', $rest_menus );
120
+            return apply_filters('rest_menus_format_menus', $rest_menus);
121 121
         }
122 122
 
123 123
 
@@ -128,38 +128,38 @@  discard block
 block discarded – undo
128 128
          * @param  $request
129 129
          * @return array Menu data
130 130
          */
131
-        public function get_menu( $request ) {
131
+        public function get_menu($request) {
132 132
 
133 133
             $id             = (int) $request['id'];
134
-            $rest_url       = get_rest_url() . self::get_api_namespace() . '/menus/';
135
-            $wp_menu_object = $id ? wp_get_nav_menu_object( $id ) : array();
136
-            $wp_menu_items  = $id ? wp_get_nav_menu_items( $id ) : array();
134
+            $rest_url       = get_rest_url().self::get_api_namespace().'/menus/';
135
+            $wp_menu_object = $id ? wp_get_nav_menu_object($id) : array();
136
+            $wp_menu_items  = $id ? wp_get_nav_menu_items($id) : array();
137 137
 
138 138
             $rest_menu = array();
139 139
 
140
-            if ( $wp_menu_object ) :
140
+            if ($wp_menu_object) :
141 141
 
142 142
                 $menu = (array) $wp_menu_object;
143
-                $rest_menu['ID']          = abs( $menu['term_id'] );
143
+                $rest_menu['ID']          = abs($menu['term_id']);
144 144
                 $rest_menu['name']        = $menu['name'];
145 145
                 $rest_menu['slug']        = $menu['slug'];
146 146
                 $rest_menu['description'] = $menu['description'];
147
-                $rest_menu['count']       = abs( $menu['count'] );
147
+                $rest_menu['count']       = abs($menu['count']);
148 148
 
149 149
                 $rest_menu_items = array();
150
-                foreach ( $wp_menu_items as $item_object ) {
151
-	                $rest_menu_items[] = $this->format_menu_item( $item_object );
150
+                foreach ($wp_menu_items as $item_object) {
151
+	                $rest_menu_items[] = $this->format_menu_item($item_object);
152 152
                 }
153 153
 
154 154
                 $rest_menu_items = $this->nested_menu_items($rest_menu_items, 0);
155 155
 
156 156
                 $rest_menu['items']                       = $rest_menu_items;
157 157
                 $rest_menu['meta']['links']['collection'] = $rest_url;
158
-                $rest_menu['meta']['links']['self']       = $rest_url . $id;
158
+                $rest_menu['meta']['links']['self']       = $rest_url.$id;
159 159
 
160 160
             endif;
161 161
 
162
-            return apply_filters( 'rest_menus_format_menu', $rest_menu );
162
+            return apply_filters('rest_menus_format_menu', $rest_menu);
163 163
         }
164 164
 
165 165
 
@@ -174,24 +174,24 @@  discard block
 block discarded – undo
174 174
          * @param  $parent
175 175
          * @return array
176 176
          */
177
-        private function nested_menu_items( &$menu_items, $parent = null ) {
177
+        private function nested_menu_items(&$menu_items, $parent = null) {
178 178
 
179 179
             $parents = array();
180 180
             $children = array();
181 181
 
182 182
             // Separate menu_items into parents & children.
183
-            array_map( function( $i ) use ( $parent, &$children, &$parents ){
184
-                if ( $i['id'] != $parent && $i['parent'] == $parent ) {
183
+            array_map(function($i) use ($parent, &$children, &$parents){
184
+                if ($i['id'] != $parent && $i['parent'] == $parent) {
185 185
                     $parents[] = $i;
186 186
                 } else {
187 187
                     $children[] = $i;
188 188
                 }
189
-            }, $menu_items );
189
+            }, $menu_items);
190 190
 
191
-            foreach ( $parents as &$parent ) {
191
+            foreach ($parents as &$parent) {
192 192
 
193
-                if ( $this->has_children( $children, $parent['id'] ) ) {
194
-                    $parent['children'] = $this->nested_menu_items( $children, $parent['id'] );
193
+                if ($this->has_children($children, $parent['id'])) {
194
+                    $parent['children'] = $this->nested_menu_items($children, $parent['id']);
195 195
                 }
196 196
             }
197 197
 
@@ -207,8 +207,8 @@  discard block
 block discarded – undo
207 207
          * @param  int $id
208 208
          * @return array
209 209
          */
210
-        private function has_children( $items, $id ) {
211
-            return array_filter( $items, function( $i ) use ( $id ) {
210
+        private function has_children($items, $id) {
211
+            return array_filter($items, function($i) use ($id) {
212 212
                 return $i['parent'] == $id;
213 213
             } );
214 214
         }
@@ -221,26 +221,26 @@  discard block
 block discarded – undo
221 221
          * @param  $request
222 222
          * @return array All registered menus locations
223 223
          */
224
-        public static function get_menu_locations( $request ) {
224
+        public static function get_menu_locations($request) {
225 225
 
226 226
             $locations        = get_nav_menu_locations();
227 227
             $registered_menus = get_registered_nav_menus();
228
-	        $rest_url         = get_rest_url() . self::get_api_namespace() . '/menu-locations/';
228
+	        $rest_url = get_rest_url().self::get_api_namespace().'/menu-locations/';
229 229
             $rest_menus       = array();
230 230
 
231
-            if ( $locations && $registered_menus ) :
231
+            if ($locations && $registered_menus) :
232 232
 
233
-                foreach ( $registered_menus as $slug => $label ) :
233
+                foreach ($registered_menus as $slug => $label) :
234 234
 
235 235
 	                // Sanity check
236
-	                if ( ! isset( $locations[ $slug ] ) ) {
236
+	                if ( ! isset($locations[$slug])) {
237 237
 		                continue;
238 238
 	                }
239 239
 
240
-	                $rest_menus[ $slug ]['ID']                          = $locations[ $slug ];
241
-                    $rest_menus[ $slug ]['label']                       = $label;
242
-                    $rest_menus[ $slug ]['meta']['links']['collection'] = $rest_url;
243
-                    $rest_menus[ $slug ]['meta']['links']['self']       = $rest_url . $slug;
240
+	                $rest_menus[$slug]['ID'] = $locations[$slug];
241
+                    $rest_menus[$slug]['label']                       = $label;
242
+                    $rest_menus[$slug]['meta']['links']['collection'] = $rest_url;
243
+                    $rest_menus[$slug]['meta']['links']['self']       = $rest_url.$slug;
244 244
 
245 245
                 endforeach;
246 246
 
@@ -257,72 +257,72 @@  discard block
 block discarded – undo
257 257
          * @param  $request
258 258
          * @return array The menu for the corresponding location
259 259
          */
260
-        public function get_menu_location( $request ) {
260
+        public function get_menu_location($request) {
261 261
 
262 262
             $params     = $request->get_params();
263 263
             $location   = $params['location'];
264 264
             $locations  = get_nav_menu_locations();
265 265
 
266
-            if ( ! isset( $locations[ $location ] ) ) {
266
+            if ( ! isset($locations[$location])) {
267 267
 	            return array();
268 268
             }
269 269
 
270
-            $wp_menu = wp_get_nav_menu_object( $locations[ $location ] );
271
-            $menu_items = wp_get_nav_menu_items( $wp_menu->term_id );
270
+            $wp_menu = wp_get_nav_menu_object($locations[$location]);
271
+            $menu_items = wp_get_nav_menu_items($wp_menu->term_id);
272 272
 
273 273
 			/**
274 274
 			 * wp_get_nav_menu_items() outputs a list that's already sequenced correctly.
275 275
 			 * So the easiest thing to do is to reverse the list and then build our tree
276 276
 			 * from the ground up
277 277
 			 */
278
-			$rev_items = array_reverse ( $menu_items );
278
+			$rev_items = array_reverse($menu_items);
279 279
 			$rev_menu  = array();
280 280
 			$cache     = array();
281 281
 
282
-			foreach ( $rev_items as $item ) :
282
+			foreach ($rev_items as $item) :
283 283
 
284
-                $post_id = url_to_postid( $item->url );
284
+                $post_id = url_to_postid($item->url);
285 285
 				$formatted = array(
286
-					'ID'          => abs( $item->ID ),
286
+					'ID'          => abs($item->ID),
287 287
 					'order'       => (int) $item->menu_order,
288
-					'parent'      => abs( $item->menu_item_parent ),
288
+					'parent'      => abs($item->menu_item_parent),
289 289
 					'title'       => $item->title,
290 290
 					'url'         => $item->url,
291
-                    'thumbnail'   => has_post_thumbnail( $post_id ) ? get_the_post_thumbnail_url( $post_id ) : '',
291
+                    'thumbnail'   => has_post_thumbnail($post_id) ? get_the_post_thumbnail_url($post_id) : '',
292 292
 					'attr'        => $item->attr_title,
293 293
 					'target'      => $item->target,
294
-					'classes'     => implode( ' ', $item->classes ),
294
+					'classes'     => implode(' ', $item->classes),
295 295
 					'xfn'         => $item->xfn,
296 296
 					'description' => $item->description,
297
-					'object_id'   => abs( $item->object_id ),
297
+					'object_id'   => abs($item->object_id),
298 298
 					'object'      => $item->object,
299 299
 					'type'        => $item->type,
300 300
 					'type_label'  => $item->type_label,
301 301
 					'children'    => array(),
302 302
 				);
303 303
 
304
-				if ( array_key_exists( $item->ID , $cache ) ) {
305
-					$formatted['children'] = array_reverse( $cache[ $item->ID ] );
304
+				if (array_key_exists($item->ID, $cache)) {
305
+					$formatted['children'] = array_reverse($cache[$item->ID]);
306 306
 				}
307 307
 
308
-            	$formatted = apply_filters( 'rest_menus_format_menu_item', $formatted );
308
+            	$formatted = apply_filters('rest_menus_format_menu_item', $formatted);
309 309
 
310
-				if ( $item->menu_item_parent != 0 ) {
310
+				if ($item->menu_item_parent != 0) {
311 311
 
312
-					if ( array_key_exists( $item->menu_item_parent , $cache ) ) {
313
-						array_push( $cache[ $item->menu_item_parent ], $formatted );
312
+					if (array_key_exists($item->menu_item_parent, $cache)) {
313
+						array_push($cache[$item->menu_item_parent], $formatted);
314 314
 					} else {
315
-						$cache[ $item->menu_item_parent ] = array( $formatted, );
315
+						$cache[$item->menu_item_parent] = array($formatted,);
316 316
 					}
317 317
 
318 318
 				} else {
319 319
 
320
-					array_push( $rev_menu, $formatted );
320
+					array_push($rev_menu, $formatted);
321 321
 				}
322 322
 
323 323
 			endforeach;
324 324
 
325
-			return array_reverse ( $rev_menu );
325
+			return array_reverse($rev_menu);
326 326
         }
327 327
 
328 328
 
@@ -335,19 +335,19 @@  discard block
 block discarded – undo
335 335
          * @param bool  $depth          Gives all children or direct children only
336 336
          * @return array	returns filtered array of nav_menu_items
337 337
          */
338
-        public function get_nav_menu_item_children( $parent_id, $nav_menu_items, $depth = true ) {
338
+        public function get_nav_menu_item_children($parent_id, $nav_menu_items, $depth = true) {
339 339
 
340 340
             $nav_menu_item_list = array();
341 341
 
342
-            foreach ( (array) $nav_menu_items as $nav_menu_item ) :
342
+            foreach ((array) $nav_menu_items as $nav_menu_item) :
343 343
 
344
-                if ( $nav_menu_item->menu_item_parent == $parent_id ) :
344
+                if ($nav_menu_item->menu_item_parent == $parent_id) :
345 345
 
346
-                    $nav_menu_item_list[] = $this->format_menu_item( $nav_menu_item, true, $nav_menu_items );
346
+                    $nav_menu_item_list[] = $this->format_menu_item($nav_menu_item, true, $nav_menu_items);
347 347
 
348
-                    if ( $depth ) {
349
-                        if ( $children = $this->get_nav_menu_item_children( $nav_menu_item->ID, $nav_menu_items ) ) {
350
-                            $nav_menu_item_list = array_merge( $nav_menu_item_list, $children );
348
+                    if ($depth) {
349
+                        if ($children = $this->get_nav_menu_item_children($nav_menu_item->ID, $nav_menu_items)) {
350
+                            $nav_menu_item_list = array_merge($nav_menu_item_list, $children);
351 351
                         }
352 352
                     }
353 353
 
@@ -368,33 +368,33 @@  discard block
 block discarded – undo
368 368
          * @param  array        $menu       The menu the item belongs to (used when $children is set to true)
369 369
          * @return array	a formatted menu item for REST
370 370
          */
371
-        public function format_menu_item( $menu_item, $children = false, $menu = array() ) {
371
+        public function format_menu_item($menu_item, $children = false, $menu = array()) {
372 372
 
373 373
             $item = (array) $menu_item;
374 374
 
375 375
             $menu_item = array(
376
-                'id'          => abs( $item['ID'] ),
376
+                'id'          => abs($item['ID']),
377 377
                 'order'       => (int) $item['menu_order'],
378
-                'parent'      => abs( $item['menu_item_parent'] ),
378
+                'parent'      => abs($item['menu_item_parent']),
379 379
                 'title'       => $item['title'],
380 380
                 'url'         => $item['url'],
381 381
                 'attr'        => $item['attr_title'],
382 382
                 'target'      => $item['target'],
383
-                'classes'     => implode( ' ', $item['classes'] ),
383
+                'classes'     => implode(' ', $item['classes']),
384 384
                 'xfn'         => $item['xfn'],
385 385
                 'description' => $item['description'],
386
-                'object_id'   => abs( $item['object_id'] ),
386
+                'object_id'   => abs($item['object_id']),
387 387
                 'object'      => $item['object'],
388
-                'object_slug' => get_post( $item['object_id'] )->post_name,
388
+                'object_slug' => get_post($item['object_id'])->post_name,
389 389
                 'type'        => $item['type'],
390 390
                 'type_label'  => $item['type_label'],
391 391
             );
392 392
 
393
-            if ( $children === true && ! empty( $menu ) ) {
394
-	            $menu_item['children'] = $this->get_nav_menu_item_children( $item['ID'], $menu );
393
+            if ($children === true && ! empty($menu)) {
394
+	            $menu_item['children'] = $this->get_nav_menu_item_children($item['ID'], $menu);
395 395
             }
396 396
 
397
-            return apply_filters( 'rest_menus_format_menu_item', $menu_item );
397
+            return apply_filters('rest_menus_format_menu_item', $menu_item);
398 398
         }
399 399
 
400 400
 
Please login to merge, or discard this patch.