diff --git wp-admin/edit-comments.php wp-admin/edit-comments.php
index 29e5f03..98f0373 100644
|
|
if ( !current_user_can('edit_posts') ) |
12 | 12 | wp_die(__('Cheatin’ uh?')); |
13 | 13 | |
14 | 14 | $wp_list_table = get_list_table('WP_Comments_List_Table'); |
15 | | $pagenum = $wp_list_table->get_pagenum(); |
16 | | |
17 | 15 | $doaction = $wp_list_table->current_action(); |
18 | 16 | |
19 | 17 | if ( $doaction ) { |
… |
… |
if ( $doaction ) { |
37 | 35 | $approved = $unapproved = $spammed = $unspammed = $trashed = $untrashed = $deleted = 0; |
38 | 36 | |
39 | 37 | $redirect_to = remove_query_arg( array( 'trashed', 'untrashed', 'deleted', 'spammed', 'unspammed', 'approved', 'unapproved', 'ids' ), wp_get_referer() ); |
40 | | $redirect_to = add_query_arg( 'paged', $pagenum, $redirect_to ); |
| 38 | $redirect_to = $wp_list_table->add_query_args( $redirect_to ); |
41 | 39 | |
42 | 40 | foreach ( $comment_ids as $comment_id ) { // Check the permissions on each |
43 | 41 | if ( !current_user_can( 'edit_comment', $comment_id ) ) |
… |
… |
if ( $doaction ) { |
102 | 100 | $wp_list_table->prepare_items(); |
103 | 101 | |
104 | 102 | $total_pages = $wp_list_table->get_pagination_arg( 'total_pages' ); |
105 | | if ( $pagenum > $total_pages && $total_pages > 0 ) { |
| 103 | if ( $wp_list_table->get_pagenum() > $total_pages && $total_pages > 0 ) { |
106 | 104 | wp_redirect( add_query_arg( 'paged', $total_pages ) ); |
107 | 105 | exit; |
108 | 106 | } |
diff --git wp-admin/edit-tags.php wp-admin/edit-tags.php
index cfaba6c..cf9af28 100644
|
|
case 'delete': |
78 | 78 | |
79 | 79 | wp_delete_term( $tag_ID, $taxonomy ); |
80 | 80 | |
| 81 | $location = $wp_list_table->add_query_args( $location ); |
81 | 82 | $location = add_query_arg( 'message', 2, $location ); |
82 | 83 | wp_redirect( $location ); |
83 | 84 | exit; |
… |
… |
case 'bulk-delete': |
102 | 103 | if ( false !== strpos( $referer, 'edit-tags.php' ) ) |
103 | 104 | $location = $referer; |
104 | 105 | } |
105 | | |
| 106 | |
106 | 107 | $location = add_query_arg( 'message', 6, $location ); |
| 108 | $location = $wp_list_table->add_query_args( $location ); |
| 109 | |
107 | 110 | wp_redirect( $location ); |
108 | 111 | exit; |
109 | 112 | |
diff --git wp-admin/edit.php wp-admin/edit.php
index 5e0154f..da8d828 100644
|
|
if ( !current_user_can($post_type_object->cap->edit_posts) ) |
24 | 24 | wp_die(__('Cheatin’ uh?')); |
25 | 25 | |
26 | 26 | $wp_list_table = get_list_table('WP_Posts_List_Table'); |
27 | | $pagenum = $wp_list_table->get_pagenum(); |
28 | 27 | |
29 | 28 | // Back-compat for viewing comments of an entry |
30 | 29 | foreach ( array( 'p', 'attachment_id', 'page_id' ) as $_redirect ) { |
… |
… |
if ( $doaction ) { |
41 | 40 | check_admin_referer('bulk-posts'); |
42 | 41 | |
43 | 42 | $sendback = remove_query_arg( array('trashed', 'untrashed', 'deleted', 'ids'), wp_get_referer() ); |
44 | | $sendback = add_query_arg( 'paged', $pagenum, $sendback ); |
| 43 | $sendback = $wp_list_table->add_query_args( $sendback ); |
45 | 44 | if ( strpos($sendback, 'post.php') !== false ) |
46 | 45 | $sendback = admin_url($post_new_file); |
47 | 46 | |
… |
… |
if ( 'post' != $post_type ) { |
143 | 142 | $wp_list_table->prepare_items(); |
144 | 143 | |
145 | 144 | $total_pages = $wp_list_table->get_pagination_arg( 'total_pages' ); |
146 | | if ( $pagenum > $total_pages && $total_pages > 0 ) { |
| 145 | if ( $wp_list_table->get_pagenum() > $total_pages && $total_pages > 0 ) { |
147 | 146 | wp_redirect( add_query_arg( 'paged', $total_pages ) ); |
148 | 147 | exit; |
149 | 148 | } |
diff --git wp-admin/includes/class-wp-list-table.php wp-admin/includes/class-wp-list-table.php
index fa2001d..084cd3f 100644
|
|
class WP_List_Table { |
611 | 611 | $hidden = array_intersect( array_keys( $columns ), array_filter( $hidden ) ); |
612 | 612 | return count( $columns ) - count( $hidden ); |
613 | 613 | } |
| 614 | |
| 615 | function get_order_info() { |
| 616 | if ( isset( $_GET['orderby'] ) ) |
| 617 | $current_orderby = $_GET['orderby']; |
| 618 | else |
| 619 | $current_orderby = ''; |
| 620 | |
| 621 | if ( ! $current_orderby ) |
| 622 | $current_order = ''; |
| 623 | elseif ( isset( $_GET['order'] ) && 'desc' == $_GET['order'] ) |
| 624 | $current_order = 'desc'; |
| 625 | else |
| 626 | $current_order = 'asc'; |
| 627 | |
| 628 | return array($current_orderby, $current_order); |
| 629 | } |
| 630 | |
| 631 | function add_query_args( $location ) { |
| 632 | $pagenum = $this->get_pagenum(); |
| 633 | list( $current_orderby, $current_order ) = $this->get_order_info(); |
| 634 | $location = add_query_arg( 'paged', $pagenum, $location ); |
| 635 | if ( $current_orderby ) |
| 636 | $location = add_query_arg( array( 'orderby' => $current_orderby, 'order' => $current_order ), $location ); |
| 637 | |
| 638 | return $location; |
| 639 | } |
614 | 640 | |
615 | 641 | /** |
616 | 642 | * Print column headers, accounting for hidden and sortable columns. |
… |
… |
class WP_List_Table { |
627 | 653 | |
628 | 654 | $current_url = ( is_ssl() ? 'https://' : 'http://' ) . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; |
629 | 655 | |
630 | | if ( isset( $_GET['orderby'] ) ) |
631 | | $current_orderby = $_GET['orderby']; |
632 | | else |
633 | | $current_orderby = ''; |
634 | | |
635 | | if ( isset( $_GET['order'] ) && 'desc' == $_GET['order'] ) |
636 | | $current_order = 'desc'; |
637 | | else |
638 | | $current_order = 'asc'; |
| 656 | list( $current_orderby, $current_order ) = $this->get_order_info(); |
639 | 657 | |
640 | 658 | foreach ( $columns as $column_key => $column_display_name ) { |
641 | 659 | $class = array( 'manage-column', "column-$column_key" ); |
… |
… |
class WP_List_Table { |
728 | 746 | * @access protected |
729 | 747 | */ |
730 | 748 | function display_tablenav( $which ) { |
731 | | if ( 'top' == $which ) |
| 749 | if ( 'top' == $which ) { |
732 | 750 | wp_nonce_field( 'bulk-' . $this->_args['plural'] ); |
| 751 | list( $current_orderby, $current_order ) = $this->get_order_info(); |
| 752 | echo '<input type="hidden" name="orderby" value="' . $current_orderby . '" /><input type="hidden" name="order" value="' . $current_order . '" />'; |
| 753 | } |
733 | 754 | ?> |
734 | 755 | <div class="tablenav <?php echo esc_attr( $which ); ?>"> |
735 | 756 | |
diff --git wp-admin/js/list-table.dev.js wp-admin/js/list-table.dev.js
index 51b52d1..2176da2 100644
|
|
window.listTable = { |
103 | 103 | if ( 'object' != typeof response ) { |
104 | 104 | this.handle_error(); |
105 | 105 | } else { |
106 | | var tablenav = $('.tablenav-pages'); |
| 106 | var tablenav = $('.tablenav-pages'), |
| 107 | order = $.query.GET('order'), |
| 108 | orderby = (order) ? $.query.GET('orderby') : ''; |
107 | 109 | |
108 | 110 | this.stop_loading(); |
109 | 111 | |
… |
… |
window.listTable = { |
124 | 126 | // Disable buttons that should noop. |
125 | 127 | tablenav.find('.first-page, .prev-page').toggleClass('disabled', 1 == $.query.GET('paged')); |
126 | 128 | tablenav.find('.next-page, .last-page').toggleClass('disabled', response.total_pages == $.query.GET('paged')); |
127 | | |
| 129 | |
| 130 | $('input[name=order]').val(order); |
| 131 | $('input[name=orderby]').val(orderby); |
| 132 | |
128 | 133 | $('th.column-cb :input').attr('checked', false); |
129 | 134 | |
130 | 135 | if ( history.replaceState ) { |