Nav menus: Apply the `wp_get_nav_menu_items` filter also on an empty list of menu items.
props westonruter. fixes #32631. Built from https://develop.svn.wordpress.org/trunk@32748 git-svn-id: http://core.svn.wordpress.org/trunk@32719 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
144a28a5c2
commit
792295d077
|
@ -560,25 +560,27 @@ function _is_valid_nav_menu_item( $item ) {
|
||||||
function wp_get_nav_menu_items( $menu, $args = array() ) {
|
function wp_get_nav_menu_items( $menu, $args = array() ) {
|
||||||
$menu = wp_get_nav_menu_object( $menu );
|
$menu = wp_get_nav_menu_object( $menu );
|
||||||
|
|
||||||
if ( ! $menu )
|
if ( ! $menu ) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static $fetched = array();
|
static $fetched = array();
|
||||||
|
|
||||||
$items = get_objects_in_term( $menu->term_id, 'nav_menu' );
|
$items = get_objects_in_term( $menu->term_id, 'nav_menu' );
|
||||||
|
if ( is_wp_error( $items ) ) {
|
||||||
if ( empty( $items ) )
|
return false;
|
||||||
return $items;
|
}
|
||||||
|
|
||||||
$defaults = array( 'order' => 'ASC', 'orderby' => 'menu_order', 'post_type' => 'nav_menu_item',
|
$defaults = array( 'order' => 'ASC', 'orderby' => 'menu_order', 'post_type' => 'nav_menu_item',
|
||||||
'post_status' => 'publish', 'output' => ARRAY_A, 'output_key' => 'menu_order', 'nopaging' => true );
|
'post_status' => 'publish', 'output' => ARRAY_A, 'output_key' => 'menu_order', 'nopaging' => true );
|
||||||
$args = wp_parse_args( $args, $defaults );
|
$args = wp_parse_args( $args, $defaults );
|
||||||
$args['include'] = $items;
|
$args['include'] = $items;
|
||||||
|
|
||||||
$items = get_posts( $args );
|
if ( ! empty( $items ) ) {
|
||||||
|
$items = get_posts( $args );
|
||||||
if ( is_wp_error( $items ) || ! is_array( $items ) )
|
} else {
|
||||||
return false;
|
$items = array();
|
||||||
|
}
|
||||||
|
|
||||||
// Get all posts and terms at once to prime the caches
|
// Get all posts and terms at once to prime the caches
|
||||||
if ( empty( $fetched[$menu->term_id] ) || wp_using_ext_object_cache() ) {
|
if ( empty( $fetched[$menu->term_id] ) || wp_using_ext_object_cache() ) {
|
||||||
|
@ -616,8 +618,9 @@ function wp_get_nav_menu_items( $menu, $args = array() ) {
|
||||||
|
|
||||||
$items = array_map( 'wp_setup_nav_menu_item', $items );
|
$items = array_map( 'wp_setup_nav_menu_item', $items );
|
||||||
|
|
||||||
if ( ! is_admin() ) // Remove invalid items only in frontend
|
if ( ! is_admin() ) { // Remove invalid items only in frontend
|
||||||
$items = array_filter( $items, '_is_valid_nav_menu_item' );
|
$items = array_filter( $items, '_is_valid_nav_menu_item' );
|
||||||
|
}
|
||||||
|
|
||||||
if ( ARRAY_A == $args['output'] ) {
|
if ( ARRAY_A == $args['output'] ) {
|
||||||
$GLOBALS['_menu_item_sort_prop'] = $args['output_key'];
|
$GLOBALS['_menu_item_sort_prop'] = $args['output_key'];
|
||||||
|
@ -637,7 +640,7 @@ function wp_get_nav_menu_items( $menu, $args = array() ) {
|
||||||
* @param object $menu The menu object.
|
* @param object $menu The menu object.
|
||||||
* @param array $args An array of arguments used to retrieve menu item objects.
|
* @param array $args An array of arguments used to retrieve menu item objects.
|
||||||
*/
|
*/
|
||||||
return apply_filters( 'wp_get_nav_menu_items', $items, $menu, $args );
|
return apply_filters( 'wp_get_nav_menu_items', $items, $menu, $args );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '4.3-alpha-32747';
|
$wp_version = '4.3-alpha-32748';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
|
Loading…
Reference in New Issue