Customizer: Add missing text or labels to some nav menu UI controls.

props afercia, celloexpressions, westonruter.
fixes #32715.

git-svn-id: https://develop.svn.wordpress.org/trunk@33413 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Dominik Schilling (ocean90) 2015-07-24 20:27:04 +00:00
parent c412fd0398
commit cac1d55621
5 changed files with 95 additions and 24 deletions

View File

@ -620,7 +620,33 @@
background: #eee; background: #eee;
} }
#available-menu-items .open .accordion-section-title:after { /* rework the arrow indicator implementation for NVDA bug see #32715 */
#available-menu-items .accordion-section-title:after {
content: none !important;
}
#available-menu-items .accordion-section-title .toggle-indicator {
display: inline-block;
font-size: 20px;
line-height: 1;
}
#available-menu-items .accordion-section-title .toggle-indicator:after {
content: '\f140';
font: normal 20px/1 'dashicons';
color: #a0a5aa;
vertical-align: top;
speak: none;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-decoration: none !important;
}
#available-menu-items .accordion-section-title:hover .toggle-indicator:after {
color: #777;
}
#available-menu-items .open .accordion-section-title .toggle-indicator:after {
content: '\f142'; content: '\f142';
} }
@ -645,10 +671,11 @@ button.not-a-button {
#available-menu-items .accordion-section-title button { #available-menu-items .accordion-section-title button {
display: block; display: block;
width: 28px; width: 28px;
height: 32px; height: 35px;
position: absolute; position: absolute;
top: 5px; top: 5px;
right: 5px; right: 5px;
cursor: pointer;
} }
#available-menu-items .accordion-section-title button:focus { #available-menu-items .accordion-section-title button:focus {
@ -657,10 +684,15 @@ button.not-a-button {
} }
#available-menu-items .accordion-section-title .no-items, #available-menu-items .accordion-section-title .no-items,
#available-menu-items .cannot-expand .accordion-section-title .spinner { #available-menu-items .cannot-expand .accordion-section-title .spinner,
#available-menu-items .cannot-expand .accordion-section-title > button {
display: none; display: none;
} }
#available-menu-items-search.cannot-expand .accordion-section-title .spinner {
display: block;
}
#available-menu-items .cannot-expand .accordion-section-title .no-items { #available-menu-items .cannot-expand .accordion-section-title .no-items {
display: block; display: block;
color: #777; color: #777;
@ -778,7 +810,7 @@ button.not-a-button {
#available-menu-items-search .spinner { #available-menu-items-search .spinner {
position: absolute; position: absolute;
top: 18px; top: 20px;
margin: 0 !important; margin: 0 !important;
right: 20px; right: 20px;
} }

View File

@ -53,7 +53,9 @@
*/ */
function accordionSwitch ( el ) { function accordionSwitch ( el ) {
var section = el.closest( '.accordion-section' ), var section = el.closest( '.accordion-section' ),
sectionToggleControl = section.find( '[aria-expanded]' ).first(),
siblings = section.closest( '.accordion-container' ).find( '.open' ), siblings = section.closest( '.accordion-container' ).find( '.open' ),
siblingsToggleControl = siblings.find( '[aria-expanded]' ).first(),
content = section.find( '.accordion-section-content' ); content = section.find( '.accordion-section-content' );
// This section has no content and cannot be expanded. // This section has no content and cannot be expanded.
@ -65,11 +67,17 @@
section.toggleClass( 'open' ); section.toggleClass( 'open' );
content.toggle( true ).slideToggle( 150 ); content.toggle( true ).slideToggle( 150 );
} else { } else {
siblingsToggleControl.attr( 'aria-expanded', 'false' );
siblings.removeClass( 'open' ); siblings.removeClass( 'open' );
siblings.find( '.accordion-section-content' ).show().slideUp( 150 ); siblings.find( '.accordion-section-content' ).show().slideUp( 150 );
content.toggle( false ).slideToggle( 150 ); content.toggle( false ).slideToggle( 150 );
section.toggleClass( 'open' ); section.toggleClass( 'open' );
} }
// If there's an element with an aria-expanded attribute, assume it's a toggle control and toggle the aria-expanded value.
if ( sectionToggleControl ) {
sectionToggleControl.attr( 'aria-expanded', String( sectionToggleControl.attr( 'aria-expanded' ) === 'false' ) );
}
} }
})(jQuery); })(jQuery);

View File

@ -153,10 +153,12 @@
// Load more items. // Load more items.
this.sectionContent.scroll( function() { this.sectionContent.scroll( function() {
var totalHeight = self.$el.find( '.accordion-section.open .accordion-section-content' ).prop( 'scrollHeight' ), var totalHeight = self.$el.find( '.accordion-section.open .accordion-section-content' ).prop( 'scrollHeight' ),
visibleHeight = self.$el.find( '.accordion-section.open' ).height(); visibleHeight = self.$el.find( '.accordion-section.open' ).height();
if ( ! self.loading && $( this ).scrollTop() > 3 / 4 * totalHeight - visibleHeight ) { if ( ! self.loading && $( this ).scrollTop() > 3 / 4 * totalHeight - visibleHeight ) {
var type = $( this ).data( 'type' ), var type = $( this ).data( 'type' ),
object = $( this ).data( 'object' ); object = $( this ).data( 'object' );
if ( 'search' === type ) { if ( 'search' === type ) {
if ( self.searchTerm ) { if ( self.searchTerm ) {
self.doSearch( self.pages.search ); self.doSearch( self.pages.search );
@ -173,18 +175,22 @@
// Search input change handler. // Search input change handler.
search: function( event ) { search: function( event ) {
var $searchSection = $( '#available-menu-items-search' ),
$openSections = $( '#available-menu-items .accordion-section.open' );
if ( ! event ) { if ( ! event ) {
return; return;
} }
// Manual accordion-opening behavior. // Manual accordion-opening behavior.
if ( this.searchTerm && ! $( '#available-menu-items-search' ).hasClass( 'open' ) ) { if ( this.searchTerm && ! $searchSection.hasClass( 'open' ) ) {
$( '#available-menu-items .accordion-section-content' ).slideUp( 'fast' ); $openSections.find( '.accordion-section-content' ).slideUp( 'fast' );
$( '#available-menu-items-search .accordion-section-content' ).slideDown( 'fast' ); $searchSection.find( '.accordion-section-content' ).slideDown( 'fast' );
$( '#available-menu-items .accordion-section.open' ).removeClass( 'open' ); $openSections.find( '[aria-expanded]' ).first().attr( 'aria-expanded', 'false' );
$( '#available-menu-items-search' ).addClass( 'open' ); $openSections.removeClass( 'open' );
$searchSection.addClass( 'open' );
} }
if ( '' === event.target.value ) { if ( '' === event.target.value ) {
$( '#available-menu-items-search' ).removeClass( 'open' ); $searchSection.removeClass( 'open' );
} }
if ( this.searchTerm === event.target.value ) { if ( this.searchTerm === event.target.value ) {
return; return;
@ -197,9 +203,9 @@
// Get search results. // Get search results.
doSearch: function( page ) { doSearch: function( page ) {
var self = this, params, var self = this, params,
$section = $( '#available-menu-items-search' ), $section = $( '#available-menu-items-search' ),
$content = $section.find( '.accordion-section-content' ), $content = $section.find( '.accordion-section-content' ),
itemTemplate = wp.template( 'available-menu-item' ); itemTemplate = wp.template( 'available-menu-item' );
if ( self.currentRequest ) { if ( self.currentRequest ) {
self.currentRequest.abort(); self.currentRequest.abort();
@ -1991,7 +1997,8 @@
*/ */
toggleReordering: function( showOrHide ) { toggleReordering: function( showOrHide ) {
var addNewItemBtn = this.container.find( '.add-new-menu-item' ), var addNewItemBtn = this.container.find( '.add-new-menu-item' ),
reorderBtn = this.container.find( '.reorder-toggle' ); reorderBtn = this.container.find( '.reorder-toggle' ),
itemsTitle = this.$sectionContent.find( '.item-title' );
showOrHide = Boolean( showOrHide ); showOrHide = Boolean( showOrHide );
@ -2003,13 +2010,15 @@
this.$sectionContent.toggleClass( 'reordering', showOrHide ); this.$sectionContent.toggleClass( 'reordering', showOrHide );
this.$sectionContent.sortable( this.isReordering ? 'disable' : 'enable' ); this.$sectionContent.sortable( this.isReordering ? 'disable' : 'enable' );
if ( this.isReordering ) { if ( this.isReordering ) {
addNewItemBtn.attr( 'tabindex', '-1' ); addNewItemBtn.attr({ 'tabindex': '-1', 'aria-hidden': 'true' });
reorderBtn.attr( 'aria-label', api.Menus.data.l10n.reorderLabelOff ); reorderBtn.attr( 'aria-label', api.Menus.data.l10n.reorderLabelOff );
wp.a11y.speak( api.Menus.data.l10n.reorderModeOn ); wp.a11y.speak( api.Menus.data.l10n.reorderModeOn );
itemsTitle.attr( 'aria-hidden', 'false' );
} else { } else {
addNewItemBtn.removeAttr( 'tabindex' ); addNewItemBtn.removeAttr( 'tabindex aria-hidden' );
reorderBtn.attr( 'aria-label', api.Menus.data.l10n.reorderLabelOn ); reorderBtn.attr( 'aria-label', api.Menus.data.l10n.reorderLabelOn );
wp.a11y.speak( api.Menus.data.l10n.reorderModeOff ); wp.a11y.speak( api.Menus.data.l10n.reorderModeOff );
itemsTitle.attr( 'aria-hidden', 'true' );
} }
if ( showOrHide ) { if ( showOrHide ) {

View File

@ -1679,14 +1679,20 @@ class WP_Customize_Nav_Menu_Item_Control extends WP_Customize_Control {
?> ?>
<div class="menu-item-bar"> <div class="menu-item-bar">
<div class="menu-item-handle"> <div class="menu-item-handle">
<span class="item-type">{{ data.item_type_label }}</span> <span class="item-type" aria-hidden="true">{{ data.item_type_label }}</span>
<span class="item-title"> <span class="item-title" aria-hidden="true">
<span class="spinner"></span> <span class="spinner"></span>
<span class="menu-item-title<# if ( ! data.title ) { #> no-title<# } #>">{{ data.title || wp.customize.Menus.data.l10n.untitled }}</span> <span class="menu-item-title<# if ( ! data.title ) { #> no-title<# } #>">{{ data.title || wp.customize.Menus.data.l10n.untitled }}</span>
</span> </span>
<span class="item-controls"> <span class="item-controls">
<button type="button" class="not-a-button item-edit"><span class="screen-reader-text"><?php _e( 'Edit Menu Item' ); ?></span></button> <button type="button" class="not-a-button item-edit"><span class="screen-reader-text"><?php
<button type="button" class="not-a-button item-delete submitdelete deletion"><span class="screen-reader-text"><?php _e( 'Remove Menu Item' ); ?></span></button> /* translators: 1: Title of a menu item, 2: Type of a menu item */
printf( __( 'Edit menu item: %1$s (%2$s)' ), '{{ data.title || wp.customize.Menus.data.l10n.untitled }}', '{{ data.item_type_label }}' );
?></span></button>
<button type="button" class="not-a-button item-delete submitdelete deletion"><span class="screen-reader-text"><?php
/* translators: 1: Title of a menu item, 2: Type of a menu item */
printf( __( 'Remove Menu Item: %1$s (%2$s)' ), '{{ data.title || wp.customize.Menus.data.l10n.untitled }}', '{{ data.item_type_label }}' );
?></span></button>
</span> </span>
</div> </div>
</div> </div>

View File

@ -721,7 +721,13 @@ final class WP_Customize_Nav_Menus {
<ul class="accordion-section-content" data-type="search"></ul> <ul class="accordion-section-content" data-type="search"></ul>
</div> </div>
<div id="new-custom-menu-item" class="accordion-section"> <div id="new-custom-menu-item" class="accordion-section">
<h4 class="accordion-section-title"><?php _e( 'Custom Links' ); ?><button type="button" class="not-a-button"><span class="screen-reader-text"><?php _e( 'Toggle' ); ?></span></button></h4> <h4 class="accordion-section-title" role="presentation">
<?php _e( 'Custom Links' ); ?>
<button type="button" class="not-a-button" aria-expanded="false">
<span class="screen-reader-text"><?php _e( 'Toggle section: Custom Links' ); ?></span>
<span class="toggle-indicator" aria-hidden="true"></span>
</button>
</h4>
<div class="accordion-section-content"> <div class="accordion-section-content">
<input type="hidden" value="custom" id="custom-menu-item-type" name="menu-item[-1][menu-item-type]" /> <input type="hidden" value="custom" id="custom-menu-item-type" name="menu-item[-1][menu-item-type]" />
<p id="menu-item-url-wrap"> <p id="menu-item-url-wrap">
@ -750,7 +756,17 @@ final class WP_Customize_Nav_Menus {
$id = sprintf( 'available-menu-items-%s-%s', $available_item_type['type'], $available_item_type['object'] ); $id = sprintf( 'available-menu-items-%s-%s', $available_item_type['type'], $available_item_type['object'] );
?> ?>
<div id="<?php echo esc_attr( $id ); ?>" class="accordion-section"> <div id="<?php echo esc_attr( $id ); ?>" class="accordion-section">
<h4 class="accordion-section-title"><?php echo esc_html( $available_item_type['title'] ); ?> <span class="no-items"><?php _e( 'No items' ); ?></span><span class="spinner"></span> <button type="button" class="not-a-button"><span class="screen-reader-text"><?php _e( 'Toggle' ); ?></span></button></h4> <h4 class="accordion-section-title" role="presentation">
<?php echo esc_html( $available_item_type['title'] ); ?>
<span class="spinner"></span>
<span class="no-items"><?php _e( 'No items' ); ?></span>
<button type="button" class="not-a-button" aria-expanded="false">
<span class="screen-reader-text"><?php
/* translators: %s: Title of a section with menu items */
printf( 'Toggle section: %s', esc_html( $available_item_type['title'] ) ); ?></span>
<span class="toggle-indicator" aria-hidden="true"></span>
</button>
</h4>
<ul class="accordion-section-content" data-type="<?php echo esc_attr( $available_item_type['type'] ); ?>" data-object="<?php echo esc_attr( $available_item_type['object'] ); ?>"></ul> <ul class="accordion-section-content" data-type="<?php echo esc_attr( $available_item_type['type'] ); ?>" data-object="<?php echo esc_attr( $available_item_type['object'] ); ?>"></ul>
</div> </div>
<?php <?php