Redirect to correct page after bulk action for posts and comments. Props garyc40. Fixes #15416

git-svn-id: https://develop.svn.wordpress.org/trunk@16855 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
scribu
2010-12-10 08:49:16 +00:00
parent ab5cd7a4f5
commit 70e3fbe1e8
2 changed files with 29 additions and 1 deletions

View File

@@ -13,6 +13,7 @@ if ( !current_user_can('edit_posts') )
$wp_list_table = get_list_table('WP_Comments_List_Table');
$wp_list_table->check_permissions();
$pagenum = $wp_list_table->get_pagenum();
$doaction = $wp_list_table->current_action();
@@ -37,6 +38,11 @@ if ( $doaction ) {
$approved = $unapproved = $spammed = $unspammed = $trashed = $untrashed = $deleted = 0;
$redirect_to = remove_query_arg( array( 'trashed', 'untrashed', 'deleted', 'spammed', 'unspammed', 'approved', 'unapproved', 'ids' ), wp_get_referer() );
// Fix the problem with wrong page number. This happens when the user use the javascript
// pagination feature to navigate to a certain page, then does some bulk actions there,
// he will be redirected back to te original page number instead of the navigated one.
$redirect_to = add_query_arg( 'paged', $pagenum, $redirect_to );
foreach ( $comment_ids as $comment_id ) { // Check the permissions on each
if ( !current_user_can( 'edit_comment', $comment_id ) )
continue;
@@ -99,6 +105,14 @@ if ( $doaction ) {
$wp_list_table->prepare_items();
// redirect to the last page if the page number is larger than the total number of pages
// this can happen when all the items in the last page are deleted, for example
$total_pages = $wp_list_table->get_pagination_arg( 'total_pages' );
if ( $pagenum > $total_pages && $total_pages > 0 ) {
wp_redirect( add_query_arg( 'paged', $total_pages ) );
exit;
}
wp_enqueue_script('admin-comments');
enqueue_comment_hotkeys_js();