X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/4feeb71a9d812a9ae371c28a3d8b442a4394ded7..607b7e02d77e7326161e8ec15639052d2040f745:/wp-admin/includes/nav-menu.php diff --git a/wp-admin/includes/nav-menu.php b/wp-admin/includes/nav-menu.php index 18dcc97f..cb1519c8 100644 --- a/wp-admin/includes/nav-menu.php +++ b/wp-admin/includes/nav-menu.php @@ -70,24 +70,28 @@ function _wp_ajax_menu_quick_search( $request = array() ) { } elseif ( preg_match('/quick-search-(posttype|taxonomy)-([a-zA-Z_-]*\b)/', $type, $matches) ) { if ( 'posttype' == $matches[1] && get_post_type_object( $matches[2] ) ) { - query_posts(array( - 'posts_per_page' => 10, - 'post_type' => $matches[2], - 's' => $query, - )); - if ( ! have_posts() ) + $search_results_query = new WP_Query( array( + 'no_found_rows' => true, + 'update_post_meta_cache' => false, + 'update_post_term_cache' => false, + 'posts_per_page' => 10, + 'post_type' => $matches[2], + 's' => $query, + ) ); + if ( ! $search_results_query->have_posts() ) { return; - while ( have_posts() ) { - the_post(); + } + while ( $search_results_query->have_posts() ) { + $post = $search_results_query->next_post(); if ( 'markup' == $response_format ) { - $var_by_ref = get_the_ID(); + $var_by_ref = $post->ID; echo walk_nav_menu_tree( array_map('wp_setup_nav_menu_item', array( get_post( $var_by_ref ) ) ), 0, (object) $args ); } elseif ( 'json' == $response_format ) { echo wp_json_encode( array( - 'ID' => get_the_ID(), - 'post_title' => get_the_title(), - 'post_type' => get_post_type(), + 'ID' => $post->ID, + 'post_title' => get_the_title( $post->ID ), + 'post_type' => $matches[2], ) ); echo "\n"; @@ -119,7 +123,7 @@ function _wp_ajax_menu_quick_search( $request = array() ) { } /** - * Register nav menu metaboxes and advanced menu items + * Register nav menu meta boxes and advanced menu items. * * @since 3.0.0 **/ @@ -174,7 +178,7 @@ function wp_initial_nav_menu_meta_boxes() { } /** - * Creates metaboxes for any post type menu item. + * Creates meta boxes for any post type menu item.. * * @since 3.0.0 */ @@ -186,7 +190,7 @@ function wp_nav_menu_post_type_meta_boxes() { foreach ( $post_types as $post_type ) { /** - * Filter whether a menu items meta box will be added for the current + * Filters whether a menu items meta box will be added for the current * object type. * * If a falsey value is returned instead of an object, the menu items @@ -208,7 +212,7 @@ function wp_nav_menu_post_type_meta_boxes() { } /** - * Creates metaboxes for any taxonomy menu item. + * Creates meta boxes for any taxonomy menu item. * * @since 3.0.0 */ @@ -248,7 +252,7 @@ function wp_nav_menu_disabled_check( $nav_menu_selected_id ) { } /** - * Displays a metabox for the custom links menu item. + * Displays a meta box for the custom links menu item. * * @since 3.0.0 * @@ -285,7 +289,7 @@ function wp_nav_menu_item_link_meta_box() { } /** - * Displays a metabox for a post type menu item. + * Displays a meta box for a post type menu item. * * @since 3.0.0 * @@ -293,12 +297,19 @@ function wp_nav_menu_item_link_meta_box() { * @global int|string $nav_menu_selected_id * * @param string $object Not used. - * @param string $post_type The post type object. + * @param array $box { + * Post type menu item meta box arguments. + * + * @type string $id Meta box 'id' attribute. + * @type string $title Meta box title. + * @type string $callback Meta box display callback. + * @type WP_Post_Type $args Extra meta box arguments (the post type object for this meta box). + * } */ -function wp_nav_menu_item_post_type_meta_box( $object, $post_type ) { +function wp_nav_menu_item_post_type_meta_box( $object, $box ) { global $_nav_menu_placeholder, $nav_menu_selected_id; - $post_type_name = $post_type['args']->name; + $post_type_name = $box['args']->name; // Paginate browsing for large numbers of post objects. $per_page = 50; @@ -316,8 +327,8 @@ function wp_nav_menu_item_post_type_meta_box( $object, $post_type ) { 'update_post_meta_cache' => false ); - if ( isset( $post_type['args']->_default_query ) ) - $args = array_merge($args, (array) $post_type['args']->_default_query ); + if ( isset( $box['args']->_default_query ) ) + $args = array_merge($args, (array) $box['args']->_default_query ); // @todo transient caching of these results with proper invalidation on updating of a post of this type $get_posts = new WP_Query; @@ -400,18 +411,18 @@ function wp_nav_menu_item_post_type_meta_box( $object, $post_type ) { $args['walker'] = $walker; /** - * Filter the posts displayed in the 'Most Recent' tab of the current + * Filters the posts displayed in the 'Most Recent' tab of the current * post type's menu items meta box. * * The dynamic portion of the hook name, `$post_type_name`, refers to the post type name. * * @since 4.3.0 * - * @param array $most_recent An array of post objects being listed. - * @param array $args An array of WP_Query arguments. - * @param object $post_type The current post type object for this menu item meta box. + * @param array $most_recent An array of post objects being listed. + * @param array $args An array of WP_Query arguments. + * @param array $box Arguments passed to wp_nav_menu_item_post_type_meta_box(). */ - $most_recent = apply_filters( "nav_menu_items_{$post_type_name}_recent", $most_recent, $args, $post_type ); + $most_recent = apply_filters( "nav_menu_items_{$post_type_name}_recent", $most_recent, $args, $box ); echo walk_nav_menu_tree( array_map('wp_setup_nav_menu_item', $most_recent), 0, (object) $args ); ?> @@ -508,21 +519,23 @@ function wp_nav_menu_item_post_type_meta_box( $object, $post_type ) { } /** - * Filter the posts displayed in the 'View All' tab of the current + * Filters the posts displayed in the 'View All' tab of the current * post type's menu items meta box. * * The dynamic portion of the hook name, `$post_type_name`, refers * to the slug of the current post type. * * @since 3.2.0 + * @since 4.6.0 Converted the `$post_type` parameter to accept a WP_Post_Type object. * * @see WP_Query::query() * - * @param array $posts The posts for the current post type. - * @param array $args An array of WP_Query arguments. - * @param object $post_type The current post type object for this menu item meta box. + * @param array $posts The posts for the current post type. + * @param array $args An array of WP_Query arguments. + * @param WP_Post_Type $post_type The current post type object for this menu item meta box. */ $posts = apply_filters( "nav_menu_items_{$post_type_name}", $posts, $args, $post_type ); + $checkbox_items = walk_nav_menu_tree( array_map('wp_setup_nav_menu_item', $posts), 0, (object) $args ); if ( 'all' == $current_tab && ! empty( $_REQUEST['selectall'] ) ) { @@ -564,18 +577,25 @@ function wp_nav_menu_item_post_type_meta_box( $object, $post_type ) { } /** - * Displays a metabox for a taxonomy menu item. + * Displays a meta box for a taxonomy menu item. * * @since 3.0.0 * * @global int|string $nav_menu_selected_id * * @param string $object Not used. - * @param string $taxonomy The taxonomy object. + * @param array $box { + * Taxonomy menu item meta box arguments. + * + * @type string $id Meta box 'id' attribute. + * @type string $title Meta box title. + * @type string $callback Meta box display callback. + * @type object $args Extra meta box arguments (the taxonomy object for this meta box). + * } */ -function wp_nav_menu_item_taxonomy_meta_box( $object, $taxonomy ) { +function wp_nav_menu_item_taxonomy_meta_box( $object, $box ) { global $nav_menu_selected_id; - $taxonomy_name = $taxonomy['args']->name; + $taxonomy_name = $box['args']->name; // Paginate browsing for large numbers of objects. $per_page = 50; @@ -888,7 +908,7 @@ function wp_get_nav_menu_to_edit( $menu_id = 0 ) { return $result . ' '; /** - * Filter the Walker class used when adding nav menu items. + * Filters the Walker class used when adding nav menu items. * * @since 3.0.0 * @@ -916,11 +936,13 @@ function wp_get_nav_menu_to_edit( $menu_id = 0 ) { $some_invalid_menu_items = true; } - if ( $some_pending_menu_items ) - $result .= '

' . __('Click Save Menu to make pending menu items public.') . '

'; + if ( $some_pending_menu_items ) { + $result .= '

' . __( 'Click Save Menu to make pending menu items public.' ) . '

'; + } - if ( $some_invalid_menu_items ) - $result .= '

' . __('There are some invalid menu items. Please check or delete them.') . '

'; + if ( $some_invalid_menu_items ) { + $result .= '

' . __( 'There are some invalid menu items. Please check or delete them.' ) . '

'; + } $result .= '