Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save douglasanro/8126b8e95aebff4011990a1b209e7038 to your computer and use it in GitHub Desktop.
Save douglasanro/8126b8e95aebff4011990a1b209e7038 to your computer and use it in GitHub Desktop.
Add numeric pagination to your WordPress theme
<?php
/* ----------------------------------------------------------------------------
* Add numeric pagination to your theme
* ------------------------------------------------------------------------- */
function numeric_posts_nav() {
if( is_singular() )
return;
global $wp_query;
/** Stop execution if there's only 1 page */
if( $wp_query->max_num_pages <= 1 )
return;
$paged = get_query_var( 'paged' ) ? absint( get_query_var( 'paged' ) ) : 1;
$max = intval( $wp_query->max_num_pages );
/** Add current page to the array */
if ( $paged >= 1 )
$links[] = $paged;
/** Add the pages around the current page to the array */
if ( $paged >= 3 ) {
$links[] = $paged - 1;
$links[] = $paged - 2;
}
if ( ( $paged + 2 ) <= $max ) {
$links[] = $paged + 2;
$links[] = $paged + 1;
}
echo '<div class="navigation"><ul>' . "\n";
/** Previous Post Link */
if ( get_previous_posts_link() )
printf( '<li class="arrow">%s</li>' . "\n", get_previous_posts_link('<i class="my-left-arrow"></i>') );
/** Link to first page, plus ellipses if necessary */
if ( ! in_array( 1, $links ) ) {
$class = 1 == $paged ? ' class="active"' : '';
printf( '<li%s><a href="%s">%s</a></li>' . "\n", $class, esc_url( get_pagenum_link( 1 ) ), '1' );
if ( ! in_array( 2, $links ) )
echo '<li class="points">…</li>';
}
/** Link to current page, plus 2 pages in either direction if necessary */
sort( $links );
foreach ( (array) $links as $link ) {
$class = $paged == $link ? ' class="active"' : '';
printf( '<li%s><a href="%s">%s</a></li>' . "\n", $class, esc_url( get_pagenum_link( $link ) ), $link );
}
/** Link to last page, plus ellipses if necessary */
if ( ! in_array( $max, $links ) ) {
if ( ! in_array( $max - 1, $links ) )
echo '<li class="points">…</li>' . "\n";
$class = $paged == $max ? ' class="active"' : '';
printf( '<li%s><a href="%s">%s</a></li>' . "\n", $class, esc_url( get_pagenum_link( $max ) ), $max );
}
/** Next Post Link */
if ( get_next_posts_link() )
printf( '<li class="arrow"/>%s</li>' . "\n", get_next_posts_link('<i class="my-right-arrow"></i>') );
echo '</ul></div>' . "\n";
}
<?php
// Insert this where you want it to appear in your template:
if ( function_exists( 'numeric_posts_nav' ) ) { numeric_posts_nav(); }
?>
?>
<?php
// If you have cpt with tags and use numeric_posts_nav function add this to fix the pagination.
/* ----------------------------------------------------------------------------
* Fix custom post type tags pagination
* ------------------------------------------------------------------------- */
function tagfix_add_custom_types( $query ) {
if( is_tag() && $query->is_main_query() ) {
$post_types = get_post_types();
$query->set( 'post_type', $post_types );
}
}
add_filter( 'pre_get_posts', 'tagfix_add_custom_types' );
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment