Administration: Admin menu: Use `aria-current` for the current active page.

The `aria-current` attribute is a simple, effective way to communicate to assistive
technologies which the current item within a set of items is. While the admin menu
structure isn't 100% ideal (the top-level item is repeated also as a sub-item)
adding `aria-current="page"` to the sub-items gives an important feedback to
assistive technologies users.

This change introduces `aria-current` for the first time in core. Worth noting
there are other places where it can be used to improve accessibility. These should
be addressed in separate tickets and patches.

Fixes #41589.

Built from https://develop.svn.wordpress.org/trunk@41359


git-svn-id: http://core.svn.wordpress.org/trunk@41192 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Andrea Fercia 2017-09-09 14:50:43 +00:00
parent eeb147e349
commit d35be7a120
2 changed files with 14 additions and 5 deletions

View File

@ -89,7 +89,12 @@ function _wp_menu_output( $menu, $submenu, $submenu_as_parent = true ) {
} }
if ( ( $parent_file && $item[2] == $parent_file ) || ( empty($typenow) && $self == $item[2] ) ) { if ( ( $parent_file && $item[2] == $parent_file ) || ( empty($typenow) && $self == $item[2] ) ) {
$class[] = ! empty( $submenu_items ) ? 'wp-has-current-submenu wp-menu-open' : 'current'; if ( ! empty( $submenu_items ) ) {
$class[] = 'wp-has-current-submenu wp-menu-open';
} else {
$class[] = 'current';
$aria_attributes .= 'aria-current="page"';
}
} else { } else {
$class[] = 'wp-not-current-submenu'; $class[] = 'wp-not-current-submenu';
if ( ! empty( $submenu_items ) ) if ( ! empty( $submenu_items ) )
@ -178,6 +183,7 @@ function _wp_menu_output( $menu, $submenu, $submenu_as_parent = true ) {
continue; continue;
$class = array(); $class = array();
$aria_attributes = '';
if ( $first ) { if ( $first ) {
$class[] = 'wp-first-item'; $class[] = 'wp-first-item';
$first = false; $first = false;
@ -192,8 +198,10 @@ function _wp_menu_output( $menu, $submenu, $submenu_as_parent = true ) {
$self_type = ! empty( $typenow ) ? $self . '?post_type=' . $typenow : 'nothing'; $self_type = ! empty( $typenow ) ? $self . '?post_type=' . $typenow : 'nothing';
if ( isset( $submenu_file ) ) { if ( isset( $submenu_file ) ) {
if ( $submenu_file == $sub_item[2] ) if ( $submenu_file == $sub_item[2] ) {
$class[] = 'current'; $class[] = 'current';
$aria_attributes .= ' aria-current="page"';
}
// If plugin_page is set the parent must either match the current page or not physically exist. // If plugin_page is set the parent must either match the current page or not physically exist.
// This allows plugin pages with the same hook to exist under different parents. // This allows plugin pages with the same hook to exist under different parents.
} elseif ( } elseif (
@ -201,6 +209,7 @@ function _wp_menu_output( $menu, $submenu, $submenu_as_parent = true ) {
( isset( $plugin_page ) && $plugin_page == $sub_item[2] && ( $item[2] == $self_type || $item[2] == $self || file_exists($menu_file) === false ) ) ( isset( $plugin_page ) && $plugin_page == $sub_item[2] && ( $item[2] == $self_type || $item[2] == $self || file_exists($menu_file) === false ) )
) { ) {
$class[] = 'current'; $class[] = 'current';
$aria_attributes .= ' aria-current="page"';
} }
if ( ! empty( $sub_item[4] ) ) { if ( ! empty( $sub_item[4] ) ) {
@ -224,9 +233,9 @@ function _wp_menu_output( $menu, $submenu, $submenu_as_parent = true ) {
$sub_item_url = add_query_arg( array( 'page' => $sub_item[2] ), 'admin.php' ); $sub_item_url = add_query_arg( array( 'page' => $sub_item[2] ), 'admin.php' );
$sub_item_url = esc_url( $sub_item_url ); $sub_item_url = esc_url( $sub_item_url );
echo "<li$class><a href='$sub_item_url'$class>$title</a></li>"; echo "<li$class><a href='$sub_item_url'$class$aria_attributes>$title</a></li>";
} else { } else {
echo "<li$class><a href='{$sub_item[2]}'$class>$title</a></li>"; echo "<li$class><a href='{$sub_item[2]}'$class$aria_attributes>$title</a></li>";
} }
} }
echo "</ul>"; echo "</ul>";

View File

@ -4,7 +4,7 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '4.9-alpha-41358'; $wp_version = '4.9-alpha-41359';
/** /**
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema. * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.