WordPress.org

Make WordPress Core

Ticket #23770: 23770.5.diff

File 23770.5.diff, 11.1 KB (added by lessbloat, 13 months ago)
  • wp-admin/js/nav-menu.js

     
    4848                        if ( menus.oneThemeLocationNoMenus ) 
    4949                                $( '#posttype-page' ).addSelectedToMenu( api.addMenuItemToBottom ); 
    5050 
     51                        this.initManageLocations(); 
     52 
    5153                        this.initAccessibility(); 
    5254 
    5355                        this.initToggles(); 
     
    735737                        } 
    736738                }, 
    737739 
     740                initManageLocations : function () { 
     741                        $('.menu-location-menus select').on('change', function () { 
     742                                var editLink = $('.locations-edit-menu-link'); 
     743                                if ($(this).find('option:selected').data('orig')) 
     744                                        editLink.show(); 
     745                                else 
     746                                        editLink.hide(); 
     747                        }); 
     748                }, 
     749 
    738750                attachMenuEditListeners : function() { 
    739751                        var that = this; 
    740752                        $('#update-nav-menu').bind('click', function(e) { 
     
    927939                }, 
    928940 
    929941                attachUnsavedChangesListener : function() { 
    930                         $('#menu-management input, #menu-management select, #menu-management, #menu-management textarea').change(function(){ 
     942                        $('#menu-management input, #menu-management select, #menu-management, #menu-management textarea, .menu-location-menus select').change(function(){ 
    931943                                api.registerChange(); 
    932944                        }); 
    933945 
    934                         if ( 0 != $('#menu-to-edit').length ) { 
     946                        if ( 0 != $('#menu-to-edit').length || 0 != $('.menu-location-menus select').length ) { 
    935947                                window.onbeforeunload = function(){ 
    936948                                        if ( api.menusChanged ) 
    937949                                                return navMenuL10n.saveAlert; 
  • wp-admin/nav-menus.php

     
    3737// The menu id of the current menu being edited 
    3838$nav_menu_selected_id = isset( $_REQUEST['menu'] ) ? (int) $_REQUEST['menu'] : 0; 
    3939 
     40// Get existing menu locations assignments 
     41$locations = get_registered_nav_menus(); 
     42$menu_locations = get_nav_menu_locations(); 
     43$num_locations = count( array_keys( $locations ) ); 
     44 
    4045// Allowed actions: add, update, delete 
    4146$action = isset( $_REQUEST['action'] ) ? $_REQUEST['action'] : 'edit'; 
    4247 
     
    262267        case 'update': 
    263268                check_admin_referer( 'update-nav_menu', 'update-nav-menu-nonce' ); 
    264269 
    265                 // Get existing menu locations assignments 
    266                 $locations = get_registered_nav_menus(); 
    267                 $menu_locations = get_nav_menu_locations(); 
    268  
    269270                // Remove menu locations that have been unchecked 
    270271                foreach ( $locations as $location => $description ) { 
    271272                        if ( ( empty( $_POST['menu-locations'] ) || empty( $_POST['menu-locations'][ $location ] ) ) && isset( $menu_locations[ $location ] ) && $menu_locations[ $location ] == $nav_menu_selected_id ) 
     
    341342                        } 
    342343                } 
    343344                break; 
     345        case 'locations': 
     346                add_filter( 'screen_options_show_screen', '__return_false' ); 
     347 
     348                if ( isset( $_POST['menu-locations'] ) ) { 
     349                        check_admin_referer( 'save-menu-locations' ); 
     350 
     351                        $new_menu_locations = array_map( 'absint', $_POST['menu-locations'] ); 
     352                        $menu_locations = array_merge( $menu_locations, $new_menu_locations ); 
     353                        // Set menu locations 
     354                        set_theme_mod( 'nav_menu_locations', $menu_locations ); 
     355 
     356                        $messages[] = '<div id="message" class="updated"><p>' . __( 'Menu locations updated.' ) . '</p></div>'; 
     357                } 
     358                break; 
    344359} 
    345360 
    346361// Get all nav menus 
     
    350365// Are we on the add new screen? 
    351366$add_new_screen = ( isset( $_GET['menu'] ) && 0 == $_GET['menu'] ) ? true : false; 
    352367 
     368$locations_screen = ( isset( $_GET['action'] ) && 'locations' == $_GET['action'] ) ? true : false; 
     369 
    353370// If we have one theme location, and zero menus, we take them right into editing their first menu 
    354371$page_count = wp_count_posts( 'page' ); 
    355372$one_theme_location_no_menus = ( 1 == count( get_registered_nav_menus() ) && ! $add_new_screen && empty( $nav_menus ) && ! empty( $page_count->publish ) ) ? true : false; 
     
    474491?> 
    475492<div class="wrap"> 
    476493        <?php screen_icon(); ?> 
    477         <h2><?php _e( 'Menus' ); ?> <a href="<?php echo esc_url( add_query_arg( array( 'action' => 'edit', 'menu' => 0, ), admin_url( 'nav-menus.php' ) ) ); ?>" class="add-new-h2"><?php _ex( 'Add New', 'menu' ); ?></a></h2> 
     494        <h2 class="nav-tab-wrapper"> 
     495                <a href="<?php echo admin_url( 'nav-menus.php' ); ?>" class="nav-tab<?php if ( ! isset( $_GET['action'] ) || isset( $_GET['action'] ) && 'locations' != $_GET['action'] ) echo ' nav-tab-active'; ?>"><?php esc_html_e( 'Edit Menus' ); ?></a> 
     496                <a href="<?php echo esc_url( add_query_arg( array( 'action' => 'locations' ), admin_url( 'nav-menus.php' ) ) ); ?>" class="nav-tab<?php if ( $locations_screen ) echo ' nav-tab-active'; ?>"><?php esc_html_e( 'Manage Locations' ); ?></a> 
     497        </h2> 
    478498        <?php 
    479499        foreach( $messages as $message ) : 
    480500                echo $message . "\n"; 
    481501        endforeach; 
    482502        ?> 
     503        <?php 
     504        if ( $locations_screen ) : 
     505                echo '<p>' . sprintf( _n( 'Your theme supports %s menu. Select which menu you would like to use below.', 'Your theme supports %s menus. Select a menu to use for each theme location below.', $num_locations ), number_format_i18n( $num_locations ) ) . '</p>'; 
     506        ?> 
     507        <div id="menu-locations-wrap"> 
     508                <form method="post" action="<?php echo esc_url( add_query_arg( array( 'action' => 'locations' ), admin_url( 'nav-menus.php' ) ) ); ?>"> 
     509                        <p class="button-controls"><?php submit_button( __( 'Save Changes' ), 'primary left', 'nav-menu-locations', false ); ?></p> 
     510                        <table class="widefat fixed" cellspacing="0" id="menu-locations-table"> 
     511                                <thead> 
     512                                <tr> 
     513                                        <th scope="col" class="manage-column column-locations"><?php _e( 'Theme Location' ); ?></th> 
     514                                        <th scope="col" class="manage-column column-menus"><?php _e( 'Assigned Menu' ); ?></th> 
     515                                </tr> 
     516                                </thead> 
     517                                <tfoot> 
     518                                <tr> 
     519                                        <th scope="col" class="manage-column column-locations"><?php _e( 'Theme Location' ); ?></th> 
     520                                        <th scope="col" class="manage-column column-menus"><?php _e( 'Assigned Menu' ); ?></th> 
     521                                </tr> 
     522                                </tfoot> 
     523                                <tbody class="menu-locations"> 
     524                                <?php foreach ( $locations as $_location => $_name ) { ?> 
     525                                        <tr id="menu-locations-row"> 
     526                                                <td class="menu-location-title"><strong><?php echo $_name; ?></strong></td> 
     527                                                <td class="menu-location-menus"> 
     528                                                        <select name="menu-locations[<?php echo $_location; ?>]" id="locations-<?php echo $_location; ?>"> 
     529                                                                <option value="0"><?php printf( '&mdash; %s &mdash;', esc_html__( 'Select a Menu' ) ); ?></option> 
     530                                                                <?php foreach ( $nav_menus as $menu ) : ?> 
     531                                                                <?php $selected = isset( $menu_locations[ $_location ] ) && $menu_locations[ $_location ] == $menu->term_id; ?> 
     532                                                                <option <?php if ( $selected ) echo 'data-orig="true"'; ?> <?php selected($selected  ); ?> value="<?php echo $menu->term_id; ?>"> 
     533                                                                        <?php $truncated_name = wp_html_excerpt( $menu->name, 40 ); 
     534                                                                        echo $truncated_name == $menu->name ? $menu->name : trim( $truncated_name ) . '&hellip;'; ?> 
     535                                                                </option> 
     536                                                                <?php endforeach; ?> 
     537                                                        </select> 
     538                                                        <div class="locations-row-links"> 
     539                                                                <?php if ( isset( $menu_locations[ $_location ] ) && 0 != $menu_locations[ $_location ] ) : ?> 
     540                                                                <span class="locations-edit-menu-link"> 
     541                                                                        <a href="<?php echo esc_url( add_query_arg( array( 'action' => 'edit', 'menu' => $menu->term_id ), admin_url( 'nav-menus.php' ) ) ); ?>"> 
     542                                                                                <?php _ex( 'Edit', 'menu' ); ?> 
     543                                                                        </a> 
     544                                                                </span> 
     545                                                                <?php endif; ?> 
     546                                                                <span class="locations-add-menu-link"> 
     547                                                                        <a href="<?php echo esc_url( add_query_arg( array( 'action' => 'edit', 'menu' => 0 ), admin_url( 'nav-menus.php' ) ) ); ?>"> 
     548                                                                                <?php _ex( 'Use new menu', 'menu' ); ?> 
     549                                                                        </a> 
     550                                                                </span> 
     551                                                        </div><!-- #locations-row-links --> 
     552                                                </td><!-- .menu-location-menus --> 
     553                                        </tr><!-- #menu-locations-row --> 
     554                                <?php } // foreach ?> 
     555                                </tbody> 
     556                        </table> 
     557                        <p class="button-controls"><?php submit_button( __( 'Save Changes' ), 'primary left', 'nav-menu-locations', false ); ?></p> 
     558                        <?php wp_nonce_field( 'save-menu-locations' ); ?> 
     559                        <input type="hidden" name="menu" id="nav-menu-meta-object-id" value="<?php echo esc_attr( $nav_menu_selected_id ); ?>" /> 
     560                </form> 
     561        </div><!-- #menu-locations-wrap --> 
     562        <?php else : ?> 
    483563        <div class="manage-menus"> 
    484         <?php if ( $menu_count < 2 ) : ?> 
     564                <?php if ( $menu_count < 2 ) : ?> 
    485565                <span class="add-edit-menu-action"> 
    486566                        <?php printf( __( 'Edit your menu below, or <a href="%s">create a new menu</a>.' ), esc_url( add_query_arg( array( 'action' => 'edit', 'menu' => 0 ), admin_url( 'nav-menus.php' ) ) ) ); ?> 
    487567                </span><!-- /add-edit-menu-action --> 
    488         <?php else : ?> 
    489                 <form method="post" action="<?php echo admin_url( 'nav-menus.php' ); ?>"> 
     568                <?php else : ?> 
     569                <form method="get" action="<?php echo admin_url( 'nav-menus.php' ); ?>"> 
    490570                        <input type="hidden" name="action" value="edit" /> 
    491571                        <label for="menu" class="selected-menu"><?php _e( 'Select a menu to edit:' ); ?></label> 
    492572                        <select name="menu" id="menu"> 
     
    520600                                <?php printf( __( 'or <a href="%s">create a new menu</a>.' ), esc_url( add_query_arg( array( 'action' => 'edit', 'menu' => 0 ), admin_url( 'nav-menus.php' ) ) ) ); ?> 
    521601                        </span><!-- /add-new-menu-action --> 
    522602                </form> 
    523         <?php endif; ?> 
     603                <?php endif; ?> 
    524604        </div><!-- /manage-menus --> 
    525605        <div id="nav-menus-frame"> 
    526606        <div id="menu-settings-column" class="metabox-holder<?php if ( isset( $_GET['menu'] ) && '0' == $_GET['menu'] ) { echo ' metabox-holder-disabled'; } ?>"> 
     
    633713                </div><!-- /#menu-management --> 
    634714        </div><!-- /#menu-management-liquid --> 
    635715        </div><!-- /#nav-menus-frame --> 
     716        <?php endif; ?> 
    636717</div><!-- /.wrap--> 
    637718<?php include( './admin-footer.php' ); ?> 
  • wp-admin/css/wp-admin.css

     
    166166        padding: 0 7px; 
    167167} 
    168168 
     169#col-left-locations { 
     170        width: 40%; 
     171} 
     172 
    169173/* utility classes */ 
    170174.alignleft { 
    171175        float: left; 
     
    24232427        width: 8%; 
    24242428} 
    24252429 
     2430.fixed .column-posts, 
    24262431.fixed .column-date, 
    24272432.fixed .column-parent, 
    24282433.fixed .column-links, 
     
    24392444        width: 15%; 
    24402445} 
    24412446 
     2447.fixed .column-slug { 
     2448        width: 25%; 
     2449} 
     2450 
     2451.fixed .column-locations { 
     2452        width: 25%; 
     2453} 
     2454 
    24422455.fixed .column-comments { 
    24432456        width: 4em; 
    24442457        padding: 8px 0; 
     
    24532466        float: left; 
    24542467} 
    24552468 
    2456 .fixed .column-slug { 
    2457         width: 25%; 
    2458 } 
    2459  
    2460 .fixed .column-posts { 
    2461         width: 10%; 
    2462 } 
    2463  
    24642469.fixed .column-icon { 
    24652470        width: 80px; 
    24662471} 
     
    73807385 
    73817386#nav-menus-frame { 
    73827387        margin-left: 300px; 
    7383         margin-top: 28px; 
     7388        margin-top: 23px; 
    73847389} 
    73857390 
    73867391#wpbody-content #menu-settings-column { 
     
    74287433} 
    74297434 
    74307435.manage-menus { 
    7431         margin-top: 13px; 
     7436        margin-top: 23px; 
    74327437        padding: 10px; 
    74337438        overflow: hidden; 
    74347439        -webkit-border-radius: 3px; 
     
    75627567        margin-top: -2px; 
    75637568} 
    75647569 
     7570.widefat td.menu-location-menus { 
     7571        padding-bottom: 5px; 
     7572} 
     7573 
     7574.menu-location-menus select { 
     7575        float: left; 
     7576} 
     7577 
     7578#locations-nav-menu-wrapper { 
     7579        padding: 5px 0; 
     7580} 
     7581 
     7582.locations-nav-menu-select select { 
     7583        float: left; 
     7584        width: 160px; 
     7585        margin-right: 5px; 
     7586} 
     7587 
     7588.locations-row-links { 
     7589        float: left; 
     7590        margin: 6px 0 0 6px; 
     7591} 
     7592 
     7593.locations-edit-menu-link, 
     7594.locations-add-menu-link { 
     7595        margin: 0 3px; 
     7596} 
     7597 
     7598.locations-edit-menu-link { 
     7599        padding-right: 3px; 
     7600        border-right: 1px solid #ccc; 
     7601} 
     7602 
    75657603#wpbody .open-label { 
    75667604        display: block; 
    75677605        float:left;