-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add ability to omit the current post from a Query Loop's posts #42810
Comments
👋 - Actually we had a similar and not complete handling for this(for different reasons though) and removed it later. Your use case is having a Query Loop in a template(ex. post) for For the templates use case this should be possible in server side(front end) only as we don't have a specific id in the site editor if we are editing the Do you have a work around for that in your code now? If yes, can you share? |
Thank you for the info @ntsekouras, Indeed. The idea is to do this in a single post template, it is only needed for front end. I have not found a workaround yet, as I currently use a custom ACF block and a php query loop, and am looking for ways to do this with WP only. I’d like to help but I’m not that familiar with creating a new property. |
To continue on this: I've found the constant This seems to hold the query arguments. But I also see a variation that replaces this array with a new one. So, I could register a new variation, and exclude the current post ID. There already is an exclude array in the arguments, but how to get the current post_id in there I don't know. Furthest I get: is adding |
yep, a highly needed feature, to be able to make use of the Query Loop Block on all websites. |
This came up in a forums support thread, here https://wordpress.org/support/topic/query-loop-and-related-posts-exclude-current-post/ |
@Humanify-nl what is the difference between this issue and #39192? |
I'm watching this. Hope it becomes a reality! My use case: I have a "related posts" section in a post. I set it to a related category as the current posts and I want it to include the newest posts from that category, excluding the current post. |
I also have a use case for this, same as OP, wanting to use it in a post template to show related posts. |
I'd also love to see this feature under the 'Filters' section. I'm currently including 3 'Related Posts' and using Javascript to hide the current post if it displays on itself. |
We have a request in our forums for this, too: where the sidebar shows a query loop with latest posts, it's a bit silly to show the post the user is currently viewing, but I see no way to exclude the current post ID. |
While I’d love for the query loop to have the old arguments array back as a filter, this needs an interface in the current paradigma, and I assume this is why fine control of queries is still not a thing. The easiest solution for this issue, is to make it default for every query block to exclude the post with the current post ID. I can’t think of a context where this would not work or cause problems. |
Another (PHP) workaround is filtering Here is an example to exclude the current post. Note that
We're not limited to simple modification. If plugins can provide IDs of related posts, we can feed them to the query through |
Thanks @dinhtungdu - I could use your snippet to remove the current post from a custom query loop block instance on a single post page/template. I couldn't make the To help folks needing an example:
<!-- wp:post-template {"className":"fse-pilot--read-next"} -->
(...)
function fse_pilot_remove_current_from_queries( $query_vars, $block ) {
if ( 'fse-pilot--read-next' === $block->parsed_block['attrs']['className'] )
$query_vars['post__not_in'] = array( get_the_ID() );
return $query_vars;
}
add_filter( 'query_loop_block_query_vars', 'fse_pilot_remove_current_from_queries', 10, 2 ); |
Hello! Can i work on this ? |
A pretty naive take, but I'm wondering if it could be achieved by reading a (new) Query block Putting the challenge of a useable UI in the Query block aside, the Post Template block has access to the Query block query param attributes in So it could skip rendering block content if an excluded post is matched: if ( in_array( $current_post_id, $query_post_id_to_exclude ) ) {
continue;
}
Hi @efu98 👋🏻 No need to ask! I'm sure if you can get a PR up there'll be folks to help review 🙇🏻 Thanks |
Seems like it could work. |
hi, naive question, but did you have a look at @ryanwelcher 's AQL plugin (https://wordpress.org/plugins/advanced-query-loop/) ? |
Hey all - I've implemented this feature previously as an extension of the core query block. I've opened a PR to share my solution, as I think this is something that should be part of core, it's so commonly needed #64916 |
Here's a plugin to handle this issue while we sort it out in core: https://github.com/colinduwe/exclude-posts I'd appreciate your feedback. |
I've implemented this on my Advanced Query Loop block and would be more than happy to contribute it back to core. |
It seems lots of folks have code for this and opening a PR would be great. My thoughts would be to use internally the Finally I'm curious if we could go incrementally about this and add a |
The only thing we need to be careful of when doing this is that under the hood, |
What problem does this address?
I think it is a very common practice to add query loops in the bottom of a single template to show ‘other/related posts’. This is currently not possible with the block.
What is your proposed solution?
In the classic approach, we could use the query argument to remove the current postID (with get_the_id) (I used this as a default for all queries).
This works because we very rarely have cases where the post(-type) or page query should include itself in the loop (correct me if I’m wrong).
Can we do this for the query-loop block? It would enable ‘related posts’ lists under any page, while omitting the post currently on screen. Without having to add another filter arg in the block settings.
The text was updated successfully, but these errors were encountered: