265 lines
6.4 KiB
PHP
265 lines
6.4 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
|
|
*/
|
|
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 gmdate( get_option( 'date_format', 'r' ), $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 gmdate( get_option( 'date_format', 'r' ), $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 ) {
|
|
submit_button(
|
|
__( 'Revoke' ),
|
|
'delete',
|
|
'revoke-application-password-' . $item['uuid'],
|
|
false,
|
|
array(
|
|
/* translators: %s: the application password's given name. */
|
|
'title' => sprintf( __( 'Revoke "%s"' ), $item['name'] ),
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* 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">
|
|
<?php submit_button( __( 'Revoke all application passwords' ), 'delete', 'revoke-all-application-passwords', false ); ?>
|
|
</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':
|
|
echo "<# print( wp.date.dateI18n( '" . esc_js( get_option( 'date_format' ) ) . "', data.created ) ) #>";
|
|
break;
|
|
case 'last_used':
|
|
echo "<# print( data.last_used !== null ? wp.date.dateI18n( '" . esc_js( get_option( 'date_format' ) ) . "', data.last_used ) : '—' ) #>";
|
|
break;
|
|
case 'last_ip':
|
|
echo "{{ data.last_ip || '—' }}";
|
|
break;
|
|
case 'revoke':
|
|
printf(
|
|
'<input type="submit" class="button delete" value="%1$s" title="%2$s">',
|
|
esc_attr( __( 'Revoke' ) ),
|
|
/* translators: %s: the application password's given name. */
|
|
esc_attr( sprintf( __( 'Revoke "%s"' ), '{{ data.name }}' ) )
|
|
);
|
|
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>';
|
|
}
|
|
}
|