X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/af50974463450c98503e763a7836a50e260461a9..53f4633144ed68c8b8fb5861f992b5489894a940:/wp-admin/nav-menus.php diff --git a/wp-admin/nav-menus.php b/wp-admin/nav-menus.php index 5f99e720..ed9d0523 100644 --- a/wp-admin/nav-menus.php +++ b/wp-admin/nav-menus.php @@ -231,7 +231,7 @@ switch ( $action ) { check_admin_referer( 'delete-menu_item_' . $menu_item_id ); if ( is_nav_menu_item( $menu_item_id ) && wp_delete_post( $menu_item_id, true ) ) - $messages[] = '

' . __('The menu item has been successfully deleted.') . '

'; + $messages[] = '

' . __('The menu item has been successfully deleted.') . '

'; break; case 'delete': @@ -248,9 +248,9 @@ switch ( $action ) { break; if ( is_wp_error( $deletion ) ) - $messages[] = '

' . $deletion->get_error_message() . '

'; + $messages[] = '

' . $deletion->get_error_message() . '

'; else - $messages[] = '

' . __( 'The menu has been successfully deleted.' ) . '

'; + $messages[] = '

' . __( 'The menu has been successfully deleted.' ) . '

'; break; case 'delete_menus': @@ -261,13 +261,13 @@ switch ( $action ) { $deletion = wp_delete_nav_menu( $menu_id_to_delete ); if ( is_wp_error( $deletion ) ) { - $messages[] = '

' . $deletion->get_error_message() . '

'; + $messages[] = '

' . $deletion->get_error_message() . '

'; $deletion_error = true; } } if ( empty( $deletion_error ) ) - $messages[] = '

' . __( 'Selected menus have been successfully deleted.' ) . '

'; + $messages[] = '

' . __( 'Selected menus have been successfully deleted.' ) . '

'; break; case 'update': @@ -296,7 +296,7 @@ switch ( $action ) { $_nav_menu_selected_id = wp_update_nav_menu_object( 0, array('menu-name' => $new_menu_title) ); if ( is_wp_error( $_nav_menu_selected_id ) ) { - $messages[] = '

' . $_nav_menu_selected_id->get_error_message() . '

'; + $messages[] = '

' . $_nav_menu_selected_id->get_error_message() . '

'; } else { $_menu_object = wp_get_nav_menu_object( $_nav_menu_selected_id ); $nav_menu_selected_id = $_nav_menu_selected_id; @@ -327,7 +327,7 @@ switch ( $action ) { exit(); } } else { - $messages[] = '

' . __( 'Please enter a valid menu name.' ) . '

'; + $messages[] = '

' . __( 'Please enter a valid menu name.' ) . '

'; } // Update existing menu. @@ -337,7 +337,7 @@ switch ( $action ) { $menu_title = trim( esc_html( $_POST['menu-name'] ) ); if ( ! $menu_title ) { - $messages[] = '

' . __( 'Please enter a valid menu name.' ) . '

'; + $messages[] = '

' . __( 'Please enter a valid menu name.' ) . '

'; $menu_title = $_menu_object->name; } @@ -345,7 +345,7 @@ switch ( $action ) { $_nav_menu_selected_id = wp_update_nav_menu_object( $nav_menu_selected_id, array( 'menu-name' => $menu_title ) ); if ( is_wp_error( $_nav_menu_selected_id ) ) { $_menu_object = $_nav_menu_selected_id; - $messages[] = '

' . $_nav_menu_selected_id->get_error_message() . '

'; + $messages[] = '

' . $_nav_menu_selected_id->get_error_message() . '

'; } else { $_menu_object = wp_get_nav_menu_object( $_nav_menu_selected_id ); $nav_menu_selected_title = $_menu_object->name; @@ -354,7 +354,13 @@ switch ( $action ) { // Update menu items. if ( ! is_wp_error( $_menu_object ) ) { - $messages = array_merge( $messages, wp_nav_menu_update_menu_items( $nav_menu_selected_id, $nav_menu_selected_title ) ); + $messages = array_merge( $messages, wp_nav_menu_update_menu_items( $_nav_menu_selected_id, $nav_menu_selected_title ) ); + + // If the menu ID changed, redirect to the new URL. + if ( $nav_menu_selected_id != $_nav_menu_selected_id ) { + wp_redirect( admin_url( 'nav-menus.php?menu=' . intval( $_nav_menu_selected_id ) ) ); + exit(); + } } } break; @@ -374,7 +380,7 @@ switch ( $action ) { // Set menu locations set_theme_mod( 'nav_menu_locations', $menu_locations ); - $messages[] = '

' . __( 'Menu locations updated.' ) . '

'; + $messages[] = '

' . __( 'Menu locations updated.' ) . '

'; } break; } @@ -467,6 +473,8 @@ if ( current_theme_supports( 'menus' ) ) { /* * Ensure the user will be able to scroll horizontally * by adding a class for the max menu depth. + * + * @global int $_wp_nav_menu_max_depth */ global $_wp_nav_menu_max_depth; $_wp_nav_menu_max_depth = 0; @@ -477,7 +485,14 @@ if ( is_nav_menu( $nav_menu_selected_id ) ) { $edit_markup = wp_get_nav_menu_to_edit( $nav_menu_selected_id ); } -function wp_nav_menu_max_depth($classes) { +/** + * + * @global int $_wp_nav_menu_max_depth + * + * @param string $classes + * @return string + */ +function wp_nav_menu_max_depth( $classes ) { global $_wp_nav_menu_max_depth; return "$classes menu-max-depth-$_wp_nav_menu_max_depth"; } @@ -517,7 +532,7 @@ if ( ! $locations_screen ) : // Main tab $editing_menus = '

' . __( 'Each custom menu may contain a mix of links to pages, categories, custom URLs or other content types. Menu links are added by selecting items from the expanding boxes in the left-hand column below.' ) . '

'; $editing_menus .= '

' . __( 'Clicking the arrow to the right of any menu item in the editor will reveal a standard group of settings. Additional settings such as link target, CSS classes, link relationships, and link descriptions can be enabled and disabled via the Screen Options tab.' ) . '

'; $editing_menus .= ''; @@ -541,7 +556,7 @@ endif; get_current_screen()->set_help_sidebar( '

' . __('For more information:') . '

' . - '

' . __('Documentation on Menus') . '

' . + '

' . __('Documentation on Menus') . '

' . '

' . __('Support Forums') . '

' ); @@ -549,11 +564,28 @@ get_current_screen()->set_help_sidebar( require_once( ABSPATH . 'wp-admin/admin-header.php' ); ?>
+

+ 'menu_locations' ) : array( 'panel' => 'nav_menus' ); + printf( + ' %2$s', + esc_url( add_query_arg( array( + array( 'autofocus' => $focus ), + 'return' => urlencode( wp_unslash( $_SERVER['REQUEST_URI'] ) ), + ), admin_url( 'customize.php' ) ) ), + __( 'Manage in Customizer' ) + ); + endif; + ?> +

' . sprintf( _n( 'Your theme supports %s menu. Select which menu you would like to use.', 'Your theme supports %s menus. Select which menu appears in each location.', $num_locations ), number_format_i18n( $num_locations ) ) . '

'; + if ( 1 == $num_locations ) { + echo '

' . __( 'Your theme supports one menu. Select which menu you would like to use.' ) . '

'; + } else { + echo '

' . sprintf( _n( 'Your theme supports %s menu. Select which menu appears in each location.', 'Your theme supports %s menus. Select which menu appears in each location.', $num_locations ), number_format_i18n( $num_locations ) ) . '

'; + } ?>