-
Notifications
You must be signed in to change notification settings - Fork 45
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
Avoid Post Duplication (View Only) #61
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this should work well!
I looked into using offset
instead of oversized posts_per_page
(for much better performance), but I wasn't able to figure out how to make it work nicely when there are homepage blocks with categories. Ping me if you want to give it a whirl and I'll explain it further, but your current implementation should work well in all situations.
I tried this approach too, but as you say it only really works if all blocks use the exact same query, which they won't. Do you think the oversized |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
When testing, I managed to 'trick' the code into screwing up the posts-per-section count -- this is a bit convoluted, so just give me a ping if something doesn't make sense!
Steps to reproduce:
- Add at least three new posts; publish date is very important here, so set the second two to have older published dates:
- the first one should have at least one category (Category A), and set to be published today
- the second one should have at least two categories (Category A and Category B), and set to be published yesterday
- the third post should have at least one category (Category B), and be set to have been published the day before yesterday
- Set up the homepage to display two blocks. Each block should show only one post.
- Set the first block to display Category A, and the second block to display Category B.
- Confirm that only two posts are displaying in the editor, one for each block.
- Save and publish.
- See that the second block is showing two posts -- it's not duplicating one -- it wouldn't without the fix -- but it's miscounting the number to show.
I've put together some screenshots from my test site; I've done the following so it's hopefully easier to tell what the settings are:
- I've renamed the posts, so they say their assigned categories so it's a bit easier to tell what's happening.
- I've set each block's section header to read the category that it should show.
In the editor: the block showing 'Category A' (Business & Tech) shows it's newest post; the second block shows 'Category B' (Arts & Culture), but the post there is also assigned to 'Business & Tech'.
When published, the second block shows a second article, even though it's only set to display one:
If the second-newest article, the one assigned to both 'Category A' and 'Category B', has the publication date changed so it's the newest article, the correct number of posts will show.
If the first block's post count is increased to two, it will display two posts on the front end, but the second block will still incorrectly show two:
I think it has something to do with the query being increased to make up for a post that's not actually being removed/hidden, but I could have that wrong! Just let me know if I can provide more info!
Good sleuthing. I think the issue may be as simple as this being an off-by-one error? e.g.
|
c45305f
to
5c5507f
Compare
Nice sleuthing both of you! This should fix it: 365d8d1 |
Looks good to me! I turned my front page into a dumpster fire of multi-category posts; there aren't any dupes, and the post counts are right; parsing through the /wp-admin posts screen, it looks like everything is displaying in order and where expected. 🎉 |
OK! Onward to solving the issue in the editor now... |
Could you let me know where this work is happening? The difference between the editor and the front-end of the site is very confusing at the moment. cc @Automattic/ajax |
This editor de-duplication work is occurring in #176 which is a different block. It's conceivable the work in that block could be applied to Homepage Articles, but this isn't being actively explored at the moment. This is the commit where editor de-dupe was first introduced: 672ff19 cc: @georgeh |
🎉 This PR is included in version 1.0.0 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |
All Submissions:
Changes proposed in this Pull Request:
This PR is an attempt to ensure that multiple articles blocks on the same page will not show the same post more than once. Some questions and caveats:
Newspack Homepage Articles
block. Would we need the flexibility to exempt certain blocks from the logic?This is a partial resolution of #12
How to test the changes in this Pull Request:
Other information: