diff options
Diffstat (limited to '')
-rw-r--r-- | wp-admin/js/customize-nav-menus.js | 99 |
1 files changed, 87 insertions, 12 deletions
diff --git a/wp-admin/js/customize-nav-menus.js b/wp-admin/js/customize-nav-menus.js index 9dad3e1..2b5cea3 100644 --- a/wp-admin/js/customize-nav-menus.js +++ b/wp-admin/js/customize-nav-menus.js @@ -2,7 +2,7 @@ * @output wp-admin/js/customize-nav-menus.js */ -/* global _wpCustomizeNavMenusSettings, wpNavMenu, console */ +/* global menus, _wpCustomizeNavMenusSettings, wpNavMenu, console */ ( function( api, wp, $ ) { 'use strict'; @@ -1132,6 +1132,8 @@ $( '#menu-to-edit' ).removeAttr( 'id' ); wpNavMenu.menuList.attr( 'id', 'menu-to-edit' ).addClass( 'menu' ); + api.Menus.MenuItemControl.prototype.initAccessibility(); + _.each( api.section( section.id ).controls(), function( control ) { if ( 'nav_menu_item' === control.params.type ) { control.actuallyEmbed(); @@ -1575,6 +1577,80 @@ }, /** + * Set up the initial state of the screen reader accessibility information for menu items. + * + * @since 6.6.0 + */ + initAccessibility: function() { + var control = this, + menu = $( '#menu-to-edit' ); + + // Refresh the accessibility when the user comes close to the item in any way. + menu.on( 'mouseenter.refreshAccessibility focus.refreshAccessibility touchstart.refreshAccessibility', '.menu-item', function(){ + control.refreshAdvancedAccessibilityOfItem( $( this ).find( 'button.item-edit' ) ); + } ); + + // We have to update on click as well because we might hover first, change the item, and then click. + menu.on( 'click', 'button.item-edit', function() { + control.refreshAdvancedAccessibilityOfItem( $( this ) ); + } ); + }, + + /** + * refreshAdvancedAccessibilityOfItem( [itemToRefresh] ) + * + * Refreshes advanced accessibility buttons for one menu item. + * Shows or hides buttons based on the location of the menu item. + * + * @param {Object} itemToRefresh The menu item that might need its advanced accessibility buttons refreshed + * + * @since 6.6.0 + */ + refreshAdvancedAccessibilityOfItem: function( itemToRefresh ) { + // Only refresh accessibility when necessary. + if ( true !== $( itemToRefresh ).data( 'needs_accessibility_refresh' ) ) { + return; + } + + var primaryItems, itemPosition, title, + parentItem, parentItemId, parentItemName, subItems, totalSubItems, + $this = $( itemToRefresh ), + menuItem = $this.closest( 'li.menu-item' ).first(), + depth = menuItem.menuItemDepth(), + isPrimaryMenuItem = ( 0 === depth ), + itemName = $this.closest( '.menu-item-handle' ).find( '.menu-item-title' ).text(), + menuItemType = $this.closest( '.menu-item-handle' ).find( '.item-type' ).text(), + totalMenuItems = $( '#menu-to-edit li' ).length; + + if ( isPrimaryMenuItem ) { + primaryItems = $( '.menu-item-depth-0' ), + itemPosition = primaryItems.index( menuItem ) + 1, + totalMenuItems = primaryItems.length, + // String together help text for primary menu items. + title = menus.menuFocus.replace( '%1$s', itemName ).replace( '%2$s', menuItemType ).replace( '%3$d', itemPosition ).replace( '%4$d', totalMenuItems ); + } else { + parentItem = menuItem.prevAll( '.menu-item-depth-' + parseInt( depth - 1, 10 ) ).first(), + parentItemId = parentItem.find( '.menu-item-data-db-id' ).val(), + parentItemName = parentItem.find( '.menu-item-title' ).text(), + subItems = $( '.menu-item .menu-item-data-parent-id[value="' + parentItemId + '"]' ), + totalSubItems = subItems.length, + itemPosition = $( subItems.parents( '.menu-item' ).get().reverse() ).index( menuItem ) + 1; + + // String together help text for sub menu items. + if ( depth < 2 ) { + title = menus.subMenuFocus.replace( '%1$s', itemName ).replace( '%2$s', menuItemType ).replace( '%3$d', itemPosition ).replace( '%4$d', totalSubItems ).replace( '%5$s', parentItemName ); + } else { + title = menus.subMenuMoreDepthFocus.replace( '%1$s', itemName ).replace( '%2$s', menuItemType ).replace( '%3$d', itemPosition ).replace( '%4$d', totalSubItems ).replace( '%5$s', parentItemName ).replace( '%6$d', depth ); + } + } + + $this.find( '.screen-reader-text' ).text( title ); + + // Mark this item's accessibility as refreshed. + $this.data( 'needs_accessibility_refresh', false ); + }, + + /** * Override the embed() method to do nothing, * so that the control isn't embedded on load, * unless the containing section is already expanded. @@ -1607,6 +1683,9 @@ } control.renderContent(); control.deferred.embedded.resolve(); // This triggers control.ready(). + + // Mark all menu items as unprocessed. + $( 'button.item-edit' ).data( 'needs_accessibility_refresh', true ); }, /** @@ -1679,22 +1758,15 @@ control.moveDown(); } else if ( isMoveLeft ) { control.moveLeft(); - if ( 1 === control.params.depth ) { - control.container.find( '.is-submenu' ).hide(); - } else { - control.container.find( '.is-submenu' ).show(); - } } else if ( isMoveRight ) { control.moveRight(); control.params.depth += 1; - if ( 0 === control.params.depth ) { - control.container.find( '.is-submenu' ).hide(); - } else { - control.container.find( '.is-submenu' ).show(); - } } - + moveBtn.focus(); // Re-focus after the container was moved. + + // Mark all menu items as unprocessed. + $( 'button.item-edit' ).data( 'needs_accessibility_refresh', true ); } ); }, @@ -2726,6 +2798,9 @@ menuItemControl.setting.set( setting ); }); + + // Mark all menu items as unprocessed. + $( 'button.item-edit' ).data( 'needs_accessibility_refresh', true ); }); }); |