Passed
Branch master (7fd102)
by Claudio
01:44
created
Category
wp-rest-api-v2-menus.php 1 patch
Spacing   +64 added lines, -64 removed lines patch added patch discarded remove patch
@@ -12,16 +12,16 @@  discard block
 block discarded – undo
12 12
  * @return array List of menus with slug and description
13 13
  */
14 14
 function wp_api_v2_menus_get_all_menus() {
15
-	$menus = get_terms( 'nav_menu', array( 'hide_empty' => true ) );
15
+	$menus = get_terms('nav_menu', array('hide_empty' => true));
16 16
 
17
-	foreach ( $menus as $key => $menu ) {
17
+	foreach ($menus as $key => $menu) {
18 18
 		// check if there is acf installed
19
-		if ( class_exists( 'acf' ) ) {
20
-			$fields = get_fields( $menu );
21
-			if ( ! empty( $fields ) ) {
22
-				foreach ( $fields as $field_key => $item ) {
19
+		if (class_exists('acf')) {
20
+			$fields = get_fields($menu);
21
+			if ( ! empty($fields)) {
22
+				foreach ($fields as $field_key => $item) {
23 23
 					// add all acf custom fields
24
-					$menus[ $key ]->$field_key = $item;
24
+					$menus[$key]->$field_key = $item;
25 25
 				}
26 26
 			}
27 27
 		}
@@ -38,14 +38,14 @@  discard block
 block discarded – undo
38 38
 function wp_api_v2_menu_get_all_locations() {
39 39
 	$nav_menu_locations = get_nav_menu_locations();
40 40
 	$locations          = new stdClass;
41
-	foreach ( $nav_menu_locations as $location_slug => $menu_id ) {
42
-		if ( get_term( $location_slug ) !== null ) {
43
-			$locations->{$location_slug} = get_term( $location_slug );
41
+	foreach ($nav_menu_locations as $location_slug => $menu_id) {
42
+		if (get_term($location_slug) !== null) {
43
+			$locations->{$location_slug} = get_term($location_slug);
44 44
 		} else {
45 45
 			$locations->{$location_slug} = new stdClass;
46 46
 		}
47 47
 		$locations->{$location_slug}->slug = $location_slug;
48
-		$locations->{$location_slug}->menu = get_term( $menu_id );
48
+		$locations->{$location_slug}->menu = get_term($menu_id);
49 49
 	}
50 50
 
51 51
 	return $locations;
@@ -58,24 +58,24 @@  discard block
 block discarded – undo
58 58
  *
59 59
  * @return object Menu's data with his items
60 60
  */
61
-function wp_api_v2_locations_get_menu_data( $data ) {
61
+function wp_api_v2_locations_get_menu_data($data) {
62 62
 	// Create default empty object
63 63
 	$menu = new stdClass;
64 64
 
65 65
 	// this could be replaced with `if (has_nav_menu($data['id']))`
66
-	if ( ( $locations = get_nav_menu_locations() ) && isset( $locations[ $data['id'] ] ) ) {
66
+	if (($locations = get_nav_menu_locations()) && isset($locations[$data['id']])) {
67 67
 		// Replace default empty object with the location object
68
-		$menu        = get_term( $locations[ $data['id'] ] );
69
-		$menu->items = wp_api_v2_menus_get_menu_items( $locations[ $data['id'] ] );
68
+		$menu        = get_term($locations[$data['id']]);
69
+		$menu->items = wp_api_v2_menus_get_menu_items($locations[$data['id']]);
70 70
 	} else {
71
-		return new WP_Error( 'not_found', 'No location has been found with this id or slug: `' . $data['id'] . '`. Please ensure you passed an existing location ID or location slug.', array( 'status' => 404 ) );
71
+		return new WP_Error('not_found', 'No location has been found with this id or slug: `' . $data['id'] . '`. Please ensure you passed an existing location ID or location slug.', array('status' => 404));
72 72
 	}
73 73
 
74 74
 	// check if there is acf installed
75
-	if ( class_exists( 'acf' ) ) {
76
-		$fields = get_fields( $menu );
77
-		if ( ! empty( $fields ) ) {
78
-			foreach ( $fields as $field_key => $item ) {
75
+	if (class_exists('acf')) {
76
+		$fields = get_fields($menu);
77
+		if ( ! empty($fields)) {
78
+			foreach ($fields as $field_key => $item) {
79 79
 				// add all acf custom fields
80 80
 				$menu->$field_key = $item;
81 81
 			}
@@ -93,18 +93,18 @@  discard block
 block discarded – undo
93 93
  *
94 94
  * @return bool True if the parent is found, false otherwise
95 95
  */
96
-function wp_api_v2_menus_dna_test( &$parents, $child ) {
97
-	foreach ( $parents as $key => $item ) {
98
-		if ( $child->menu_item_parent == $item->ID ) {
99
-			if ( ! $item->child_items ) {
96
+function wp_api_v2_menus_dna_test(&$parents, $child) {
97
+	foreach ($parents as $key => $item) {
98
+		if ($child->menu_item_parent == $item->ID) {
99
+			if ( ! $item->child_items) {
100 100
 				$item->child_items = [];
101 101
 			}
102
-			array_push( $item->child_items, $child );
102
+			array_push($item->child_items, $child);
103 103
 			return true;
104 104
 		}
105 105
 
106
-		if($item->child_items) {
107
-			if(wp_api_v2_menus_dna_test($item->child_items, $child)) {
106
+		if ($item->child_items) {
107
+			if (wp_api_v2_menus_dna_test($item->child_items, $child)) {
108 108
 				return true;
109 109
 			}
110 110
 		}
@@ -120,17 +120,17 @@  discard block
 block discarded – undo
120 120
  *
121 121
  * @return array List of menu items
122 122
  */
123
-function wp_api_v2_menus_get_menu_items( $id ) {
124
-	$menu_items = wp_get_nav_menu_items( $id );
123
+function wp_api_v2_menus_get_menu_items($id) {
124
+	$menu_items = wp_get_nav_menu_items($id);
125 125
 
126 126
 	// check if there is acf installed
127
-	if ( class_exists( 'acf' ) ) {
128
-		foreach ( $menu_items as $menu_key => $menu_item ) {
129
-			$fields = get_fields( $menu_item->ID );
130
-			if ( ! empty( $fields ) ) {
131
-				foreach ( $fields as $field_key => $item ) {
127
+	if (class_exists('acf')) {
128
+		foreach ($menu_items as $menu_key => $menu_item) {
129
+			$fields = get_fields($menu_item->ID);
130
+			if ( ! empty($fields)) {
131
+				foreach ($fields as $field_key => $item) {
132 132
 					// add all acf custom fields
133
-					$menu_items[ $menu_key ]->$field_key = $item;
133
+					$menu_items[$menu_key]->$field_key = $item;
134 134
 				}
135 135
 			}
136 136
 		}
@@ -139,21 +139,21 @@  discard block
 block discarded – undo
139 139
 	// wordpress does not group child menu items with parent menu items
140 140
 	$child_items = [];
141 141
 	// pull all child menu items into separate object
142
-	foreach ( $menu_items as $key => $item ) {
143
-		if ( $item->menu_item_parent ) {
144
-			array_push( $child_items, $item );
145
-			unset( $menu_items[ $key ] );
142
+	foreach ($menu_items as $key => $item) {
143
+		if ($item->menu_item_parent) {
144
+			array_push($child_items, $item);
145
+			unset($menu_items[$key]);
146 146
 		}
147 147
 	}
148 148
 
149 149
 	// push child items into their parent item in the original object
150 150
 	do {
151
-		foreach($child_items as $key => $child_item) {
152
-			if(wp_api_v2_menus_dna_test($menu_items, $child_item)) {
151
+		foreach ($child_items as $key => $child_item) {
152
+			if (wp_api_v2_menus_dna_test($menu_items, $child_item)) {
153 153
 				unset($child_items[$key]);
154 154
 			}
155 155
 		}
156
-	} while(count($child_items));
156
+	} while (count($child_items));
157 157
 
158 158
 	return array_values($menu_items);
159 159
 }
@@ -167,28 +167,28 @@  discard block
 block discarded – undo
167 167
  *
168 168
  * @return object Menu's data with his items
169 169
  */
170
-function wp_api_v2_menus_get_menu_data( $data ) {
170
+function wp_api_v2_menus_get_menu_data($data) {
171 171
 	// This ensure retro compatibility with versions `<= 0.5` when this endpoint
172 172
 	//   was allowing locations id in place of menus id
173
-	if ( has_nav_menu( $data['id'] ) ) {
174
-		$menu = wp_api_v2_locations_get_menu_data( $data );
175
-	} else if ( is_nav_menu( $data['id'] ) ) {
176
-		if ( is_int( $data['id'] ) ) {
173
+	if (has_nav_menu($data['id'])) {
174
+		$menu = wp_api_v2_locations_get_menu_data($data);
175
+	} else if (is_nav_menu($data['id'])) {
176
+		if (is_int($data['id'])) {
177 177
 			$id = $data['id'];
178 178
 		} else {
179
-			$id = wp_get_nav_menu_object( $data['id'] );
179
+			$id = wp_get_nav_menu_object($data['id']);
180 180
 		}
181
-		$menu        = get_term( $id );
182
-		$menu->items = wp_api_v2_menus_get_menu_items( $id );
181
+		$menu        = get_term($id);
182
+		$menu->items = wp_api_v2_menus_get_menu_items($id);
183 183
 	} else {
184
-		return new WP_Error( 'not_found', 'No menu has been found with this id or slug: `' . $data['id'] . '`. Please ensure you passed an existing menu ID, menu slug, location ID or location slug.', array( 'status' => 404 ) );
184
+		return new WP_Error('not_found', 'No menu has been found with this id or slug: `' . $data['id'] . '`. Please ensure you passed an existing menu ID, menu slug, location ID or location slug.', array('status' => 404));
185 185
 	}
186 186
 
187 187
 	// check if there is acf installed
188
-	if ( class_exists( 'acf' ) ) {
189
-		$fields = get_fields( $menu );
190
-		if ( ! empty( $fields ) ) {
191
-			foreach ( $fields as $field_key => $item ) {
188
+	if (class_exists('acf')) {
189
+		$fields = get_fields($menu);
190
+		if ( ! empty($fields)) {
191
+			foreach ($fields as $field_key => $item) {
192 192
 				// add all acf custom fields
193 193
 				$menu->$field_key = $item;
194 194
 			}
@@ -198,24 +198,24 @@  discard block
 block discarded – undo
198 198
 	return $menu;
199 199
 }
200 200
 
201
-add_action( 'rest_api_init', function () {
202
-	register_rest_route( 'menus/v1', '/menus', array(
201
+add_action('rest_api_init', function() {
202
+	register_rest_route('menus/v1', '/menus', array(
203 203
 		'methods'  => 'GET',
204 204
 		'callback' => 'wp_api_v2_menus_get_all_menus',
205
-	) );
205
+	));
206 206
 
207
-	register_rest_route( 'menus/v1', '/menus/(?P<id>[a-zA-Z0-9_-]+)', array(
207
+	register_rest_route('menus/v1', '/menus/(?P<id>[a-zA-Z0-9_-]+)', array(
208 208
 		'methods'  => 'GET',
209 209
 		'callback' => 'wp_api_v2_menus_get_menu_data',
210
-	) );
210
+	));
211 211
 
212
-	register_rest_route( 'menus/v1', '/locations/(?P<id>[a-zA-Z0-9_-]+)', array(
212
+	register_rest_route('menus/v1', '/locations/(?P<id>[a-zA-Z0-9_-]+)', array(
213 213
 		'methods'  => 'GET',
214 214
 		'callback' => 'wp_api_v2_locations_get_menu_data',
215
-	) );
215
+	));
216 216
 
217
-	register_rest_route( 'menus/v1', '/locations', array(
217
+	register_rest_route('menus/v1', '/locations', array(
218 218
 		'methods'  => 'GET',
219 219
 		'callback' => 'wp_api_v2_menu_get_all_locations',
220
-	) );
220
+	));
221 221
 } );
Please login to merge, or discard this patch.