Upgrade/Install: Use ARIA button class on plugin and theme auto-updates action links
According to the [accesability guidelines](https://developer.wordpress.org/coding-standards/wordpress-coding-standards/accessibility/#semantics-for-controls), the control should be a link when JavaScript is not available and a button the rest of the time. In addition, handlers were added for spacebar usage, and some changes to the a11y speak verbiage. Fixes #50516. Props ryokuhi, audrasjb, afercia, whyisjake/ git-svn-id: https://develop.svn.wordpress.org/trunk@48418 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
bf93e9699f
commit
1b251feeec
@ -2677,44 +2677,63 @@
|
|||||||
$( window ).on( 'beforeunload', wp.updates.beforeunload );
|
$( window ).on( 'beforeunload', wp.updates.beforeunload );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Click handler for enabling and disabling plugin and theme auto-updates.
|
* Prevents the page form scrolling when activating auto-updates with the Spacebar key.
|
||||||
*
|
*
|
||||||
* @since 5.5.0
|
* @since 5.5.0
|
||||||
*/
|
*/
|
||||||
$document.on( 'click', '.column-auto-updates a.toggle-auto-update, .theme-overlay a.toggle-auto-update', function( event ) {
|
$document.on( 'keydown', '.column-auto-updates .toggle-auto-update, .theme-overlay .toggle-auto-update', function( event ) {
|
||||||
var data, asset, type, $parent;
|
if ( 32 === event.which ) {
|
||||||
var $anchor = $( this ),
|
event.preventDefault();
|
||||||
action = $anchor.attr( 'data-wp-action' ),
|
}
|
||||||
$label = $anchor.find( '.label' );
|
} );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Click and keyup handler for enabling and disabling plugin and theme auto-updates.
|
||||||
|
*
|
||||||
|
* These controls can be either links or buttons. When JavaScript is enabled,
|
||||||
|
* we want them to behave like buttons. An ARIA role `button` is added via
|
||||||
|
* the JavaScript that targets elements with the CSS class `aria-button-if-js`.
|
||||||
|
*
|
||||||
|
* @since 5.5.0
|
||||||
|
*/
|
||||||
|
$document.on( 'click keyup', '.column-auto-updates .toggle-auto-update, .theme-overlay .toggle-auto-update', function( event ) {
|
||||||
|
var data, asset, type, $parent,
|
||||||
|
$toggler = $( this ),
|
||||||
|
action = $toggler.attr( 'data-wp-action' ),
|
||||||
|
$label = $toggler.find( '.label' );
|
||||||
|
|
||||||
|
if ( 'keyup' === event.type && 32 !== event.which ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if ( 'themes' !== pagenow ) {
|
if ( 'themes' !== pagenow ) {
|
||||||
$parent = $anchor.closest( '.column-auto-updates' );
|
$parent = $toggler.closest( '.column-auto-updates' );
|
||||||
} else {
|
} else {
|
||||||
$parent = $anchor.closest( '.theme-autoupdate' );
|
$parent = $toggler.closest( '.theme-autoupdate' );
|
||||||
}
|
}
|
||||||
|
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
// Prevent multiple simultaneous requests.
|
// Prevent multiple simultaneous requests.
|
||||||
if ( $anchor.attr( 'data-doing-ajax' ) === 'yes' ) {
|
if ( $toggler.attr( 'data-doing-ajax' ) === 'yes' ) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$anchor.attr( 'data-doing-ajax', 'yes' );
|
$toggler.attr( 'data-doing-ajax', 'yes' );
|
||||||
|
|
||||||
switch ( pagenow ) {
|
switch ( pagenow ) {
|
||||||
case 'plugins':
|
case 'plugins':
|
||||||
case 'plugins-network':
|
case 'plugins-network':
|
||||||
type = 'plugin';
|
type = 'plugin';
|
||||||
asset = $anchor.closest( 'tr' ).attr( 'data-plugin' );
|
asset = $toggler.closest( 'tr' ).attr( 'data-plugin' );
|
||||||
break;
|
break;
|
||||||
case 'themes-network':
|
case 'themes-network':
|
||||||
type = 'theme';
|
type = 'theme';
|
||||||
asset = $anchor.closest( 'tr' ).attr( 'data-slug' );
|
asset = $toggler.closest( 'tr' ).attr( 'data-slug' );
|
||||||
break;
|
break;
|
||||||
case 'themes':
|
case 'themes':
|
||||||
type = 'theme';
|
type = 'theme';
|
||||||
asset = $anchor.attr( 'data-slug' );
|
asset = $toggler.attr( 'data-slug' );
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2728,7 +2747,7 @@
|
|||||||
$label.text( __( 'Disabling...' ) );
|
$label.text( __( 'Disabling...' ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
$anchor.find( '.dashicons-update' ).removeClass( 'hidden' );
|
$toggler.find( '.dashicons-update' ).removeClass( 'hidden' );
|
||||||
|
|
||||||
data = {
|
data = {
|
||||||
action: 'toggle-auto-updates',
|
action: 'toggle-auto-updates',
|
||||||
@ -2740,8 +2759,8 @@
|
|||||||
|
|
||||||
$.post( window.ajaxurl, data )
|
$.post( window.ajaxurl, data )
|
||||||
.done( function( response ) {
|
.done( function( response ) {
|
||||||
var $enabled, $disabled, enabledNumber, disabledNumber, errorMessage;
|
var $enabled, $disabled, enabledNumber, disabledNumber, errorMessage,
|
||||||
var href = $anchor.attr( 'href' );
|
href = $toggler.attr( 'href' );
|
||||||
|
|
||||||
if ( ! response.success ) {
|
if ( ! response.success ) {
|
||||||
// if WP returns 0 for response (which can happen in a few cases),
|
// if WP returns 0 for response (which can happen in a few cases),
|
||||||
@ -2784,25 +2803,27 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
if ( 'enable' === action ) {
|
if ( 'enable' === action ) {
|
||||||
href = href.replace( 'action=enable-auto-update', 'action=disable-auto-update' );
|
// The toggler control can be either a link or a button.
|
||||||
$anchor.attr( {
|
if ( $toggler[ 0 ].hasAttribute( 'href' ) ) {
|
||||||
'data-wp-action': 'disable',
|
href = href.replace( 'action=enable-auto-update', 'action=disable-auto-update' );
|
||||||
href: href
|
$toggler.attr( 'href', href );
|
||||||
} );
|
}
|
||||||
|
$toggler.attr( 'data-wp-action', 'disable' );
|
||||||
|
|
||||||
$label.text( __( 'Disable auto-updates' ) );
|
$label.text( __( 'Disable auto-updates' ) );
|
||||||
$parent.find( '.auto-update-time' ).removeClass( 'hidden' );
|
$parent.find( '.auto-update-time' ).removeClass( 'hidden' );
|
||||||
wp.a11y.speak( __( 'Enable auto-updates' ), 'polite' );
|
wp.a11y.speak( __( 'Auto-updates enabled' ) );
|
||||||
} else {
|
} else {
|
||||||
href = href.replace( 'action=disable-auto-update', 'action=enable-auto-update' );
|
// The toggler control can be either a link or a button.
|
||||||
$anchor.attr( {
|
if ( $toggler[ 0 ].hasAttribute( 'href' ) ) {
|
||||||
'data-wp-action': 'enable',
|
href = href.replace( 'action=disable-auto-update', 'action=enable-auto-update' );
|
||||||
href: href
|
$toggler.attr( 'href', href );
|
||||||
} );
|
}
|
||||||
|
$toggler.attr( 'data-wp-action', 'enable' );
|
||||||
|
|
||||||
$label.text( __( 'Enable auto-updates' ) );
|
$label.text( __( 'Enable auto-updates' ) );
|
||||||
$parent.find( '.auto-update-time' ).addClass( 'hidden' );
|
$parent.find( '.auto-update-time' ).addClass( 'hidden' );
|
||||||
wp.a11y.speak( __( 'Auto-updates disabled' ), 'polite' );
|
wp.a11y.speak( __( 'Auto-updates disabled' ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
$document.trigger( 'wp-auto-update-setting-changed', { state: action, type: type, asset: asset } );
|
$document.trigger( 'wp-auto-update-setting-changed', { state: action, type: type, asset: asset } );
|
||||||
@ -2816,7 +2837,7 @@
|
|||||||
wp.a11y.speak( __( 'The request could not be completed.' ), 'polite' );
|
wp.a11y.speak( __( 'The request could not be completed.' ), 'polite' );
|
||||||
} )
|
} )
|
||||||
.always( function() {
|
.always( function() {
|
||||||
$anchor.removeAttr( 'data-doing-ajax' ).find( '.dashicons-update' ).addClass( 'hidden' );
|
$toggler.removeAttr( 'data-doing-ajax' ).find( '.dashicons-update' ).addClass( 'hidden' );
|
||||||
} );
|
} );
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
@ -1499,6 +1499,10 @@ div.error {
|
|||||||
animation: rotation 2s infinite linear;
|
animation: rotation 2s infinite linear;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.theme-overlay .theme-autoupdate .dashicons-update.spin {
|
||||||
|
margin-right: 3px;
|
||||||
|
}
|
||||||
|
|
||||||
/* Updated icon (check mark). */
|
/* Updated icon (check mark). */
|
||||||
.updated-message p:before,
|
.updated-message p:before,
|
||||||
.installed p:before,
|
.installed p:before,
|
||||||
|
@ -684,6 +684,15 @@ body.folded .theme-browser ~ .theme-overlay .theme-wrap {
|
|||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.theme-overlay .toggle-auto-update {
|
||||||
|
/* Better align spin icon and text. */
|
||||||
|
display: inline-flex;
|
||||||
|
align-items: center;
|
||||||
|
/* Prevents content after the auto-update toggler from jumping down and up. */
|
||||||
|
min-height: 20px; /* Same height as the spinning dashicon. */
|
||||||
|
vertical-align: top;
|
||||||
|
}
|
||||||
|
|
||||||
.theme-overlay .theme-description {
|
.theme-overlay .theme-description {
|
||||||
color: #555;
|
color: #555;
|
||||||
font-size: 15px;
|
font-size: 15px;
|
||||||
|
@ -744,7 +744,7 @@ class WP_MS_Themes_List_Table extends WP_List_Table {
|
|||||||
$url = add_query_arg( $query_args, 'themes.php' );
|
$url = add_query_arg( $query_args, 'themes.php' );
|
||||||
|
|
||||||
$html[] = sprintf(
|
$html[] = sprintf(
|
||||||
'<a href="%s" class="toggle-auto-update" data-wp-action="%s">',
|
'<a href="%s" class="toggle-auto-update aria-button-if-js" data-wp-action="%s">',
|
||||||
wp_nonce_url( $url, 'updates' ),
|
wp_nonce_url( $url, 'updates' ),
|
||||||
$action
|
$action
|
||||||
);
|
);
|
||||||
|
@ -1076,7 +1076,7 @@ class WP_Plugins_List_Table extends WP_List_Table {
|
|||||||
$url = add_query_arg( $query_args, 'plugins.php' );
|
$url = add_query_arg( $query_args, 'plugins.php' );
|
||||||
|
|
||||||
$html[] = sprintf(
|
$html[] = sprintf(
|
||||||
'<a href="%s" class="toggle-auto-update" data-wp-action="%s">',
|
'<a href="%s" class="toggle-auto-update aria-button-if-js" data-wp-action="%s">',
|
||||||
wp_nonce_url( $url, 'updates' ),
|
wp_nonce_url( $url, 'updates' ),
|
||||||
$action
|
$action
|
||||||
);
|
);
|
||||||
|
@ -562,14 +562,12 @@ function wp_theme_auto_update_setting_template() {
|
|||||||
$template = '
|
$template = '
|
||||||
<div class="theme-autoupdate">
|
<div class="theme-autoupdate">
|
||||||
<# if ( data.autoupdate ) { #>
|
<# if ( data.autoupdate ) { #>
|
||||||
<a href="{{{ data.actions.autoupdate }}}" class="toggle-auto-update" data-slug="{{ data.id }}" data-wp-action="disable">
|
<button type="button" class="toggle-auto-update button-link" data-slug="{{ data.id }}" data-wp-action="disable">
|
||||||
<span class="dashicons dashicons-update spin hidden" aria-hidden="true"></span>
|
<span class="dashicons dashicons-update spin hidden" aria-hidden="true"></span><span class="label">' . __( 'Disable auto-updates' ) . '</span>
|
||||||
<span class="label">' . __( 'Disable auto-updates' ) . '</span>
|
</button>
|
||||||
</a>
|
|
||||||
<# } else { #>
|
<# } else { #>
|
||||||
<a href="{{{ data.actions.autoupdate }}}" class="toggle-auto-update" data-slug="{{ data.id }}" data-wp-action="enable">
|
<button type="button" class="toggle-auto-update button-link" data-slug="{{ data.id }}" data-wp-action="enable">
|
||||||
<span class="dashicons dashicons-update spin hidden" aria-hidden="true"></span>
|
<span class="dashicons dashicons-update spin hidden" aria-hidden="true"></span><span class="label">' . __( 'Enable auto-updates' ) . '</span>
|
||||||
<span class="label">' . __( 'Enable auto-updates' ) . '</span>
|
|
||||||
</a>
|
</a>
|
||||||
<# } #>
|
<# } #>
|
||||||
<# if ( data.hasUpdate ) { #>
|
<# if ( data.hasUpdate ) { #>
|
||||||
|
Loading…
Reference in New Issue
Block a user