• Resolved Guido

    (@guido07111975)


    Hi,

    I’m having trouble getting the pagination of posts to work on a frontpage. It’s pagination of a custom post type called “event”.

    I use this (taken from codex) en this should support frontpage:

    
    if ( get_query_var( 'paged' ) ) { 
    	$paged = get_query_var( 'paged' ); 
    } elseif ( get_query_var( 'page' ) ) { 
    	$paged = get_query_var( 'page' ); 
    } else { 
    	$paged = 1; 
    }
    

    My query:

    
    $my_args = array( 
    	'post_type' => 'event', 
    	'paged' => $paged 
    ); 
    $my_query = new WP_Query( $my_args );
    

    And my navigation is:

    
    get_next_posts_link(  __( 'Next »' ), $my_query->max_num_pages ); 
    get_previous_posts_link( __( '« Previous' ) ); 
    

    I can navigate to page 2 (only).. but the same events are displayed there. So pagination doesn’t work at all. On a regular page pagination works as expected.

    What am I doing wrong here?

    Guido

Viewing 13 replies - 1 through 13 (of 13 total)
  • Moderator bcworkz

    (@bcworkz)

    Hi Guido,

    The WP native pagination functions assume they are paginating the main query. When you do your own query, the pages WP thinks it is doing are out of sync with what your query is doing. It’s supposedly possible to manage this some way by fooling WP into thinking your query is the main query. I personally don’t think it’s worth the effort. Managing your own query pagination with offset and posts per page is not that difficult. See Making Custom Queries using Offset and Pagination.

    I don’t even like getting the page requested from $paged. I prefer to use my own parameters. It’s easiest as URL parameters: example.com/event/sample-post/?ev-page=3. Clearly uglier than pages as part of the permalink. With a bit more processing we can get our own page parameter out of a permalink, or just trust that $paged will be correct.

    The other option is to not make your own query onject. Alter the main query through “pre_get_posts” action. Then the native WP pagination functions should work correctly.

    Thread Starter Guido

    (@guido07111975)

    Hi BC ??

    Thanks for your response.

    I don’t think using the main query is an alternative because I use many query args in my loop (not only the 2 in my example).

    FYI the whole loop I use for my custom post type (I thought it was quite basic and should work everywhere):

    
    if ( get_query_var( 'paged' ) ) { 
    	$paged = get_query_var( 'paged' ); 
    } elseif ( get_query_var( 'page' ) ) { 
    	$paged = get_query_var( 'page' ); 
    } else { 
    	$paged = 1; 
    }
    
    $my_args = array( 
    	'post_type' => 'event', 
    	'paged' => $paged 
    ); 
    $my_query = new WP_Query( $my_args );
    
    if ( $my_query->have_posts() ) : 
    	while( $my_query->have_posts() ): $my_query->the_post();
    		// do stuf
    	endwhile; 
    
    	get_next_posts_link(  __( 'Next »' ), $my_query->max_num_pages ); 
    	get_previous_posts_link( __( '« Previous' ) ); 
    
    	wp_reset_postdata(); 
    endif;
    

    It does work on regular pages, but not (properly) on a homepage.

    I will take a look at your other suggestions now..

    Guido

    Moderator bcworkz

    (@bcworkz)

    Home page! That even further complicates things. Is this the so called “static” home page or the blog listing home page? Changing the main query can invalidate the home page status, so that really would not be an alternative. Having a bunch of query args isn’t really a reason, though setting all of them can get cumbersome and is reason to avoid doing so in itself. You could actually make a new query in the pre_get_posts callback and return that object instead of the altered query. It still would not be a home page query though.

    If this is a static home page, you really have no choice but to manage pagination yourself. I don’t know how you even managed page 2 if this were the case! Even with the blog listing type, WP will limit $paged to the number of pages of default post listings. If your query has more, you cannot use $paged, you need your own parameter for requested page number.

    Thread Starter Guido

    (@guido07111975)

    Hi again,

    I might have found it… it might been caused because this loop is inside a shortcode.

    I have added the loop from above in my theme index file and pagination seems to work fine now.

    So the shortcode is causing this I think.

    Any suggestions?

    Guido

    Thread Starter Guido

    (@guido07111975)

    LOL, we both replied simultaneously..

    After my response I’ve noticed the paged parameter didn’t work in my query, when on static frontpage. As you already mentioned in your response.

    With or without paged parameter, same behaviour on static frontpage.

    You have any suggestions regarding how to create this custom pagination?

    Guido

    Thread Starter Guido

    (@guido07111975)

    Hi again,

    Update: but wait, when adding the shortcode on a page it becomes the second loop.. and when added in a template file as described in my previous post, it’s the first (main) loop. Never thought of that! So I guess the shortcode isn’t the problem here, but the second loop (on frontpage) is. Guess you were trying to explain this to me, or not?

    Guido

    • This reply was modified 7 years, 4 months ago by Guido. Reason: update
    Moderator bcworkz

    (@bcworkz)

    Yes, I think so anyway. If the second loop is for a new WP_Query object, then yes.

    Does it really make sense for next or previous page links to relate to the second loop content and not the initial loop? Seems a little odd, but I can imagine scenarios where it makes sense. Would it be possible to reverse what is first and second loop? The first loop would be for a new WP_Query object that returns what is now the main query results. The new main query would be for what is now achieved by a new WP_Query object. Nothing changes in the output, only what query is for what items is changed. The default pagination ought to work correctly.

    You were reluctant to customize the main query because of the many query args to change. Changing them through WP_Query::set() would indeed be a pain. The query vars you want to change are all in a single array. The entire query object is passed by reference, so you can directly set parts of the query_vars array with array_merge() or similar. You don’t have to use WP_Query::set(). So don’t let that be a deterrent.

    Or leave things as they are query-wise and manage your own pagination on the second loop’s query.

    Thread Starter Guido

    (@guido07111975)

    Hi BC,

    Can you explain why it does work fine when I add my shortcode (containing this second loop) on a regular page and it does not work properly when setting the same page as static front page? In both cases 2 loops: the page itself and the second loop inside my shortcode.

    FYI I’ve set up a temp test:
    For events on static front page, click here.
    For events on a regular page, click here.
    I use the same loop as posted here.

    Or leave things as they are query-wise and manage your own pagination on the second loop’s query.

    But how, I don’t have the skills to build my own one. Searched the web but am not able to find something I could use..

    Guido

    Thread Starter Guido

    (@guido07111975)

    Hi BC,

    You’re not gonna believe this but I think I have found it… after spending many hours searching and trying I found out the solution was adding the paged global:

    
    global $paged;
    if ( get_query_var( 'paged' ) ) { 
    	$paged = get_query_var( 'paged' ); 
    } elseif ( get_query_var( 'page' ) ) { 
    	$paged = get_query_var( 'page' ); 
    } else { 
    	$paged = 1; 
    }
    

    So paged wasn’t working at all, in this second loop.

    Guido

    @guido07111975 – thank you so much!!!

    After two days of frustration trying to get pagination working on the home page I found this post. The query I’d written worked on every page apart from the home page – adding global $paged; before the if/else statements solved it.

    Would be great if this could be added to the codex to help others: https://codex.www.ads-software.com/Pagination#Static_Front_Page

    • This reply was modified 6 years, 11 months ago by redsundesign.
    Thread Starter Guido

    (@guido07111975)

    Nice to hear my reply in this thread helped you as well ??

    Maybe @bcworkz is able to add this in the codex, as forum moderator.

    Guido

    Hello,
    Page 2 is not working in wordpress pagination
    link-https://ingminds.com/projects/ettingerreport/

    Thanks
    Sudipto Poddar

    Hello,
    Page 2 is not working in wordpress pagination
    link-https://ingminds.com/projects/ettingerreport/

    Thanks
    Sudipto Poddar

Viewing 13 replies - 1 through 13 (of 13 total)
  • The topic ‘Custom post type pagination on homepage’ is closed to new replies.