Make WordPress Core

Ticket #38341: 38314.6.diff

File 38314.6.diff, 3.5 KB (added by cazm, 8 years ago)

Fixing missing button when Spam is deleted and no trash

  • src/wp-admin/includes/class-wp-comments-list-table.php

     
    354354                        submit_button( __( 'Filter' ), '', 'filter_action', false, array( 'id' => 'post-query-submit' ) );
    355355                }
    356356
    357                 if ( ( 'spam' === $comment_status || 'trash' === $comment_status ) && current_user_can( 'moderate_comments' ) ) {
     357                if ( ( 'spam' === $comment_status || 'trash' === $comment_status ) && current_user_can( 'moderate_comments' ) && $this->has_items() ) {
    358358                        wp_nonce_field( 'bulk-destroy', '_destroy_nonce' );
    359359                        $title = ( 'spam' === $comment_status ) ? esc_attr__( 'Empty Spam' ) : esc_attr__( 'Empty Trash' );
    360360                        submit_button( $title, 'apply', 'delete_all', false );
  • src/wp-admin/includes/class-wp-media-list-table.php

     
    177177                        submit_button( __( 'Filter' ), '', 'filter_action', false, array( 'id' => 'post-query-submit' ) );
    178178                }
    179179
    180                 if ( $this->is_trash && current_user_can( 'edit_others_posts' ) ) {
     180                if ( $this->is_trash && current_user_can( 'edit_others_posts' ) && $this->has_items() ) {
    181181                        submit_button( __( 'Empty Trash' ), 'apply', 'delete_all', false );
    182182                } ?>
    183183                </div>
  • src/wp-admin/includes/class-wp-posts-list-table.php

     
    489489                        }
    490490                }
    491491
    492                 if ( $this->is_trash && current_user_can( get_post_type_object( $this->screen->post_type )->cap->edit_others_posts ) ) {
     492                if ( $this->is_trash && current_user_can( get_post_type_object( $this->screen->post_type )->cap->edit_others_posts ) && $this->has_items() ) {
    493493                        submit_button( __( 'Empty Trash' ), 'apply', 'delete_all', false );
    494494                }
    495495?>
  • src/wp-admin/js/edit-comments.js

     
    461461                        updateCountText( 'span.trash-count', trashDiff );
    462462                }
    463463
     464                if ( ( 'trash' === settings.data.comment_status ) && ( 0 === getCount( $( 'span.trash-count' ) ) ) {
     465                        $( '#delete_all' ).hide();
     466                }
     467               
     468                if ( ( 'spam' === settings.data.comment_status ) && ( 0 === getCount( $( 'span.spam-count' ) ) ) {
     469                        $( '#delete_all' ).hide();
     470                }
     471
    464472                if ( ! isDashboard ) {
    465473                        total = totalInput.val() ? parseInt( totalInput.val(), 10 ) : 0;
    466474                        if ( $(settings.target).parent().is('span.undo') )
  • tests/phpunit/tests/admin/includesListTable.php

     
    235235
    236236                $this->assertNotContains( 'id="cat"', $output );
    237237        }
     238
     239        /**
     240         * @ticket 38341
     241         */
     242        function test_empty_trash_button_should_not_be_shown_if_there_are_no_posts() {
     243                // Set post type to a non-existent one.
     244                $this->table->screen->post_type = 'foo';
     245
     246                ob_start();
     247                $this->table->extra_tablenav( 'top' );
     248                $output = ob_get_clean();
     249
     250                $this->assertNotContains( 'id="delete_all"', $output );
     251        }
    238252}