mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-25 17:51:27 +01:00
e53ace6056
Fix the enter key in profile form fields moving focus to the application password input instead of submitting the profile update for. Replace the submit button type used for application passwords with `button type="button"` and ensure that the enter key's native behavior isn't overwritten. props audrasjb, alexstine, promz, sabernhardt. Fixes #52849. Built from https://develop.svn.wordpress.org/trunk@51086 git-svn-id: http://core.svn.wordpress.org/trunk@50695 1a063a9b-81f0-0310-95a4-ce76da25c4cd
266 lines
6.7 KiB
PHP
266 lines
6.7 KiB
PHP
<?php
|
|
/**
|
|
* List Table API: WP_Application_Passwords_List_Table class
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Administration
|
|
* @since 5.6.0
|
|
*/
|
|
|
|
/**
|
|
* Class for displaying the list of application password items.
|
|
*
|
|
* @since 5.6.0
|
|
* @access private
|
|
*
|
|
* @see WP_List_Table
|
|
*/
|
|
class WP_Application_Passwords_List_Table extends WP_List_Table {
|
|
|
|
/**
|
|
* Gets the list of columns.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @return array
|
|
*/
|
|
public function get_columns() {
|
|
return array(
|
|
'name' => __( 'Name' ),
|
|
'created' => __( 'Created' ),
|
|
'last_used' => __( 'Last Used' ),
|
|
'last_ip' => __( 'Last IP' ),
|
|
'revoke' => __( 'Revoke' ),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Prepares the list of items for displaying.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @global int $user_id User ID.
|
|
*/
|
|
public function prepare_items() {
|
|
global $user_id;
|
|
$this->items = array_reverse( WP_Application_Passwords::get_user_application_passwords( $user_id ) );
|
|
}
|
|
|
|
/**
|
|
* Handles the name column output.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param array $item The current application password item.
|
|
*/
|
|
public function column_name( $item ) {
|
|
echo esc_html( $item['name'] );
|
|
}
|
|
|
|
/**
|
|
* Handles the created column output.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param array $item The current application password item.
|
|
*/
|
|
public function column_created( $item ) {
|
|
if ( empty( $item['created'] ) ) {
|
|
echo '—';
|
|
} else {
|
|
echo date_i18n( __( 'F j, Y' ), $item['created'] );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Handles the last used column output.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param array $item The current application password item.
|
|
*/
|
|
public function column_last_used( $item ) {
|
|
if ( empty( $item['last_used'] ) ) {
|
|
echo '—';
|
|
} else {
|
|
echo date_i18n( __( 'F j, Y' ), $item['last_used'] );
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Handles the last ip column output.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param array $item The current application password item.
|
|
*/
|
|
public function column_last_ip( $item ) {
|
|
if ( empty( $item['last_ip'] ) ) {
|
|
echo '—';
|
|
} else {
|
|
echo $item['last_ip'];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Handles the revoke column output.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param array $item The current application password item.
|
|
*/
|
|
public function column_revoke( $item ) {
|
|
$name = 'revoke-application-password-' . $item['uuid'];
|
|
printf(
|
|
'<button type="button" name="%1$s" id="%1$s" class="button delete" aria-label="%2$s">%3$s</button>',
|
|
esc_attr( $name ),
|
|
/* translators: %s: the application password's given name. */
|
|
esc_attr( sprintf( __( 'Revoke "%s"' ), $item['name'] ) ),
|
|
__( 'Revoke' )
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Generates content for a single row of the table
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param array $item The current item.
|
|
* @param string $column_name The current column name.
|
|
*/
|
|
protected function column_default( $item, $column_name ) {
|
|
/**
|
|
* Fires for each custom column in the Application Passwords list table.
|
|
*
|
|
* Custom columns are registered using the {@see 'manage_application-passwords-user_columns'} filter.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param string $column_name Name of the custom column.
|
|
* @param array $item The application password item.
|
|
*/
|
|
do_action( "manage_{$this->screen->id}_custom_column", $column_name, $item );
|
|
}
|
|
|
|
/**
|
|
* Generates custom table navigation to prevent conflicting nonces.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param string $which The location of the bulk actions: 'top' or 'bottom'.
|
|
*/
|
|
protected function display_tablenav( $which ) {
|
|
?>
|
|
<div class="tablenav <?php echo esc_attr( $which ); ?>">
|
|
<?php if ( 'bottom' === $which ) : ?>
|
|
<div class="alignright">
|
|
<button type="button" name="revoke-all-application-passwords" id="revoke-all-application-passwords" class="button delete"><?php _e( 'Revoke all application passwords' ); ?></button>
|
|
</div>
|
|
<?php endif; ?>
|
|
<div class="alignleft actions bulkactions">
|
|
<?php $this->bulk_actions( $which ); ?>
|
|
</div>
|
|
<?php
|
|
$this->extra_tablenav( $which );
|
|
$this->pagination( $which );
|
|
?>
|
|
<br class="clear" />
|
|
</div>
|
|
<?php
|
|
}
|
|
|
|
/**
|
|
* Generates content for a single row of the table.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param array $item The current item.
|
|
*/
|
|
public function single_row( $item ) {
|
|
echo '<tr data-uuid="' . esc_attr( $item['uuid'] ) . '">';
|
|
$this->single_row_columns( $item );
|
|
echo '</tr>';
|
|
}
|
|
|
|
/**
|
|
* Gets the name of the default primary column.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @return string Name of the default primary column, in this case, 'name'.
|
|
*/
|
|
protected function get_default_primary_column_name() {
|
|
return 'name';
|
|
}
|
|
|
|
/**
|
|
* Prints the JavaScript template for the new row item.
|
|
*
|
|
* @since 5.6.0
|
|
*/
|
|
public function print_js_template_row() {
|
|
list( $columns, $hidden, , $primary ) = $this->get_column_info();
|
|
|
|
echo '<tr data-uuid="{{ data.uuid }}">';
|
|
|
|
foreach ( $columns as $column_name => $display_name ) {
|
|
$is_primary = $primary === $column_name;
|
|
$classes = "{$column_name} column-{$column_name}";
|
|
|
|
if ( $is_primary ) {
|
|
$classes .= ' has-row-actions column-primary';
|
|
}
|
|
|
|
if ( in_array( $column_name, $hidden, true ) ) {
|
|
$classes .= ' hidden';
|
|
}
|
|
|
|
printf( '<td class="%s" data-colname="%s">', esc_attr( $classes ), esc_attr( wp_strip_all_tags( $display_name ) ) );
|
|
|
|
switch ( $column_name ) {
|
|
case 'name':
|
|
echo '{{ data.name }}';
|
|
break;
|
|
case 'created':
|
|
// JSON encoding automatically doubles backslashes to ensure they don't get lost when printing the inline JS.
|
|
echo '<# print( wp.date.dateI18n( ' . wp_json_encode( __( 'F j, Y' ) ) . ', data.created ) ) #>';
|
|
break;
|
|
case 'last_used':
|
|
echo '<# print( data.last_used !== null ? wp.date.dateI18n( ' . wp_json_encode( __( 'F j, Y' ) ) . ", data.last_used ) : '—' ) #>";
|
|
break;
|
|
case 'last_ip':
|
|
echo "{{ data.last_ip || '—' }}";
|
|
break;
|
|
case 'revoke':
|
|
printf(
|
|
'<button type="button" class="button delete" aria-label="%1$s">%2$s</button>',
|
|
/* translators: %s: the application password's given name. */
|
|
esc_attr( sprintf( __( 'Revoke "%s"' ), '{{ data.name }}' ) ),
|
|
esc_html__( 'Revoke' )
|
|
);
|
|
break;
|
|
default:
|
|
/**
|
|
* Fires in the JavaScript row template for each custom column in the Application Passwords list table.
|
|
*
|
|
* Custom columns are registered using the {@see 'manage_application-passwords-user_columns'} filter.
|
|
*
|
|
* @since 5.6.0
|
|
*
|
|
* @param string $column_name Name of the custom column.
|
|
*/
|
|
do_action( "manage_{$this->screen->id}_custom_column_js_template", $column_name );
|
|
break;
|
|
}
|
|
|
|
if ( $is_primary ) {
|
|
echo '<button type="button" class="toggle-row"><span class="screen-reader-text">' . __( 'Show more details' ) . '</span></button>';
|
|
}
|
|
|
|
echo '</td>';
|
|
}
|
|
|
|
echo '</tr>';
|
|
}
|
|
}
|