//uses global $wp_query * or with custom WP_Query(): * posts stuff ... endwhile() ... * echo bootstrap_pagination($query); * ?> */ function bootstrap_pagination( \WP_Query $wp_query = null, $echo = true, $params = [] ) { if ( null === $wp_query ) { global $wp_query; } $add_args = []; //add query (GET) parameters to generated page URLs /*if (isset($_GET[ 'sort' ])) { $add_args[ 'sort' ] = (string)$_GET[ 'sort' ]; }*/ $pages = paginate_links( array_merge( [ 'base' => str_replace( 999999999, '%#%', esc_url( get_pagenum_link( 999999999 ) ) ), 'format' => '?paged=%#%', 'current' => max( 1, get_query_var( 'paged' ) ), 'total' => $wp_query->max_num_pages, 'type' => 'array', 'show_all' => false, 'end_size' => 3, 'mid_size' => 1, 'prev_next' => true, 'prev_text' => __( '« Prev' ), 'next_text' => __( 'Next »' ), 'add_args' => $add_args, 'add_fragment' => '' ], $params ) ); if ( is_array( $pages ) ) { //$current_page = ( get_query_var( 'paged' ) == 0 ) ? 1 : get_query_var( 'paged' ); $pagination = ''; if ( $echo ) { echo $pagination; } else { return $pagination; } } return null; } /** * Notes: * AJAX: * - When used with wp_ajax (generate pagination HTML from ajax) you'll need to provide base URL (or it'll be admin-ajax URL) * - Example for a term page: bootstrap_pagination( $query, false, ['base' => get_term_link($term) . '?paged=%#%'] ) * * Images as next/prev: * - You can use image as next/prev buttons * - Example: 'prev_text' => '', * * Add query parameters to page URLs * - If you need custom URL parameters on your page URLS, use the "add_args" attribute * - Example (before paginate_links() call): * $arg = []; * if (isset($_GET[ 'sort' ])) { * $args[ 'sort' ] = (string)$_GET[ 'sort' ]; * } * ... * 'add_args' => $args, */