Plugins: Add HTML ID attributes to plugin action links for easier targeting in browser-based testing.

Props roytanck, shooper.
Fixes #49916.

git-svn-id: https://develop.svn.wordpress.org/trunk@47588 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Sergey Biryukov 2020-04-16 17:00:58 +00:00
parent 07bc94cc11
commit 9f5d9a932d

View File

@ -529,6 +529,7 @@ class WP_Plugins_List_Table extends WP_List_Table {
if ( current_user_can( 'update_plugins' ) ) { if ( current_user_can( 'update_plugins' ) ) {
$actions['update-selected'] = __( 'Update' ); $actions['update-selected'] = __( 'Update' );
} }
if ( current_user_can( 'delete_plugins' ) && ( 'active' != $status ) ) { if ( current_user_can( 'delete_plugins' ) && ( 'active' != $status ) ) {
$actions['delete-selected'] = __( 'Delete' ); $actions['delete-selected'] = __( 'Delete' );
} }
@ -620,6 +621,9 @@ class WP_Plugins_List_Table extends WP_List_Table {
global $status, $page, $s, $totals; global $status, $page, $s, $totals;
list( $plugin_file, $plugin_data ) = $item; list( $plugin_file, $plugin_data ) = $item;
$plugin_slug = isset( $plugin_data['slug'] ) ? $plugin_data['slug'] : sanitize_title( $plugin_data['Name'] );
$context = $status; $context = $status;
$screen = $this->screen; $screen = $this->screen;
@ -675,8 +679,9 @@ class WP_Plugins_List_Table extends WP_List_Table {
if ( $is_active ) { if ( $is_active ) {
if ( current_user_can( 'manage_network_plugins' ) ) { if ( current_user_can( 'manage_network_plugins' ) ) {
$actions['deactivate'] = sprintf( $actions['deactivate'] = sprintf(
'<a href="%s" aria-label="%s">%s</a>', '<a href="%s" id="deactivate-%s" aria-label="%s">%s</a>',
wp_nonce_url( 'plugins.php?action=deactivate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'deactivate-plugin_' . $plugin_file ), wp_nonce_url( 'plugins.php?action=deactivate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'deactivate-plugin_' . $plugin_file ),
esc_attr( $plugin_slug ),
/* translators: %s: Plugin name. */ /* translators: %s: Plugin name. */
esc_attr( sprintf( _x( 'Network Deactivate %s', 'plugin' ), $plugin_data['Name'] ) ), esc_attr( sprintf( _x( 'Network Deactivate %s', 'plugin' ), $plugin_data['Name'] ) ),
__( 'Network Deactivate' ) __( 'Network Deactivate' )
@ -685,17 +690,20 @@ class WP_Plugins_List_Table extends WP_List_Table {
} else { } else {
if ( current_user_can( 'manage_network_plugins' ) ) { if ( current_user_can( 'manage_network_plugins' ) ) {
$actions['activate'] = sprintf( $actions['activate'] = sprintf(
'<a href="%s" class="edit" aria-label="%s">%s</a>', '<a href="%s" id="activate-%s" class="edit" aria-label="%s">%s</a>',
wp_nonce_url( 'plugins.php?action=activate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'activate-plugin_' . $plugin_file ), wp_nonce_url( 'plugins.php?action=activate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'activate-plugin_' . $plugin_file ),
esc_attr( $plugin_slug ),
/* translators: %s: Plugin name. */ /* translators: %s: Plugin name. */
esc_attr( sprintf( _x( 'Network Activate %s', 'plugin' ), $plugin_data['Name'] ) ), esc_attr( sprintf( _x( 'Network Activate %s', 'plugin' ), $plugin_data['Name'] ) ),
__( 'Network Activate' ) __( 'Network Activate' )
); );
} }
if ( current_user_can( 'delete_plugins' ) && ! is_plugin_active( $plugin_file ) ) { if ( current_user_can( 'delete_plugins' ) && ! is_plugin_active( $plugin_file ) ) {
$actions['delete'] = sprintf( $actions['delete'] = sprintf(
'<a href="%s" class="delete" aria-label="%s">%s</a>', '<a href="%s" id="delete-%s" class="delete" aria-label="%s">%s</a>',
wp_nonce_url( 'plugins.php?action=delete-selected&amp;checked[]=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'bulk-plugins' ), wp_nonce_url( 'plugins.php?action=delete-selected&amp;checked[]=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'bulk-plugins' ),
esc_attr( $plugin_slug ),
/* translators: %s: Plugin name. */ /* translators: %s: Plugin name. */
esc_attr( sprintf( _x( 'Delete %s', 'plugin' ), $plugin_data['Name'] ) ), esc_attr( sprintf( _x( 'Delete %s', 'plugin' ), $plugin_data['Name'] ) ),
__( 'Delete' ) __( 'Delete' )
@ -714,17 +722,20 @@ class WP_Plugins_List_Table extends WP_List_Table {
} elseif ( $is_active ) { } elseif ( $is_active ) {
if ( current_user_can( 'deactivate_plugin', $plugin_file ) ) { if ( current_user_can( 'deactivate_plugin', $plugin_file ) ) {
$actions['deactivate'] = sprintf( $actions['deactivate'] = sprintf(
'<a href="%s" aria-label="%s">%s</a>', '<a href="%s" id="deactivate-%s" aria-label="%s">%s</a>',
wp_nonce_url( 'plugins.php?action=deactivate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'deactivate-plugin_' . $plugin_file ), wp_nonce_url( 'plugins.php?action=deactivate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'deactivate-plugin_' . $plugin_file ),
esc_attr( $plugin_slug ),
/* translators: %s: Plugin name. */ /* translators: %s: Plugin name. */
esc_attr( sprintf( _x( 'Deactivate %s', 'plugin' ), $plugin_data['Name'] ) ), esc_attr( sprintf( _x( 'Deactivate %s', 'plugin' ), $plugin_data['Name'] ) ),
__( 'Deactivate' ) __( 'Deactivate' )
); );
} }
if ( current_user_can( 'resume_plugin', $plugin_file ) && is_plugin_paused( $plugin_file ) ) { if ( current_user_can( 'resume_plugin', $plugin_file ) && is_plugin_paused( $plugin_file ) ) {
$actions['resume'] = sprintf( $actions['resume'] = sprintf(
'<a class="resume-link" href="%s" aria-label="%s">%s</a>', '<a href="%s" id="resume-%s" class="resume-link" aria-label="%s">%s</a>',
wp_nonce_url( 'plugins.php?action=resume&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'resume-plugin_' . $plugin_file ), wp_nonce_url( 'plugins.php?action=resume&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'resume-plugin_' . $plugin_file ),
esc_attr( $plugin_slug ),
/* translators: %s: Plugin name. */ /* translators: %s: Plugin name. */
esc_attr( sprintf( _x( 'Resume %s', 'plugin' ), $plugin_data['Name'] ) ), esc_attr( sprintf( _x( 'Resume %s', 'plugin' ), $plugin_data['Name'] ) ),
__( 'Resume' ) __( 'Resume' )
@ -733,8 +744,9 @@ class WP_Plugins_List_Table extends WP_List_Table {
} else { } else {
if ( current_user_can( 'activate_plugin', $plugin_file ) ) { if ( current_user_can( 'activate_plugin', $plugin_file ) ) {
$actions['activate'] = sprintf( $actions['activate'] = sprintf(
'<a href="%s" class="edit" aria-label="%s">%s</a>', '<a href="%s" id="activate-%s" class="edit" aria-label="%s">%s</a>',
wp_nonce_url( 'plugins.php?action=activate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'activate-plugin_' . $plugin_file ), wp_nonce_url( 'plugins.php?action=activate&amp;plugin=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'activate-plugin_' . $plugin_file ),
esc_attr( $plugin_slug ),
/* translators: %s: Plugin name. */ /* translators: %s: Plugin name. */
esc_attr( sprintf( _x( 'Activate %s', 'plugin' ), $plugin_data['Name'] ) ), esc_attr( sprintf( _x( 'Activate %s', 'plugin' ), $plugin_data['Name'] ) ),
__( 'Activate' ) __( 'Activate' )
@ -743,8 +755,9 @@ class WP_Plugins_List_Table extends WP_List_Table {
if ( ! is_multisite() && current_user_can( 'delete_plugins' ) ) { if ( ! is_multisite() && current_user_can( 'delete_plugins' ) ) {
$actions['delete'] = sprintf( $actions['delete'] = sprintf(
'<a href="%s" class="delete" aria-label="%s">%s</a>', '<a href="%s" id="delete-%s" class="delete" aria-label="%s">%s</a>',
wp_nonce_url( 'plugins.php?action=delete-selected&amp;checked[]=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'bulk-plugins' ), wp_nonce_url( 'plugins.php?action=delete-selected&amp;checked[]=' . urlencode( $plugin_file ) . '&amp;plugin_status=' . $context . '&amp;paged=' . $page . '&amp;s=' . $s, 'bulk-plugins' ),
esc_attr( $plugin_slug ),
/* translators: %s: Plugin name. */ /* translators: %s: Plugin name. */
esc_attr( sprintf( _x( 'Delete %s', 'plugin' ), $plugin_data['Name'] ) ), esc_attr( sprintf( _x( 'Delete %s', 'plugin' ), $plugin_data['Name'] ) ),
__( 'Delete' ) __( 'Delete' )
@ -860,7 +873,6 @@ class WP_Plugins_List_Table extends WP_List_Table {
$class .= ' paused'; $class .= ' paused';
} }
$plugin_slug = isset( $plugin_data['slug'] ) ? $plugin_data['slug'] : sanitize_title( $plugin_name );
printf( printf(
'<tr class="%s" data-slug="%s" data-plugin="%s">', '<tr class="%s" data-slug="%s" data-plugin="%s">',
esc_attr( $class ), esc_attr( $class ),