diff --git a/src/wp-admin/includes/class-wp-comments-list-table.php b/src/wp-admin/includes/class-wp-comments-list-table.php index 6f5f7f80d6..1e25dde70c 100644 --- a/src/wp-admin/includes/class-wp-comments-list-table.php +++ b/src/wp-admin/includes/class-wp-comments-list-table.php @@ -80,11 +80,16 @@ class WP_Comments_List_Table extends WP_List_Table { /** * @global int $post_id * @global string $comment_status - * @global string $search * @global string $comment_type + * @global string $search */ public function prepare_items() { - global $post_id, $comment_status, $search, $comment_type; + global $post_id, $comment_status, $comment_type, $search; + + if ( ! empty( $_REQUEST['mode'] ) ) { + $mode = 'extended' === $_REQUEST['mode'] ? 'extended' : 'list'; + set_user_setting( 'posts_list_mode', $mode ); + } $comment_status = isset( $_REQUEST['comment_status'] ) ? $_REQUEST['comment_status'] : 'all'; if ( ! in_array( $comment_status, array( 'all', 'mine', 'moderated', 'approved', 'spam', 'trash' ), true ) ) { @@ -124,13 +129,6 @@ class WP_Comments_List_Table extends WP_List_Table { $start += $_REQUEST['offset']; } - if ( ! empty( $_REQUEST['mode'] ) ) { - $mode = 'extended' === $_REQUEST['mode'] ? 'extended' : 'list'; - set_user_setting( 'posts_list_mode', $mode ); - } else { - $mode = get_user_setting( 'posts_list_mode', 'list' ); - } - $status_map = array( 'mine' => '', 'moderated' => 'hold', @@ -759,21 +757,34 @@ class WP_Comments_List_Table extends WP_List_Table { $actions = apply_filters( 'comment_row_actions', array_filter( $actions ), $comment ); $always_visible = false; - $mode = get_user_setting( 'posts_list_mode', 'list' ); + + $mode = get_user_setting( 'posts_list_mode', 'list' ); + if ( 'extended' === $mode ) { $always_visible = true; } - $i = 0; $out .= '
'; + + $i = 0; + foreach ( $actions as $action => $link ) { ++$i; - ( ( ( 'approve' === $action || 'unapprove' === $action ) && 2 === $i ) || 1 === $i ) ? $sep = '' : $sep = ' | '; - // Reply and quickedit need a hide-if-no-js span when not added with ajax. + if ( ( ( 'approve' === $action || 'unapprove' === $action ) && 2 === $i ) + || 1 === $i + ) { + $sep = ''; + } else { + $sep = ' | '; + } + + // Reply and quickedit need a hide-if-no-js span when not added with Ajax. if ( ( 'reply' === $action || 'quickedit' === $action ) && ! wp_doing_ajax() ) { $action .= ' hide-if-no-js'; - } elseif ( ( 'untrash' === $action && 'trash' === $the_comment_status ) || ( 'unspam' === $action && 'spam' === $the_comment_status ) ) { + } elseif ( ( 'untrash' === $action && 'trash' === $the_comment_status ) + || ( 'unspam' === $action && 'spam' === $the_comment_status ) + ) { if ( '1' == get_comment_meta( $comment->comment_ID, '_wp_trash_meta_status', true ) ) { $action .= ' approve'; } else { @@ -783,6 +794,7 @@ class WP_Comments_List_Table extends WP_List_Table { $out .= "$sep$link"; } + $out .= '
'; $out .= ''; diff --git a/src/wp-admin/includes/class-wp-list-table.php b/src/wp-admin/includes/class-wp-list-table.php index 38540c4121..978200c6a3 100644 --- a/src/wp-admin/includes/class-wp-list-table.php +++ b/src/wp-admin/includes/class-wp-list-table.php @@ -166,8 +166,8 @@ class WP_List_Table { if ( empty( $this->modes ) ) { $this->modes = array( - 'list' => __( 'Compact View' ), - 'extended' => __( 'Extended View' ), + 'list' => __( 'Compact view' ), + 'extended' => __( 'Extended view' ), ); } } @@ -517,23 +517,29 @@ class WP_List_Table { */ protected function row_actions( $actions, $always_visible = false ) { $action_count = count( $actions ); - $i = 0; if ( ! $action_count ) { return ''; } $mode = get_user_setting( 'posts_list_mode', 'list' ); + if ( 'extended' === $mode ) { $always_visible = true; } $out = '
'; + + $i = 0; + foreach ( $actions as $action => $link ) { ++$i; - ( $i == $action_count ) ? $sep = '' : $sep = ' | '; - $out .= "$link$sep"; + + $sep = ( $i < $action_count ) ? ' | ' : ''; + + $out .= "$link$sep"; } + $out .= '
'; $out .= ''; @@ -1252,20 +1258,12 @@ class WP_List_Table { * @return string[] Array of CSS classes for the table tag. */ protected function get_table_classes() { - $mode = get_user_setting( 'posts_list_mode', 'list' ); - $mode_class = 'extended' === $mode ? 'table-view-extended' : 'table-view-list'; - $mode = get_user_setting( 'posts_list_mode', 'list' ); - /** - * Filters the current view mode. - * - * @since 5.5.0 - * - * @param string $mode The current selected mode. Default value of - * posts_list_mode user setting. - */ + $mode = get_user_setting( 'posts_list_mode', 'list' ); + + /** This filter is documented in wp-admin/includes/class-wp-screen.php */ $mode = apply_filters( 'table_view_mode', $mode ); - $mode_class = 'extended' === $mode ? 'table-view-extended' : 'table-view-' . $mode; + $mode_class = esc_attr( 'table-view-' . $mode ); return array( 'widefat', 'fixed', 'striped', $mode_class, $this->_args['plural'] ); } diff --git a/src/wp-admin/includes/class-wp-media-list-table.php b/src/wp-admin/includes/class-wp-media-list-table.php index 1724b96728..b0fbfaea22 100644 --- a/src/wp-admin/includes/class-wp-media-list-table.php +++ b/src/wp-admin/includes/class-wp-media-list-table.php @@ -61,13 +61,15 @@ class WP_Media_List_Table extends WP_List_Table { } /** + * @global string $mode List table view mode. * @global WP_Query $wp_query WordPress Query object. * @global array $post_mime_types * @global array $avail_post_mime_types - * @global string $mode */ public function prepare_items() { - global $wp_query, $post_mime_types, $avail_post_mime_types, $mode; + global $mode, $wp_query, $post_mime_types, $avail_post_mime_types; + + $mode = empty( $_REQUEST['mode'] ) ? 'list' : $_REQUEST['mode']; // Exclude attachments scheduled for deletion in the next two hours // if they are for zip packages for interrupted or failed updates. @@ -96,8 +98,6 @@ class WP_Media_List_Table extends WP_List_Table { $this->is_trash = isset( $_REQUEST['attachment-filter'] ) && 'trash' === $_REQUEST['attachment-filter']; - $mode = empty( $_REQUEST['mode'] ) ? 'list' : $_REQUEST['mode']; - $this->set_pagination_args( array( 'total_items' => $wp_query->found_posts, diff --git a/src/wp-admin/includes/class-wp-ms-sites-list-table.php b/src/wp-admin/includes/class-wp-ms-sites-list-table.php index 995a733823..acd22daa82 100644 --- a/src/wp-admin/includes/class-wp-ms-sites-list-table.php +++ b/src/wp-admin/includes/class-wp-ms-sites-list-table.php @@ -62,12 +62,12 @@ class WP_MS_Sites_List_Table extends WP_List_Table { * * @since 3.1.0 * + * @global string $mode List table view mode. * @global string $s - * @global string $mode * @global wpdb $wpdb WordPress database abstraction object. */ public function prepare_items() { - global $s, $mode, $wpdb; + global $mode, $s, $wpdb; if ( ! empty( $_REQUEST['mode'] ) ) { $mode = 'excerpt' === $_REQUEST['mode'] ? 'excerpt' : 'list'; @@ -576,7 +576,7 @@ class WP_MS_Sites_List_Table extends WP_List_Table { } /** - * @global string $mode + * @global string $mode List table view mode. */ public function display_rows() { foreach ( $this->items as $blog ) { diff --git a/src/wp-admin/includes/class-wp-ms-users-list-table.php b/src/wp-admin/includes/class-wp-ms-users-list-table.php index 57968ae935..461411e910 100644 --- a/src/wp-admin/includes/class-wp-ms-users-list-table.php +++ b/src/wp-admin/includes/class-wp-ms-users-list-table.php @@ -24,12 +24,19 @@ class WP_MS_Users_List_Table extends WP_List_Table { } /** + * @global string $mode List table view mode. * @global string $usersearch * @global string $role - * @global string $mode */ public function prepare_items() { - global $usersearch, $role, $mode; + global $mode, $usersearch, $role; + + if ( ! empty( $_REQUEST['mode'] ) ) { + $mode = 'excerpt' === $_REQUEST['mode'] ? 'excerpt' : 'list'; + set_user_setting( 'network_users_list_mode', $mode ); + } else { + $mode = get_user_setting( 'network_users_list_mode', 'list' ); + } $usersearch = isset( $_REQUEST['s'] ) ? wp_unslash( trim( $_REQUEST['s'] ) ) : ''; @@ -83,13 +90,6 @@ class WP_MS_Users_List_Table extends WP_List_Table { $args['order'] = $_REQUEST['order']; } - if ( ! empty( $_REQUEST['mode'] ) ) { - $mode = 'excerpt' === $_REQUEST['mode'] ? 'excerpt' : 'list'; - set_user_setting( 'network_users_list_mode', $mode ); - } else { - $mode = get_user_setting( 'network_users_list_mode', 'list' ); - } - /** This filter is documented in wp-admin/includes/class-wp-users-list-table.php */ $args = apply_filters( 'users_list_table_query_args', $args ); @@ -422,13 +422,18 @@ class WP_MS_Users_List_Table extends WP_List_Table { */ $actions = apply_filters( 'ms_user_list_site_actions', $actions, $val->userblog_id ); - $i = 0; $action_count = count( $actions ); + + $i = 0; + foreach ( $actions as $action => $link ) { ++$i; - $sep = ( $i == $action_count ) ? '' : ' | '; + + $sep = ( $i < $action_count ) ? ' | ' : ''; + echo "$link$sep"; } + echo '
'; } } diff --git a/src/wp-admin/includes/class-wp-posts-list-table.php b/src/wp-admin/includes/class-wp-posts-list-table.php index b4fcfe5bdb..03112a0917 100644 --- a/src/wp-admin/includes/class-wp-posts-list-table.php +++ b/src/wp-admin/includes/class-wp-posts-list-table.php @@ -135,13 +135,20 @@ class WP_Posts_List_Table extends WP_List_Table { } /** + * @global string $mode List table view mode. * @global array $avail_post_stati * @global WP_Query $wp_query WordPress Query object. * @global int $per_page - * @global string $mode */ public function prepare_items() { - global $avail_post_stati, $wp_query, $per_page, $mode; + global $mode, $avail_post_stati, $wp_query, $per_page; + + if ( ! empty( $_REQUEST['mode'] ) ) { + $mode = 'extended' === $_REQUEST['mode'] ? 'extended' : 'list'; + set_user_setting( 'posts_list_mode', $mode ); + } else { + $mode = get_user_setting( 'posts_list_mode', 'list' ); + } // Is going to call wp(). $avail_post_stati = wp_edit_posts_query(); @@ -177,13 +184,6 @@ class WP_Posts_List_Table extends WP_List_Table { } } - if ( ! empty( $_REQUEST['mode'] ) ) { - $mode = 'extended' === $_REQUEST['mode'] ? 'extended' : 'list'; - set_user_setting( 'posts_list_mode', $mode ); - } else { - $mode = get_user_setting( 'posts_list_mode', 'list' ); - } - $this->is_trash = isset( $_REQUEST['post_status'] ) && 'trash' === $_REQUEST['post_status']; $this->set_pagination_args( @@ -595,23 +595,17 @@ class WP_Posts_List_Table extends WP_List_Table { } /** + * @global string $mode List table view mode. + * * @return array */ protected function get_table_classes() { - $mode = get_user_setting( 'posts_list_mode', 'list' ); - $mode_class = 'extended' === $mode ? 'table-view-extended' : 'table-view-list'; - $mode = get_user_setting( 'posts_list_mode', 'list' ); - /** - * Filters the current view mode. - * - * @since 5.5.0 - * - * @param string $mode The current selected mode. Default value of - * posts_list_mode user setting. - */ + global $mode; + + /** This filter is documented in wp-admin/includes/class-wp-screen.php */ $mode = apply_filters( 'table_view_mode', $mode ); - $mode_class = 'extended' === $mode ? 'table-view-extended' : 'table-view-' . $mode; + $mode_class = esc_attr( 'table-view-' . $mode ); return array( 'widefat', 'fixed', 'striped', $mode_class, is_post_type_hierarchical( $this->screen->post_type ) ? 'pages' : 'posts' ); } diff --git a/src/wp-admin/includes/dashboard.php b/src/wp-admin/includes/dashboard.php index 27bdeb0cae..913b955eab 100644 --- a/src/wp-admin/includes/dashboard.php +++ b/src/wp-admin/includes/dashboard.php @@ -756,10 +756,13 @@ function _wp_dashboard_recent_comments_row( &$comment, $show_date = true ) { $actions = apply_filters( 'comment_row_actions', array_filter( $actions ), $comment ); $i = 0; + foreach ( $actions as $action => $link ) { ++$i; - if ( ( ( 'approve' === $action || 'unapprove' === $action ) && 2 === $i ) || 1 === $i ) { + if ( ( ( 'approve' === $action || 'unapprove' === $action ) && 2 === $i ) + || 1 === $i + ) { $sep = ''; } else { $sep = ' | ';