WordPress.org

Make WordPress Core

Changeset 47588


Ignore:
Timestamp:
04/16/2020 05:00:58 PM (21 months ago)
Author:
SergeyBiryukov
Message:

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

Props roytanck, shooper.
Fixes #49916.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-admin/includes/class-wp-plugins-list-table.php

    r47550 r47588  
    530530                $actions['update-selected'] = __( 'Update' );
    531531            }
     532
    532533            if ( current_user_can( 'delete_plugins' ) && ( 'active' != $status ) ) {
    533534                $actions['delete-selected'] = __( 'Delete' );
     
    621622
    622623        list( $plugin_file, $plugin_data ) = $item;
    623         $context                           = $status;
    624         $screen                            = $this->screen;
     624
     625        $plugin_slug = isset( $plugin_data['slug'] ) ? $plugin_data['slug'] : sanitize_title( $plugin_data['Name'] );
     626
     627        $context = $status;
     628        $screen  = $this->screen;
    625629
    626630        // Pre-order.
     
    676680                    if ( current_user_can( 'manage_network_plugins' ) ) {
    677681                        $actions['deactivate'] = sprintf(
    678                             '<a href="%s" aria-label="%s">%s</a>',
     682                            '<a href="%s" id="deactivate-%s" aria-label="%s">%s</a>',
    679683                            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 ),
     684                            esc_attr( $plugin_slug ),
    680685                            /* translators: %s: Plugin name. */
    681686                            esc_attr( sprintf( _x( 'Network Deactivate %s', 'plugin' ), $plugin_data['Name'] ) ),
     
    686691                    if ( current_user_can( 'manage_network_plugins' ) ) {
    687692                        $actions['activate'] = sprintf(
    688                             '<a href="%s" class="edit" aria-label="%s">%s</a>',
     693                            '<a href="%s" id="activate-%s" class="edit" aria-label="%s">%s</a>',
    689694                            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 ),
     695                            esc_attr( $plugin_slug ),
    690696                            /* translators: %s: Plugin name. */
    691697                            esc_attr( sprintf( _x( 'Network Activate %s', 'plugin' ), $plugin_data['Name'] ) ),
     
    693699                        );
    694700                    }
     701
    695702                    if ( current_user_can( 'delete_plugins' ) && ! is_plugin_active( $plugin_file ) ) {
    696703                        $actions['delete'] = sprintf(
    697                             '<a href="%s" class="delete" aria-label="%s">%s</a>',
     704                            '<a href="%s" id="delete-%s" class="delete" aria-label="%s">%s</a>',
    698705                            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' ),
     706                            esc_attr( $plugin_slug ),
    699707                            /* translators: %s: Plugin name. */
    700708                            esc_attr( sprintf( _x( 'Delete %s', 'plugin' ), $plugin_data['Name'] ) ),
     
    715723                    if ( current_user_can( 'deactivate_plugin', $plugin_file ) ) {
    716724                        $actions['deactivate'] = sprintf(
    717                             '<a href="%s" aria-label="%s">%s</a>',
     725                            '<a href="%s" id="deactivate-%s" aria-label="%s">%s</a>',
    718726                            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 ),
     727                            esc_attr( $plugin_slug ),
    719728                            /* translators: %s: Plugin name. */
    720729                            esc_attr( sprintf( _x( 'Deactivate %s', 'plugin' ), $plugin_data['Name'] ) ),
     
    722731                        );
    723732                    }
     733
    724734                    if ( current_user_can( 'resume_plugin', $plugin_file ) && is_plugin_paused( $plugin_file ) ) {
    725735                        $actions['resume'] = sprintf(
    726                             '<a class="resume-link" href="%s" aria-label="%s">%s</a>',
     736                            '<a href="%s" id="resume-%s" class="resume-link" aria-label="%s">%s</a>',
    727737                            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 ),
     738                            esc_attr( $plugin_slug ),
    728739                            /* translators: %s: Plugin name. */
    729740                            esc_attr( sprintf( _x( 'Resume %s', 'plugin' ), $plugin_data['Name'] ) ),
     
    734745                    if ( current_user_can( 'activate_plugin', $plugin_file ) ) {
    735746                        $actions['activate'] = sprintf(
    736                             '<a href="%s" class="edit" aria-label="%s">%s</a>',
     747                            '<a href="%s" id="activate-%s" class="edit" aria-label="%s">%s</a>',
    737748                            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 ),
     749                            esc_attr( $plugin_slug ),
    738750                            /* translators: %s: Plugin name. */
    739751                            esc_attr( sprintf( _x( 'Activate %s', 'plugin' ), $plugin_data['Name'] ) ),
     
    744756                    if ( ! is_multisite() && current_user_can( 'delete_plugins' ) ) {
    745757                        $actions['delete'] = sprintf(
    746                             '<a href="%s" class="delete" aria-label="%s">%s</a>',
     758                            '<a href="%s" id="delete-%s" class="delete" aria-label="%s">%s</a>',
    747759                            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' ),
     760                            esc_attr( $plugin_slug ),
    748761                            /* translators: %s: Plugin name. */
    749762                            esc_attr( sprintf( _x( 'Delete %s', 'plugin' ), $plugin_data['Name'] ) ),
     
    861874        }
    862875
    863         $plugin_slug = isset( $plugin_data['slug'] ) ? $plugin_data['slug'] : sanitize_title( $plugin_name );
    864876        printf(
    865877            '<tr class="%s" data-slug="%s" data-plugin="%s">',
Note: See TracChangeset for help on using the changeset viewer.